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

@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 0.28.0 to 0.29.0

6

lib/user-pool-client.d.ts

@@ -1,2 +0,2 @@

import cdk = require('@aws-cdk/cdk');
import { Construct, Resource } from '@aws-cdk/cdk';
import { IUserPool } from './user-pool';

@@ -44,5 +44,5 @@ /**

*/
export declare class UserPoolClient extends cdk.Construct {
export declare class UserPoolClient extends Resource {
readonly clientId: string;
constructor(scope: cdk.Construct, id: string, props: UserPoolClientProps);
constructor(scope: Construct, id: string, props: UserPoolClientProps);
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const cdk = require("@aws-cdk/cdk");
const cdk_1 = require("@aws-cdk/cdk");
const cognito_generated_1 = require("./cognito.generated");

@@ -26,3 +26,3 @@ /**

*/
class UserPoolClient extends cdk.Construct {
class UserPoolClient extends cdk_1.Resource {
constructor(scope, id, props) {

@@ -40,2 +40,2 @@ super(scope, id);

exports.UserPoolClient = UserPoolClient;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1wb29sLWNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVzZXItcG9vbC1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsMkRBQXdEO0FBR3hEOztHQUVHO0FBQ0gsSUFBWSxRQWVYO0FBZkQsV0FBWSxRQUFRO0lBQ2xCOztPQUVHO0lBQ0gsNENBQWdDLENBQUE7SUFFaEM7O09BRUc7SUFDSCxvREFBd0MsQ0FBQTtJQUV4Qzs7T0FFRztJQUNILCtDQUFtQyxDQUFBO0FBQ3JDLENBQUMsRUFmVyxRQUFRLEdBQVIsZ0JBQVEsS0FBUixnQkFBUSxRQWVuQjtBQTJCRDs7R0FFRztBQUNILE1BQWEsY0FBZSxTQUFRLEdBQUcsQ0FBQyxTQUFTO0lBRy9DLFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQUUsS0FBMEI7UUFDdEUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixNQUFNLGNBQWMsR0FBRyxJQUFJLHFDQUFpQixDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDN0QsVUFBVSxFQUFFLEtBQUssQ0FBQyxVQUFVO1lBQzVCLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYztZQUNwQyxVQUFVLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxVQUFVO1lBQ3JDLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxnQkFBZ0I7U0FDMUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLFFBQVEsR0FBRyxjQUFjLENBQUMsZ0JBQWdCLENBQUM7SUFDbEQsQ0FBQztDQUNGO0FBZEQsd0NBY0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBDZm5Vc2VyUG9vbENsaWVudCB9IGZyb20gJy4vY29nbml0by5nZW5lcmF0ZWQnO1xuaW1wb3J0IHsgSVVzZXJQb29sIH0gZnJvbSAnLi91c2VyLXBvb2wnO1xuXG4vKipcbiAqIFR5cGVzIG9mIGF1dGhlbnRpY2F0aW9uIGZsb3dcbiAqL1xuZXhwb3J0IGVudW0gQXV0aEZsb3cge1xuICAvKipcbiAgICogRW5hYmxlIGZsb3cgZm9yIHNlcnZlci1zaWRlIG9yIGFkbWluIGF1dGhlbnRpY2F0aW9uIChubyBjbGllbnQgYXBwKVxuICAgKi9cbiAgQWRtaW5Ob1NycCA9ICdBRE1JTl9OT19TUlBfQVVUSCcsXG5cbiAgLyoqXG4gICAqIEVuYWJsZSBjdXN0b20gYXV0aGVudGljYXRpb24gZmxvd1xuICAgKi9cbiAgQ3VzdG9tRmxvd09ubHkgPSAnQ1VTVE9NX0FVVEhfRkxPV19PTkxZJyxcblxuICAvKipcbiAgICogRW5hYmxlIGF1dGggdXNpbmcgdXNlcm5hbWUgJiBwYXNzd29yZFxuICAgKi9cbiAgVXNlclBhc3N3b3JkID0gJ1VTRVJfUEFTU1dPUkRfQVVUSCdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVc2VyUG9vbENsaWVudFByb3BzIHtcbiAgLyoqXG4gICAqIE5hbWUgb2YgdGhlIGFwcGxpY2F0aW9uIGNsaWVudFxuICAgKiBAZGVmYXVsdCBjbG91ZGZvcm1hdGlvbiBnZW5lcmF0ZWQgbmFtZVxuICAgKi9cbiAgcmVhZG9ubHkgY2xpZW50TmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIFVzZXJQb29sIHJlc291cmNlIHRoaXMgY2xpZW50IHdpbGwgaGF2ZSBhY2Nlc3MgdG9cbiAgICovXG4gIHJlYWRvbmx5IHVzZXJQb29sOiBJVXNlclBvb2w7XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdG8gZ2VuZXJhdGUgYSBjbGllbnQgc2VjcmV0XG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBnZW5lcmF0ZVNlY3JldD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIExpc3Qgb2YgZW5hYmxlZCBhdXRoZW50aWNhdGlvbiBmbG93c1xuICAgKiBAZGVmYXVsdCBubyBlbmFibGVkIGZsb3dzXG4gICAqL1xuICByZWFkb25seSBlbmFibGVkQXV0aEZsb3dzPzogQXV0aEZsb3dbXVxufVxuXG4vKipcbiAqIERlZmluZSBhIFVzZXJQb29sIEFwcCBDbGllbnRcbiAqL1xuZXhwb3J0IGNsYXNzIFVzZXJQb29sQ2xpZW50IGV4dGVuZHMgY2RrLkNvbnN0cnVjdCB7XG4gIHB1YmxpYyByZWFkb25seSBjbGllbnRJZDogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBjZGsuQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogVXNlclBvb2xDbGllbnRQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBjb25zdCB1c2VyUG9vbENsaWVudCA9IG5ldyBDZm5Vc2VyUG9vbENsaWVudCh0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBjbGllbnROYW1lOiBwcm9wcy5jbGllbnROYW1lLFxuICAgICAgZ2VuZXJhdGVTZWNyZXQ6IHByb3BzLmdlbmVyYXRlU2VjcmV0LFxuICAgICAgdXNlclBvb2xJZDogcHJvcHMudXNlclBvb2wudXNlclBvb2xJZCxcbiAgICAgIGV4cGxpY2l0QXV0aEZsb3dzOiBwcm9wcy5lbmFibGVkQXV0aEZsb3dzXG4gICAgfSk7XG4gICAgdGhpcy5jbGllbnRJZCA9IHVzZXJQb29sQ2xpZW50LnVzZXJQb29sQ2xpZW50SWQ7XG4gIH1cbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1wb29sLWNsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInVzZXItcG9vbC1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxzQ0FBbUQ7QUFDbkQsMkRBQXdEO0FBR3hEOztHQUVHO0FBQ0gsSUFBWSxRQWVYO0FBZkQsV0FBWSxRQUFRO0lBQ2xCOztPQUVHO0lBQ0gsNENBQWdDLENBQUE7SUFFaEM7O09BRUc7SUFDSCxvREFBd0MsQ0FBQTtJQUV4Qzs7T0FFRztJQUNILCtDQUFtQyxDQUFBO0FBQ3JDLENBQUMsRUFmVyxRQUFRLEdBQVIsZ0JBQVEsS0FBUixnQkFBUSxRQWVuQjtBQTJCRDs7R0FFRztBQUNILE1BQWEsY0FBZSxTQUFRLGNBQVE7SUFHMUMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUEwQjtRQUNsRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sY0FBYyxHQUFHLElBQUkscUNBQWlCLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUM3RCxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7WUFDNUIsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ3BDLFVBQVUsRUFBRSxLQUFLLENBQUMsUUFBUSxDQUFDLFVBQVU7WUFDckMsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQjtTQUMxQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsUUFBUSxHQUFHLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQztJQUNsRCxDQUFDO0NBQ0Y7QUFkRCx3Q0FjQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCwgUmVzb3VyY2UgfSBmcm9tICdAYXdzLWNkay9jZGsnO1xuaW1wb3J0IHsgQ2ZuVXNlclBvb2xDbGllbnQgfSBmcm9tICcuL2NvZ25pdG8uZ2VuZXJhdGVkJztcbmltcG9ydCB7IElVc2VyUG9vbCB9IGZyb20gJy4vdXNlci1wb29sJztcblxuLyoqXG4gKiBUeXBlcyBvZiBhdXRoZW50aWNhdGlvbiBmbG93XG4gKi9cbmV4cG9ydCBlbnVtIEF1dGhGbG93IHtcbiAgLyoqXG4gICAqIEVuYWJsZSBmbG93IGZvciBzZXJ2ZXItc2lkZSBvciBhZG1pbiBhdXRoZW50aWNhdGlvbiAobm8gY2xpZW50IGFwcClcbiAgICovXG4gIEFkbWluTm9TcnAgPSAnQURNSU5fTk9fU1JQX0FVVEgnLFxuXG4gIC8qKlxuICAgKiBFbmFibGUgY3VzdG9tIGF1dGhlbnRpY2F0aW9uIGZsb3dcbiAgICovXG4gIEN1c3RvbUZsb3dPbmx5ID0gJ0NVU1RPTV9BVVRIX0ZMT1dfT05MWScsXG5cbiAgLyoqXG4gICAqIEVuYWJsZSBhdXRoIHVzaW5nIHVzZXJuYW1lICYgcGFzc3dvcmRcbiAgICovXG4gIFVzZXJQYXNzd29yZCA9ICdVU0VSX1BBU1NXT1JEX0FVVEgnXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXNlclBvb2xDbGllbnRQcm9wcyB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBhcHBsaWNhdGlvbiBjbGllbnRcbiAgICogQGRlZmF1bHQgY2xvdWRmb3JtYXRpb24gZ2VuZXJhdGVkIG5hbWVcbiAgICovXG4gIHJlYWRvbmx5IGNsaWVudE5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBVc2VyUG9vbCByZXNvdXJjZSB0aGlzIGNsaWVudCB3aWxsIGhhdmUgYWNjZXNzIHRvXG4gICAqL1xuICByZWFkb25seSB1c2VyUG9vbDogSVVzZXJQb29sO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIGdlbmVyYXRlIGEgY2xpZW50IHNlY3JldFxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgZ2VuZXJhdGVTZWNyZXQ/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBMaXN0IG9mIGVuYWJsZWQgYXV0aGVudGljYXRpb24gZmxvd3NcbiAgICogQGRlZmF1bHQgbm8gZW5hYmxlZCBmbG93c1xuICAgKi9cbiAgcmVhZG9ubHkgZW5hYmxlZEF1dGhGbG93cz86IEF1dGhGbG93W11cbn1cblxuLyoqXG4gKiBEZWZpbmUgYSBVc2VyUG9vbCBBcHAgQ2xpZW50XG4gKi9cbmV4cG9ydCBjbGFzcyBVc2VyUG9vbENsaWVudCBleHRlbmRzIFJlc291cmNlIHtcbiAgcHVibGljIHJlYWRvbmx5IGNsaWVudElkOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFVzZXJQb29sQ2xpZW50UHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgdXNlclBvb2xDbGllbnQgPSBuZXcgQ2ZuVXNlclBvb2xDbGllbnQodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgY2xpZW50TmFtZTogcHJvcHMuY2xpZW50TmFtZSxcbiAgICAgIGdlbmVyYXRlU2VjcmV0OiBwcm9wcy5nZW5lcmF0ZVNlY3JldCxcbiAgICAgIHVzZXJQb29sSWQ6IHByb3BzLnVzZXJQb29sLnVzZXJQb29sSWQsXG4gICAgICBleHBsaWNpdEF1dGhGbG93czogcHJvcHMuZW5hYmxlZEF1dGhGbG93c1xuICAgIH0pO1xuICAgIHRoaXMuY2xpZW50SWQgPSB1c2VyUG9vbENsaWVudC51c2VyUG9vbENsaWVudElkO1xuICB9XG59Il19
import lambda = require('@aws-cdk/aws-lambda');
import cdk = require('@aws-cdk/cdk');
import { Construct, IResource, Resource } from '@aws-cdk/cdk';
/**

@@ -217,3 +217,3 @@ * Standard attributes

}
export interface IUserPool extends cdk.IConstruct {
export interface IUserPool extends IResource {
/**

@@ -244,3 +244,3 @@ * The physical ID of this user pool resource

*/
export declare class UserPool extends cdk.Construct implements IUserPool {
export declare class UserPool extends Resource implements IUserPool {
/**

@@ -252,3 +252,3 @@ * Import an existing user pool resource

*/
static import(scope: cdk.Construct, id: string, props: UserPoolImportProps): IUserPool;
static import(scope: Construct, id: string, props: UserPoolImportProps): IUserPool;
/**

@@ -271,3 +271,3 @@ * The physical ID of this user pool resource

private triggers;
constructor(scope: cdk.Construct, id: string, props: UserPoolProps);
constructor(scope: Construct, id: string, props?: UserPoolProps);
/**

@@ -274,0 +274,0 @@ * Attach 'Create Auth Challenge' trigger

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const iam = require("@aws-cdk/aws-iam");
const cdk = require("@aws-cdk/cdk");
const cdk_1 = require("@aws-cdk/cdk");
const cognito_generated_1 = require("./cognito.generated");

@@ -132,4 +132,4 @@ /**

*/
class UserPool extends cdk.Construct {
constructor(scope, id, props) {
class UserPool extends cdk_1.Resource {
constructor(scope, id, props = {}) {
super(scope, id);

@@ -183,3 +183,3 @@ this.triggers = {};

autoVerifiedAttributes: props.autoVerifiedAttributes,
lambdaConfig: new cdk.Token(() => this.triggers)
lambdaConfig: new cdk_1.Token(() => this.triggers)
});

@@ -208,3 +208,3 @@ this.userPoolId = userPool.userPoolId;

this.addLambdaPermission(fn, 'CreateAuthChallenge');
this.triggers = Object.assign({}, this.triggers, { createAuthChallenge: fn.functionArn });
this.triggers = { ...this.triggers, createAuthChallenge: fn.functionArn };
}

@@ -219,3 +219,3 @@ /**

this.addLambdaPermission(fn, 'CustomMessage');
this.triggers = Object.assign({}, this.triggers, { customMessage: fn.functionArn });
this.triggers = { ...this.triggers, customMessage: fn.functionArn };
}

@@ -230,3 +230,3 @@ /**

this.addLambdaPermission(fn, 'DefineAuthChallenge');
this.triggers = Object.assign({}, this.triggers, { defineAuthChallenge: fn.functionArn });
this.triggers = { ...this.triggers, defineAuthChallenge: fn.functionArn };
}

@@ -241,3 +241,3 @@ /**

this.addLambdaPermission(fn, 'PostAuthentication');
this.triggers = Object.assign({}, this.triggers, { postAuthentication: fn.functionArn });
this.triggers = { ...this.triggers, postAuthentication: fn.functionArn };
}

@@ -252,3 +252,3 @@ /**

this.addLambdaPermission(fn, 'PostConfirmation');
this.triggers = Object.assign({}, this.triggers, { postConfirmation: fn.functionArn });
this.triggers = { ...this.triggers, postConfirmation: fn.functionArn };
}

@@ -263,3 +263,3 @@ /**

this.addLambdaPermission(fn, 'PreAuthentication');
this.triggers = Object.assign({}, this.triggers, { preAuthentication: fn.functionArn });
this.triggers = { ...this.triggers, preAuthentication: fn.functionArn };
}

@@ -274,3 +274,3 @@ /**

this.addLambdaPermission(fn, 'PreSignUp');
this.triggers = Object.assign({}, this.triggers, { preSignUp: fn.functionArn });
this.triggers = { ...this.triggers, preSignUp: fn.functionArn };
}

@@ -285,10 +285,10 @@ /**

this.addLambdaPermission(fn, 'VerifyAuthChallengeResponse');
this.triggers = Object.assign({}, this.triggers, { verifyAuthChallengeResponse: fn.functionArn });
this.triggers = { ...this.triggers, verifyAuthChallengeResponse: fn.functionArn };
}
export() {
return {
userPoolId: new cdk.CfnOutput(this, 'UserPoolId', { value: this.userPoolId }).makeImportValue().toString(),
userPoolArn: new cdk.CfnOutput(this, 'UserPoolArn', { value: this.userPoolArn }).makeImportValue().toString(),
userPoolProviderName: new cdk.CfnOutput(this, 'UserPoolProviderName', { value: this.userPoolProviderName }).makeImportValue().toString(),
userPoolProviderUrl: new cdk.CfnOutput(this, 'UserPoolProviderUrl', { value: this.userPoolProviderUrl }).makeImportValue().toString()
userPoolId: new cdk_1.CfnOutput(this, 'UserPoolId', { value: this.userPoolId }).makeImportValue().toString(),
userPoolArn: new cdk_1.CfnOutput(this, 'UserPoolArn', { value: this.userPoolArn }).makeImportValue().toString(),
userPoolProviderName: new cdk_1.CfnOutput(this, 'UserPoolProviderName', { value: this.userPoolProviderName }).makeImportValue().toString(),
userPoolProviderUrl: new cdk_1.CfnOutput(this, 'UserPoolProviderUrl', { value: this.userPoolProviderUrl }).makeImportValue().toString()
};

@@ -308,3 +308,3 @@ }

*/
class ImportedUserPool extends cdk.Construct {
class ImportedUserPool extends cdk_1.Construct {
constructor(scope, id, props) {

@@ -322,2 +322,2 @@ super(scope, id);

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-pool.js","sourceRoot":"","sources":["user-pool.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport lambda = require('@aws-cdk/aws-lambda');\nimport cdk = require('@aws-cdk/cdk');\nimport { CfnUserPool } from './cognito.generated';\n\n/**\n * Standard attributes\n * Specified following the OpenID Connect spec\n * @see https://openid.net/specs/openid-connect-core-1_0.html#StandardClaims\n */\nexport enum UserPoolAttribute {\n  /**\n   * End-User's preferred postal address.\n   */\n  Address = 'address',\n\n  /**\n   * End-User's birthday, represented as an ISO 8601:2004 [ISO8601‑2004] YYYY-MM-DD format.\n   * The year MAY be 0000, indicating that it is omitted.\n   * To represent only the year, YYYY format is allowed.\n   */\n  Birthdate = 'birthdate',\n\n  /**\n   * End-User's preferred e-mail address.\n   * Its value MUST conform to the RFC 5322 [RFC5322] addr-spec syntax.\n   */\n  Email = 'email',\n\n  /**\n   * Surname(s) or last name(s) of the End-User.\n   * Note that in some cultures, people can have multiple family names or no family name;\n   * all can be present, with the names being separated by space characters.\n   */\n  FamilyName = 'family_name',\n\n  /**\n   * End-User's gender.\n   */\n  Gender = 'gender',\n\n  /**\n   * Given name(s) or first name(s) of the End-User.\n   * Note that in some cultures, people can have multiple given names;\n   * all can be present, with the names being separated by space characters.\n   */\n  GivenName = 'given_name',\n\n  /**\n   * End-User's locale, represented as a BCP47 [RFC5646] language tag.\n   * This is typically an ISO 639-1 Alpha-2 [ISO639‑1] language code in lowercase\n   * and an ISO 3166-1 Alpha-2 [ISO3166‑1] country code in uppercase, separated by a dash.\n   * For example, en-US or fr-CA.\n   */\n  Locale = 'locale',\n\n  /**\n   * Middle name(s) of the End-User.\n   * Note that in some cultures, people can have multiple middle names;\n   * all can be present, with the names being separated by space characters.\n   * Also note that in some cultures, middle names are not used.\n   */\n  MiddleName = 'middle_name',\n\n  /**\n   * End-User's full name in displayable form including all name parts,\n   * possibly including titles and suffixes, ordered according to the End-User's locale and preferences.\n   */\n  Name = 'name',\n\n  /**\n   * Casual name of the End-User that may or may not be the same as the given_name.\n   * For instance, a nickname value of Mike might be returned alongside a given_name value of Michael.\n   */\n  Nickname = 'nickname',\n\n  /**\n   * End-User's preferred telephone number.\n   * E.164 [E.164] is RECOMMENDED as the format of this Claim, for example, +1 (425) 555-1212 or +56 (2) 687 2400.\n   * If the phone number contains an extension, it is RECOMMENDED that the extension be represented using the\n   * RFC 3966 [RFC3966] extension syntax, for example, +1 (604) 555-1234;ext=5678.\n   */\n  PhoneNumber = 'phone_number',\n\n  /**\n   * URL of the End-User's profile picture.\n   * This URL MUST refer to an image file (for example, a PNG, JPEG, or GIF image file),\n   * rather than to a Web page containing an image.\n   * Note that this URL SHOULD specifically reference a profile photo of the End-User\n   * suitable for displaying when describing the End-User, rather than an arbitrary photo taken by the End-User\n   */\n  Picture = 'picture',\n\n  /**\n   * Shorthand name by which the End-User wishes to be referred to.\n   */\n  PreferredUsername = 'preferred_username',\n\n  /**\n   * URL of the End-User's profile page. The contents of this Web page SHOULD be about the End-User.\n   */\n  Profile = 'profile',\n\n  /**\n   * The End-User's time zone\n   */\n  Timezone = 'timezone',\n\n  /**\n   * Time the End-User's information was last updated.\n   * Its value is a JSON number representing the number of seconds from 1970-01-01T0:0:0Z\n   * as measured in UTC until the date/time.\n   */\n  UpdatedAt = 'updated_at',\n\n  /**\n   * URL of the End-User's Web page or blog.\n   * This Web page SHOULD contain information published by the End-User or an organization that the End-User is affiliated with.\n   */\n  Website = 'website'\n}\n\n/**\n * Methods of user sign-in\n */\nexport enum SignInType {\n  /**\n   * End-user will sign in with a username, with optional aliases\n   */\n  Username,\n\n  /**\n   * End-user will sign in using an email address\n   */\n  Email,\n\n  /**\n   * End-user will sign in using a phone number\n   */\n  Phone,\n\n  /**\n   * End-user will sign in using either an email address or phone number\n   */\n  EmailOrPhone\n}\n\nexport interface UserPoolTriggers {\n  /**\n   * Creates an authentication challenge.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-create-auth-challenge.html\n   */\n  readonly createAuthChallenge?: lambda.IFunction;\n\n  /**\n   * A custom Message AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-custom-message.html\n   */\n  readonly customMessage?: lambda.IFunction;\n\n  /**\n   * Defines the authentication challenge.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-define-auth-challenge.html\n   */\n  readonly defineAuthChallenge?: lambda.IFunction;\n\n  /**\n   * A post-authentication AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-authentication.html\n   */\n  readonly postAuthentication?: lambda.IFunction;\n\n  /**\n   * A post-confirmation AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-confirmation.html\n   */\n  readonly postConfirmation?: lambda.IFunction;\n\n  /**\n   * A pre-authentication AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-authentication.html\n   */\n  readonly preAuthentication?: lambda.IFunction;\n\n  /**\n   * A pre-registration AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-sign-up.html\n   */\n  readonly preSignUp?: lambda.IFunction;\n\n  /**\n   * Verifies the authentication challenge response.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-verify-auth-challenge-response.html\n   */\n  readonly verifyAuthChallengeResponse?: lambda.IFunction;\n\n  /**\n   * Index signature\n   */\n  [trigger: string]: lambda.IFunction | undefined;\n}\n\nexport interface UserPoolProps {\n  /**\n   * Name of the user pool\n   * @default unique ID\n   */\n  readonly poolName?: string;\n\n  /**\n   * Method used for user registration & sign in.\n   * Allows either username with aliases OR sign in with email, phone, or both.\n   * @default SignInType.USERNAME\n   */\n  readonly signInType?: SignInType;\n\n  /**\n   * Attributes to allow as username alias.\n   * Only valid if signInType is USERNAME\n   * @default no alias\n   */\n  readonly usernameAliasAttributes?: UserPoolAttribute[];\n\n  /**\n   * Attributes which Cognito will automatically send a verification message to.\n   * Must be either EMAIL, PHONE, or both.\n   * @default no auto verification\n   */\n  readonly autoVerifiedAttributes?: UserPoolAttribute[];\n\n  /**\n   * Lambda functions to use for supported Cognito triggers.\n   */\n  readonly lambdaTriggers?: UserPoolTriggers;\n}\n\nexport interface UserPoolImportProps {\n  /**\n   * The ID of an existing user pool\n   */\n  readonly userPoolId: string;\n\n  /**\n   * The ARN of the imported user pool\n   */\n  readonly userPoolArn: string;\n\n  /**\n   * The provider name of the imported user pool\n   */\n  readonly userPoolProviderName: string;\n\n  /**\n   * The URL of the imported user pool\n   */\n  readonly userPoolProviderUrl: string;\n}\n\nexport interface IUserPool extends cdk.IConstruct {\n  /**\n   * The physical ID of this user pool resource\n   */\n  readonly userPoolId: string;\n\n  /**\n   * The ARN of this user pool resource\n   */\n  readonly userPoolArn: string;\n\n  /**\n   * The provider name of this user pool resource\n   */\n  readonly userPoolProviderName: string;\n\n  /**\n   * The provider URL of this user pool resource\n   */\n  readonly userPoolProviderUrl: string;\n\n  /**\n   * Exports a User Pool from this stack\n   * @returns user pool props that can be imported into another stack\n   */\n  export(): UserPoolImportProps;\n}\n\n/**\n * Define a Cognito User Pool\n */\nexport class UserPool extends cdk.Construct implements IUserPool {\n  /**\n   * Import an existing user pool resource\n   * @param scope Parent construct\n   * @param id Construct ID\n   * @param props Imported user pool properties\n   */\n  public static import(scope: cdk.Construct, id: string, props: UserPoolImportProps): IUserPool {\n    return new ImportedUserPool(scope, id, props);\n  }\n\n  /**\n   * The physical ID of this user pool resource\n   */\n  public readonly userPoolId: string;\n\n  /**\n   * The ARN of the user pool\n   */\n  public readonly userPoolArn: string;\n\n  /**\n   * User pool provider name\n   */\n  public readonly userPoolProviderName: string;\n\n  /**\n   * User pool provider URL\n   */\n  public readonly userPoolProviderUrl: string;\n\n  private triggers: CfnUserPool.LambdaConfigProperty = { };\n\n  constructor(scope: cdk.Construct, id: string, props: UserPoolProps) {\n    super(scope, id);\n\n    let aliasAttributes: UserPoolAttribute[] | undefined;\n    let usernameAttributes: UserPoolAttribute[] | undefined;\n\n    if (props.usernameAliasAttributes != null && props.signInType !== SignInType.Username) {\n      throw new Error(`'usernameAliasAttributes' can only be set with a signInType of 'USERNAME'`);\n    }\n\n    if (props.usernameAliasAttributes\n      && !props.usernameAliasAttributes.every(a => {\n        return a === UserPoolAttribute.Email || a === UserPoolAttribute.PhoneNumber || a === UserPoolAttribute.PreferredUsername;\n      })) {\n      throw new Error(`'usernameAliasAttributes' can only include EMAIL, PHONE_NUMBER, or PREFERRED_USERNAME`);\n    }\n\n    if (props.autoVerifiedAttributes\n      && !props.autoVerifiedAttributes.every(a => a === UserPoolAttribute.Email || a === UserPoolAttribute.PhoneNumber)) {\n      throw new Error(`'autoVerifiedAttributes' can only include EMAIL or PHONE_NUMBER`);\n    }\n\n    switch (props.signInType) {\n      case SignInType.Username:\n        aliasAttributes = props.usernameAliasAttributes;\n        break;\n\n      case SignInType.Email:\n        usernameAttributes = [UserPoolAttribute.Email];\n        break;\n\n      case SignInType.Phone:\n        usernameAttributes = [UserPoolAttribute.PhoneNumber];\n        break;\n\n      case SignInType.EmailOrPhone:\n        usernameAttributes = [UserPoolAttribute.Email, UserPoolAttribute.PhoneNumber];\n        break;\n\n      default:\n        aliasAttributes = props.usernameAliasAttributes;\n        break;\n    }\n\n    if (props.lambdaTriggers) {\n      for (const t of Object.keys(props.lambdaTriggers)) {\n        const trigger = props.lambdaTriggers[t];\n        if (trigger !== undefined) {\n          this.addLambdaPermission(trigger as lambda.IFunction, t);\n          (this.triggers as any)[t] = (trigger as lambda.IFunction).functionArn;\n        }\n      }\n    }\n\n    const userPool = new CfnUserPool(this, 'Resource', {\n      userPoolName: props.poolName || this.node.uniqueId,\n      usernameAttributes,\n      aliasAttributes,\n      autoVerifiedAttributes: props.autoVerifiedAttributes,\n      lambdaConfig: new cdk.Token(() => this.triggers)\n    });\n    this.userPoolId = userPool.userPoolId;\n    this.userPoolArn = userPool.userPoolArn;\n    this.userPoolProviderName = userPool.userPoolProviderName;\n    this.userPoolProviderUrl = userPool.userPoolProviderUrl;\n  }\n\n  /**\n   * Attach 'Create Auth Challenge' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-create-auth-challenge.html\n   * @param fn the lambda function to attach\n   */\n  public onCreateAuthChallenge(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'CreateAuthChallenge');\n    this.triggers = { ...this.triggers, createAuthChallenge: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Custom Message' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-custom-message.html\n   * @param fn the lambda function to attach\n   */\n  public onCustomMessage(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'CustomMessage');\n    this.triggers = { ...this.triggers, customMessage: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Define Auth Challenge' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-define-auth-challenge.html\n   * @param fn the lambda function to attach\n   */\n  public onDefineAuthChallenge(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'DefineAuthChallenge');\n    this.triggers = { ...this.triggers, defineAuthChallenge: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Post Authentication' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-authentication.html\n   * @param fn the lambda function to attach\n   */\n  public onPostAuthentication(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PostAuthentication');\n    this.triggers = { ...this.triggers, postAuthentication: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Post Confirmation' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-confirmation.html\n   * @param fn the lambda function to attach\n   */\n  public onPostConfirmation(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PostConfirmation');\n    this.triggers = { ...this.triggers, postConfirmation: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Pre Authentication' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-authentication.html\n   * @param fn the lambda function to attach\n   */\n  public onPreAuthentication(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PreAuthentication');\n    this.triggers = { ...this.triggers, preAuthentication: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Pre Sign Up' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-sign-up.html\n   * @param fn the lambda function to attach\n   */\n  public onPreSignUp(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PreSignUp');\n    this.triggers = { ...this.triggers, preSignUp: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Verify Auth Challenge Response' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-verify-auth-challenge-response.html\n   * @param fn the lambda function to attach\n   */\n  public onVerifyAuthChallengeResponse(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'VerifyAuthChallengeResponse');\n    this.triggers = { ...this.triggers, verifyAuthChallengeResponse: fn.functionArn };\n  }\n\n  public export(): UserPoolImportProps {\n    return {\n      userPoolId: new cdk.CfnOutput(this, 'UserPoolId', { value: this.userPoolId }).makeImportValue().toString(),\n      userPoolArn: new cdk.CfnOutput(this, 'UserPoolArn', { value: this.userPoolArn }).makeImportValue().toString(),\n      userPoolProviderName: new cdk.CfnOutput(this, 'UserPoolProviderName', { value: this.userPoolProviderName }).makeImportValue().toString(),\n      userPoolProviderUrl: new cdk.CfnOutput(this, 'UserPoolProviderUrl', { value: this.userPoolProviderUrl }).makeImportValue().toString()\n    };\n  }\n\n  private addLambdaPermission(fn: lambda.IFunction, name: string): void {\n    const normalize = name.charAt(0).toUpperCase() + name.slice(1);\n    fn.addPermission(`${normalize}Cognito`, {\n      principal: new iam.ServicePrincipal('cognito-idp.amazonaws.com'),\n      sourceArn: this.userPoolArn\n    });\n  }\n}\n\n/**\n * Define a user pool which has been declared in another stack\n */\nclass ImportedUserPool extends cdk.Construct implements IUserPool {\n  /**\n   * The ID of an existing user pool\n   */\n  public readonly userPoolId: string;\n\n  /**\n   * The ARN of the imported user pool\n   */\n  public readonly userPoolArn: string;\n\n  /**\n   * The provider name of the imported user pool\n   */\n  public readonly userPoolProviderName: string;\n\n  /**\n   * The URL of the imported user pool\n   */\n  public readonly userPoolProviderUrl: string;\n\n  constructor(scope: cdk.Construct, id: string, private readonly props: UserPoolImportProps) {\n    super(scope, id);\n\n    this.userPoolId = props.userPoolId;\n    this.userPoolArn = props.userPoolArn;\n    this.userPoolProviderName = props.userPoolProviderName;\n    this.userPoolProviderUrl = props.userPoolProviderUrl;\n  }\n\n  public export(): UserPoolImportProps {\n    return this.props;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-pool.js","sourceRoot":"","sources":["user-pool.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport lambda = require('@aws-cdk/aws-lambda');\nimport { CfnOutput, Construct, IResource, Resource, Token } from '@aws-cdk/cdk';\nimport { CfnUserPool } from './cognito.generated';\n\n/**\n * Standard attributes\n * Specified following the OpenID Connect spec\n * @see https://openid.net/specs/openid-connect-core-1_0.html#StandardClaims\n */\nexport enum UserPoolAttribute {\n  /**\n   * End-User's preferred postal address.\n   */\n  Address = 'address',\n\n  /**\n   * End-User's birthday, represented as an ISO 8601:2004 [ISO8601‑2004] YYYY-MM-DD format.\n   * The year MAY be 0000, indicating that it is omitted.\n   * To represent only the year, YYYY format is allowed.\n   */\n  Birthdate = 'birthdate',\n\n  /**\n   * End-User's preferred e-mail address.\n   * Its value MUST conform to the RFC 5322 [RFC5322] addr-spec syntax.\n   */\n  Email = 'email',\n\n  /**\n   * Surname(s) or last name(s) of the End-User.\n   * Note that in some cultures, people can have multiple family names or no family name;\n   * all can be present, with the names being separated by space characters.\n   */\n  FamilyName = 'family_name',\n\n  /**\n   * End-User's gender.\n   */\n  Gender = 'gender',\n\n  /**\n   * Given name(s) or first name(s) of the End-User.\n   * Note that in some cultures, people can have multiple given names;\n   * all can be present, with the names being separated by space characters.\n   */\n  GivenName = 'given_name',\n\n  /**\n   * End-User's locale, represented as a BCP47 [RFC5646] language tag.\n   * This is typically an ISO 639-1 Alpha-2 [ISO639‑1] language code in lowercase\n   * and an ISO 3166-1 Alpha-2 [ISO3166‑1] country code in uppercase, separated by a dash.\n   * For example, en-US or fr-CA.\n   */\n  Locale = 'locale',\n\n  /**\n   * Middle name(s) of the End-User.\n   * Note that in some cultures, people can have multiple middle names;\n   * all can be present, with the names being separated by space characters.\n   * Also note that in some cultures, middle names are not used.\n   */\n  MiddleName = 'middle_name',\n\n  /**\n   * End-User's full name in displayable form including all name parts,\n   * possibly including titles and suffixes, ordered according to the End-User's locale and preferences.\n   */\n  Name = 'name',\n\n  /**\n   * Casual name of the End-User that may or may not be the same as the given_name.\n   * For instance, a nickname value of Mike might be returned alongside a given_name value of Michael.\n   */\n  Nickname = 'nickname',\n\n  /**\n   * End-User's preferred telephone number.\n   * E.164 [E.164] is RECOMMENDED as the format of this Claim, for example, +1 (425) 555-1212 or +56 (2) 687 2400.\n   * If the phone number contains an extension, it is RECOMMENDED that the extension be represented using the\n   * RFC 3966 [RFC3966] extension syntax, for example, +1 (604) 555-1234;ext=5678.\n   */\n  PhoneNumber = 'phone_number',\n\n  /**\n   * URL of the End-User's profile picture.\n   * This URL MUST refer to an image file (for example, a PNG, JPEG, or GIF image file),\n   * rather than to a Web page containing an image.\n   * Note that this URL SHOULD specifically reference a profile photo of the End-User\n   * suitable for displaying when describing the End-User, rather than an arbitrary photo taken by the End-User\n   */\n  Picture = 'picture',\n\n  /**\n   * Shorthand name by which the End-User wishes to be referred to.\n   */\n  PreferredUsername = 'preferred_username',\n\n  /**\n   * URL of the End-User's profile page. The contents of this Web page SHOULD be about the End-User.\n   */\n  Profile = 'profile',\n\n  /**\n   * The End-User's time zone\n   */\n  Timezone = 'timezone',\n\n  /**\n   * Time the End-User's information was last updated.\n   * Its value is a JSON number representing the number of seconds from 1970-01-01T0:0:0Z\n   * as measured in UTC until the date/time.\n   */\n  UpdatedAt = 'updated_at',\n\n  /**\n   * URL of the End-User's Web page or blog.\n   * This Web page SHOULD contain information published by the End-User or an organization that the End-User is affiliated with.\n   */\n  Website = 'website'\n}\n\n/**\n * Methods of user sign-in\n */\nexport enum SignInType {\n  /**\n   * End-user will sign in with a username, with optional aliases\n   */\n  Username,\n\n  /**\n   * End-user will sign in using an email address\n   */\n  Email,\n\n  /**\n   * End-user will sign in using a phone number\n   */\n  Phone,\n\n  /**\n   * End-user will sign in using either an email address or phone number\n   */\n  EmailOrPhone\n}\n\nexport interface UserPoolTriggers {\n  /**\n   * Creates an authentication challenge.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-create-auth-challenge.html\n   */\n  readonly createAuthChallenge?: lambda.IFunction;\n\n  /**\n   * A custom Message AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-custom-message.html\n   */\n  readonly customMessage?: lambda.IFunction;\n\n  /**\n   * Defines the authentication challenge.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-define-auth-challenge.html\n   */\n  readonly defineAuthChallenge?: lambda.IFunction;\n\n  /**\n   * A post-authentication AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-authentication.html\n   */\n  readonly postAuthentication?: lambda.IFunction;\n\n  /**\n   * A post-confirmation AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-confirmation.html\n   */\n  readonly postConfirmation?: lambda.IFunction;\n\n  /**\n   * A pre-authentication AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-authentication.html\n   */\n  readonly preAuthentication?: lambda.IFunction;\n\n  /**\n   * A pre-registration AWS Lambda trigger.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-sign-up.html\n   */\n  readonly preSignUp?: lambda.IFunction;\n\n  /**\n   * Verifies the authentication challenge response.\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-verify-auth-challenge-response.html\n   */\n  readonly verifyAuthChallengeResponse?: lambda.IFunction;\n\n  /**\n   * Index signature\n   */\n  [trigger: string]: lambda.IFunction | undefined;\n}\n\nexport interface UserPoolProps {\n  /**\n   * Name of the user pool\n   * @default unique ID\n   */\n  readonly poolName?: string;\n\n  /**\n   * Method used for user registration & sign in.\n   * Allows either username with aliases OR sign in with email, phone, or both.\n   * @default SignInType.USERNAME\n   */\n  readonly signInType?: SignInType;\n\n  /**\n   * Attributes to allow as username alias.\n   * Only valid if signInType is USERNAME\n   * @default no alias\n   */\n  readonly usernameAliasAttributes?: UserPoolAttribute[];\n\n  /**\n   * Attributes which Cognito will automatically send a verification message to.\n   * Must be either EMAIL, PHONE, or both.\n   * @default no auto verification\n   */\n  readonly autoVerifiedAttributes?: UserPoolAttribute[];\n\n  /**\n   * Lambda functions to use for supported Cognito triggers.\n   */\n  readonly lambdaTriggers?: UserPoolTriggers;\n}\n\nexport interface UserPoolImportProps {\n  /**\n   * The ID of an existing user pool\n   */\n  readonly userPoolId: string;\n\n  /**\n   * The ARN of the imported user pool\n   */\n  readonly userPoolArn: string;\n\n  /**\n   * The provider name of the imported user pool\n   */\n  readonly userPoolProviderName: string;\n\n  /**\n   * The URL of the imported user pool\n   */\n  readonly userPoolProviderUrl: string;\n}\n\nexport interface IUserPool extends IResource {\n  /**\n   * The physical ID of this user pool resource\n   */\n  readonly userPoolId: string;\n\n  /**\n   * The ARN of this user pool resource\n   */\n  readonly userPoolArn: string;\n\n  /**\n   * The provider name of this user pool resource\n   */\n  readonly userPoolProviderName: string;\n\n  /**\n   * The provider URL of this user pool resource\n   */\n  readonly userPoolProviderUrl: string;\n\n  /**\n   * Exports a User Pool from this stack\n   * @returns user pool props that can be imported into another stack\n   */\n  export(): UserPoolImportProps;\n}\n\n/**\n * Define a Cognito User Pool\n */\nexport class UserPool extends Resource implements IUserPool {\n  /**\n   * Import an existing user pool resource\n   * @param scope Parent construct\n   * @param id Construct ID\n   * @param props Imported user pool properties\n   */\n  public static import(scope: Construct, id: string, props: UserPoolImportProps): IUserPool {\n    return new ImportedUserPool(scope, id, props);\n  }\n\n  /**\n   * The physical ID of this user pool resource\n   */\n  public readonly userPoolId: string;\n\n  /**\n   * The ARN of the user pool\n   */\n  public readonly userPoolArn: string;\n\n  /**\n   * User pool provider name\n   */\n  public readonly userPoolProviderName: string;\n\n  /**\n   * User pool provider URL\n   */\n  public readonly userPoolProviderUrl: string;\n\n  private triggers: CfnUserPool.LambdaConfigProperty = { };\n\n  constructor(scope: Construct, id: string, props: UserPoolProps = {}) {\n    super(scope, id);\n\n    let aliasAttributes: UserPoolAttribute[] | undefined;\n    let usernameAttributes: UserPoolAttribute[] | undefined;\n\n    if (props.usernameAliasAttributes != null && props.signInType !== SignInType.Username) {\n      throw new Error(`'usernameAliasAttributes' can only be set with a signInType of 'USERNAME'`);\n    }\n\n    if (props.usernameAliasAttributes\n      && !props.usernameAliasAttributes.every(a => {\n        return a === UserPoolAttribute.Email || a === UserPoolAttribute.PhoneNumber || a === UserPoolAttribute.PreferredUsername;\n      })) {\n      throw new Error(`'usernameAliasAttributes' can only include EMAIL, PHONE_NUMBER, or PREFERRED_USERNAME`);\n    }\n\n    if (props.autoVerifiedAttributes\n      && !props.autoVerifiedAttributes.every(a => a === UserPoolAttribute.Email || a === UserPoolAttribute.PhoneNumber)) {\n      throw new Error(`'autoVerifiedAttributes' can only include EMAIL or PHONE_NUMBER`);\n    }\n\n    switch (props.signInType) {\n      case SignInType.Username:\n        aliasAttributes = props.usernameAliasAttributes;\n        break;\n\n      case SignInType.Email:\n        usernameAttributes = [UserPoolAttribute.Email];\n        break;\n\n      case SignInType.Phone:\n        usernameAttributes = [UserPoolAttribute.PhoneNumber];\n        break;\n\n      case SignInType.EmailOrPhone:\n        usernameAttributes = [UserPoolAttribute.Email, UserPoolAttribute.PhoneNumber];\n        break;\n\n      default:\n        aliasAttributes = props.usernameAliasAttributes;\n        break;\n    }\n\n    if (props.lambdaTriggers) {\n      for (const t of Object.keys(props.lambdaTriggers)) {\n        const trigger = props.lambdaTriggers[t];\n        if (trigger !== undefined) {\n          this.addLambdaPermission(trigger as lambda.IFunction, t);\n          (this.triggers as any)[t] = (trigger as lambda.IFunction).functionArn;\n        }\n      }\n    }\n\n    const userPool = new CfnUserPool(this, 'Resource', {\n      userPoolName: props.poolName || this.node.uniqueId,\n      usernameAttributes,\n      aliasAttributes,\n      autoVerifiedAttributes: props.autoVerifiedAttributes,\n      lambdaConfig: new Token(() => this.triggers)\n    });\n    this.userPoolId = userPool.userPoolId;\n    this.userPoolArn = userPool.userPoolArn;\n    this.userPoolProviderName = userPool.userPoolProviderName;\n    this.userPoolProviderUrl = userPool.userPoolProviderUrl;\n  }\n\n  /**\n   * Attach 'Create Auth Challenge' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-create-auth-challenge.html\n   * @param fn the lambda function to attach\n   */\n  public onCreateAuthChallenge(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'CreateAuthChallenge');\n    this.triggers = { ...this.triggers, createAuthChallenge: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Custom Message' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-custom-message.html\n   * @param fn the lambda function to attach\n   */\n  public onCustomMessage(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'CustomMessage');\n    this.triggers = { ...this.triggers, customMessage: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Define Auth Challenge' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-define-auth-challenge.html\n   * @param fn the lambda function to attach\n   */\n  public onDefineAuthChallenge(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'DefineAuthChallenge');\n    this.triggers = { ...this.triggers, defineAuthChallenge: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Post Authentication' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-authentication.html\n   * @param fn the lambda function to attach\n   */\n  public onPostAuthentication(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PostAuthentication');\n    this.triggers = { ...this.triggers, postAuthentication: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Post Confirmation' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-post-confirmation.html\n   * @param fn the lambda function to attach\n   */\n  public onPostConfirmation(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PostConfirmation');\n    this.triggers = { ...this.triggers, postConfirmation: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Pre Authentication' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-authentication.html\n   * @param fn the lambda function to attach\n   */\n  public onPreAuthentication(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PreAuthentication');\n    this.triggers = { ...this.triggers, preAuthentication: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Pre Sign Up' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-pre-sign-up.html\n   * @param fn the lambda function to attach\n   */\n  public onPreSignUp(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'PreSignUp');\n    this.triggers = { ...this.triggers, preSignUp: fn.functionArn };\n  }\n\n  /**\n   * Attach 'Verify Auth Challenge Response' trigger\n   * Grants access from cognito-idp.amazonaws.com to the lambda\n   * @see https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-lambda-verify-auth-challenge-response.html\n   * @param fn the lambda function to attach\n   */\n  public onVerifyAuthChallengeResponse(fn: lambda.IFunction): void {\n    this.addLambdaPermission(fn, 'VerifyAuthChallengeResponse');\n    this.triggers = { ...this.triggers, verifyAuthChallengeResponse: fn.functionArn };\n  }\n\n  public export(): UserPoolImportProps {\n    return {\n      userPoolId: new CfnOutput(this, 'UserPoolId', { value: this.userPoolId }).makeImportValue().toString(),\n      userPoolArn: new CfnOutput(this, 'UserPoolArn', { value: this.userPoolArn }).makeImportValue().toString(),\n      userPoolProviderName: new CfnOutput(this, 'UserPoolProviderName', { value: this.userPoolProviderName }).makeImportValue().toString(),\n      userPoolProviderUrl: new CfnOutput(this, 'UserPoolProviderUrl', { value: this.userPoolProviderUrl }).makeImportValue().toString()\n    };\n  }\n\n  private addLambdaPermission(fn: lambda.IFunction, name: string): void {\n    const normalize = name.charAt(0).toUpperCase() + name.slice(1);\n    fn.addPermission(`${normalize}Cognito`, {\n      principal: new iam.ServicePrincipal('cognito-idp.amazonaws.com'),\n      sourceArn: this.userPoolArn\n    });\n  }\n}\n\n/**\n * Define a user pool which has been declared in another stack\n */\nclass ImportedUserPool extends Construct implements IUserPool {\n  /**\n   * The ID of an existing user pool\n   */\n  public readonly userPoolId: string;\n\n  /**\n   * The ARN of the imported user pool\n   */\n  public readonly userPoolArn: string;\n\n  /**\n   * The provider name of the imported user pool\n   */\n  public readonly userPoolProviderName: string;\n\n  /**\n   * The URL of the imported user pool\n   */\n  public readonly userPoolProviderUrl: string;\n\n  constructor(scope: Construct, id: string, private readonly props: UserPoolImportProps) {\n    super(scope, id);\n\n    this.userPoolId = props.userPoolId;\n    this.userPoolArn = props.userPoolArn;\n    this.userPoolProviderName = props.userPoolProviderName;\n    this.userPoolProviderUrl = props.userPoolProviderUrl;\n  }\n\n  public export(): UserPoolImportProps {\n    return this.props;\n  }\n}\n"]}
{
"name": "@aws-cdk/aws-cognito",
"version": "0.28.0",
"version": "0.29.0",
"description": "The CDK Construct Library for AWS::Cognito",

@@ -32,3 +32,4 @@ "main": "lib/index.js",

"type": "git",
"url": "https://github.com/awslabs/aws-cdk.git"
"url": "https://github.com/awslabs/aws-cdk.git",
"directory": "packages/@aws-cdk/aws-cognito"
},

@@ -62,16 +63,17 @@ "scripts": {

"devDependencies": {
"@aws-cdk/assert": "^0.28.0",
"cdk-build-tools": "^0.28.0",
"cfn2ts": "^0.28.0",
"pkglint": "^0.28.0"
"@aws-cdk/assert": "^0.29.0",
"cdk-build-tools": "^0.29.0",
"cfn2ts": "^0.29.0",
"pkglint": "^0.29.0"
},
"dependencies": {
"@aws-cdk/aws-iam": "^0.28.0",
"@aws-cdk/aws-lambda": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0"
"@aws-cdk/aws-iam": "^0.29.0",
"@aws-cdk/aws-lambda": "^0.29.0",
"@aws-cdk/cdk": "^0.29.0"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-lambda": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0"
"@aws-cdk/aws-iam": "^0.29.0",
"@aws-cdk/aws-lambda": "^0.29.0",
"@aws-cdk/cdk": "^0.29.0"
},

@@ -81,2 +83,2 @@ "engines": {

}
}
}

Sorry, the diff of this file is not supported yet

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