Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@aws-cdk/aws-cognito

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-cognito - npm Package Compare versions

Comparing version 1.31.0 to 1.32.0

test/integ.user-pool-client-explcit-props.d.ts

170

lib/user-pool-client.d.ts

@@ -1,31 +0,130 @@

import { Construct, Resource } from '@aws-cdk/core';
import { Construct, IResource, Resource } from '@aws-cdk/core';
import { IUserPool } from './user-pool';
/**
* Types of authentication flow
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/amazon-cognito-user-pools-authentication-flow.html
*/
export declare enum AuthFlow {
export interface AuthFlow {
/**
* Enable flow for server-side or admin authentication (no client app)
* Enable admin based user password authentication flow
* @default false
*/
ADMIN_NO_SRP = "ADMIN_NO_SRP_AUTH",
readonly adminUserPassword?: boolean;
/**
* Enable custom authentication flow
* @default false
*/
CUSTOM_FLOW_ONLY = "CUSTOM_AUTH_FLOW_ONLY",
readonly custom?: boolean;
/**
* Enable auth using username & password
* @default false
*/
USER_PASSWORD = "USER_PASSWORD_AUTH"
readonly userPassword?: boolean;
/**
* Enable SRP based authentication
* @default false
*/
readonly userSrp?: boolean;
/**
* Enable authflow to refresh tokens
* @default false
*/
readonly refreshToken?: boolean;
}
export interface UserPoolClientProps {
/**
* OAuth settings to configure the interaction between the app and this client.
*/
export interface OAuthSettings {
/**
* OAuth flows that are allowed with this client.
* @see - the 'Allowed OAuth Flows' section at https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html
* @default - all OAuth flows disabled
*/
readonly flows: OAuthFlows;
/**
* List of allowed redirect URLs for the identity providers.
* @default - no callback URLs
*/
readonly callbackUrls?: string[];
/**
* OAuth scopes that are allowed with this client.
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html
* @default - no OAuth scopes are configured.
*/
readonly scopes: OAuthScope[];
}
/**
* Types of OAuth grant flows
* @see - the 'Allowed OAuth Flows' section at https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html
*/
export interface OAuthFlows {
/**
* Initiate an authorization code grant flow, which provides an authorization code as the response.
* @default false
*/
readonly authorizationCodeGrant?: boolean;
/**
* The client should get the access token and ID token directly.
* @default false
*/
readonly implicitCodeGrant?: boolean;
/**
* Client should get the access token and ID token from the token endpoint
* using a combination of client and client_secret.
* @default false
*/
readonly clientCredentials?: boolean;
}
/**
* OAuth scopes that are allowed with this client.
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html
*/
export declare class OAuthScope {
/**
* Grants access to the 'phone_number' and 'phone_number_verified' claims.
* Automatically includes access to `OAuthScope.OPENID`.
*/
static readonly PHONE: OAuthScope;
/**
* Grants access to the 'email' and 'email_verified' claims.
* Automatically includes access to `OAuthScope.OPENID`.
*/
static readonly EMAIL: OAuthScope;
/**
* Returns all user attributes in the ID token that are readable by the client
*/
static readonly OPENID: OAuthScope;
/**
* Grants access to all user attributes that are readable by the client
* Automatically includes access to `OAuthScope.OPENID`.
*/
static readonly PROFILE: OAuthScope;
/**
* Grants access to Amazon Cognito User Pool API operations that require access tokens,
* such as UpdateUserAttributes and VerifyUserAttribute.
*/
static readonly COGNITO_ADMIN: OAuthScope;
/**
* Custom scope is one that you define for your own resource server in the Resource Servers.
* The format is 'resource-server-identifier/scope'.
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-define-resource-servers.html
*/
static custom(name: string): OAuthScope;
/**
* The name of this scope as recognized by CloudFormation.
* @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cognito-userpoolclient.html#cfn-cognito-userpoolclient-allowedoauthscopes
*/
readonly scopeName: string;
private constructor();
}
/**
* Properties for the UserPoolClient construct
*/
export interface UserPoolClientOptions {
/**
* Name of the application client
* @default cloudformation generated name
* @default - cloudformation generated name
*/
readonly userPoolClientName?: string;
/**
* The UserPool resource this client will have access to
*/
readonly userPool: IUserPool;
/**
* Whether to generate a client secret

@@ -36,24 +135,51 @@ * @default false

/**
* List of enabled authentication flows
* @default no enabled flows
* The set of OAuth authentication flows to enable on the client
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/amazon-cognito-user-pools-authentication-flow.html
* @default - all auth flows disabled
*/
readonly enabledAuthFlows?: AuthFlow[];
readonly authFlows?: AuthFlow;
/**
* OAuth settings for this to client to interact with the app.
* @default - see defaults in `OAuthSettings`
*/
readonly oAuth?: OAuthSettings;
}
/**
* Define a UserPool App Client
* Properties for the UserPoolClient construct
*/
export declare class UserPoolClient extends Resource {
export interface UserPoolClientProps extends UserPoolClientOptions {
/**
* The UserPool resource this client will have access to
*/
readonly userPool: IUserPool;
}
/**
* Represents a Cognito user pool client.
*/
export interface IUserPoolClient extends IResource {
/**
* Name of the application client
* @attribute
*/
readonly userPoolClientId: string;
}
/**
* Define a UserPool App Client
*/
export declare class UserPoolClient extends Resource implements IUserPoolClient {
/**
* @attribute
* Import a user pool client given its id.
*/
readonly userPoolClientName: string;
static fromUserPoolClientId(scope: Construct, id: string, userPoolClientId: string): IUserPoolClient;
readonly userPoolClientId: string;
private readonly _userPoolClientName?;
constructor(scope: Construct, id: string, props: UserPoolClientProps);
/**
* @attribute
* The client name that was specified via the `userPoolClientName` property during initialization,
* throws an error otherwise.
*/
readonly userPoolClientClientSecret: string;
constructor(scope: Construct, id: string, props: UserPoolClientProps);
get userPoolClientName(): string;
private configureAuthFlows;
private configureOAuthFlows;
private configureOAuthScopes;
}

@@ -6,39 +6,152 @@ "use strict";

/**
* Types of authentication flow
* OAuth scopes that are allowed with this client.
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html
*/
var AuthFlow;
(function (AuthFlow) {
class OAuthScope {
constructor(scopeName) {
this.scopeName = scopeName;
}
/**
* Enable flow for server-side or admin authentication (no client app)
* Custom scope is one that you define for your own resource server in the Resource Servers.
* The format is 'resource-server-identifier/scope'.
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-define-resource-servers.html
*/
AuthFlow["ADMIN_NO_SRP"] = "ADMIN_NO_SRP_AUTH";
/**
* Enable custom authentication flow
*/
AuthFlow["CUSTOM_FLOW_ONLY"] = "CUSTOM_AUTH_FLOW_ONLY";
/**
* Enable auth using username & password
*/
AuthFlow["USER_PASSWORD"] = "USER_PASSWORD_AUTH";
})(AuthFlow = exports.AuthFlow || (exports.AuthFlow = {}));
static custom(name) {
return new OAuthScope(name);
}
}
exports.OAuthScope = OAuthScope;
/**
* Grants access to the 'phone_number' and 'phone_number_verified' claims.
* Automatically includes access to `OAuthScope.OPENID`.
*/
OAuthScope.PHONE = new OAuthScope('phone');
/**
* Grants access to the 'email' and 'email_verified' claims.
* Automatically includes access to `OAuthScope.OPENID`.
*/
OAuthScope.EMAIL = new OAuthScope('email');
/**
* Returns all user attributes in the ID token that are readable by the client
*/
OAuthScope.OPENID = new OAuthScope('openid');
/**
* Grants access to all user attributes that are readable by the client
* Automatically includes access to `OAuthScope.OPENID`.
*/
OAuthScope.PROFILE = new OAuthScope('profile');
/**
* Grants access to Amazon Cognito User Pool API operations that require access tokens,
* such as UpdateUserAttributes and VerifyUserAttribute.
*/
OAuthScope.COGNITO_ADMIN = new OAuthScope('aws.cognito.signin.user.admin');
/**
* Define a UserPool App Client
*/
class UserPoolClient extends core_1.Resource {
/*
* Note to implementers: Two CloudFormation return values Name and ClientSecret are part of the spec.
* However, they have been explicity not implemented here. They are not documented in CloudFormation, and
* CloudFormation returns the following the string when these two attributes are 'GetAtt' - "attribute not supported
* at this time, please use the CLI or Console to retrieve this value".
* Awaiting updates from CloudFormation.
*/
constructor(scope, id, props) {
super(scope, id, {
physicalName: props.userPoolClientName,
});
var _a, _b, _c;
super(scope, id);
const resource = new cognito_generated_1.CfnUserPoolClient(this, 'Resource', {
clientName: this.physicalName,
clientName: props.userPoolClientName,
generateSecret: props.generateSecret,
userPoolId: props.userPool.userPoolId,
explicitAuthFlows: props.enabledAuthFlows
explicitAuthFlows: this.configureAuthFlows(props),
allowedOAuthFlows: this.configureOAuthFlows(props.oAuth),
allowedOAuthScopes: this.configureOAuthScopes(props.oAuth),
callbackUrLs: (((_a = props.oAuth) === null || _a === void 0 ? void 0 : _a.callbackUrls) && ((_b = props.oAuth) === null || _b === void 0 ? void 0 : _b.callbackUrls.length) > 0) ? (_c = props.oAuth) === null || _c === void 0 ? void 0 : _c.callbackUrls : undefined,
allowedOAuthFlowsUserPoolClient: props.oAuth ? true : undefined,
});
this.userPoolClientId = resource.ref;
this.userPoolClientClientSecret = resource.attrClientSecret;
this.userPoolClientName = resource.attrName;
this._userPoolClientName = props.userPoolClientName;
}
/**
* Import a user pool client given its id.
*/
static fromUserPoolClientId(scope, id, userPoolClientId) {
class Import extends core_1.Resource {
constructor() {
super(...arguments);
this.userPoolClientId = userPoolClientId;
}
}
return new Import(scope, id);
}
/**
* The client name that was specified via the `userPoolClientName` property during initialization,
* throws an error otherwise.
*/
get userPoolClientName() {
if (this._userPoolClientName === undefined) {
throw new Error('userPoolClientName is available only if specified on the UserPoolClient during initialization');
}
return this._userPoolClientName;
}
configureAuthFlows(props) {
var _a, _b, _c, _d, _e;
const authFlows = [];
if ((_a = props.authFlows) === null || _a === void 0 ? void 0 : _a.userPassword) {
authFlows.push('ALLOW_USER_PASSWORD_AUTH');
}
if ((_b = props.authFlows) === null || _b === void 0 ? void 0 : _b.adminUserPassword) {
authFlows.push('ALLOW_ADMIN_USER_PASSWORD_AUTH');
}
if ((_c = props.authFlows) === null || _c === void 0 ? void 0 : _c.custom) {
authFlows.push('ALLOW_CUSTOM_AUTH');
}
if ((_d = props.authFlows) === null || _d === void 0 ? void 0 : _d.userSrp) {
authFlows.push('ALLOW_USER_SRP_AUTH');
}
if ((_e = props.authFlows) === null || _e === void 0 ? void 0 : _e.refreshToken) {
authFlows.push('ALLOW_REFRESH_TOKEN_AUTH');
}
if (authFlows.length === 0) {
return undefined;
}
return authFlows;
}
configureOAuthFlows(oAuth) {
if ((oAuth === null || oAuth === void 0 ? void 0 : oAuth.flows.authorizationCodeGrant) || (oAuth === null || oAuth === void 0 ? void 0 : oAuth.flows.implicitCodeGrant)) {
if ((oAuth === null || oAuth === void 0 ? void 0 : oAuth.callbackUrls) === undefined || (oAuth === null || oAuth === void 0 ? void 0 : oAuth.callbackUrls.length) === 0) {
throw new Error('callbackUrl must be specified when codeGrant or implicitGrant OAuth flows are enabled.');
}
if (oAuth === null || oAuth === void 0 ? void 0 : oAuth.flows.clientCredentials) {
throw new Error('clientCredentials OAuth flow cannot be selected along with codeGrant or implicitGrant.');
}
}
const oAuthFlows = [];
if (oAuth === null || oAuth === void 0 ? void 0 : oAuth.flows.clientCredentials) {
oAuthFlows.push('client_credentials');
}
if (oAuth === null || oAuth === void 0 ? void 0 : oAuth.flows.implicitCodeGrant) {
oAuthFlows.push('implicit');
}
if (oAuth === null || oAuth === void 0 ? void 0 : oAuth.flows.authorizationCodeGrant) {
oAuthFlows.push('code');
}
if (oAuthFlows.length === 0) {
return undefined;
}
return oAuthFlows;
}
configureOAuthScopes(oAuth) {
const oAuthScopes = new Set(oAuth === null || oAuth === void 0 ? void 0 : oAuth.scopes.map((x) => x.scopeName));
const autoOpenIdScopes = [OAuthScope.PHONE, OAuthScope.EMAIL, OAuthScope.PROFILE];
if (autoOpenIdScopes.reduce((agg, s) => agg || oAuthScopes.has(s.scopeName), false)) {
oAuthScopes.add(OAuthScope.OPENID.scopeName);
}
if (oAuthScopes.size > 0) {
return Array.from(oAuthScopes);
}
return undefined;
}
}
exports.UserPoolClient = UserPoolClient;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1wb29sLWNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVzZXItcG9vbC1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx3Q0FBb0Q7QUFDcEQsMkRBQXdEO0FBR3hEOztHQUVHO0FBQ0gsSUFBWSxRQWVYO0FBZkQsV0FBWSxRQUFRO0lBQ2xCOztPQUVHO0lBQ0gsOENBQWtDLENBQUE7SUFFbEM7O09BRUc7SUFDSCxzREFBMEMsQ0FBQTtJQUUxQzs7T0FFRztJQUNILGdEQUFvQyxDQUFBO0FBQ3RDLENBQUMsRUFmVyxRQUFRLEdBQVIsZ0JBQVEsS0FBUixnQkFBUSxRQWVuQjtBQTJCRDs7R0FFRztBQUNILE1BQWEsY0FBZSxTQUFRLGVBQVE7SUFnQjFDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMEI7UUFDbEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixZQUFZLEVBQUUsS0FBSyxDQUFDLGtCQUFrQjtTQUN2QyxDQUFDLENBQUM7UUFFSCxNQUFNLFFBQVEsR0FBRyxJQUFJLHFDQUFpQixDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDdkQsVUFBVSxFQUFFLElBQUksQ0FBQyxZQUFZO1lBQzdCLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYztZQUNwQyxVQUFVLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxVQUFVO1lBQ3JDLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxnQkFBZ0I7U0FDMUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUM7UUFDckMsSUFBSSxDQUFDLDBCQUEwQixHQUFHLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQztRQUM1RCxJQUFJLENBQUMsa0JBQWtCLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQztJQUM5QyxDQUFDO0NBQ0Y7QUFoQ0Qsd0NBZ0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0LCBSZXNvdXJjZSB9IGZyb20gJ0Bhd3MtY2RrL2NvcmUnO1xuaW1wb3J0IHsgQ2ZuVXNlclBvb2xDbGllbnQgfSBmcm9tICcuL2NvZ25pdG8uZ2VuZXJhdGVkJztcbmltcG9ydCB7IElVc2VyUG9vbCB9IGZyb20gJy4vdXNlci1wb29sJztcblxuLyoqXG4gKiBUeXBlcyBvZiBhdXRoZW50aWNhdGlvbiBmbG93XG4gKi9cbmV4cG9ydCBlbnVtIEF1dGhGbG93IHtcbiAgLyoqXG4gICAqIEVuYWJsZSBmbG93IGZvciBzZXJ2ZXItc2lkZSBvciBhZG1pbiBhdXRoZW50aWNhdGlvbiAobm8gY2xpZW50IGFwcClcbiAgICovXG4gIEFETUlOX05PX1NSUCA9ICdBRE1JTl9OT19TUlBfQVVUSCcsXG5cbiAgLyoqXG4gICAqIEVuYWJsZSBjdXN0b20gYXV0aGVudGljYXRpb24gZmxvd1xuICAgKi9cbiAgQ1VTVE9NX0ZMT1dfT05MWSA9ICdDVVNUT01fQVVUSF9GTE9XX09OTFknLFxuXG4gIC8qKlxuICAgKiBFbmFibGUgYXV0aCB1c2luZyB1c2VybmFtZSAmIHBhc3N3b3JkXG4gICAqL1xuICBVU0VSX1BBU1NXT1JEID0gJ1VTRVJfUEFTU1dPUkRfQVVUSCdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVc2VyUG9vbENsaWVudFByb3BzIHtcbiAgLyoqXG4gICAqIE5hbWUgb2YgdGhlIGFwcGxpY2F0aW9uIGNsaWVudFxuICAgKiBAZGVmYXVsdCBjbG91ZGZvcm1hdGlvbiBnZW5lcmF0ZWQgbmFtZVxuICAgKi9cbiAgcmVhZG9ubHkgdXNlclBvb2xDbGllbnROYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgVXNlclBvb2wgcmVzb3VyY2UgdGhpcyBjbGllbnQgd2lsbCBoYXZlIGFjY2VzcyB0b1xuICAgKi9cbiAgcmVhZG9ubHkgdXNlclBvb2w6IElVc2VyUG9vbDtcblxuICAvKipcbiAgICogV2hldGhlciB0byBnZW5lcmF0ZSBhIGNsaWVudCBzZWNyZXRcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IGdlbmVyYXRlU2VjcmV0PzogYm9vbGVhbjtcblxuICAvKipcbiAgICogTGlzdCBvZiBlbmFibGVkIGF1dGhlbnRpY2F0aW9uIGZsb3dzXG4gICAqIEBkZWZhdWx0IG5vIGVuYWJsZWQgZmxvd3NcbiAgICovXG4gIHJlYWRvbmx5IGVuYWJsZWRBdXRoRmxvd3M/OiBBdXRoRmxvd1tdXG59XG5cbi8qKlxuICogRGVmaW5lIGEgVXNlclBvb2wgQXBwIENsaWVudFxuICovXG5leHBvcnQgY2xhc3MgVXNlclBvb2xDbGllbnQgZXh0ZW5kcyBSZXNvdXJjZSB7XG4gIC8qKlxuICAgKiBAYXR0cmlidXRlXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgdXNlclBvb2xDbGllbnRJZDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBAYXR0cmlidXRlXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgdXNlclBvb2xDbGllbnROYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEBhdHRyaWJ1dGVcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSB1c2VyUG9vbENsaWVudENsaWVudFNlY3JldDogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBVc2VyUG9vbENsaWVudFByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICBwaHlzaWNhbE5hbWU6IHByb3BzLnVzZXJQb29sQ2xpZW50TmFtZSxcbiAgICB9KTtcblxuICAgIGNvbnN0IHJlc291cmNlID0gbmV3IENmblVzZXJQb29sQ2xpZW50KHRoaXMsICdSZXNvdXJjZScsIHtcbiAgICAgIGNsaWVudE5hbWU6IHRoaXMucGh5c2ljYWxOYW1lLFxuICAgICAgZ2VuZXJhdGVTZWNyZXQ6IHByb3BzLmdlbmVyYXRlU2VjcmV0LFxuICAgICAgdXNlclBvb2xJZDogcHJvcHMudXNlclBvb2wudXNlclBvb2xJZCxcbiAgICAgIGV4cGxpY2l0QXV0aEZsb3dzOiBwcm9wcy5lbmFibGVkQXV0aEZsb3dzXG4gICAgfSk7XG5cbiAgICB0aGlzLnVzZXJQb29sQ2xpZW50SWQgPSByZXNvdXJjZS5yZWY7XG4gICAgdGhpcy51c2VyUG9vbENsaWVudENsaWVudFNlY3JldCA9IHJlc291cmNlLmF0dHJDbGllbnRTZWNyZXQ7XG4gICAgdGhpcy51c2VyUG9vbENsaWVudE5hbWUgPSByZXNvdXJjZS5hdHRyTmFtZTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-pool-client.js","sourceRoot":"","sources":["user-pool-client.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, IResource, Resource } from '@aws-cdk/core';\nimport { CfnUserPoolClient } from './cognito.generated';\nimport { IUserPool } from './user-pool';\n\n/**\n * Types of authentication flow\n * @see https://docs.aws.amazon.com/cognito/latest/developerguide/amazon-cognito-user-pools-authentication-flow.html\n */\nexport interface AuthFlow {\n  /**\n   * Enable admin based user password authentication flow\n   * @default false\n   */\n  readonly adminUserPassword?: boolean;\n\n  /**\n   * Enable custom authentication flow\n   * @default false\n   */\n  readonly custom?: boolean;\n\n  /**\n   * Enable auth using username & password\n   * @default false\n   */\n  readonly userPassword?: boolean;\n\n  /**\n   * Enable SRP based authentication\n   * @default false\n   */\n  readonly userSrp?: boolean;\n\n  /**\n   * Enable authflow to refresh tokens\n   * @default false\n   */\n  readonly refreshToken?: boolean;\n}\n\n/**\n * OAuth settings to configure the interaction between the app and this client.\n */\nexport interface OAuthSettings {\n\n  /**\n   * OAuth flows that are allowed with this client.\n   * @see - the 'Allowed OAuth Flows' section at https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html\n   * @default - all OAuth flows disabled\n   */\n  readonly flows: OAuthFlows;\n\n  /**\n   * List of allowed redirect URLs for the identity providers.\n   * @default - no callback URLs\n   */\n  readonly callbackUrls?: string[];\n\n  /**\n   * OAuth scopes that are allowed with this client.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html\n   * @default - no OAuth scopes are configured.\n   */\n  readonly scopes: OAuthScope[];\n}\n\n/**\n * Types of OAuth grant flows\n * @see - the 'Allowed OAuth Flows' section at https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html\n */\nexport interface OAuthFlows {\n  /**\n   * Initiate an authorization code grant flow, which provides an authorization code as the response.\n   * @default false\n   */\n  readonly authorizationCodeGrant?: boolean;\n\n  /**\n   * The client should get the access token and ID token directly.\n   * @default false\n   */\n  readonly implicitCodeGrant?: boolean;\n\n  /**\n   * Client should get the access token and ID token from the token endpoint\n   * using a combination of client and client_secret.\n   * @default false\n   */\n  readonly clientCredentials?: boolean;\n}\n\n/**\n * OAuth scopes that are allowed with this client.\n * @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-app-idp-settings.html\n */\nexport class OAuthScope {\n  /**\n   * Grants access to the 'phone_number' and 'phone_number_verified' claims.\n   * Automatically includes access to `OAuthScope.OPENID`.\n   */\n  public static readonly PHONE = new OAuthScope('phone');\n\n  /**\n   * Grants access to the 'email' and 'email_verified' claims.\n   * Automatically includes access to `OAuthScope.OPENID`.\n   */\n  public static readonly EMAIL = new OAuthScope('email');\n\n  /**\n   * Returns all user attributes in the ID token that are readable by the client\n   */\n  public static readonly OPENID = new OAuthScope('openid');\n\n  /**\n   * Grants access to all user attributes that are readable by the client\n   * Automatically includes access to `OAuthScope.OPENID`.\n   */\n  public static readonly PROFILE = new OAuthScope('profile');\n\n  /**\n   * Grants access to Amazon Cognito User Pool API operations that require access tokens,\n   * such as UpdateUserAttributes and VerifyUserAttribute.\n   */\n  public static readonly COGNITO_ADMIN = new OAuthScope('aws.cognito.signin.user.admin');\n\n  /**\n   * Custom scope is one that you define for your own resource server in the Resource Servers.\n   * The format is 'resource-server-identifier/scope'.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-pools-define-resource-servers.html\n   */\n  public static custom(name: string) {\n    return new OAuthScope(name);\n  }\n\n  // tslint:disable:max-line-length\n  /**\n   * The name of this scope as recognized by CloudFormation.\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cognito-userpoolclient.html#cfn-cognito-userpoolclient-allowedoauthscopes\n   */\n  // tslint:enable:max-line-length\n  public readonly scopeName: string;\n\n  private constructor(scopeName: string) {\n    this.scopeName = scopeName;\n  }\n}\n\n/**\n * Properties for the UserPoolClient construct\n */\nexport interface UserPoolClientOptions {\n  /**\n   * Name of the application client\n   * @default - cloudformation generated name\n   */\n  readonly userPoolClientName?: string;\n\n  /**\n   * Whether to generate a client secret\n   * @default false\n   */\n  readonly generateSecret?: boolean;\n\n  /**\n   * The set of OAuth authentication flows to enable on the client\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/amazon-cognito-user-pools-authentication-flow.html\n   * @default - all auth flows disabled\n   */\n  readonly authFlows?: AuthFlow;\n\n  /**\n   * OAuth settings for this to client to interact with the app.\n   * @default - see defaults in `OAuthSettings`\n   */\n  readonly oAuth?: OAuthSettings;\n}\n\n/**\n * Properties for the UserPoolClient construct\n */\nexport interface UserPoolClientProps extends UserPoolClientOptions {\n  /**\n   * The UserPool resource this client will have access to\n   */\n  readonly userPool: IUserPool;\n}\n\n/**\n * Represents a Cognito user pool client.\n */\nexport interface IUserPoolClient extends IResource {\n  /**\n   * Name of the application client\n   * @attribute\n   */\n  readonly userPoolClientId: string;\n}\n\n/**\n * Define a UserPool App Client\n */\nexport class UserPoolClient extends Resource implements IUserPoolClient {\n  /**\n   * Import a user pool client given its id.\n   */\n  public static fromUserPoolClientId(scope: Construct, id: string, userPoolClientId: string): IUserPoolClient {\n    class Import extends Resource implements IUserPoolClient {\n      public readonly userPoolClientId = userPoolClientId;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly userPoolClientId: string;\n  private readonly _userPoolClientName?: string;\n\n  /*\n   * Note to implementers: Two CloudFormation return values Name and ClientSecret are part of the spec.\n   * However, they have been explicity not implemented here. They are not documented in CloudFormation, and\n   * CloudFormation returns the following the string when these two attributes are 'GetAtt' - \"attribute not supported\n   * at this time, please use the CLI or Console to retrieve this value\".\n   * Awaiting updates from CloudFormation.\n   */\n\n  constructor(scope: Construct, id: string, props: UserPoolClientProps) {\n    super(scope, id);\n\n    const resource = new CfnUserPoolClient(this, 'Resource', {\n      clientName: props.userPoolClientName,\n      generateSecret: props.generateSecret,\n      userPoolId: props.userPool.userPoolId,\n      explicitAuthFlows: this.configureAuthFlows(props),\n      allowedOAuthFlows: this.configureOAuthFlows(props.oAuth),\n      allowedOAuthScopes: this.configureOAuthScopes(props.oAuth),\n      callbackUrLs: (props.oAuth?.callbackUrls && props.oAuth?.callbackUrls.length > 0) ? props.oAuth?.callbackUrls : undefined,\n      allowedOAuthFlowsUserPoolClient: props.oAuth ? true : undefined,\n    });\n\n    this.userPoolClientId = resource.ref;\n    this._userPoolClientName = props.userPoolClientName;\n  }\n\n  /**\n   * The client name that was specified via the `userPoolClientName` property during initialization,\n   * throws an error otherwise.\n   */\n  public get userPoolClientName(): string {\n    if (this._userPoolClientName === undefined) {\n      throw new Error('userPoolClientName is available only if specified on the UserPoolClient during initialization');\n    }\n    return this._userPoolClientName;\n  }\n\n  private configureAuthFlows(props: UserPoolClientProps): string[] | undefined {\n    const authFlows: string[] = [];\n    if (props.authFlows?.userPassword) { authFlows.push('ALLOW_USER_PASSWORD_AUTH'); }\n    if (props.authFlows?.adminUserPassword) { authFlows.push('ALLOW_ADMIN_USER_PASSWORD_AUTH'); }\n    if (props.authFlows?.custom) { authFlows.push('ALLOW_CUSTOM_AUTH'); }\n    if (props.authFlows?.userSrp) { authFlows.push('ALLOW_USER_SRP_AUTH'); }\n    if (props.authFlows?.refreshToken) { authFlows.push('ALLOW_REFRESH_TOKEN_AUTH'); }\n\n    if (authFlows.length === 0) {\n      return undefined;\n    }\n    return authFlows;\n  }\n\n  private configureOAuthFlows(oAuth?: OAuthSettings): string[] | undefined {\n    if (oAuth?.flows.authorizationCodeGrant || oAuth?.flows.implicitCodeGrant) {\n      if (oAuth?.callbackUrls === undefined || oAuth?.callbackUrls.length === 0) {\n        throw new Error('callbackUrl must be specified when codeGrant or implicitGrant OAuth flows are enabled.');\n      }\n      if (oAuth?.flows.clientCredentials) {\n        throw new Error('clientCredentials OAuth flow cannot be selected along with codeGrant or implicitGrant.');\n      }\n    }\n\n    const oAuthFlows: string[] = [];\n    if (oAuth?.flows.clientCredentials) { oAuthFlows.push('client_credentials'); }\n    if (oAuth?.flows.implicitCodeGrant) { oAuthFlows.push('implicit'); }\n    if (oAuth?.flows.authorizationCodeGrant) { oAuthFlows.push('code'); }\n\n    if (oAuthFlows.length === 0) {\n      return undefined;\n    }\n    return oAuthFlows;\n  }\n\n  private configureOAuthScopes(oAuth?: OAuthSettings): string[] | undefined {\n    const oAuthScopes = new Set(oAuth?.scopes.map((x) => x.scopeName));\n    const autoOpenIdScopes = [ OAuthScope.PHONE, OAuthScope.EMAIL, OAuthScope.PROFILE ];\n    if (autoOpenIdScopes.reduce((agg, s) => agg || oAuthScopes.has(s.scopeName), false)) {\n      oAuthScopes.add(OAuthScope.OPENID.scopeName);\n    }\n    if (oAuthScopes.size > 0) {\n      return Array.from(oAuthScopes);\n    }\n    return undefined;\n  }\n}\n"]}

153

lib/user-pool.d.ts

@@ -5,2 +5,3 @@ import { IRole } from '@aws-cdk/aws-iam';

import { ICustomAttribute, RequiredAttributes } from './user-pool-attr';
import { IUserPoolClient, UserPoolClientOptions } from './user-pool-client';
/**

@@ -51,2 +52,6 @@ * The different ways in which users of this pool can sign up or sign in.

}
/**
* Triggers for a user pool
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-identity-pools-working-with-aws-lambda-triggers.html
*/
export interface UserPoolTriggers {

@@ -56,2 +61,3 @@ /**

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-create-auth-challenge.html
* @default - no trigger configured
*/

@@ -62,2 +68,3 @@ readonly createAuthChallenge?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-custom-message.html
* @default - no trigger configured
*/

@@ -68,2 +75,3 @@ readonly customMessage?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-define-auth-challenge.html
* @default - no trigger configured
*/

@@ -74,2 +82,3 @@ readonly defineAuthChallenge?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-authentication.html
* @default - no trigger configured
*/

@@ -80,2 +89,3 @@ readonly postAuthentication?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-confirmation.html
* @default - no trigger configured
*/

@@ -86,2 +96,3 @@ readonly postConfirmation?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-authentication.html
* @default - no trigger configured
*/

@@ -92,2 +103,3 @@ readonly preAuthentication?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-sign-up.html
* @default - no trigger configured
*/

@@ -98,2 +110,3 @@ readonly preSignUp?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-token-generation.html
* @default - no trigger configured
*/

@@ -104,2 +117,3 @@ readonly preTokenGeneration?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-migrate-user.html
* @default - no trigger configured
*/

@@ -110,2 +124,3 @@ readonly userMigration?: lambda.IFunction;

* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-verify-auth-challenge-response.html
* @default - no trigger configured
*/

@@ -119,2 +134,62 @@ readonly verifyAuthChallengeResponse?: lambda.IFunction;

/**
* User pool operations to which lambda triggers can be attached.
*/
export declare class UserPoolOperation {
/**
* Creates a challenge in a custom auth flow
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-create-auth-challenge.html
*/
static readonly CREATE_AUTH_CHALLENGE: UserPoolOperation;
/**
* Advanced customization and localization of messages
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-custom-message.html
*/
static readonly CUSTOM_MESSAGE: UserPoolOperation;
/**
* Determines the next challenge in a custom auth flow
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-define-auth-challenge.html
*/
static readonly DEFINE_AUTH_CHALLENGE: UserPoolOperation;
/**
* Event logging for custom analytics
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-authentication.html
*/
static readonly POST_AUTHENTICATION: UserPoolOperation;
/**
* Custom welcome messages or event logging for custom analytics
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-confirmation.html
*/
static readonly POST_CONFIRMATION: UserPoolOperation;
/**
* Custom validation to accept or deny the sign-in request
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-authentication.html
*/
static readonly PRE_AUTHENTICATION: UserPoolOperation;
/**
* Custom validation to accept or deny the sign-up request
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-sign-up.html
*/
static readonly PRE_SIGN_UP: UserPoolOperation;
/**
* Add or remove attributes in Id tokens
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-token-generation.html
*/
static readonly PRE_TOKEN_GENERATION: UserPoolOperation;
/**
* Migrate a user from an existing user directory to user pools
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-migrate-user.html
*/
static readonly USER_MIGRATION: UserPoolOperation;
/**
* Determines if a response is correct in a custom auth flow
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-verify-auth-challenge-response.html
*/
static readonly VERIFY_AUTH_CHALLENGE_RESPONSE: UserPoolOperation;
/** A custom user pool operation */
static of(name: string): UserPoolOperation;
/** The key to use in `CfnUserPool.LambdaConfigProperty` */
readonly operationName: string;
private constructor();
}
/**
* The email verification style

@@ -368,3 +443,3 @@ */

* Lambda functions to use for supported Cognito triggers.
*
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-identity-pools-working-with-aws-lambda-triggers.html
* @default - No Lambda triggers.

@@ -388,2 +463,6 @@ */

readonly userPoolArn: string;
/**
* Create a user pool client.
*/
addClient(id: string, options?: UserPoolClientOptions): IUserPoolClient;
}

@@ -423,71 +502,7 @@ /**

/**
* Attach 'Create Auth Challenge' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-create-auth-challenge.html
* @param fn the lambda function to attach
* Add a lambda trigger to a user pool operation
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-identity-pools-working-with-aws-lambda-triggers.html
*/
addCreateAuthChallengeTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Custom Message' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-custom-message.html
* @param fn the lambda function to attach
*/
addCustomMessageTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Define Auth Challenge' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-define-auth-challenge.html
* @param fn the lambda function to attach
*/
addDefineAuthChallengeTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Post Authentication' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-authentication.html
* @param fn the lambda function to attach
*/
addPostAuthenticationTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Post Confirmation' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-confirmation.html
* @param fn the lambda function to attach
*/
addPostConfirmationTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Pre Authentication' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-authentication.html
* @param fn the lambda function to attach
*/
addPreAuthenticationTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Pre Sign Up' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-sign-up.html
* @param fn the lambda function to attach
*/
addPreSignUpTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Pre Token Generation' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-token-generation.html
* @param fn the lambda function to attach
*/
addPreTokenGenerationTrigger(fn: lambda.IFunction): void;
/**
* Attach 'User Migration' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-migrate-user.html
* @param fn the lambda function to attach
*/
addUserMigrationTrigger(fn: lambda.IFunction): void;
/**
* Attach 'Verify Auth Challenge Response' trigger
* Grants access from cognito-idp.amazonaws.com to the lambda
* @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-verify-auth-challenge-response.html
* @param fn the lambda function to attach
*/
addVerifyAuthChallengeResponseTrigger(fn: lambda.IFunction): void;
addTrigger(operation: UserPoolOperation, fn: lambda.IFunction): void;
addClient(id: string, options?: UserPoolClientOptions): IUserPoolClient;
private addLambdaPermission;

@@ -494,0 +509,0 @@ private verificationMessageConfiguration;

{
"name": "@aws-cdk/aws-cognito",
"version": "1.31.0",
"version": "1.32.0",
"description": "The CDK Construct Library for AWS::Cognito",

@@ -65,15 +65,15 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "1.31.0",
"@aws-cdk/assert": "1.32.0",
"@types/nodeunit": "^0.0.30",
"cdk-build-tools": "1.31.0",
"cdk-integ-tools": "1.31.0",
"cfn2ts": "1.31.0",
"cdk-build-tools": "1.32.0",
"cdk-integ-tools": "1.32.0",
"cfn2ts": "1.32.0",
"jest": "^24.9.0",
"nodeunit": "^0.11.3",
"pkglint": "1.31.0"
"pkglint": "1.32.0"
},
"dependencies": {
"@aws-cdk/aws-iam": "1.31.0",
"@aws-cdk/aws-lambda": "1.31.0",
"@aws-cdk/core": "1.31.0",
"@aws-cdk/aws-iam": "1.32.0",
"@aws-cdk/aws-lambda": "1.32.0",
"@aws-cdk/core": "1.32.0",
"constructs": "^2.0.0"

@@ -83,5 +83,5 @@ },

"peerDependencies": {
"@aws-cdk/aws-iam": "1.31.0",
"@aws-cdk/aws-lambda": "1.31.0",
"@aws-cdk/core": "1.31.0",
"@aws-cdk/aws-iam": "1.32.0",
"@aws-cdk/aws-lambda": "1.32.0",
"@aws-cdk/core": "1.32.0",
"constructs": "^2.0.0"

@@ -95,17 +95,4 @@ },

"exclude": [
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.verifyAuthChallengeResponse",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.userMigration",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.preTokenGeneration",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.preSignUp",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.preAuthentication",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.postConfirmation",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.postAuthentication",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.defineAuthChallenge",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.customMessage",
"props-default-doc:@aws-cdk/aws-cognito.UserPoolTriggers.createAuthChallenge",
"docs-public-apis:@aws-cdk/aws-cognito.UserPoolTriggers",
"docs-public-apis:@aws-cdk/aws-cognito.UserPoolClient.userPoolClientClientSecret",
"docs-public-apis:@aws-cdk/aws-cognito.UserPoolClient.userPoolClientId",
"docs-public-apis:@aws-cdk/aws-cognito.UserPoolClient.userPoolClientName",
"docs-public-apis:@aws-cdk/aws-cognito.UserPoolClientProps"
"attribute-tag:@aws-cdk/aws-cognito.UserPoolClient.userPoolClientName",
"resource-attribute:@aws-cdk/aws-cognito.UserPoolClient.userPoolClientClientSecret"
]

@@ -112,0 +99,0 @@ },

@@ -41,3 +41,5 @@ ## Amazon Cognito Construct Library

- [Emails](#emails)
- [Lambda Triggers](#lambda-triggers)
- [Import](#importing-user-pools)
- [App Clients](#app-clients)

@@ -281,2 +283,34 @@ ## User Pools

### Lambda Triggers
User pools can be configured such that AWS Lambda functions can be triggered when certain user operations or actions
occur, such as, sign up, user confirmation, sign in, etc. They can also be used to add custom authentication
challenges, user migrations and custom verification messages. Learn more about triggers at [User Pool Workflows with
Triggers](https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-identity-pools-working-with-aws-lambda-triggers.html).
Lambda triggers can either be specified as part of the `UserPool` initialization, or it can be added later, via methods
on the construct, as so -
```ts
const authChallengeFn = new lambda.Function(this, 'authChallengeFn', {
// ...
});
const userpool = new UserPool(this, 'myuserpool', {
// ...
triggers: {
createAuthChallenge: authChallengeFn,
// ...
}
});
userpool.addTrigger(UserPoolOperation.USER_MIGRATION, new lambda.Function(this, 'userMigrationFn', {
// ...
}));
```
The following table lists the set of triggers available, and their corresponding method to add it to the user pool.
For more information on the function of these triggers and how to configure them, read [User Pool Workflows with
Triggers](https://docs.aws.amazon.com/cognito/latest/developerguide/cognito-user-identity-pools-working-with-aws-lambda-triggers.html).
### Importing User Pools

@@ -300,2 +334,71 @@

'arn:aws:cognito-idp:eu-west-1:123456789012:userpool/us-east-1_mtRyYQ14D');
```
```
### App Clients
An app is an entity within a user pool that has permission to call unauthenticated APIs (APIs that do not have an
authenticated user), such as APIs to register, sign in, and handle forgotten passwords. To call these APIs, you need an
app client ID and an optional client secret. Read [Configuring a User Pool App
Client](https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-settings-client-apps.html) to learn more.
The following code creates an app client and retrieves the client id -
```ts
const pool = new UserPool(this, 'pool');
const client = pool.addClient('customer-app-client');
const clientId = client.userPoolClientId;
```
Existing app clients can be imported into the CDK app using the `UserPoolClient.fromUserPoolClientId()` API. For new
and imported user pools, clients can also be created via the `UserPoolClient` constructor, as so -
```ts
const importedPool = UserPool.fromUserPoolId(this, 'imported-pool', 'us-east-1_oiuR12Abd');
new UserPoolClient(this, 'customer-app-client', {
userPool: importedPool
});
```
Clients can be configured with authentication flows. Authentication flows allow users on a client to be authenticated
with a user pool. Cognito user pools provide several several different types of authentication, such as, SRP (Secure
Remote Password) authentication, username-and-password authentication, etc. Learn more about this at [UserPool Authentication
Flow](https://docs.aws.amazon.com/cognito/latest/developerguide/amazon-cognito-user-pools-authentication-flow.html).
The following code configures a client to use both SRP and username-and-password authentication -
```ts
const pool = new UserPool(this, 'pool');
pool.addClient('app-client', {
authFlows: {
userPassword: true,
userSrp: true,
}
});
```
Custom authentication protocols can be configured by setting the `custom` property under `authFlow` and defining lambda
functions for the corresponding user pool [triggers](#lambda-triggers). Learn more at [Custom Authentication
Flow](https://docs.aws.amazon.com/cognito/latest/developerguide/amazon-cognito-user-pools-authentication-flow.html#amazon-cognito-user-pools-custom-authentication-flow).
In addition to these authentication mechanisms, Cognito user pools also support using OAuth 2.0 framework for
authenticating users. User pool clients can be configured with OAuth 2.0 authorization flows and scopes. Learn more
about the [OAuth 2.0 authorization framework](https://tools.ietf.org/html/rfc6749) and [Cognito user pool's
implementation of
OAuth2.0](https://aws.amazon.com/blogs/mobile/understanding-amazon-cognito-user-pool-oauth-2-0-grants/).
The following code configures an app client with the authorization code grant flow and registers the the app's welcome
page as a callback (or redirect) URL. It also configures the access token scope to 'openid'. All of these concepts can
be found in the [OAuth 2.0 RFC](https://tools.ietf.org/html/rfc6749).
```ts
const pool = new UserPool(this, 'Pool');
pool.addClient('app-client', {
oAuth: {
flows: {
authorizationCodeGrant: true,
},
scopes: [ OAuthScope.OPENID ],
callbackUrls: [ 'https://my-app-domain.com/welcome' ],
}
});
```
{
"Resources": {
"createAuthChallengeServiceRole611710B5": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"createAuthChallengeB185B225": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"createAuthChallengeServiceRole611710B5",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "createAuthChallenge"
},
"DependsOn": [
"createAuthChallengeServiceRole611710B5"
]
},
"createAuthChallengeCreateAuthChallengeCognito57E2297E": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"createAuthChallengeB185B225",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"customMessageServiceRoleB4AE7F17": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"customMessage52BA91E2": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"customMessageServiceRoleB4AE7F17",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "customMessage"
},
"DependsOn": [
"customMessageServiceRoleB4AE7F17"
]
},
"customMessageCustomMessageCognitoB4F894A6": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"customMessage52BA91E2",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"defineAuthChallengeServiceRole9E2D15DF": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"defineAuthChallengeAE7BCDA1": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"defineAuthChallengeServiceRole9E2D15DF",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "defineAuthChallenge"
},
"DependsOn": [
"defineAuthChallengeServiceRole9E2D15DF"
]
},
"defineAuthChallengeDefineAuthChallengeCognito4DBD8021": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"defineAuthChallengeAE7BCDA1",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"postAuthenticationServiceRole5B3B242A": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"postAuthentication741BD8E3": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"postAuthenticationServiceRole5B3B242A",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "postAuthentication"
},
"DependsOn": [
"postAuthenticationServiceRole5B3B242A"
]
},
"postAuthenticationPostAuthenticationCognito8B923BC3": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"postAuthentication741BD8E3",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"postConfirmationServiceRole864BE5F9": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"postConfirmationD5E3F1DD": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"postConfirmationServiceRole864BE5F9",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "postConfirmation"
},
"DependsOn": [
"postConfirmationServiceRole864BE5F9"
]
},
"postConfirmationPostConfirmationCognito9D010393": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"postConfirmationD5E3F1DD",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"preAuthenticationServiceRole9712F4D8": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"preAuthentication56F78C81": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"preAuthenticationServiceRole9712F4D8",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "preAuthentication"
},
"DependsOn": [
"preAuthenticationServiceRole9712F4D8"
]
},
"preAuthenticationPreAuthenticationCognito67FACB54": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"preAuthentication56F78C81",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"preSignUpServiceRole0A7E91EB": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"preSignUp1934B27C": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"preSignUpServiceRole0A7E91EB",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "preSignUp"
},
"DependsOn": [
"preSignUpServiceRole0A7E91EB"
]
},
"preSignUpPreSignUpCognitoE986CC53": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"preSignUp1934B27C",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"preTokenGenerationServiceRole430C3D14": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"preTokenGeneration1E968302": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"preTokenGenerationServiceRole430C3D14",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "preTokenGeneration"
},
"DependsOn": [
"preTokenGenerationServiceRole430C3D14"
]
},
"preTokenGenerationPreTokenGenerationCognitoC1959918": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"preTokenGeneration1E968302",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"userMigrationServiceRole091766B0": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"userMigrationAAA960EC": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"userMigrationServiceRole091766B0",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "userMigration"
},
"DependsOn": [
"userMigrationServiceRole091766B0"
]
},
"userMigrationUserMigrationCognito29EEC4AD": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"userMigrationAAA960EC",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"verifyAuthChallengeResponseServiceRole7077884C": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
}
}
],
"Version": "2012-10-17"
},
"ManagedPolicyArns": [
{
"Fn::Join": [
"",
[
"arn:",
{
"Ref": "AWS::Partition"
},
":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
]
]
}
]
}
},
"verifyAuthChallengeResponse211FE4A6": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"ZipFile": "foo"
},
"Handler": "index.handler",
"Role": {
"Fn::GetAtt": [
"verifyAuthChallengeResponseServiceRole7077884C",
"Arn"
]
},
"Runtime": "nodejs12.x",
"FunctionName": "verifyAuthChallengeResponse"
},
"DependsOn": [
"verifyAuthChallengeResponseServiceRole7077884C"
]
},
"verifyAuthChallengeResponseVerifyAuthChallengeResponseCognito9DC48AFC": {
"Type": "AWS::Lambda::Permission",
"Properties": {
"Action": "lambda:InvokeFunction",
"FunctionName": {
"Fn::GetAtt": [
"verifyAuthChallengeResponse211FE4A6",
"Arn"
]
},
"Principal": "cognito-idp.amazonaws.com"
}
},
"myuserpoolsmsRole0E16FDD9": {

@@ -68,3 +708,75 @@ "Type": "AWS::IAM::Role",

],
"LambdaConfig": {},
"LambdaConfig": {
"CreateAuthChallenge": {
"Fn::GetAtt": [
"createAuthChallengeB185B225",
"Arn"
]
},
"CustomMessage": {
"Fn::GetAtt": [
"customMessage52BA91E2",
"Arn"
]
},
"DefineAuthChallenge": {
"Fn::GetAtt": [
"defineAuthChallengeAE7BCDA1",
"Arn"
]
},
"PostAuthentication": {
"Fn::GetAtt": [
"postAuthentication741BD8E3",
"Arn"
]
},
"PostConfirmation": {
"Fn::GetAtt": [
"postConfirmationD5E3F1DD",
"Arn"
]
},
"PreAuthentication": {
"Fn::GetAtt": [
"preAuthentication56F78C81",
"Arn"
]
},
"PreSignUp": {
"Fn::GetAtt": [
"preSignUp1934B27C",
"Arn"
]
},
"PreTokenGeneration": {
"Fn::GetAtt": [
"preTokenGeneration1E968302",
"Arn"
]
},
"UserMigration": {
"Fn::GetAtt": [
"userMigrationAAA960EC",
"Arn"
]
},
"VerifyAuthChallengeResponse": {
"Fn::GetAtt": [
"verifyAuthChallengeResponse211FE4A6",
"Arn"
]
}
},
"MfaConfiguration": "ON",
"Policies": {
"PasswordPolicy": {
"MinimumLength": 12,
"RequireLowercase": true,
"RequireNumbers": true,
"RequireSymbols": true,
"RequireUppercase": true,
"TemporaryPasswordValidityDays": 10
}
},
"Schema": [

@@ -112,13 +824,2 @@ {

],
"MfaConfiguration": "ON",
"Policies": {
"PasswordPolicy": {
"MinimumLength": 12,
"RequireLowercase": true,
"RequireNumbers": true,
"RequireSymbols": true,
"RequireUppercase": true,
"TemporaryPasswordValidityDays": 10
}
},
"SmsConfiguration": {

@@ -125,0 +826,0 @@ "ExternalId": "integuserpoolmyuserpoolDA38443C",

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const aws_lambda_1 = require("@aws-cdk/aws-lambda");
const core_1 = require("@aws-cdk/core");

@@ -57,2 +58,14 @@ const lib_1 = require("../lib");

},
lambdaTriggers: {
createAuthChallenge: dummyTrigger('createAuthChallenge'),
customMessage: dummyTrigger('customMessage'),
defineAuthChallenge: dummyTrigger('defineAuthChallenge'),
postAuthentication: dummyTrigger('postAuthentication'),
postConfirmation: dummyTrigger('postConfirmation'),
preAuthentication: dummyTrigger('preAuthentication'),
preSignUp: dummyTrigger('preSignUp'),
preTokenGeneration: dummyTrigger('preTokenGeneration'),
userMigration: dummyTrigger('userMigration'),
verifyAuthChallengeResponse: dummyTrigger('verifyAuthChallengeResponse'),
},
});

