Cryptography tool based on RSA and AES
Project description
NyxCrypta
NyxCrypta is a Python cryptography library that combines asymmetric RSA encryption and symmetric AES encryption to secure your data efficiently and easily.
Features
- 🔒 Hybrid encryption: Combines AES-256 and RSA (2048 to 4096 bits)
- 🎯 Configurable security levels: Standard, High, and Paranoid
- 🔑 Key management: Simple generation and use of RSA key pairs
- 📚 Intuitive command-line interface
- 🛡️ Proactive security: integrated file and permissions checks
Installation
pip install NyxCrypta
Quick guide
1. Key generation
nyxcrypta keygen -o ./keys -p "my_strong_password"
This command generates a pair of RSA keys and saves them in the specified folder.
2. File encryption
nyxcrypta encrypt -i secret.txt -o encrypted.nyx -k ./keys/public_key.pem
3. File decryption
nyxcrypta decrypt -i encrypted.nyx -o decrypted.txt -k ./keys/private_key.pem -p "my_strong_password"
4. Data encryption
nyxcrypta encryptdata -d "my data" -k ./keys/public_key.pem
5. Data decryption
nyxcrypta decryptdata -d "006bd6203029" -k ./keys/private_key.pem -p "my_stong_password"
Security levels
NyxCrypta offers three levels of security:
-
STANDARD (default) :
- RSA 2048 bits
- SHA-256 for OAEP padding
-
HIGH :
- RSA 3072 bits
- SHA-256 for OAEP padding
-
PARANOID:
- RSA 4096 bits
- SHA-256 for OAEP padding
The security level is selected via the --securitylevel option:
nyxcrypta --securitylevel 2 encrypt -i secret.txt -o encrypted.nyx -k ./keys/public_key.pem
Technical implementation
- Use of AES-256 in CBC mode for symmetrical encryption
- AES key encryption with RSA-OAEP
- Secure generation of IV (Initialization Vector) for each operation
- Automatic data padding management
Best security practices
-
Key management :
- Store private keys securely
- Limit access to key files
-
File selection:
- Always check input and output file paths
- Make sure you have the necessary permissions
-
Security level :
- The STANDARD level is sufficient for most uses.
- Use higher levels for specific needs
Python example
from nyxcrypta import NyxCrypta, SecurityLevel
# initialization
nx = NyxCrypta(SecurityLevel.HIGH)
password = "my_strong_password"
# Keys generation
nx.save_keys("./keys", password)
# Encryption & Decryption
nx.encrypt_file("secret.txt", "encrypted.nyx", "./keys/public_key.pem")
nx.decrypt_file("encrypted.nyx", "decrypted.txt", "./keys/private_key.pem", password)
nx.encrypt_data("données secrètes".encode("utf-8"), "./keys/public_key.pem")
nx.decrypt_data(bytes.fromhex("023gna5donnéescryptées"), "./keys/private_key.pem", password)
Dependencies
- cryptography>=3.3.2
- argon2-cffi>=20.1.0
- cffi>=1.0.0
License
NyxCrypta is distributed under the MIT license. See the LICENSE file for more details.
Authors
Division of Cyber Anarchy (DCA)
Contact : malic1tus@proton.me nyxcrypta@proton.me calypt0sis@proton.me viral0x@proton.me
Github : https://github.com/Division-of-Cyber-Anarchy/
Simplicity is the ultimate sophistication. - Leonardo da Vinci
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nyxcrypta-1.3.1.tar.gz.
File metadata
- Download URL: nyxcrypta-1.3.1.tar.gz
- Upload date:
- Size: 9.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
aa002919b38697f4f596776ce72f5fbf4b4ec2edd016a779cc81a6b8986c6058
|
|
| MD5 |
d1ed57b2a10f28e73b4fb17c514fe7f8
|
|
| BLAKE2b-256 |
09dfbab688d9ecb9470b7b41b6c929e1603221405855c71ad15de4a891f4a4af
|
File details
Details for the file nyxcrypta-1.3.1-py3-none-any.whl.
File metadata
- Download URL: nyxcrypta-1.3.1-py3-none-any.whl
- Upload date:
- Size: 9.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e1c22fda45e9c1e39ded109d93a43c4837c25a5979a946893bf88c86e4240fd0
|
|
| MD5 |
3c8c717f4f6984c4acf0ab328b47536e
|
|
| BLAKE2b-256 |
c49b971da4cfa6ae2d08a79e5aa0556146ceb8ac6bb5bfe24f3717f8fff29d85
|