Mixin that adds useful password methods to your Python objects
Project description
Password Mixin
Mixin that adds some useful methods to ORM objects
Compatible with Python 3.5 >= 3.9
Install
pip install password-mixin
Setup
first create your objects (or ORM model) and add a __hash_secret__
meta field.
Assign your application's secret value to __hash_secret__
.
from password_mixin import PasswordMixin
from sqlalchemy import Model # or Django , Flask-Sqlalchemy... etc.
class UserModel(OrmModel, PasswordMixin):
password = Column(String()) # you must have a `password`.
# Now create a meta field to define the secret used to create the salt, for example:
__hash_secret__ = "your-app-secret"
Usage
The password is saved as the following: "<hash_name>:<hash>"
Password Hashing
from password_mixin import PasswordAttributeError
try:
user = UserModel()
user.password = "wizard123"
user.hash_password() # password is now `sha256:7ac5cf88e8c9d262b49af168d9c30e47f2945cc9c207f20af0a39f09aa04595e`
# Now you can save your user to your db etc.
except PasswordAttributeError:
# handle no password attribute
Validating Passwords
from password_mixin import PasswordMatchError
try:
user.check_password("wizard111")
except PasswordMatchError:
# handle passwords don't match
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
password-mixin-0.1.2.tar.gz
(3.4 kB
view hashes)
Built Distribution
Close
Hashes for password_mixin-0.1.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d3a5f4f51608796f9e20b81ab72fc4820abe1135963de561550be1c13abd3bb4 |
|
MD5 | 116af26888927814d7abbc7ff4ae9080 |
|
BLAKE2b-256 | 94abfac13024bf646045c4c0dcc7107c962036f8b99a0a774988c718016f21e3 |