2023-09-04 03:25:04 +00:00
|
|
|
#![allow(non_snake_case)]
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[wasm_bindgen]
|
|
|
|
extern "C" {
|
|
|
|
#[wasm_bindgen(typescript_type = "string[]")]
|
|
|
|
pub type ValidCryptoKinds;
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
#[wasm_bindgen(js_name = veilidCrypto)]
|
2023-09-04 03:25:04 +00:00
|
|
|
pub struct VeilidCrypto {}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
// Since this implementation doesn't contain a `new` fn that's marked as a constructor,
|
|
|
|
// and none of the member fns take a &self arg,
|
|
|
|
// this is just a namespace/class of static functions.
|
2023-09-04 03:25:04 +00:00
|
|
|
#[wasm_bindgen(js_class = veilidCrypto)]
|
|
|
|
impl VeilidCrypto {
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn validCryptoKinds() -> StringArray {
|
2023-09-04 03:25:04 +00:00
|
|
|
let res = veilid_core::VALID_CRYPTO_KINDS
|
|
|
|
.iter()
|
2023-09-04 18:04:57 +00:00
|
|
|
.map(|k| (*k).to_string())
|
|
|
|
.collect();
|
|
|
|
into_unchecked_string_array(res)
|
2023-09-04 03:25:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn bestCryptoKind() -> String {
|
|
|
|
veilid_core::best_crypto_kind().to_string()
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn cachedDh(kind: String, key: String, secret: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
let key: veilid_core::PublicKey = veilid_core::PublicKey::from_str(&key)?;
|
|
|
|
let secret: veilid_core::SecretKey = veilid_core::SecretKey::from_str(&secret)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_cached_dh",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.cached_dh(&key, &secret)?;
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn computeDh(kind: String, key: String, secret: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let key: veilid_core::PublicKey = veilid_core::PublicKey::from_str(&key)?;
|
|
|
|
let secret: veilid_core::SecretKey = veilid_core::SecretKey::from_str(&secret)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_compute_dh",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.compute_dh(&key, &secret)?;
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn randomBytes(kind: String, len: u32) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_random_bytes",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.random_bytes(len);
|
2023-09-04 03:25:04 +00:00
|
|
|
let out = data_encoding::BASE64URL_NOPAD.encode(&out);
|
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn defaultSaltLength(kind: String) -> APIResult<u32> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_default_salt_length",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.default_salt_length();
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn hashPassword(kind: String, password: String, salt: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
let password: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(password.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
let salt: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(salt.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_hash_password",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.hash_password(&password, &salt)?;
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn verifyPassword(
|
|
|
|
kind: String,
|
|
|
|
password: String,
|
|
|
|
password_hash: String,
|
2023-09-04 18:04:57 +00:00
|
|
|
) -> APIResult<bool> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
let password: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(password.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_verify_password",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.verify_password(&password, &password_hash)?;
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn deriveSharedSecret(kind: String, password: String, salt: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
let password: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(password.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
let salt: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(salt.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_derive_shared_secret",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.derive_shared_secret(&password, &salt)?;
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn randomNonce(kind: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_random_nonce",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.random_nonce();
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn randomSharedSecret(kind: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_random_shared_secret",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.random_shared_secret();
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn generateKeyPair(kind: String) -> APIResult<KeyPair> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_generate_key_pair",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.generate_keypair();
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn generateHash(kind: String, data: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let data: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(data.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_generate_hash",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.generate_hash(&data);
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn validateKeyPair(kind: String, key: String, secret: String) -> APIResult<bool> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let key: veilid_core::PublicKey = veilid_core::PublicKey::from_str(&key)?;
|
|
|
|
let secret: veilid_core::SecretKey = veilid_core::SecretKey::from_str(&secret)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_validate_key_pair",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.validate_keypair(&key, &secret);
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn validateHash(kind: String, data: String, hash: String) -> APIResult<bool> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let data: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(data.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let hash: veilid_core::HashDigest = veilid_core::HashDigest::from_str(&hash)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_validate_hash",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.validate_hash(&data, &hash);
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn distance(kind: String, key1: String, key2: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let key1: veilid_core::CryptoKey = veilid_core::CryptoKey::from_str(&key1)?;
|
|
|
|
let key2: veilid_core::CryptoKey = veilid_core::CryptoKey::from_str(&key2)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_distance",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.distance(&key1, &key2);
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn sign(kind: String, key: String, secret: String, data: String) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let key: veilid_core::PublicKey = veilid_core::PublicKey::from_str(&key)?;
|
|
|
|
let secret: veilid_core::SecretKey = veilid_core::SecretKey::from_str(&secret)?;
|
|
|
|
|
|
|
|
let data: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(data.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument("crypto_sign", "kind", kind.to_string())
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.sign(&key, &secret, &data)?;
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out.to_string())
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn verify(kind: String, key: String, data: String, signature: String) -> APIResult<()> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let key: veilid_core::PublicKey = veilid_core::PublicKey::from_str(&key)?;
|
|
|
|
let data: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(data.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
let signature: veilid_core::Signature = veilid_core::Signature::from_str(&signature)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument("crypto_verify", "kind", kind.to_string())
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
crypto_system.verify(&key, &data, &signature)?;
|
2023-09-04 03:25:04 +00:00
|
|
|
APIRESULT_UNDEFINED
|
|
|
|
}
|
|
|
|
|
2023-09-04 18:04:57 +00:00
|
|
|
pub fn aeadOverhead(kind: String) -> APIResult<usize> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_aead_overhead",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.aead_overhead();
|
2023-09-04 03:25:04 +00:00
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn decryptAead(
|
|
|
|
kind: String,
|
|
|
|
body: String,
|
|
|
|
nonce: String,
|
|
|
|
shared_secret: String,
|
|
|
|
associated_data: Option<String>,
|
2023-09-04 18:04:57 +00:00
|
|
|
) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let body: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(body.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let nonce: veilid_core::Nonce = veilid_core::Nonce::from_str(&nonce)?;
|
|
|
|
|
|
|
|
let shared_secret: veilid_core::SharedSecret =
|
|
|
|
veilid_core::SharedSecret::from_str(&shared_secret)?;
|
|
|
|
|
|
|
|
let associated_data: Option<Vec<u8>> = associated_data.map(|ad| {
|
|
|
|
data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(ad.as_bytes())
|
|
|
|
.unwrap()
|
|
|
|
});
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_decrypt_aead",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.decrypt_aead(
|
2023-09-04 03:25:04 +00:00
|
|
|
&body,
|
|
|
|
&nonce,
|
|
|
|
&shared_secret,
|
|
|
|
match &associated_data {
|
|
|
|
Some(ad) => Some(ad.as_slice()),
|
|
|
|
None => None,
|
|
|
|
},
|
|
|
|
)?;
|
|
|
|
let out = data_encoding::BASE64URL_NOPAD.encode(&out);
|
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn encryptAead(
|
|
|
|
kind: String,
|
|
|
|
body: String,
|
|
|
|
nonce: String,
|
|
|
|
shared_secret: String,
|
|
|
|
associated_data: Option<String>,
|
2023-09-04 18:04:57 +00:00
|
|
|
) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let body: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(body.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let nonce: veilid_core::Nonce = veilid_core::Nonce::from_str(&nonce).unwrap();
|
|
|
|
|
|
|
|
let shared_secret: veilid_core::SharedSecret =
|
|
|
|
veilid_core::SharedSecret::from_str(&shared_secret).unwrap();
|
|
|
|
|
|
|
|
let associated_data: Option<Vec<u8>> = associated_data.map(|ad| {
|
|
|
|
data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(ad.as_bytes())
|
|
|
|
.unwrap()
|
|
|
|
});
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_encrypt_aead",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let out = crypto_system.encrypt_aead(
|
2023-09-04 03:25:04 +00:00
|
|
|
&body,
|
|
|
|
&nonce,
|
|
|
|
&shared_secret,
|
|
|
|
match &associated_data {
|
|
|
|
Some(ad) => Some(ad.as_slice()),
|
|
|
|
None => None,
|
|
|
|
},
|
|
|
|
)?;
|
|
|
|
let out = data_encoding::BASE64URL_NOPAD.encode(&out);
|
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn cryptNoAuth(
|
|
|
|
kind: String,
|
|
|
|
body: String,
|
|
|
|
nonce: String,
|
|
|
|
shared_secret: String,
|
2023-09-04 18:04:57 +00:00
|
|
|
) -> APIResult<String> {
|
2023-09-04 03:25:04 +00:00
|
|
|
let kind: veilid_core::CryptoKind = veilid_core::FourCC::from_str(&kind)?;
|
|
|
|
|
|
|
|
let mut body: Vec<u8> = data_encoding::BASE64URL_NOPAD
|
|
|
|
.decode(body.as_bytes())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let nonce: veilid_core::Nonce = veilid_core::Nonce::from_str(&nonce).unwrap();
|
|
|
|
|
|
|
|
let shared_secret: veilid_core::SharedSecret =
|
|
|
|
veilid_core::SharedSecret::from_str(&shared_secret).unwrap();
|
|
|
|
|
|
|
|
let veilid_api = get_veilid_api()?;
|
|
|
|
let crypto = veilid_api.crypto()?;
|
2023-09-04 18:04:57 +00:00
|
|
|
let crypto_system = crypto.get(kind).ok_or_else(|| {
|
2023-09-04 03:25:04 +00:00
|
|
|
veilid_core::VeilidAPIError::invalid_argument(
|
|
|
|
"crypto_crypt_no_auth",
|
|
|
|
"kind",
|
|
|
|
kind.to_string(),
|
|
|
|
)
|
|
|
|
})?;
|
2023-09-04 18:04:57 +00:00
|
|
|
crypto_system.crypt_in_place_no_auth(&mut body, &nonce, &shared_secret);
|
2023-09-04 03:25:04 +00:00
|
|
|
let out = data_encoding::BASE64URL_NOPAD.encode(&body);
|
|
|
|
APIResult::Ok(out)
|
|
|
|
}
|
|
|
|
}
|