Cryptographically strong pseudorandom key generator based on the XStrip Algorithm
Via PyPI:
pip install xstrip_auth
Generate a 256-bit key for use
from xstrip_auth import XStripKeyConstruct
key = "#P@$$W0R9"
construct = XStripKeyConstruct(key)
# Creating a 16Bit key for use from the key under a md5 hash implementation
construct.generateKey(hf='md5')
# Prints
# [md5](16): 'ec1a93e0f8d41d75ffb77914e7a31cbf'
# Create a 256bit key for use from the key under the sha256 hash implementation
construct.generateKey(hf='sha256')
# Prints
# [sha256](32): 'd6b05d17e2e15152c478825ca6e7adafd0045b0c7fd92850ead98bad0cced9a4'
hash
: <bytes> The key, final content to be encapsulated by the instancesalt
: <bytes> The salt used to intensify the operationiterations
: <number> Number of iterations undergone to generate thehash
. Default:100000
hf
: <string> Hash function used for the operation. Default:'sha256'
Encapsulate a generated key within an interfacing instance for managing the inherent content
The XStripKey
class is defined and exposed publicly by the module:
from xstrip_auth import XStripKey
key = XStripKey(bytes.fromhex('d4d64d71c71ed5365ddde126ca8e6a17301e5f9601a15119e53c2f91def21f11'),
bytes.fromhex('422f487975c57bb648f3'))
print(key.verify("#P@$$W0R9"))
# Prints
# True
Shows the encapsulated key in byte hex format
Returns the hash function of the key
Returns the salt of the key in bytes
Returns the number of iterations used in encoding the key
key
: <string>encoder
: <function>
Returns: <boolean>
Verify whether or not the specified key
matches the inherent key of the self
instance
encoder
is defined by any transformers that was used used in generating the construct else, this falls back to a noop
function that returns its parameters
Returns a boolean for the condition result
key
: <string>fn
: <function>*args
: <any>encoder
: <function>
Returns: <any>
Execute the fn
function if the key
matches the inherent key of the self
instance by checking self.verify
(key
, encoder
)
fn is called by arguments defined in args
(if-any)
encoder
is defined by any transformers that was used used in generating the construct else, this falls back to a noop
function that returns its parameters
Returns the return content of the function fn
def fn(value):
print("Password Matches, arg: %d" % value)
key.matchExec("#P@$$W0R9", fn, 10)
# Prints
# Password Matches, arg: 10
key
: <string>fn
: <function>*args
: <any>encoder
: <function>
Returns: <any>
Execute the fn
function if the key
does not match the inherent key of the self
instance by checking self.verify
(key
, encoder
)
fn is called by arguments defined in args
(if-any)
encoder
is defined by any transformers that was used used in generating the construct else, this falls back to a noop
function that returns its parameters
Returns the return content of the function fn
def fn(value):
print("Password Matches, arg: %d" % value)
key.mismatchExec("something", fn, 19)
# Prints
# Password Matches, arg: 19
Returns the octal representation of each character in a list
Exports the entire key construct in base64 encoding parsable by XStripKey.parse()
print(key.export())
# Prints
# b'MTAwMDAwOjQyMmY0ODc5NzVjNTdiYjY0OGYzL2Q0Z...OGU2YTE3MzAxZTVmOTYwMWExNTExOWU1M2MyZjkxZGVmMjFmMTE='
fn
: <string | bytes> The exported construct to be parsed
Returns: <XStripKey>
Parse the base64 exported data from XStripKey::export
print(XStripKey.parse(key.export()))
print(key == XStripKey.parse(key.export()))
# Prints
# [sha256](32): 'd4d64d71c71ed5365ddde126ca8e6a17301e5f9601a15119e53c2f91def21f11'
# True
key
: <string | bytes> The key to be constructed oniterations
: <number> The number of times the kdf should apply the hash function to the key in the transformative process
Class to generate series of hashed keys for a single key Making the product pseudorandomly secure for every use of the same key
The XStripKey
class is defined and exposed publicly by the module:
from xstrip_auth import XStripKeyConstruct
hf
: <string> The hash function to process the key on. Default:'sha256'
salt
: <string | bytes> The hash to be used on the key when randomising the data. Default: py:os/randomencoder
: <function> The middleware transformative function. Default: noop
Returns: <XStripKey>
Generates a special key for the encapsulated key under special conditions making the product completely random and untied to the operation
Hence, generating cryptographically secure keys everytime this method is called
encoder
is defined by any transformers that was used used in generating the construct else, this falls back to a noop
function that returns its parameters
construct = XStripKeyConstruct("t0y$t0ry")
construct.generateKey()
# [sha256](32): '5e53edcff3bc4dc5e06b243dd206e4dbba1be625361bd2db3c9599edec217f01'
construct.generateKey()
# [sha256](32): '907d183f27a75c23830906063494ff073942e3f74d21605f7b19b16a7d94df06'
construct.generateKey('md5')
# [md5](16): 'd38518dccec4a4ef1767c01e48095a2c'
construct.generateKey('sha1')
# [sha1](20): '42f405740cd7a35a283b44c1ee0bbf0c9812015b'
Feel free to clone, use in adherance to the license and perhaps send pull requests
git clone https://github.com/miraclx/xstrip-auth.git
cd xstrip-auth
# hack on code
pip3 install . --user
Apache 2.0 © Miraculous Owonubi (@miraclx) <omiraculous@gmail.com>