import { ICrypto, PkceCodes } from "@azure/msal-common"; /** * This class implements MSAL node's crypto interface, which allows it to perform base64 encoding and decoding, generating cryptographically random GUIDs and * implementing Proof Key for Code Exchange specs for the OAuth Authorization Code Flow using PKCE (rfc here: https://tools.ietf.org/html/rfc7636). * @public */ export declare class CryptoProvider implements ICrypto { private pkceGenerator; private guidGenerator; private hashUtils; constructor(); /** * Creates a new random GUID - used to populate state and nonce. * @returns string (GUID) */ createNewGuid(): string; /** * Encodes input string to base64. * @param input - string to be encoded */ base64Encode(input: string): string; /** * Decodes input string from base64. * @param input - string to be decoded */ base64Decode(input: string): string; /** * Generates PKCE codes used in Authorization Code Flow. */ generatePkceCodes(): Promise; /** * Generates a keypair, stores it and returns a thumbprint - not yet implemented for node */ getPublicKeyThumbprint(): Promise; /** * Removes cryptographic keypair from key store matching the keyId passed in * @param kid */ removeTokenBindingKey(): Promise; /** * Removes all cryptographic keys from Keystore */ clearKeystore(): Promise; /** * Signs the given object as a jwt payload with private key retrieved by given kid - currently not implemented for node */ signJwt(): Promise; /** * Returns the SHA-256 hash of an input string */ hashString(plainText: string): Promise; } //# sourceMappingURL=CryptoProvider.d.ts.map