59 lines
1.8 KiB
TypeScript
59 lines
1.8 KiB
TypeScript
import { BaseAuthRequest } from "../request/BaseAuthRequest";
|
|
import { ShrOptions, SignedHttpRequest } from "./SignedHttpRequest";
|
|
/**
|
|
* The PkceCodes type describes the structure
|
|
* of objects that contain PKCE code
|
|
* challenge and verifier pairs
|
|
*/
|
|
export type PkceCodes = {
|
|
verifier: string;
|
|
challenge: string;
|
|
};
|
|
export type SignedHttpRequestParameters = Pick<BaseAuthRequest, "resourceRequestMethod" | "resourceRequestUri" | "shrClaims" | "shrNonce" | "shrOptions"> & {
|
|
correlationId?: string;
|
|
};
|
|
/**
|
|
* Interface for crypto functions used by library
|
|
*/
|
|
export interface ICrypto {
|
|
/**
|
|
* Creates a guid randomly.
|
|
*/
|
|
createNewGuid(): string;
|
|
/**
|
|
* base64 Encode string
|
|
* @param input
|
|
*/
|
|
base64Encode(input: string): string;
|
|
/**
|
|
* base64 decode string
|
|
* @param input
|
|
*/
|
|
base64Decode(input: string): string;
|
|
/**
|
|
* Generates an JWK RSA S256 Thumbprint
|
|
* @param request
|
|
*/
|
|
getPublicKeyThumbprint(request: SignedHttpRequestParameters): Promise<string>;
|
|
/**
|
|
* Removes cryptographic keypair from key store matching the keyId passed in
|
|
* @param kid
|
|
*/
|
|
removeTokenBindingKey(kid: string): Promise<boolean>;
|
|
/**
|
|
* Removes all cryptographic keys from IndexedDB storage
|
|
*/
|
|
clearKeystore(): Promise<boolean>;
|
|
/**
|
|
* Returns a signed proof-of-possession token with a given acces token that contains a cnf claim with the required kid.
|
|
* @param accessToken
|
|
*/
|
|
signJwt(payload: SignedHttpRequest, kid: string, shrOptions?: ShrOptions, correlationId?: string): Promise<string>;
|
|
/**
|
|
* Returns the SHA-256 hash of an input string
|
|
* @param plainText
|
|
*/
|
|
hashString(plainText: string): Promise<string>;
|
|
}
|
|
export declare const DEFAULT_CRYPTO_IMPLEMENTATION: ICrypto;
|
|
//# sourceMappingURL=ICrypto.d.ts.map
|