util.crypto: Update Teal interface description to match C sources
authorKim Alvefur <zash@zash.se>
Fri, 23 Feb 2024 16:33:08 +0100
changeset 13437 ff1944502160
parent 13436 116b756ced71
child 13438 4467ae4d1379
util.crypto: Update Teal interface description to match C sources Was missing some entries. Rearranged to match order of entries in the C source Reg table.
teal-src/prosody/util/crypto.d.tl
--- a/teal-src/prosody/util/crypto.d.tl	Fri Feb 23 12:16:03 2024 +0000
+++ b/teal-src/prosody/util/crypto.d.tl	Fri Feb 23 16:33:08 2024 +0100
@@ -5,23 +5,51 @@
 		get_type : function (key) : string
 	end
 
-	generate_ed25519_keypair : function () : key
-	ed25519_sign : function (key, string) : string
-	ed25519_verify : function (key, string, string) : boolean
+	type base_evp_sign = function (key, message : string) : string
+	type base_evp_verify = function (key, message : string, signature : string) : boolean
+
+	ed25519_sign : base_evp_sign
+	ed25519_verify : base_evp_verify
+
+	ecdsa_sha256_sign : base_evp_sign
+	ecdsa_sha256_verify : base_evp_verify
+	ecdsa_sha384_sign : base_evp_sign
+	ecdsa_sha384_verify : base_evp_verify
+	ecdsa_sha512_sign : base_evp_sign
+	ecdsa_sha512_verify : base_evp_verify
+
+	rsassa_pkcs1_sha256_sign : base_evp_sign
+	rsassa_pkcs1_sha256_verify : base_evp_verify
+	rsassa_pkcs1_sha384_sign : base_evp_sign
+	rsassa_pkcs1_sha384_verify : base_evp_verify
+	rsassa_pkcs1_sha512_sign : base_evp_sign
+	rsassa_pkcs1_sha512_verify : base_evp_verify
 
-	ecdsa_sha256_sign : function (key, string) : string
-	ecdsa_sha256_verify : function (key, string, string) : boolean
-	parse_ecdsa_signature : function (string) : string, string
-	build_ecdsa_signature : function (string, string) : string
+	rsassa_pss_sha256_sign : base_evp_sign
+	rsassa_pss_sha256_verify : base_evp_verify
+	rsassa_pss_sha384_sign : base_evp_sign
+	rsassa_pss_sha384_verify : base_evp_verify
+	rsassa_pss_sha512_sign : base_evp_sign
+	rsassa_pss_sha512_verify : base_evp_verify
+
+	type Levp_encrypt = function (key : string, iv : string, plaintext : string) : string
+	type Levp_decrypt = function (key : string, iv : string, ciphertext : string) : string, string
+
+	aes_128_gcm_encrypt : Levp_encrypt
+	aes_128_gcm_decrypt : Levp_decrypt
+	aes_256_gcm_encrypt : Levp_encrypt
+	aes_256_gcm_decrypt : Levp_decrypt
+
+	aes_256_ctr_encrypt : Levp_encrypt
+	aes_256_ctr_decrypt : Levp_decrypt
+
+	generate_ed25519_keypair : function () : key
 
 	import_private_pem : function (string) : key
 	import_public_pem : function (string) : key
 
-	aes_128_gcm_encrypt : function (key, string, string) : string
-	aes_128_gcm_decrypt : function (key, string, string) : string
-	aes_256_gcm_encrypt : function (key, string, string) : string
-	aes_256_gcm_decrypt : function (key, string, string) : string
-
+	parse_ecdsa_signature : function (string, integer) : string, string
+	build_ecdsa_signature : function (r : string, s : string) : string
 
 	version : string
 	_LIBCRYPTO_VERSION : string