4 releases
0.2.0 | Nov 24, 2024 |
---|---|
0.1.3 | Nov 23, 2024 |
0.1.1 | Nov 23, 2024 |
0.1.0 | Nov 23, 2024 |
#406 in Algorithms
33KB
603 lines
Nekohash
A comprehensive hashing library implementing three distinct hashing algorithms with encryption capabilities. Each algorithm provides different characteristics suitable for various use cases.
Features
- KawaiiHash: A configurable-length hash function using seeded RNG for mixing
- TsundereHash: A fixed-size (32-byte) hash with multiple mixing rounds
- MagicalHash: A compact (16-byte) hash using state transformation
- AES-256-CTR Encryption: Optional encryption layer for hash outputs
- Utility Functions: Hash combination, hex conversion, and key management
Installation
Add to your Cargo.toml
:
[dependencies]
nekohash = "0.1.3"
or using cargo
:
cargo add nekohash
Algorithm Details
KawaiiHash
KawaiiHash is a variable-length hash function that combines deterministic RNG with bit manipulation:
-
Initialization:
- Configurable output size (default: 32 bytes)
- Seeded RNG using a 64-bit seed
- Chunked processing (8 bytes at a time)
-
Processing Steps:
for chunk in data.chunks(8) { // Pack bytes into 64-bit value let mut value = chunk_to_u64(chunk); // Apply transformations value = value.wrapping_mul(0x1234_5678_9ABC_DEF0); value ^= rng.gen::<u64>(); value = value.rotate_right(17); // Append to result result.extend_from_slice(&value.to_le_bytes()); }
Example usage:
use nekohash::{KawaiiHash, NekoHash};
// Default 32-byte output
let hasher = KawaiiHash::new();
let hash = hasher.hash(b"Example data");
// Custom size (64 bytes)
let hasher = KawaiiHash::with_size(64);
let hash = hasher.hash(b"Example data");
// Custom seed for deterministic output
let hasher = KawaiiHash::with_seed(64, 0xDEADBEEF);
let hash = hasher.hash(b"Example data");
TsundereHash
TsundereHash is a fixed-size hash function using multiple rounds of state transformation:
-
Characteristics:
- 32-byte output size
- Configurable number of mixing rounds
- State-based processing with neighboring byte influence
-
Algorithm Steps:
// Initialize 32-byte state let mut state = [0u8; 32]; // Initial state mixing for (i, &byte) in data.iter().enumerate() { state[i % 32] ^= byte; state[(i + 7) % 32] = state[(i + 7) % 32].wrapping_add(byte); state[i % 32] = if i % 2 == 0 { state[i % 32].rotate_left(3) } else { state[i % 32].rotate_right(2) }; } // Multiple rounds of transformation for _ in 0..rounds { for i in 0..32 { let prev = state[(i + 31) % 32]; let next = state[(i + 1) % 32]; state[i] ^= prev.wrapping_add(next); state[i] = state[i].wrapping_mul(0x1B); } }
Example usage:
use nekohash::{TsundereHash, NekoHash};
// Default configuration (3 rounds)
let hasher = TsundereHash::new();
let hash = hasher.hash(b"Example data");
// Custom number of rounds
let hasher = TsundereHash::with_rounds(5);
let hash = hasher.hash(b"Example data");
MagicalHash
MagicalHash is a compact hash function using spell-based transformations:
-
Characteristics:
- 16-byte output size
- 64-bit internal state
- Configurable magic constant
-
Core Transformation:
fn cast_spell(value: u64, spell_power: u64) -> u64 { let mut result = value; result ^= spell_power; result = result.rotate_left(7); result = result.wrapping_mul(0xDEAD_BEEF_CAFE_BABE); result ^= result >> 33; result = result.wrapping_mul(0x1234_5678_90AB_CDEF); result ^= result >> 29; result }
Example usage:
use nekohash::{MagicalHash, NekoHash};
let hasher = MagicalHash::new();
let hash = hasher.hash(b"Example data");
// Custom magic constant
let hasher = MagicalHash::with_magic(0xCUSTOM_MAGIC);
let hash = hasher.hash(b"Example data");
Encryption Layer
The library provides AES-256-CTR encryption for hash outputs:
-
Key Management:
- 32-byte keys (user-provided or randomly generated)
- Base64 key encoding for storage
- Secure IV generation per encryption
-
Usage Examples:
use nekohash::{KawaiiHash, NekoHash, utils};
let hasher = KawaiiHash::new();
let hash = hasher.hash(b"Secret data");
// User-provided key
let key = utils::generate_key();
let key_str = utils::key_to_base64(&key);
let encrypted = hasher.encrypt_hash(&hash, Some(&key))?;
let decrypted = hasher.decrypt_hash(&encrypted, &key)?;
// Random key (unrecoverable)
let encrypted = hasher.encrypt_hash(&hash, None)?;
Hash Combination
The library provides a method to combine multiple hashes:
use nekohash::{KawaiiHash, TsundereHash, MagicalHash, NekoHash, utils};
let hash1 = KawaiiHash::new().hash(b"Data 1");
let hash2 = TsundereHash::new().hash(b"Data 2");
let hash3 = MagicalHash::new().hash(b"Data 3");
let combined = utils::combine_hashes(&[hash1, hash2, hash3]);
The combination algorithm uses a rotating XOR operation to maintain a consistent output size while incorporating all input hashes.
Cryptographic Utilities
The library includes several cryptographic utility functions for enhanced security and key management:
Key Management
// Generate a cryptographically secure key
let key = generate_key();
// Convert key to/from base64 for storage
let key_str = key_to_base64(&key);
let key_back = key_from_base64(&key_str).unwrap();
// Derive a key from password and salt
let salt = generate_salt();
let derived_key = derive_key(b"my_password", &salt);
// Generate time-based keys (useful for temporary tokens)
let seed = b"application_seed";
let temp_key = time_based_key(seed, 30); // 30-second window
Secure Operations
// Constant-time comparison (timing-attack resistant)
let hash1 = kawaii_hasher.hash(b"data1");
let hash2 = kawaii_hasher.hash(b"data2");
let are_equal = constant_time_compare(&hash1, &hash2);
// Key stretching for password hashing
let stretched = stretch_key(b"password", 10000, 32);
// Combine multiple hashes securely
let combined = combine_hashes(&[hash1, hash2, hash3]);
// Rotate keys for added security
let rotated_key = rotate_key(&key, 12); // rotate 12 bits
Encryption Layer
// Encrypt with optional key
let encrypted = encrypt_data(b"secret data", None).unwrap();
// Decrypt with key
let decrypted = decrypt_data(&encrypted, &key).unwrap();
Interactive Demo
The library includes a comprehensive interactive demo that showcases all features. To run it:
cargo run --example demo
⚠️ Note: The demo requires an interactive terminal environment.
The demo includes several sections:
-
Hash Algorithm Demo 📝
- Demonstrates all three hash algorithms (KawaiiHash, MagicalHash, TsundereHash)
- Shows different output sizes and configurations
- Displays hash results in hex format with colored output
-
Encryption Demo 🔐
- Showcases the AES-256-CTR encryption layer
- Demonstrates key generation and management
- Shows encryption and decryption of data
-
Key Derivation Demo 🔑
- Shows various key derivation methods
- Demonstrates salt generation and usage
- Includes examples of key stretching and time-based keys
-
Utility Functions Demo 🛠️
- Shows hash combination functionality
- Demonstrates constant-time comparison
- Showcases key rotation and other utilities
-
Interactive Hash Testing 🎮
- Allows testing any hash algorithm with custom input
- Supports configuring algorithm-specific parameters
- Provides immediate visual feedback
Security Considerations
- This library is primarily designed for educational and non-critical applications
- The hash functions are not cryptographically secure
- The encryption layer uses standard AES-256-CTR but should not be relied upon for high-security applications
- Key management features are provided for convenience but should be used with caution in production
Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Version History
0.1.2
- Added interactive demo with colored output
- Improved hash algorithm determinism
- Enhanced error handling and state management
- Added comprehensive documentation
0.1.1
- Initial implementation of core hash algorithms
- Added basic encryption layer
- Implemented utility functions
Acknowledgments
- Inspired by various hashing algorithms and cryptographic concepts
- Built with love for both security and anime 🐱✨
Dependencies
~1MB
~24K SLoC