003 File Manager
Current Path:
/usr/src/sys/contrib/libsodium/src/libsodium/include/sodium
usr
/
src
/
sys
/
contrib
/
libsodium
/
src
/
libsodium
/
include
/
sodium
/
📁
..
📄
core.h
(412 B)
📄
crypto_aead_aes256gcm.h
(7.36 KB)
📄
crypto_aead_chacha20poly1305.h
(8.2 KB)
📄
crypto_aead_xchacha20poly1305.h
(4.53 KB)
📄
crypto_auth.h
(1 KB)
📄
crypto_auth_hmacsha256.h
(1.9 KB)
📄
crypto_auth_hmacsha512.h
(1.89 KB)
📄
crypto_auth_hmacsha512256.h
(1.84 KB)
📄
crypto_box.h
(6.05 KB)
📄
crypto_box_curve25519xchacha20poly1305.h
(7.27 KB)
📄
crypto_box_curve25519xsalsa20poly1305.h
(4.33 KB)
📄
crypto_core_ed25519.h
(826 B)
📄
crypto_core_hchacha20.h
(769 B)
📄
crypto_core_hsalsa20.h
(757 B)
📄
crypto_core_salsa20.h
(745 B)
📄
crypto_core_salsa2012.h
(769 B)
📄
crypto_core_salsa208.h
(921 B)
📄
crypto_generichash.h
(2.24 KB)
📄
crypto_generichash_blake2b.h
(3.7 KB)
📄
crypto_hash.h
(872 B)
📄
crypto_hash_sha256.h
(1.31 KB)
📄
crypto_hash_sha512.h
(1.32 KB)
📄
crypto_kdf.h
(1.2 KB)
📄
crypto_kdf_blake2b.h
(1.01 KB)
📄
crypto_kx.h
(2 KB)
📄
crypto_onetimeauth.h
(1.67 KB)
📄
crypto_onetimeauth_poly1305.h
(1.92 KB)
📄
crypto_pwhash.h
(4.72 KB)
📄
crypto_pwhash_argon2i.h
(3.72 KB)
📄
crypto_pwhash_argon2id.h
(3.78 KB)
📄
crypto_pwhash_scryptsalsa208sha256.h
(4.45 KB)
📄
crypto_scalarmult.h
(1.08 KB)
📄
crypto_scalarmult_curve25519.h
(979 B)
📄
crypto_scalarmult_ed25519.h
(953 B)
📄
crypto_secretbox.h
(2.98 KB)
📄
crypto_secretbox_xchacha20poly1305.h
(2.62 KB)
📄
crypto_secretbox_xsalsa20poly1305.h
(2.25 KB)
📄
crypto_secretstream_xchacha20poly1305.h
(3.49 KB)
📄
crypto_shorthash.h
(878 B)
📄
crypto_shorthash_siphash24.h
(1.12 KB)
📄
crypto_sign.h
(2.96 KB)
📄
crypto_sign_ed25519.h
(3.73 KB)
📄
crypto_sign_edwards25519sha512batch.h
(1.9 KB)
📄
crypto_stream.h
(1.46 KB)
📄
crypto_stream_chacha20.h
(3.29 KB)
📄
crypto_stream_salsa20.h
(1.64 KB)
📄
crypto_stream_salsa2012.h
(1.38 KB)
📄
crypto_stream_salsa208.h
(1.61 KB)
📄
crypto_stream_xchacha20.h
(1.68 KB)
📄
crypto_stream_xsalsa20.h
(1.66 KB)
📄
crypto_verify_16.h
(393 B)
📄
crypto_verify_32.h
(393 B)
📄
crypto_verify_64.h
(393 B)
📄
export.h
(1.46 KB)
📁
private
📄
randombytes.h
(1.66 KB)
📄
randombytes_nativeclient.h
(331 B)
📄
randombytes_salsa20_random.h
(290 B)
📄
randombytes_sysrandom.h
(282 B)
📄
runtime.h
(889 B)
📄
utils.h
(5.55 KB)
📄
version.h.in
(597 B)
Editing: crypto_aead_aes256gcm.h
#ifndef crypto_aead_aes256gcm_H #define crypto_aead_aes256gcm_H /* * WARNING: Despite being the most popular AEAD construction due to its * use in TLS, safely using AES-GCM in a different context is tricky. * * No more than ~ 350 GB of input data should be encrypted with a given key. * This is for ~ 16 KB messages -- Actual figures vary according to * message sizes. * * In addition, nonces are short and repeated nonces would totally destroy * the security of this scheme. * * Nonces should thus come from atomic counters, which can be difficult to * set up in a distributed environment. * * Unless you absolutely need AES-GCM, use crypto_aead_xchacha20poly1305_ietf_*() * instead. It doesn't have any of these limitations. * Or, if you don't need to authenticate additional data, just stick to * crypto_secretbox(). */ #include <stddef.h> #include "export.h" #ifdef __cplusplus # ifdef __GNUC__ # pragma GCC diagnostic ignored "-Wlong-long" # endif extern "C" { #endif SODIUM_EXPORT int crypto_aead_aes256gcm_is_available(void); #define crypto_aead_aes256gcm_KEYBYTES 32U SODIUM_EXPORT size_t crypto_aead_aes256gcm_keybytes(void); #define crypto_aead_aes256gcm_NSECBYTES 0U SODIUM_EXPORT size_t crypto_aead_aes256gcm_nsecbytes(void); #define crypto_aead_aes256gcm_NPUBBYTES 12U SODIUM_EXPORT size_t crypto_aead_aes256gcm_npubbytes(void); #define crypto_aead_aes256gcm_ABYTES 16U SODIUM_EXPORT size_t crypto_aead_aes256gcm_abytes(void); #define crypto_aead_aes256gcm_MESSAGEBYTES_MAX \ SODIUM_MIN(SODIUM_SIZE_MAX - crypto_aead_aes256gcm_ABYTES, \ (16ULL * ((1ULL << 32) - 2ULL)) - crypto_aead_aes256gcm_ABYTES) SODIUM_EXPORT size_t crypto_aead_aes256gcm_messagebytes_max(void); typedef CRYPTO_ALIGN(16) unsigned char crypto_aead_aes256gcm_state[512]; SODIUM_EXPORT size_t crypto_aead_aes256gcm_statebytes(void); SODIUM_EXPORT int crypto_aead_aes256gcm_encrypt(unsigned char *c, unsigned long long *clen_p, const unsigned char *m, unsigned long long mlen, const unsigned char *ad, unsigned long long adlen, const unsigned char *nsec, const unsigned char *npub, const unsigned char *k); SODIUM_EXPORT int crypto_aead_aes256gcm_decrypt(unsigned char *m, unsigned long long *mlen_p, unsigned char *nsec, const unsigned char *c, unsigned long long clen, const unsigned char *ad, unsigned long long adlen, const unsigned char *npub, const unsigned char *k) __attribute__ ((warn_unused_result)); SODIUM_EXPORT int crypto_aead_aes256gcm_encrypt_detached(unsigned char *c, unsigned char *mac, unsigned long long *maclen_p, const unsigned char *m, unsigned long long mlen, const unsigned char *ad, unsigned long long adlen, const unsigned char *nsec, const unsigned char *npub, const unsigned char *k); SODIUM_EXPORT int crypto_aead_aes256gcm_decrypt_detached(unsigned char *m, unsigned char *nsec, const unsigned char *c, unsigned long long clen, const unsigned char *mac, const unsigned char *ad, unsigned long long adlen, const unsigned char *npub, const unsigned char *k) __attribute__ ((warn_unused_result)); /* -- Precomputation interface -- */ SODIUM_EXPORT int crypto_aead_aes256gcm_beforenm(crypto_aead_aes256gcm_state *ctx_, const unsigned char *k); SODIUM_EXPORT int crypto_aead_aes256gcm_encrypt_afternm(unsigned char *c, unsigned long long *clen_p, const unsigned char *m, unsigned long long mlen, const unsigned char *ad, unsigned long long adlen, const unsigned char *nsec, const unsigned char *npub, const crypto_aead_aes256gcm_state *ctx_); SODIUM_EXPORT int crypto_aead_aes256gcm_decrypt_afternm(unsigned char *m, unsigned long long *mlen_p, unsigned char *nsec, const unsigned char *c, unsigned long long clen, const unsigned char *ad, unsigned long long adlen, const unsigned char *npub, const crypto_aead_aes256gcm_state *ctx_) __attribute__ ((warn_unused_result)); SODIUM_EXPORT int crypto_aead_aes256gcm_encrypt_detached_afternm(unsigned char *c, unsigned char *mac, unsigned long long *maclen_p, const unsigned char *m, unsigned long long mlen, const unsigned char *ad, unsigned long long adlen, const unsigned char *nsec, const unsigned char *npub, const crypto_aead_aes256gcm_state *ctx_); SODIUM_EXPORT int crypto_aead_aes256gcm_decrypt_detached_afternm(unsigned char *m, unsigned char *nsec, const unsigned char *c, unsigned long long clen, const unsigned char *mac, const unsigned char *ad, unsigned long long adlen, const unsigned char *npub, const crypto_aead_aes256gcm_state *ctx_) __attribute__ ((warn_unused_result)); SODIUM_EXPORT void crypto_aead_aes256gcm_keygen(unsigned char k[crypto_aead_aes256gcm_KEYBYTES]); #ifdef __cplusplus } #endif #endif
Upload File
Create Folder