ahtishamashraf/astra512-ffi
最新稳定版本:v0.1.1
Composer 安装命令:
composer require ahtishamashraf/astra512-ffi
包简介
PHP FFI bindings for ASTRA-512 (research SIV-style AEAD) with key management helpers.
关键字:
README 文档
README
FFI bindings for ASTRA-512 (research SIV-style AEAD) with key management and password-based key derivation helpers.
⚠️ This is research cryptography. Do not use in production until independent review.
Install
composer require ahtishamashraf/astra512-ffi
Native library
The FFI loader searches:
- explicit path you pass to
Astra512::create($path) ASTRA512_LIBenv var (absolute path)- vendored
bin/<platform>/ - system names:
libastra512.so/libastra512.dylib/astra512.dll
Use with a random 32-byte key
use Astra512\Astra512; use Astra512\Key; $astra = Astra512::create(getenv('ASTRA512_LIB') ?: null); $key = Key::generate(); // 32 random bytes $aad = "app:v1"; $pt = "hello"; [$ct, $tag] = $astra->encrypt($key, $aad, $pt); $out = $astra->decrypt($key, $aad, $ct, $tag);
Use with a password (derives a 32-byte key via Argon2id)
use Astra512\Astra512; use Astra512\Password; $astra = Astra512::create(getenv('ASTRA512_LIB') ?: null); $password = "correct horse battery staple"; [$salt, $key] = Password::deriveKey($password); // returns [16-byte salt, 32-byte key] [$ct, $tag] = $astra->encrypt($key, "app:v1", "secret"); // To decrypt later, re-derive the key with the saved salt: $key2 = Password::deriveKeyWithSalt($password, $salt); $out = $astra->decrypt($key2, "app:v1", $ct, $tag);
About salt
- Encryption itself does not need a salt or nonce (ASTRA-512 is SIV-style and deterministic).
- Salt is only for password-based key derivation (Argon2id). Store the salt alongside the ciphertext so you can re-derive the same key to decrypt.
Helpers
Key::generate()→ 32 random bytesKey::save($path, $key)/Key::load($path)Password::deriveKey($password, $opslimit=?, $memlimit=?)→ returns[salt, key]Password::deriveKeyWithSalt($password, $salt, ...)→ returnskey
See examples/ for complete flows.
astra512-ffi
统计信息
- 总下载量: 1
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-08-20