@azure/msal-browser
Version:
Microsoft Authentication Library for js
62 lines • 2.08 kB
TypeScript
import { Logger } from "@azure/msal-common";
import { CryptoOptions } from "../config/Configuration";
/**
* This class implements functions used by the browser library to perform cryptography operations such as
* hashing and encoding. It also has helper functions to validate the availability of specific APIs.
*/
export declare class BrowserCrypto {
private keygenAlgorithmOptions;
private subtleCrypto;
private logger;
private cryptoOptions?;
constructor(logger: Logger, cryptoOptions?: CryptoOptions);
/**
* Check whether IE crypto or other browser cryptography is available.
*/
private hasIECrypto;
/**
* Check whether browser crypto is available.
*/
private hasBrowserCrypto;
/**
* Check whether MSR crypto polyfill is available
*/
private hasMsrCrypto;
/**
* Returns a sha-256 hash of the given dataString as an ArrayBuffer.
* @param dataString
*/
sha256Digest(dataString: string): Promise<ArrayBuffer>;
/**
* Populates buffer with cryptographically random values.
* @param dataBuffer
*/
getRandomValues(dataBuffer: Uint8Array): Uint8Array;
/**
* Generates a keypair based on current keygen algorithm config.
* @param extractable
* @param usages
*/
generateKeyPair(extractable: boolean, usages: Array<KeyUsage>): Promise<CryptoKeyPair>;
/**
* Export key as Json Web Key (JWK)
* @param key
* @param format
*/
exportJwk(key: CryptoKey): Promise<JsonWebKey>;
/**
* Imports key as Json Web Key (JWK), can set extractable and usages.
* @param key
* @param format
* @param extractable
* @param usages
*/
importJwk(key: JsonWebKey, extractable: boolean, usages: Array<KeyUsage>): Promise<CryptoKey>;
/**
* Signs given data with given key
* @param key
* @param data
*/
sign(key: CryptoKey, data: ArrayBuffer): Promise<ArrayBuffer>;
}
//# sourceMappingURL=BrowserCrypto.d.ts.map