<div align="center">
<h1> Sessionless : Python</h1>
</div>
## About
[Sessionless](https://sessionless.org/) is an open-source authentication protocol that uses the cryptography employed by Bitcoin and Ethereum to authenticate messages sent between a client and a server. Within this protocol, you create and store a private key on the client and then use that key to sign messages; the server then verifies those messages via the public key associated with the client. When you verify a message you also certify its provenance. Sessions are wholly unnecessary because no other secret needs to be shared between client and server.
## Getting Started
To install the package, run the following code within your command line interface. More information regarding release history for this package can be found [here](https://pypi.org/project/sessionless/).
```
pip install sessionless
```
## Development
### Getting started
To use this package, please call a new instance of the SessionlessSecp256k1 class. Users will need to provide a get key method. This method will be referenced later on to obtain key values.
```python
# This will create an instance of the SessionlessSecp256k1 class
sessionless = SessionlessSecp256k1()
```
### Generating private and public keys
The generate keys method will generate a unique private key and a public key. To use the method, users must provide a method to save the keys. This function to save the keys is left to the user's implementation.
```python
# The defined function will be called upon to store the generated keys
def saveKey(keyPair):
db.store(keyPair["privateKey"], keyPair["publicKey"])
private_key, public_key = sessionless.generateKeys(saveKey)
```
### Signing messages
Users can easily sign messages by providing a message to the sign method and a callable method that will return the private key. Messages do not need to be encoded before passing them to the method. The method will return an encrypted signature that users can store as needed. The method to the get the key is left to the user's implementation.
```python
# The defined method to get the keys will be called to retrieve the private key
msg = {
"message": "The weather is so nice today!"
}
signature = sessionless.sign(msg, getKey(privateKey={}))
```
### Verifying messages
Users can verify messages and signatures to ensure data integrity, authenticity, and non-repudiation. Users will pass a signature, message, and an encrypted public key as parameters. If public key is not provided, a public key will be generated from the instance's private key.
```python
result = sessionless.verifySignature(signature, msg, public_key) # Returns True
result2 = sessionless.verifySignature(first_signature, first_msg, second_primary_key) # Returns False
```
### Associating messages
Users can verify that two messages can be associated using the associate method.
```python
result = sessionless.associate(primary_sig, primary_msg, primary_public_key, secondary_sig, secondary_msg, secondary_public_key) # Returns either True or False
```
### Generating UUIDs [Universally Unique Identifiers]
Users can generate unique identifiers as needed by calling the generate UUID method.
```python
uuid = sessionless.generateUUID() # Returns UUID
```
Raw data
{
"_id": null,
"home_page": null,
"name": "sessionless",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "authentication, cryptography, authenticate",
"author": "Sessionless Team",
"author_email": "zach@planetnine.app",
"download_url": "https://files.pythonhosted.org/packages/ef/a3/78a296ac37744a89de95d83eb95c240e90333101326faf0ab9ca5d81a6ce/sessionless-0.0.5.tar.gz",
"platform": null,
"description": "<div align=\"center\">\n <h1> Sessionless : Python</h1>\n</div>\n\n## About\n\n[Sessionless](https://sessionless.org/) is an open-source authentication protocol that uses the cryptography employed by Bitcoin and Ethereum to authenticate messages sent between a client and a server. Within this protocol, you create and store a private key on the client and then use that key to sign messages; the server then verifies those messages via the public key associated with the client. When you verify a message you also certify its provenance. Sessions are wholly unnecessary because no other secret needs to be shared between client and server.\n\n## Getting Started \n\nTo install the package, run the following code within your command line interface. More information regarding release history for this package can be found [here](https://pypi.org/project/sessionless/).\n```\npip install sessionless\n```\n\n## Development \n\n### Getting started\nTo use this package, please call a new instance of the SessionlessSecp256k1 class. Users will need to provide a get key method. This method will be referenced later on to obtain key values.\n\n```python\n# This will create an instance of the SessionlessSecp256k1 class \n\nsessionless = SessionlessSecp256k1()\n```\n\n### Generating private and public keys\nThe generate keys method will generate a unique private key and a public key. To use the method, users must provide a method to save the keys. This function to save the keys is left to the user's implementation.\n```python\n# The defined function will be called upon to store the generated keys\ndef saveKey(keyPair):\n db.store(keyPair[\"privateKey\"], keyPair[\"publicKey\"])\nprivate_key, public_key = sessionless.generateKeys(saveKey) \n```\n\n### Signing messages\nUsers can easily sign messages by providing a message to the sign method and a callable method that will return the private key. Messages do not need to be encoded before passing them to the method. The method will return an encrypted signature that users can store as needed. The method to the get the key is left to the user's implementation.\n```python\n# The defined method to get the keys will be called to retrieve the private key\nmsg = {\n\"message\": \"The weather is so nice today!\"\n}\nsignature = sessionless.sign(msg, getKey(privateKey={}))\n```\n\n### Verifying messages\nUsers can verify messages and signatures to ensure data integrity, authenticity, and non-repudiation. Users will pass a signature, message, and an encrypted public key as parameters. If public key is not provided, a public key will be generated from the instance's private key.\n```python\nresult = sessionless.verifySignature(signature, msg, public_key) # Returns True\nresult2 = sessionless.verifySignature(first_signature, first_msg, second_primary_key) # Returns False\n```\n\n### Associating messages\nUsers can verify that two messages can be associated using the associate method. \n```python\nresult = sessionless.associate(primary_sig, primary_msg, primary_public_key, secondary_sig, secondary_msg, secondary_public_key) # Returns either True or False\n\n```\n\n### Generating UUIDs [Universally Unique Identifiers]\nUsers can generate unique identifiers as needed by calling the generate UUID method.\n```python\nuuid = sessionless.generateUUID() # Returns UUID\n\n```\n",
"bugtrack_url": null,
"license": null,
"summary": "Sessionless is an attempt to make authentication handling easier for developers without traditional sessions.",
"version": "0.0.5",
"project_urls": null,
"split_keywords": [
"authentication",
" cryptography",
" authenticate"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "090fef62decd216de197a54c797c97bf6bb11e0df6b70f9fc7809707109c8752",
"md5": "e2a4c1a99a8ec8ca29dec833a6069f9e",
"sha256": "a1f258be7f8293b2fa88bf0d1431dd7f695e4dc6c6c5c3f3910484d41a914903"
},
"downloads": -1,
"filename": "sessionless-0.0.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "e2a4c1a99a8ec8ca29dec833a6069f9e",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 4979,
"upload_time": "2024-05-13T22:34:04",
"upload_time_iso_8601": "2024-05-13T22:34:04.411402Z",
"url": "https://files.pythonhosted.org/packages/09/0f/ef62decd216de197a54c797c97bf6bb11e0df6b70f9fc7809707109c8752/sessionless-0.0.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "efa378a296ac37744a89de95d83eb95c240e90333101326faf0ab9ca5d81a6ce",
"md5": "45ff752ecbe7345a3bde8f9f1c360fc9",
"sha256": "54a2cba193c85b231733d16c35903b1c64a57d96699eb88649f69047cc0b22ba"
},
"downloads": -1,
"filename": "sessionless-0.0.5.tar.gz",
"has_sig": false,
"md5_digest": "45ff752ecbe7345a3bde8f9f1c360fc9",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 4581,
"upload_time": "2024-05-13T22:34:06",
"upload_time_iso_8601": "2024-05-13T22:34:06.240115Z",
"url": "https://files.pythonhosted.org/packages/ef/a3/78a296ac37744a89de95d83eb95c240e90333101326faf0ab9ca5d81a6ce/sessionless-0.0.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-05-13 22:34:06",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "sessionless"
}