Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(cognito): implement user pool and user pool client constructs #1615

Merged
merged 8 commits into from
Feb 5, 2019
3 changes: 3 additions & 0 deletions packages/@aws-cdk/aws-cognito/lib/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1,5 @@
// AWS::Cognito CloudFormation Resources:
export * from './cognito.generated';

export * from './user-pool';
export * from './user-pool-client';
67 changes: 67 additions & 0 deletions packages/@aws-cdk/aws-cognito/lib/user-pool-client.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
import cdk = require('@aws-cdk/cdk');
import { CfnUserPoolClient } from './cognito.generated';
import { IUserPool } from './user-pool';

/**
* Types of authentication flow
*/
export enum AuthFlow {
dotxlem marked this conversation as resolved.
Show resolved Hide resolved
/**
* Enable flow for server-side or admin authentication (no client app)
*/
AdminNoSrp = 'ADMIN_NO_SRP_AUTH',

/**
* Enable custom authentication flow
*/
CustomFlowOnly = 'CUSTOM_AUTH_FLOW_ONLY',

/**
* Enable auth using username & password
*/
UserPassword = 'USER_PASSWORD_AUTH'
}

export interface UserPoolClientProps {
/**
* Name of the application client
* @default cloudformation generated name
*/
clientName?: string;

/**
* The UserPool resource this client will have access to
*/
userPool: IUserPool;

/**
* Whether to generate a client secret
* @default false
*/
generateSecret?: boolean;

/**
* List of enabled authentication flows
* @default no enabled flows
*/
enabledAuthFlows?: AuthFlow[]
}

/**
* Define a UserPool App Client
*/
export class UserPoolClient extends cdk.Construct {
public readonly clientId: string;

constructor(scope: cdk.Construct, id: string, props: UserPoolClientProps) {
super(scope, id);

const userPoolClient = new CfnUserPoolClient(this, 'Resource', {
clientName: props.clientName,
generateSecret: props.generateSecret,
userPoolId: props.userPool.userPoolId,
explicitAuthFlows: props.enabledAuthFlows
});
this.clientId = userPoolClient.userPoolClientId;
}
}
Loading