This is a hobbyist project exploring a custom encryption algorithm implemented in Python. It is not intended for production use and serves as a fun exploration into cryptography concepts. The algorithm leverages hexagonal grid permutations in conjunction with AES encryption to provide an added layer of security to standard text encryption.
Note: This project is a personal exploration and is not intended for production use. Please do not use it for real-world security applications.
- Introduction
- Technologies Used
- Installation and Usage
- Code Walkthrough
- Examples
- Potential Applications
- Additional Notes
- Contributing
- License
The core of the algorithm is a hexagonal grid, a two-dimensional structure with interconnected hexagonal cells. The grid's size adapts dynamically to the length of the input text.
- Key Hashing: The user-provided key is hashed using SHA256 to generate a random number generator seed and the AES encryption key.
- Index Permutation: A random permutation of indices is created based on the seed, dictating the order in which the grid cells are shuffled.
- Matrix Transformation and Permutation: The plaintext is converted into a matrix conforming to the grid's shape, and then this matrix is permuted according to the generated indices.
The permuted data is then encrypted using AES in CBC (Cipher Block Chaining) mode with PKCS7 padding. The same hashed key used for permutation ensures consistency in encryption and decryption.
The decryption process is the inverse of encryption:
- The encrypted text is converted back into a matrix.
- The inverse permutation is applied to the matrix.
- AES decryption is used to recover the original plaintext.
The project leverages the following Python libraries:
- NumPy: For efficient numerical operations and matrix manipulations.
- PyCryptodome: For implementing the AES encryption and decryption.
- Pygame: For creating the visual representation of the permutation process.
pip install Hexagonal-Permutation-Cipher==1.0.0
Then just run hpc -h for list of commands.
While this project is a hobbyist exploration and not intended for production use, it provides insights into cryptographic concepts and can be used for:
- Educational purposes to understand encryption and permutation.
- As a base for creating custom ciphers in academic projects.
- Visual demonstrations of grid-based permutation concepts.
- Padding: The plaintext is padded with spaces if it doesn't fit perfectly into the grid. This padding is removed during decryption.
- Byte Conversion: The matrix data is converted to bytes before encryption and back to characters after decryption for compatibility.
Contributions to this project are welcome. Please fork the repository and submit pull requests with your enhancements or bug fixes. Feel free to open issues to report bugs or suggest new features.
- Fork the repository
- Create your feature branch (
git checkout -b feature/AmazingFeature
) - Commit your changes (
git commit -m 'Add some AmazingFeature'
) - Push to the branch (
git push origin feature/AmazingFeature
) - Open a pull request
This project is licensed under the MIT License - see the LICENSE file for details.