PATH:
opt
/
alt
/
tests
/
alt-php70-pecl-libsodium_2.0.23-1.el8
/
tests
--TEST-- Check for libsodium argon2i --SKIPIF-- <?php if (!extension_loaded("sodium")) print "skip"; if (!defined('SODIUM_CRYPTO_PWHASH_SALTBYTES')) print "skip libsodium without argon2i"; ?> --FILE-- <?php $passwd = 'password'; $hash = sodium_crypto_pwhash_str ($passwd, SODIUM_CRYPTO_PWHASH_OPSLIMIT_INTERACTIVE, SODIUM_CRYPTO_PWHASH_MEMLIMIT_INTERACTIVE); var_dump(substr($hash, 0, strlen(SODIUM_CRYPTO_PWHASH_STRPREFIX)) === SODIUM_CRYPTO_PWHASH_STRPREFIX); $testHash = '$argon2i$v=19$m=4096,t=3,p=1$MzE4ODFiZWFlMjAzOWUAAA$FWUV6tsyJ32qThiLi1cCsLIbf3dIOG/RwXcTzt536KY'; $c = sodium_crypto_pwhash_str_verify($testHash, $passwd); var_dump($c); $testHash = '$argon2i$v=19$m=4096,t=0,p=1$c29tZXNhbHQAAAAAAAAAAA$JTBozgKQiCn5yKAm3Hz0vUSX/XgfqhZloNCxDWmeDr0'; $c = sodium_crypto_pwhash_str_verify($testHash, $passwd); var_dump($c); $c = sodium_crypto_pwhash_str_verify($hash, $passwd); var_dump($c); $c = sodium_crypto_pwhash_str_verify($hash, 'passwd'); var_dump($c); $salt = random_bytes(SODIUM_CRYPTO_PWHASH_SALTBYTES); $out_len = 100; $key = sodium_crypto_pwhash ($out_len, $passwd, $salt, SODIUM_CRYPTO_PWHASH_OPSLIMIT_INTERACTIVE, SODIUM_CRYPTO_PWHASH_MEMLIMIT_INTERACTIVE, SODIUM_CRYPTO_PWHASH_ALG_DEFAULT); var_dump(strlen($key) === $out_len); $key2 = sodium_crypto_pwhash ($out_len, $passwd, $salt, SODIUM_CRYPTO_PWHASH_OPSLIMIT_INTERACTIVE, SODIUM_CRYPTO_PWHASH_MEMLIMIT_INTERACTIVE); var_dump($key2 === $key); ?> --EXPECT-- bool(true) bool(true) bool(false) bool(true) bool(false) bool(true) bool(true)
[-] crypto_hex.phpt
[edit]
[-] crypto_generichash.phpt
[edit]
[-] crypto_auth.phpt
[edit]
[-] crypto_secretstream.phpt
[edit]
[-] crypto_secretbox.phpt
[edit]
[-] pwhash_argon2i.phpt
[edit]
[-] crypto_aead.phpt
[edit]
[-] crypto_kx.phpt
[edit]
[-] crypto_box.phpt
[edit]
[-] crypto_scalarmult.phpt
[edit]
[-] installed.phpt
[edit]
[-] exception_trace_without_args.phpt
[edit]
[-] crypto_kdf.phpt
[edit]
[-] crypto_sign.phpt
[edit]
[+]
..
[-] version.phpt
[edit]
[-] inc_add.phpt
[edit]
[-] crypto_stream.phpt
[edit]
[-] crypto_shorthash.phpt
[edit]
[-] utils.phpt
[edit]