@@ -62,2 +75,10 @@ new core_1.CfnOutput(stack, 'userpoolId', {

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcudXNlci1wb29sLWV4cGxpY2l0LXByb3BzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcudXNlci1wb29sLWV4cGxpY2l0LXByb3BzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsd0NBQWdFO0FBQ2hFLGdDQUE4RztBQUU5RyxNQUFNLEdBQUcsR0FBRyxJQUFJLFVBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksWUFBSyxDQUFDLEdBQUcsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO0FBRWhELE1BQU0sUUFBUSxHQUFHLElBQUksY0FBUSxDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUU7SUFDakQsWUFBWSxFQUFFLFlBQVk7SUFDMUIsY0FBYyxFQUFFO1FBQ2QsWUFBWSxFQUFFLDhDQUE4QztRQUM1RCxTQUFTLEVBQUUsb0ZBQW9GO1FBQy9GLFVBQVUsRUFBRSxxRkFBcUY7S0FDbEc7SUFDRCxpQkFBaUIsRUFBRSxJQUFJO0lBQ3ZCLGdCQUFnQixFQUFFO1FBQ2hCLFNBQVMsRUFBRSw4REFBOEQ7UUFDekUsWUFBWSxFQUFFLGdEQUFnRDtRQUM5RCxVQUFVLEVBQUUsK0RBQStEO0tBQzVFO0lBQ0QsYUFBYSxFQUFFO1FBQ2IsUUFBUSxFQUFFLElBQUk7UUFDZCxLQUFLLEVBQUUsSUFBSTtLQUNaO0lBQ0QsVUFBVSxFQUFFO1FBQ1YsS0FBSyxFQUFFLElBQUk7UUFDWCxLQUFLLEVBQUUsSUFBSTtLQUNaO0lBQ0Qsa0JBQWtCLEVBQUU7UUFDbEIsUUFBUSxFQUFFLElBQUk7UUFDZCxLQUFLLEVBQUUsSUFBSTtLQUNaO0lBQ0QsZ0JBQWdCLEVBQUU7UUFDaEIsa0JBQWtCLEVBQUUsSUFBSSxxQkFBZSxFQUFFO1FBQ3pDLHFCQUFxQixFQUFFLElBQUkscUJBQWUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDO1FBQ3RFLGtCQUFrQixFQUFFLElBQUkscUJBQWUsRUFBRTtRQUN6QyxxQkFBcUIsRUFBRSxJQUFJLHFCQUFlLENBQUMsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUUsQ0FBQztRQUNoRSxtQkFBbUIsRUFBRSxJQUFJLHNCQUFnQixFQUFFO1FBQzNDLG9CQUFvQixFQUFFLElBQUksdUJBQWlCLEVBQUU7S0FDOUM7SUFDRCxHQUFHLEVBQUUsU0FBRyxDQUFDLFFBQVE7SUFDakIsZUFBZSxFQUFFO1FBQ2YsR0FBRyxFQUFFLElBQUk7UUFDVCxHQUFHLEVBQUUsSUFBSTtLQUNWO0lBQ0QsY0FBYyxFQUFFO1FBQ2Qsb0JBQW9CLEVBQUUsZUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7UUFDdkMsU0FBUyxFQUFFLEVBQUU7UUFDYixhQUFhLEVBQUUsSUFBSTtRQUNuQixnQkFBZ0IsRUFBRSxJQUFJO1FBQ3RCLGdCQUFnQixFQUFFLElBQUk7UUFDdEIsY0FBYyxFQUFFLElBQUk7S0FDckI7SUFDRCxhQUFhLEVBQUU7UUFDYixJQUFJLEVBQUUsMEJBQTBCO1FBQ2hDLE9BQU8sRUFBRSwwQkFBMEI7S0FDcEM7Q0FDRixDQUFDLENBQUM7QUFFSCxJQUFJLGdCQUFTLENBQUMsS0FBSyxFQUFFLFlBQVksRUFBRTtJQUNqQyxLQUFLLEVBQUUsUUFBUSxDQUFDLFVBQVU7Q0FDM0IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXBwLCBDZm5PdXRwdXQsIER1cmF0aW9uLCBTdGFjayB9IGZyb20gJ0Bhd3MtY2RrL2NvcmUnO1xuaW1wb3J0IHsgQm9vbGVhbkF0dHJpYnV0ZSwgRGF0ZVRpbWVBdHRyaWJ1dGUsIE1mYSwgTnVtYmVyQXR0cmlidXRlLCBTdHJpbmdBdHRyaWJ1dGUsIFVzZXJQb29sIH0gZnJvbSAnLi4vbGliJztcblxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCAnaW50ZWctdXNlci1wb29sJyk7XG5cbmNvbnN0IHVzZXJwb29sID0gbmV3IFVzZXJQb29sKHN0YWNrLCAnbXl1c2VycG9vbCcsIHtcbiAgdXNlclBvb2xOYW1lOiAnTXlVc2VyUG9vbCcsXG4gIHVzZXJJbnZpdGF0aW9uOiB7XG4gICAgZW1haWxTdWJqZWN0OiAnaW52aXRhdGlvbiBlbWFpbCBzdWJqZWN0IGZyb20gdGhlIGludGVnIHRlc3QnLFxuICAgIGVtYWlsQm9keTogJ2ludml0YXRpb24gZW1haWwgYm9keSBmcm9tIHRoZSBpbnRlZyB0ZXN0IGZvciB7dXNlcm5hbWV9LiBUZW1wIHBhc3N3b3JkIGlzIHsjIyMjfS4nLFxuICAgIHNtc01lc3NhZ2U6ICdpbnZpdGF0aW9uIHNtcyBtZXNzYWdlIGZyb20gdGhlIGludGVnIHRlc3QgZm9yIHt1c2VybmFtZX0uIFRlbXAgcGFzc3dvcmQgaXMgeyMjIyN9LicsXG4gIH0sXG4gIHNlbGZTaWduVXBFbmFibGVkOiB0cnVlLFxuICB1c2VyVmVyaWZpY2F0aW9uOiB7XG4gICAgZW1haWxCb2R5OiAndmVyaWZpY2F0aW9uIGVtYWlsIGJvZHkgZnJvbSB0aGUgaW50ZWcgdGVzdC4gQ29kZSBpcyB7IyMjI30uJyxcbiAgICBlbWFpbFN1YmplY3Q6ICd2ZXJpZmljYXRpb24gZW1haWwgc3ViamVjdCBmcm9tIHRoZSBpbnRlZyB0ZXN0JyxcbiAgICBzbXNNZXNzYWdlOiAndmVyaWZpY2F0aW9uIHNtcyBtZXNzYWdlIGZyb20gdGhlIGludGVnIHRlc3QuIENvZGUgaXMgeyMjIyN9LicsXG4gIH0sXG4gIHNpZ25JbkFsaWFzZXM6IHtcbiAgICB1c2VybmFtZTogdHJ1ZSxcbiAgICBlbWFpbDogdHJ1ZSxcbiAgfSxcbiAgYXV0b1ZlcmlmeToge1xuICAgIGVtYWlsOiB0cnVlLFxuICAgIHBob25lOiB0cnVlLFxuICB9LFxuICByZXF1aXJlZEF0dHJpYnV0ZXM6IHtcbiAgICBmdWxsbmFtZTogdHJ1ZSxcbiAgICBlbWFpbDogdHJ1ZSxcbiAgfSxcbiAgY3VzdG9tQXR0cmlidXRlczoge1xuICAgICdzb21lLXN0cmluZy1hdHRyJzogbmV3IFN0cmluZ0F0dHJpYnV0ZSgpLFxuICAgICdhbm90aGVyLXN0cmluZy1hdHRyJzogbmV3IFN0cmluZ0F0dHJpYnV0ZSh7IG1pbkxlbjogNCwgbWF4TGVuOiAxMDAgfSksXG4gICAgJ3NvbWUtbnVtYmVyLWF0dHInOiBuZXcgTnVtYmVyQXR0cmlidXRlKCksXG4gICAgJ2Fub3RoZXItbnVtYmVyLWF0dHInOiBuZXcgTnVtYmVyQXR0cmlidXRlKHsgbWluOiAxMCwgbWF4OiA1MCB9KSxcbiAgICAnc29tZS1ib29sZWFuLWF0dHInOiBuZXcgQm9vbGVhbkF0dHJpYnV0ZSgpLFxuICAgICdzb21lLWRhdGV0aW1lLWF0dHInOiBuZXcgRGF0ZVRpbWVBdHRyaWJ1dGUoKSxcbiAgfSxcbiAgbWZhOiBNZmEuUkVRVUlSRUQsXG4gIG1mYVNlY29uZEZhY3Rvcjoge1xuICAgIHNtczogdHJ1ZSxcbiAgICBvdHA6IHRydWUsXG4gIH0sXG4gIHBhc3N3b3JkUG9saWN5OiB7XG4gICAgdGVtcFBhc3N3b3JkVmFsaWRpdHk6IER1cmF0aW9uLmRheXMoMTApLFxuICAgIG1pbkxlbmd0aDogMTIsXG4gICAgcmVxdWlyZURpZ2l0czogdHJ1ZSxcbiAgICByZXF1aXJlTG93ZXJjYXNlOiB0cnVlLFxuICAgIHJlcXVpcmVVcHBlcmNhc2U6IHRydWUsXG4gICAgcmVxdWlyZVN5bWJvbHM6IHRydWUsXG4gIH0sXG4gIGVtYWlsU2V0dGluZ3M6IHtcbiAgICBmcm9tOiAnbm9yZXBseUBteWF3ZXNvbWVhcHAuY29tJyxcbiAgICByZXBseVRvOiAnc3VwcG9ydEBteWF3ZXNvbWVhcHAuY29tJyxcbiAgfSxcbn0pO1xuXG5uZXcgQ2ZuT3V0cHV0KHN0YWNrLCAndXNlcnBvb2xJZCcsIHtcbiAgdmFsdWU6IHVzZXJwb29sLnVzZXJQb29sSWRcbn0pOyJdfQ==
function dummyTrigger(name) {
return new aws_lambda_1.Function(stack, name, {
functionName: name,
handler: 'index.handler',
runtime: aws_lambda_1.Runtime.NODEJS_12_X,
code: aws_lambda_1.Code.fromInline('foo'),
});
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcudXNlci1wb29sLWV4cGxpY2l0LXByb3BzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcudXNlci1wb29sLWV4cGxpY2l0LXByb3BzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsb0RBQXlFO0FBQ3pFLHdDQUFnRTtBQUNoRSxnQ0FBOEc7QUFFOUcsTUFBTSxHQUFHLEdBQUcsSUFBSSxVQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFlBQUssQ0FBQyxHQUFHLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztBQUVoRCxNQUFNLFFBQVEsR0FBRyxJQUFJLGNBQVEsQ0FBQyxLQUFLLEVBQUUsWUFBWSxFQUFFO0lBQ2pELFlBQVksRUFBRSxZQUFZO0lBQzFCLGNBQWMsRUFBRTtRQUNkLFlBQVksRUFBRSw4Q0FBOEM7UUFDNUQsU0FBUyxFQUFFLG9GQUFvRjtRQUMvRixVQUFVLEVBQUUscUZBQXFGO0tBQ2xHO0lBQ0QsaUJBQWlCLEVBQUUsSUFBSTtJQUN2QixnQkFBZ0IsRUFBRTtRQUNoQixTQUFTLEVBQUUsOERBQThEO1FBQ3pFLFlBQVksRUFBRSxnREFBZ0Q7UUFDOUQsVUFBVSxFQUFFLCtEQUErRDtLQUM1RTtJQUNELGFBQWEsRUFBRTtRQUNiLFFBQVEsRUFBRSxJQUFJO1FBQ2QsS0FBSyxFQUFFLElBQUk7S0FDWjtJQUNELFVBQVUsRUFBRTtRQUNWLEtBQUssRUFBRSxJQUFJO1FBQ1gsS0FBSyxFQUFFLElBQUk7S0FDWjtJQUNELGtCQUFrQixFQUFFO1FBQ2xCLFFBQVEsRUFBRSxJQUFJO1FBQ2QsS0FBSyxFQUFFLElBQUk7S0FDWjtJQUNELGdCQUFnQixFQUFFO1FBQ2hCLGtCQUFrQixFQUFFLElBQUkscUJBQWUsRUFBRTtRQUN6QyxxQkFBcUIsRUFBRSxJQUFJLHFCQUFlLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQztRQUN0RSxrQkFBa0IsRUFBRSxJQUFJLHFCQUFlLEVBQUU7UUFDekMscUJBQXFCLEVBQUUsSUFBSSxxQkFBZSxDQUFDLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLENBQUM7UUFDaEUsbUJBQW1CLEVBQUUsSUFBSSxzQkFBZ0IsRUFBRTtRQUMzQyxvQkFBb0IsRUFBRSxJQUFJLHVCQUFpQixFQUFFO0tBQzlDO0lBQ0QsR0FBRyxFQUFFLFNBQUcsQ0FBQyxRQUFRO0lBQ2pCLGVBQWUsRUFBRTtRQUNmLEdBQUcsRUFBRSxJQUFJO1FBQ1QsR0FBRyxFQUFFLElBQUk7S0FDVjtJQUNELGNBQWMsRUFBRTtRQUNkLG9CQUFvQixFQUFFLGVBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3ZDLFNBQVMsRUFBRSxFQUFFO1FBQ2IsYUFBYSxFQUFFLElBQUk7UUFDbkIsZ0JBQWdCLEVBQUUsSUFBSTtRQUN0QixnQkFBZ0IsRUFBRSxJQUFJO1FBQ3RCLGNBQWMsRUFBRSxJQUFJO0tBQ3JCO0lBQ0QsYUFBYSxFQUFFO1FBQ2IsSUFBSSxFQUFFLDBCQUEwQjtRQUNoQyxPQUFPLEVBQUUsMEJBQTBCO0tBQ3BDO0lBQ0QsY0FBYyxFQUFFO1FBQ2QsbUJBQW1CLEVBQUUsWUFBWSxDQUFDLHFCQUFxQixDQUFDO1FBQ3hELGFBQWEsRUFBRSxZQUFZLENBQUMsZUFBZSxDQUFDO1FBQzVDLG1CQUFtQixFQUFFLFlBQVksQ0FBQyxxQkFBcUIsQ0FBQztRQUN4RCxrQkFBa0IsRUFBRSxZQUFZLENBQUMsb0JBQW9CLENBQUM7UUFDdEQsZ0JBQWdCLEVBQUUsWUFBWSxDQUFDLGtCQUFrQixDQUFDO1FBQ2xELGlCQUFpQixFQUFFLFlBQVksQ0FBQyxtQkFBbUIsQ0FBQztRQUNwRCxTQUFTLEVBQUUsWUFBWSxDQUFDLFdBQVcsQ0FBQztRQUNwQyxrQkFBa0IsRUFBRSxZQUFZLENBQUMsb0JBQW9CLENBQUM7UUFDdEQsYUFBYSxFQUFFLFlBQVksQ0FBQyxlQUFlLENBQUM7UUFDNUMsMkJBQTJCLEVBQUUsWUFBWSxDQUFDLDZCQUE2QixDQUFDO0tBQ3pFO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsSUFBSSxnQkFBUyxDQUFDLEtBQUssRUFBRSxZQUFZLEVBQUU7SUFDakMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxVQUFVO0NBQzNCLENBQUMsQ0FBQztBQUVILFNBQVMsWUFBWSxDQUFDLElBQVk7SUFDaEMsT0FBTyxJQUFJLHFCQUFRLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRTtRQUMvQixZQUFZLEVBQUUsSUFBSTtRQUNsQixPQUFPLEVBQUUsZUFBZTtRQUN4QixPQUFPLEVBQUUsb0JBQU8sQ0FBQyxXQUFXO1FBQzVCLElBQUksRUFBRSxpQkFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUM7S0FDN0IsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvZGUsIEZ1bmN0aW9uLCBJRnVuY3Rpb24sIFJ1bnRpbWUgfSBmcm9tICdAYXdzLWNkay9hd3MtbGFtYmRhJztcbmltcG9ydCB7IEFwcCwgQ2ZuT3V0cHV0LCBEdXJhdGlvbiwgU3RhY2sgfSBmcm9tICdAYXdzLWNkay9jb3JlJztcbmltcG9ydCB7IEJvb2xlYW5BdHRyaWJ1dGUsIERhdGVUaW1lQXR0cmlidXRlLCBNZmEsIE51bWJlckF0dHJpYnV0ZSwgU3RyaW5nQXR0cmlidXRlLCBVc2VyUG9vbCB9IGZyb20gJy4uL2xpYic7XG5cbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ2ludGVnLXVzZXItcG9vbCcpO1xuXG5jb25zdCB1c2VycG9vbCA9IG5ldyBVc2VyUG9vbChzdGFjaywgJ215dXNlcnBvb2wnLCB7XG4gIHVzZXJQb29sTmFtZTogJ015VXNlclBvb2wnLFxuICB1c2VySW52aXRhdGlvbjoge1xuICAgIGVtYWlsU3ViamVjdDogJ2ludml0YXRpb24gZW1haWwgc3ViamVjdCBmcm9tIHRoZSBpbnRlZyB0ZXN0JyxcbiAgICBlbWFpbEJvZHk6ICdpbnZpdGF0aW9uIGVtYWlsIGJvZHkgZnJvbSB0aGUgaW50ZWcgdGVzdCBmb3Ige3VzZXJuYW1lfS4gVGVtcCBwYXNzd29yZCBpcyB7IyMjI30uJyxcbiAgICBzbXNNZXNzYWdlOiAnaW52aXRhdGlvbiBzbXMgbWVzc2FnZSBmcm9tIHRoZSBpbnRlZyB0ZXN0IGZvciB7dXNlcm5hbWV9LiBUZW1wIHBhc3N3b3JkIGlzIHsjIyMjfS4nLFxuICB9LFxuICBzZWxmU2lnblVwRW5hYmxlZDogdHJ1ZSxcbiAgdXNlclZlcmlmaWNhdGlvbjoge1xuICAgIGVtYWlsQm9keTogJ3ZlcmlmaWNhdGlvbiBlbWFpbCBib2R5IGZyb20gdGhlIGludGVnIHRlc3QuIENvZGUgaXMgeyMjIyN9LicsXG4gICAgZW1haWxTdWJqZWN0OiAndmVyaWZpY2F0aW9uIGVtYWlsIHN1YmplY3QgZnJvbSB0aGUgaW50ZWcgdGVzdCcsXG4gICAgc21zTWVzc2FnZTogJ3ZlcmlmaWNhdGlvbiBzbXMgbWVzc2FnZSBmcm9tIHRoZSBpbnRlZyB0ZXN0LiBDb2RlIGlzIHsjIyMjfS4nLFxuICB9LFxuICBzaWduSW5BbGlhc2VzOiB7XG4gICAgdXNlcm5hbWU6IHRydWUsXG4gICAgZW1haWw6IHRydWUsXG4gIH0sXG4gIGF1dG9WZXJpZnk6IHtcbiAgICBlbWFpbDogdHJ1ZSxcbiAgICBwaG9uZTogdHJ1ZSxcbiAgfSxcbiAgcmVxdWlyZWRBdHRyaWJ1dGVzOiB7XG4gICAgZnVsbG5hbWU6IHRydWUsXG4gICAgZW1haWw6IHRydWUsXG4gIH0sXG4gIGN1c3RvbUF0dHJpYnV0ZXM6IHtcbiAgICAnc29tZS1zdHJpbmctYXR0cic6IG5ldyBTdHJpbmdBdHRyaWJ1dGUoKSxcbiAgICAnYW5vdGhlci1zdHJpbmctYXR0cic6IG5ldyBTdHJpbmdBdHRyaWJ1dGUoeyBtaW5MZW46IDQsIG1heExlbjogMTAwIH0pLFxuICAgICdzb21lLW51bWJlci1hdHRyJzogbmV3IE51bWJlckF0dHJpYnV0ZSgpLFxuICAgICdhbm90aGVyLW51bWJlci1hdHRyJzogbmV3IE51bWJlckF0dHJpYnV0ZSh7IG1pbjogMTAsIG1heDogNTAgfSksXG4gICAgJ3NvbWUtYm9vbGVhbi1hdHRyJzogbmV3IEJvb2xlYW5BdHRyaWJ1dGUoKSxcbiAgICAnc29tZS1kYXRldGltZS1hdHRyJzogbmV3IERhdGVUaW1lQXR0cmlidXRlKCksXG4gIH0sXG4gIG1mYTogTWZhLlJFUVVJUkVELFxuICBtZmFTZWNvbmRGYWN0b3I6IHtcbiAgICBzbXM6IHRydWUsXG4gICAgb3RwOiB0cnVlLFxuICB9LFxuICBwYXNzd29yZFBvbGljeToge1xuICAgIHRlbXBQYXNzd29yZFZhbGlkaXR5OiBEdXJhdGlvbi5kYXlzKDEwKSxcbiAgICBtaW5MZW5ndGg6IDEyLFxuICAgIHJlcXVpcmVEaWdpdHM6IHRydWUsXG4gICAgcmVxdWlyZUxvd2VyY2FzZTogdHJ1ZSxcbiAgICByZXF1aXJlVXBwZXJjYXNlOiB0cnVlLFxuICAgIHJlcXVpcmVTeW1ib2xzOiB0cnVlLFxuICB9LFxuICBlbWFpbFNldHRpbmdzOiB7XG4gICAgZnJvbTogJ25vcmVwbHlAbXlhd2Vzb21lYXBwLmNvbScsXG4gICAgcmVwbHlUbzogJ3N1cHBvcnRAbXlhd2Vzb21lYXBwLmNvbScsXG4gIH0sXG4gIGxhbWJkYVRyaWdnZXJzOiB7XG4gICAgY3JlYXRlQXV0aENoYWxsZW5nZTogZHVtbXlUcmlnZ2VyKCdjcmVhdGVBdXRoQ2hhbGxlbmdlJyksXG4gICAgY3VzdG9tTWVzc2FnZTogZHVtbXlUcmlnZ2VyKCdjdXN0b21NZXNzYWdlJyksXG4gICAgZGVmaW5lQXV0aENoYWxsZW5nZTogZHVtbXlUcmlnZ2VyKCdkZWZpbmVBdXRoQ2hhbGxlbmdlJyksXG4gICAgcG9zdEF1dGhlbnRpY2F0aW9uOiBkdW1teVRyaWdnZXIoJ3Bvc3RBdXRoZW50aWNhdGlvbicpLFxuICAgIHBvc3RDb25maXJtYXRpb246IGR1bW15VHJpZ2dlcigncG9zdENvbmZpcm1hdGlvbicpLFxuICAgIHByZUF1dGhlbnRpY2F0aW9uOiBkdW1teVRyaWdnZXIoJ3ByZUF1dGhlbnRpY2F0aW9uJyksXG4gICAgcHJlU2lnblVwOiBkdW1teVRyaWdnZXIoJ3ByZVNpZ25VcCcpLFxuICAgIHByZVRva2VuR2VuZXJhdGlvbjogZHVtbXlUcmlnZ2VyKCdwcmVUb2tlbkdlbmVyYXRpb24nKSxcbiAgICB1c2VyTWlncmF0aW9uOiBkdW1teVRyaWdnZXIoJ3VzZXJNaWdyYXRpb24nKSxcbiAgICB2ZXJpZnlBdXRoQ2hhbGxlbmdlUmVzcG9uc2U6IGR1bW15VHJpZ2dlcigndmVyaWZ5QXV0aENoYWxsZW5nZVJlc3BvbnNlJyksXG4gIH0sXG59KTtcblxubmV3IENmbk91dHB1dChzdGFjaywgJ3VzZXJwb29sSWQnLCB7XG4gIHZhbHVlOiB1c2VycG9vbC51c2VyUG9vbElkXG59KTtcblxuZnVuY3Rpb24gZHVtbXlUcmlnZ2VyKG5hbWU6IHN0cmluZyk6IElGdW5jdGlvbiB7XG4gIHJldHVybiBuZXcgRnVuY3Rpb24oc3RhY2ssIG5hbWUsIHtcbiAgICBmdW5jdGlvbk5hbWU6IG5hbWUsXG4gICAgaGFuZGxlcjogJ2luZGV4LmhhbmRsZXInLFxuICAgIHJ1bnRpbWU6IFJ1bnRpbWUuTk9ERUpTXzEyX1gsXG4gICAgY29kZTogQ29kZS5mcm9tSW5saW5lKCdmb28nKSxcbiAgfSk7XG59Il19

@@ -48,3 +48,2 @@ {

"EmailVerificationSubject": "Verify your new account",
"LambdaConfig": {},
"SmsConfiguration": {

@@ -51,0 +50,0 @@ "ExternalId": "integuserpoolmyuserpoolDA38443C",

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const assert_1 = require("@aws-cdk/assert");
require("@aws-cdk/assert/jest");

@@ -10,3 +11,3 @@ const core_1 = require("@aws-cdk/core");

const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool', {});
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN

@@ -17,7 +18,238 @@ new lib_1.UserPoolClient(stack, 'Client', {

// THEN
expect(stack).toHaveResource('AWS::Cognito::UserPoolClient', {
UserPoolId: stack.resolve(pool.userPoolId),
});
});
test('client name', () => {
// GIVEN
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN
const client1 = new lib_1.UserPoolClient(stack, 'Client1', {
userPool: pool,
userPoolClientName: 'myclient'
});
const client2 = new lib_1.UserPoolClient(stack, 'Client2', {
userPool: pool,
});
// THEN
expect(client1.userPoolClientName).toEqual('myclient');
expect(() => client2.userPoolClientName).toThrow(/available only if specified on the UserPoolClient during initialization/);
});
test('import', () => {
// GIVEN
const stack = new core_1.Stack();
// WHEN
const client = lib_1.UserPoolClient.fromUserPoolClientId(stack, 'Client', 'client-id-1');
// THEN
expect(client.userPoolClientId).toEqual('client-id-1');
});
test('ExplicitAuthFlows is absent by default', () => {
// GIVEN
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN
pool.addClient('Client');
// THEN
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
UserPoolId: stack.resolve(pool.userPoolId)
ExplicitAuthFlows: assert_1.ABSENT,
});
});
test('ExplicitAuthFlows are correctly named', () => {
// GIVEN
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN
pool.addClient('Client', {
authFlows: {
adminUserPassword: true,
custom: true,
refreshToken: true,
userPassword: true,
userSrp: true,
}
});
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
ExplicitAuthFlows: [
'ALLOW_USER_PASSWORD_AUTH',
'ALLOW_ADMIN_USER_PASSWORD_AUTH',
'ALLOW_CUSTOM_AUTH',
'ALLOW_USER_SRP_AUTH',
'ALLOW_REFRESH_TOKEN_AUTH',
],
});
});
test('AllowedOAuthFlows is absent by default', () => {
// GIVEN
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN
pool.addClient('Client');
// THEN
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
AllowedOAuthFlows: assert_1.ABSENT,
});
});
test('AllowedOAuthFlows are correctly named', () => {
// GIVEN
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN
pool.addClient('Client1', {
oAuth: {
flows: {
authorizationCodeGrant: true,
implicitCodeGrant: true,
},
callbackUrls: ['redirect-url'],
scopes: [lib_1.OAuthScope.PHONE],
},
});
pool.addClient('Client2', {
oAuth: {
flows: {
clientCredentials: true,
},
callbackUrls: ['redirect-url'],
scopes: [lib_1.OAuthScope.PHONE],
},
});
// THEN
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
AllowedOAuthFlows: ['implicit', 'code'],
AllowedOAuthFlowsUserPoolClient: true,
});
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
AllowedOAuthFlows: ['client_credentials'],
AllowedOAuthFlowsUserPoolClient: true,
});
});
test('fails when callbackUrls are not specified for codeGrant or implicitGrant', () => {
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
expect(() => pool.addClient('Client1', {
oAuth: {
flows: { authorizationCodeGrant: true },
scopes: [lib_1.OAuthScope.PHONE],
}
})).toThrow(/callbackUrl must be specified/);
expect(() => pool.addClient('Client2', {
oAuth: {
flows: { implicitCodeGrant: true },
scopes: [lib_1.OAuthScope.PHONE],
},
})).toThrow(/callbackUrl must be specified/);
expect(() => pool.addClient('Client3', {
oAuth: {
flows: { clientCredentials: true },
scopes: [lib_1.OAuthScope.PHONE],
}
})).not.toThrow();
});
test('fails when clientCredentials OAuth flow is selected along with codeGrant or implicitGrant', () => {
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
expect(() => pool.addClient('Client1', {
oAuth: {
flows: {
authorizationCodeGrant: true,
clientCredentials: true,
},
callbackUrls: ['redirect-url'],
scopes: [lib_1.OAuthScope.PHONE],
},
})).toThrow(/clientCredentials OAuth flow cannot be selected/);
expect(() => pool.addClient('Client2', {
oAuth: {
flows: {
implicitCodeGrant: true,
clientCredentials: true,
},
callbackUrls: ['redirect-url'],
scopes: [lib_1.OAuthScope.PHONE],
},
})).toThrow(/clientCredentials OAuth flow cannot be selected/);
});
test('OAuth scopes', () => {
// GIVEN
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN
pool.addClient('Client', {
oAuth: {
flows: { clientCredentials: true, },
scopes: [
lib_1.OAuthScope.PHONE,
lib_1.OAuthScope.EMAIL,
lib_1.OAuthScope.OPENID,
lib_1.OAuthScope.PROFILE,
lib_1.OAuthScope.COGNITO_ADMIN,
lib_1.OAuthScope.custom('my-resource-server/my-own-scope'),
],
},
});
// THEN
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
AllowedOAuthScopes: [
'phone',
'email',
'openid',
'profile',
'aws.cognito.signin.user.admin',
'my-resource-server/my-own-scope'
],
});
});
test('OAuthScope - openid is included when email or phone is specified', () => {
// GIVEN
const stack = new core_1.Stack();
const pool = new lib_1.UserPool(stack, 'Pool');
// WHEN
pool.addClient('Client1', {
userPoolClientName: 'Client1',
oAuth: {
flows: { clientCredentials: true, },
scopes: [lib_1.OAuthScope.PHONE,],
},
});
pool.addClient('Client2', {
userPoolClientName: 'Client2',
oAuth: {
flows: { clientCredentials: true, },
scopes: [lib_1.OAuthScope.EMAIL,],
},
});
pool.addClient('Client3', {
userPoolClientName: 'Client3',
oAuth: {
flows: { clientCredentials: true, },
scopes: [lib_1.OAuthScope.PROFILE,],
},
});
pool.addClient('Client4', {
userPoolClientName: 'Client4',
oAuth: {
flows: { clientCredentials: true, },
scopes: [lib_1.OAuthScope.COGNITO_ADMIN,],
},
});
// THEN
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
ClientName: 'Client1',
AllowedOAuthScopes: ['phone', 'openid',],
});
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
ClientName: 'Client2',
AllowedOAuthScopes: ['email', 'openid',],
});
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
ClientName: 'Client3',
AllowedOAuthScopes: ['profile', 'openid',],
});
expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {
ClientName: 'Client4',
AllowedOAuthScopes: ['aws.cognito.signin.user.admin'],
});
});
});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1wb29sLWNsaWVudC50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidXNlci1wb29sLWNsaWVudC50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsZ0NBQThCO0FBQzlCLHdDQUFzQztBQUN0QyxnQ0FBa0Q7QUFFbEQsUUFBUSxDQUFDLGtCQUFrQixFQUFFLEdBQUcsRUFBRTtJQUNoQyxJQUFJLENBQUMsZUFBZSxFQUFFLEdBQUcsRUFBRTtRQUN6QixRQUFRO1FBQ1IsTUFBTSxLQUFLLEdBQUcsSUFBSSxZQUFLLEVBQUUsQ0FBQztRQUMxQixNQUFNLElBQUksR0FBRyxJQUFJLGNBQVEsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLEVBQUcsQ0FBQyxDQUFDO1FBRTlDLE9BQU87UUFDUCxJQUFJLG9CQUFjLENBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRTtZQUNsQyxRQUFRLEVBQUUsSUFBSTtTQUNmLENBQUMsQ0FBQztRQUVILE9BQU87UUFDUCxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsa0JBQWtCLENBQUMsOEJBQThCLEVBQUU7WUFDL0QsVUFBVSxFQUFFLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztTQUMzQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICdAYXdzLWNkay9hc3NlcnQvamVzdCc7XG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJ0Bhd3MtY2RrL2NvcmUnO1xuaW1wb3J0IHsgVXNlclBvb2wsIFVzZXJQb29sQ2xpZW50IH0gZnJvbSAnLi4vbGliJztcblxuZGVzY3JpYmUoJ1VzZXIgUG9vbCBDbGllbnQnLCAoKSA9PiB7XG4gIHRlc3QoJ2RlZmF1bHQgc2V0dXAnLCAoKSA9PiB7XG4gICAgLy8gR0lWRU5cbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjaygpO1xuICAgIGNvbnN0IHBvb2wgPSBuZXcgVXNlclBvb2woc3RhY2ssICdQb29sJywgeyB9KTtcblxuICAgIC8vIFdIRU5cbiAgICBuZXcgVXNlclBvb2xDbGllbnQoc3RhY2ssICdDbGllbnQnLCB7XG4gICAgICB1c2VyUG9vbDogcG9vbFxuICAgIH0pO1xuXG4gICAgLy8gVEhFTlxuICAgIGV4cGVjdChzdGFjaykudG9IYXZlUmVzb3VyY2VMaWtlKCdBV1M6OkNvZ25pdG86OlVzZXJQb29sQ2xpZW50Jywge1xuICAgICAgVXNlclBvb2xJZDogc3RhY2sucmVzb2x2ZShwb29sLnVzZXJQb29sSWQpXG4gICAgfSk7XG4gIH0pO1xufSk7Il19
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-pool-client.test.js","sourceRoot":"","sources":["user-pool-client.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { ABSENT } from '@aws-cdk/assert';\nimport '@aws-cdk/assert/jest';\nimport { Stack } from '@aws-cdk/core';\nimport { OAuthScope, UserPool, UserPoolClient } from '../lib';\n\ndescribe('User Pool Client', () => {\n  test('default setup', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    new UserPoolClient(stack, 'Client', {\n      userPool: pool\n    });\n\n    // THEN\n    expect(stack).toHaveResource('AWS::Cognito::UserPoolClient', {\n      UserPoolId: stack.resolve(pool.userPoolId),\n    });\n  });\n\n  test('client name', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    const client1 = new UserPoolClient(stack, 'Client1', {\n      userPool: pool,\n      userPoolClientName: 'myclient'\n    });\n    const client2 = new UserPoolClient(stack, 'Client2', {\n      userPool: pool,\n    });\n\n    // THEN\n    expect(client1.userPoolClientName).toEqual('myclient');\n    expect(() => client2.userPoolClientName).toThrow(/available only if specified on the UserPoolClient during initialization/);\n  });\n\n  test('import', () => {\n    // GIVEN\n    const stack = new Stack();\n\n    // WHEN\n    const client = UserPoolClient.fromUserPoolClientId(stack, 'Client', 'client-id-1');\n\n    // THEN\n    expect(client.userPoolClientId).toEqual('client-id-1');\n  });\n\n  test('ExplicitAuthFlows is absent by default', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    pool.addClient('Client');\n\n    // THEN\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      ExplicitAuthFlows: ABSENT,\n    });\n  });\n\n  test('ExplicitAuthFlows are correctly named', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    pool.addClient('Client', {\n      authFlows: {\n        adminUserPassword: true,\n        custom: true,\n        refreshToken: true,\n        userPassword: true,\n        userSrp: true,\n      }\n    });\n\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      ExplicitAuthFlows: [\n        'ALLOW_USER_PASSWORD_AUTH',\n        'ALLOW_ADMIN_USER_PASSWORD_AUTH',\n        'ALLOW_CUSTOM_AUTH',\n        'ALLOW_USER_SRP_AUTH',\n        'ALLOW_REFRESH_TOKEN_AUTH',\n      ],\n    });\n  });\n\n  test('AllowedOAuthFlows is absent by default', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    pool.addClient('Client');\n\n    // THEN\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      AllowedOAuthFlows: ABSENT,\n      // AllowedOAuthFlowsUserPoolClient: ABSENT,\n    });\n  });\n\n  test('AllowedOAuthFlows are correctly named', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    pool.addClient('Client1', {\n      oAuth: {\n        flows: {\n          authorizationCodeGrant: true,\n          implicitCodeGrant: true,\n        },\n        callbackUrls: [ 'redirect-url' ],\n        scopes: [ OAuthScope.PHONE ],\n      },\n    });\n    pool.addClient('Client2', {\n      oAuth: {\n        flows: {\n          clientCredentials: true,\n        },\n        callbackUrls: [ 'redirect-url' ],\n        scopes: [ OAuthScope.PHONE ],\n      },\n    });\n\n    // THEN\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      AllowedOAuthFlows: [ 'implicit', 'code' ],\n      AllowedOAuthFlowsUserPoolClient: true,\n    });\n\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      AllowedOAuthFlows: [ 'client_credentials' ],\n      AllowedOAuthFlowsUserPoolClient: true,\n    });\n  });\n\n  test('fails when callbackUrls are not specified for codeGrant or implicitGrant', () => {\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    expect(() => pool.addClient('Client1', {\n      oAuth: {\n        flows: { authorizationCodeGrant: true },\n        scopes: [ OAuthScope.PHONE ],\n      }\n    })).toThrow(/callbackUrl must be specified/);\n\n    expect(() => pool.addClient('Client2', {\n      oAuth: {\n        flows: { implicitCodeGrant: true },\n        scopes: [ OAuthScope.PHONE ],\n      },\n    })).toThrow(/callbackUrl must be specified/);\n\n    expect(() => pool.addClient('Client3', {\n      oAuth: {\n        flows: { clientCredentials: true },\n        scopes: [ OAuthScope.PHONE ],\n      }\n    })).not.toThrow();\n  });\n\n  test('fails when clientCredentials OAuth flow is selected along with codeGrant or implicitGrant', () => {\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    expect(() => pool.addClient('Client1', {\n      oAuth: {\n        flows: {\n          authorizationCodeGrant: true,\n          clientCredentials: true,\n        },\n        callbackUrls: [ 'redirect-url' ],\n        scopes: [ OAuthScope.PHONE ],\n      },\n    })).toThrow(/clientCredentials OAuth flow cannot be selected/);\n\n    expect(() => pool.addClient('Client2', {\n      oAuth: {\n        flows: {\n          implicitCodeGrant: true,\n          clientCredentials: true,\n        },\n        callbackUrls: [ 'redirect-url' ],\n        scopes: [ OAuthScope.PHONE ],\n      },\n    })).toThrow(/clientCredentials OAuth flow cannot be selected/);\n  });\n\n  test('OAuth scopes', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    pool.addClient('Client', {\n      oAuth: {\n        flows: { clientCredentials: true, },\n        scopes: [\n          OAuthScope.PHONE,\n          OAuthScope.EMAIL,\n          OAuthScope.OPENID,\n          OAuthScope.PROFILE,\n          OAuthScope.COGNITO_ADMIN,\n          OAuthScope.custom('my-resource-server/my-own-scope'),\n        ],\n      },\n    });\n\n    // THEN\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      AllowedOAuthScopes: [\n        'phone',\n        'email',\n        'openid',\n        'profile',\n        'aws.cognito.signin.user.admin',\n        'my-resource-server/my-own-scope'\n      ],\n    });\n  });\n\n  test('OAuthScope - openid is included when email or phone is specified', () => {\n    // GIVEN\n    const stack = new Stack();\n    const pool = new UserPool(stack, 'Pool');\n\n    // WHEN\n    pool.addClient('Client1', {\n      userPoolClientName: 'Client1',\n      oAuth: {\n        flows: { clientCredentials: true, },\n        scopes: [ OAuthScope.PHONE, ],\n      },\n    });\n    pool.addClient('Client2', {\n      userPoolClientName: 'Client2',\n      oAuth: {\n        flows: { clientCredentials: true, },\n        scopes: [ OAuthScope.EMAIL, ],\n      },\n    });\n    pool.addClient('Client3', {\n      userPoolClientName: 'Client3',\n      oAuth: {\n        flows: { clientCredentials: true, },\n        scopes: [ OAuthScope.PROFILE, ],\n      },\n    });\n    pool.addClient('Client4', {\n      userPoolClientName: 'Client4',\n      oAuth: {\n        flows: { clientCredentials: true, },\n        scopes: [ OAuthScope.COGNITO_ADMIN, ],\n      },\n    });\n\n    // THEN\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      ClientName: 'Client1',\n      AllowedOAuthScopes: [ 'phone', 'openid', ],\n    });\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      ClientName: 'Client2',\n      AllowedOAuthScopes: [ 'email', 'openid', ],\n    });\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      ClientName: 'Client3',\n      AllowedOAuthScopes: [ 'profile', 'openid', ],\n    });\n    expect(stack).toHaveResourceLike('AWS::Cognito::UserPoolClient', {\n      ClientName: 'Client4',\n      AllowedOAuthScopes: [ 'aws.cognito.signin.user.admin' ],\n    });\n  });\n});"]}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc