htpasswd is a library for working with htpasswd user (only basic authorization) and group files. It supports CRYPT, MD5 (based) and MD5 (apache variant, 'apr1') encryption methods. To actually use MD5 encryption method you MUST have an openssl
binary installed into system $PATH
.
- Python 2.7 or 3.3 or 3.4
- orderedmultidict >= 0.7
- future
- nose >= 1.1.2 (for tests)
import htpasswd
with htpasswd.Basic("/path/to/user.db") as userdb:
try:
userdb.add("bob", "password")
except htpasswd.basic.UserExists, e:
print e
try:
userdb.change_password("alice", "newpassword")
except htpasswd.basic.UserNotExists, e:
print e
with htpasswd.Group("/path/to/group.db") as groupdb:
try:
groupdb.add_user("bob", "admins")
except htpasswd.group.UserAlreadyInAGroup, e:
print e
try:
groupdb.delete_user("alice", "managers")
except htpasswd.group.UserNotInAGroup, e:
print e
To use MD5 apache variant encryption, add mode="md5"
to the constructor:
with htpasswd.Basic("/path/to/user.db", mode="md5") as userdb
or use md5-base
for MD5 based encryotion:
with htpasswd.Basic("/path/to/user.db", mode="md5-base") as userdb
__contains__(user)
users
add(user, password)
pop(user)
change_password(user, password)
_encrypt_password(password)
__contains__(group)
groups
is_user_in(user, group)
add_user(user, group)
delete_user(user, group)
Raised by Basic.add
if user already exists.
Raised by Basic.delete
and Basic.change_password
if there is no such user.
Raised by Group.delete_user
if there is no such group.
Raised by Group.add_user
if user is already in a group.
Raised by Group.delete_user
if user isn't in a group.
Raised by _encrypt_password if mode is not 'crypt', 'md5' or 'md5-base'.