2022-01-20 16:10:16 +09:00
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
2021-02-26 22:36:26 +05:30
2021-12-10 09:12:21 +11:00
// deno-lint-ignore-file no-var
2021-02-26 22:36:26 +05:30
/// <reference no-default-lib="true" />
/// <reference lib="esnext" />
declare var crypto : Crypto ;
2021-07-06 17:46:04 +05:30
interface Algorithm {
name : string ;
}
interface KeyAlgorithm {
name : string ;
}
type AlgorithmIdentifier = string | Algorithm ;
type HashAlgorithmIdentifier = AlgorithmIdentifier ;
type KeyType = "private" | "public" | "secret" ;
type KeyUsage =
| "decrypt"
| "deriveBits"
| "deriveKey"
| "encrypt"
| "sign"
| "unwrapKey"
| "verify"
| "wrapKey" ;
2021-08-29 17:53:51 +05:30
type KeyFormat = "jwk" | "pkcs8" | "raw" | "spki" ;
2021-07-06 17:46:04 +05:30
type NamedCurve = string ;
2021-08-27 16:49:41 +05:30
interface RsaOtherPrimesInfo {
d? : string ;
r? : string ;
t? : string ;
}
interface JsonWebKey {
alg? : string ;
crv? : string ;
d? : string ;
dp? : string ;
dq? : string ;
e? : string ;
ext? : boolean ;
k? : string ;
// deno-lint-ignore camelcase
key_ops? : string [ ] ;
kty? : string ;
n? : string ;
oth? : RsaOtherPrimesInfo [ ] ;
p? : string ;
q? : string ;
qi? : string ;
use? : string ;
x? : string ;
y? : string ;
}
2021-10-11 20:07:51 +05:30
interface AesCbcParams extends Algorithm {
iv : BufferSource ;
}
2022-01-05 20:42:30 +05:30
interface AesGcmParams extends Algorithm {
iv : BufferSource ;
additionalData? : BufferSource ;
tagLength? : number ;
}
2022-01-03 08:27:28 -03:00
interface AesCtrParams extends Algorithm {
counter : BufferSource ;
length : number ;
}
2021-07-06 17:46:04 +05:30
interface HmacKeyGenParams extends Algorithm {
hash : HashAlgorithmIdentifier ;
length? : number ;
}
interface EcKeyGenParams extends Algorithm {
namedCurve : NamedCurve ;
}
2022-03-11 15:05:40 +01:00
interface EcKeyImportParams extends Algorithm {
2021-12-16 13:28:43 -03:00
namedCurve : NamedCurve ;
}
2021-07-06 17:46:04 +05:30
interface EcdsaParams extends Algorithm {
hash : HashAlgorithmIdentifier ;
}
2021-09-14 18:51:20 +05:30
interface RsaHashedImportParams extends Algorithm {
hash : HashAlgorithmIdentifier ;
}
2021-07-06 17:46:04 +05:30
interface RsaHashedKeyGenParams extends RsaKeyGenParams {
hash : HashAlgorithmIdentifier ;
}
interface RsaKeyGenParams extends Algorithm {
modulusLength : number ;
publicExponent : Uint8Array ;
}
interface RsaPssParams extends Algorithm {
saltLength : number ;
}
2021-08-25 01:29:02 +05:30
interface RsaOaepParams extends Algorithm {
label? : Uint8Array ;
}
2021-08-04 00:54:02 +05:30
interface HmacImportParams extends Algorithm {
hash : HashAlgorithmIdentifier ;
length? : number ;
}
2021-08-24 18:45:25 +05:30
interface EcKeyAlgorithm extends KeyAlgorithm {
namedCurve : NamedCurve ;
}
interface HmacKeyAlgorithm extends KeyAlgorithm {
hash : KeyAlgorithm ;
length : number ;
}
interface RsaHashedKeyAlgorithm extends RsaKeyAlgorithm {
hash : KeyAlgorithm ;
}
interface RsaKeyAlgorithm extends KeyAlgorithm {
modulusLength : number ;
publicExponent : Uint8Array ;
}
2021-09-13 02:32:49 +05:30
interface HkdfParams extends Algorithm {
hash : HashAlgorithmIdentifier ;
info : BufferSource ;
salt : BufferSource ;
}
interface Pbkdf2Params extends Algorithm {
hash : HashAlgorithmIdentifier ;
iterations : number ;
salt : BufferSource ;
}
2021-10-12 16:09:46 +05:30
interface AesDerivedKeyParams extends Algorithm {
length : number ;
}
2021-10-08 20:59:36 +05:30
interface EcdhKeyDeriveParams extends Algorithm {
public : CryptoKey ;
}
2021-10-03 18:54:46 +05:30
interface AesKeyGenParams extends Algorithm {
length : number ;
}
interface AesKeyAlgorithm extends KeyAlgorithm {
length : number ;
}
2021-07-06 17:46:04 +05:30
/** The CryptoKey dictionary of the Web Crypto API represents a cryptographic key. */
interface CryptoKey {
readonly algorithm : KeyAlgorithm ;
readonly extractable : boolean ;
readonly type : KeyType ;
readonly usages : KeyUsage [ ] ;
}
declare var CryptoKey : {
prototype : CryptoKey ;
new ( ) : CryptoKey ;
} ;
/** The CryptoKeyPair dictionary of the Web Crypto API represents a key pair for an asymmetric cryptography algorithm, also known as a public-key algorithm. */
interface CryptoKeyPair {
privateKey : CryptoKey ;
publicKey : CryptoKey ;
}
declare var CryptoKeyPair : {
prototype : CryptoKeyPair ;
new ( ) : CryptoKeyPair ;
} ;
/** This Web Crypto API interface provides a number of low-level cryptographic functions. It is accessed via the Crypto.subtle properties available in a window context (via Window.crypto). */
interface SubtleCrypto {
generateKey (
algorithm : RsaHashedKeyGenParams | EcKeyGenParams ,
extractable : boolean ,
keyUsages : KeyUsage [ ] ,
) : Promise < CryptoKeyPair > ;
generateKey (
2021-10-03 18:54:46 +05:30
algorithm : AesKeyGenParams | HmacKeyGenParams ,
2021-07-06 17:46:04 +05:30
extractable : boolean ,
keyUsages : KeyUsage [ ] ,
) : Promise < CryptoKey > ;
generateKey (
algorithm : AlgorithmIdentifier ,
extractable : boolean ,
keyUsages : KeyUsage [ ] ,
) : Promise < CryptoKeyPair | CryptoKey > ;
2021-08-27 16:49:41 +05:30
importKey (
format : "jwk" ,
keyData : JsonWebKey ,
2021-12-16 13:28:43 -03:00
algorithm :
| AlgorithmIdentifier
| HmacImportParams
| RsaHashedImportParams
2022-03-11 15:05:40 +01:00
| EcKeyImportParams ,
2021-08-27 16:49:41 +05:30
extractable : boolean ,
keyUsages : KeyUsage [ ] ,
) : Promise < CryptoKey > ;
2021-08-04 00:54:02 +05:30
importKey (
2021-09-14 18:51:20 +05:30
format : Exclude < KeyFormat , "jwk" > ,
2021-08-04 00:54:02 +05:30
keyData : BufferSource ,
2021-12-16 13:28:43 -03:00
algorithm :
| AlgorithmIdentifier
| HmacImportParams
| RsaHashedImportParams
2022-03-11 15:05:40 +01:00
| EcKeyImportParams ,
2021-08-04 00:54:02 +05:30
extractable : boolean ,
keyUsages : KeyUsage [ ] ,
) : Promise < CryptoKey > ;
2021-08-29 17:53:51 +05:30
exportKey ( format : "jwk" , key : CryptoKey ) : Promise < JsonWebKey > ;
exportKey (
format : Exclude < KeyFormat , "jwk" > ,
key : CryptoKey ,
) : Promise < ArrayBuffer > ;
2021-07-06 17:46:04 +05:30
sign (
algorithm : AlgorithmIdentifier | RsaPssParams | EcdsaParams ,
key : CryptoKey ,
2021-07-26 17:30:19 +05:30
data : BufferSource ,
2021-07-06 17:46:04 +05:30
) : Promise < ArrayBuffer > ;
2021-07-12 18:15:36 +05:30
verify (
2021-09-12 02:19:53 +05:30
algorithm : AlgorithmIdentifier | RsaPssParams | EcdsaParams ,
2021-07-12 18:15:36 +05:30
key : CryptoKey ,
2021-07-26 17:30:19 +05:30
signature : BufferSource ,
data : BufferSource ,
2021-07-12 18:15:36 +05:30
) : Promise < boolean > ;
2021-06-06 18:57:10 +08:00
digest (
algorithm : AlgorithmIdentifier ,
2021-07-26 17:30:19 +05:30
data : BufferSource ,
2021-06-06 18:57:10 +08:00
) : Promise < ArrayBuffer > ;
2021-08-25 01:29:02 +05:30
encrypt (
2022-01-03 08:27:28 -03:00
algorithm :
| AlgorithmIdentifier
| RsaOaepParams
| AesCbcParams
2022-01-05 20:42:30 +05:30
| AesGcmParams
2022-01-03 08:27:28 -03:00
| AesCtrParams ,
2021-08-25 01:29:02 +05:30
key : CryptoKey ,
data : BufferSource ,
) : Promise < ArrayBuffer > ;
decrypt (
2022-01-03 08:27:28 -03:00
algorithm :
| AlgorithmIdentifier
| RsaOaepParams
| AesCbcParams
2022-01-14 14:18:53 +05:30
| AesGcmParams
2022-01-03 08:27:28 -03:00
| AesCtrParams ,
2021-08-25 01:29:02 +05:30
key : CryptoKey ,
data : BufferSource ,
) : Promise < ArrayBuffer > ;
2021-09-13 02:32:49 +05:30
deriveBits (
2021-10-08 20:59:36 +05:30
algorithm :
| AlgorithmIdentifier
| HkdfParams
| Pbkdf2Params
| EcdhKeyDeriveParams ,
2021-09-13 02:32:49 +05:30
baseKey : CryptoKey ,
length : number ,
) : Promise < ArrayBuffer > ;
2021-10-12 16:09:46 +05:30
deriveKey (
2022-06-30 07:53:05 +02:00
algorithm :
| AlgorithmIdentifier
| HkdfParams
| Pbkdf2Params
| EcdhKeyDeriveParams ,
2021-10-12 16:09:46 +05:30
baseKey : CryptoKey ,
derivedKeyType :
| AlgorithmIdentifier
| AesDerivedKeyParams
| HmacImportParams
| HkdfParams
| Pbkdf2Params ,
extractable : boolean ,
keyUsages : KeyUsage [ ] ,
) : Promise < CryptoKey > ;
2021-10-01 15:09:49 +05:30
wrapKey (
format : KeyFormat ,
key : CryptoKey ,
wrappingKey : CryptoKey ,
2022-01-11 01:44:47 -03:00
wrapAlgorithm :
| AlgorithmIdentifier
| RsaOaepParams
| AesCbcParams
| AesCtrParams ,
2021-10-01 15:09:49 +05:30
) : Promise < ArrayBuffer > ;
2021-12-05 09:25:11 +05:30
unwrapKey (
format : KeyFormat ,
wrappedKey : BufferSource ,
unwrappingKey : CryptoKey ,
unwrapAlgorithm :
| AlgorithmIdentifier
| RsaOaepParams
2022-01-11 01:44:47 -03:00
| AesCbcParams
| AesCtrParams ,
2021-12-05 09:25:11 +05:30
unwrappedKeyAlgorithm :
| AlgorithmIdentifier
| HmacImportParams
2022-01-11 01:44:47 -03:00
| RsaHashedImportParams
2022-03-11 15:05:40 +01:00
| EcKeyImportParams ,
2021-12-05 09:25:11 +05:30
extractable : boolean ,
keyUsages : KeyUsage [ ] ,
) : Promise < CryptoKey > ;
2021-06-06 18:57:10 +08:00
}
2021-07-06 17:46:04 +05:30
declare interface Crypto {
readonly subtle : SubtleCrypto ;
getRandomValues <
T extends
| Int8Array
| Int16Array
| Int32Array
| Uint8Array
| Uint16Array
| Uint32Array
| Uint8ClampedArray
2022-06-02 15:15:46 +02:00
| BigInt64Array
| BigUint64Array
2021-07-06 17:46:04 +05:30
| DataView
| null ,
> (
array : T ,
) : T ;
randomUUID ( ) : string ;
}
2021-06-06 18:57:10 +08:00
declare var SubtleCrypto : {
prototype : SubtleCrypto ;
new ( ) : SubtleCrypto ;
} ;