-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcognito-template.yaml
164 lines (159 loc) · 15.1 KB
/
cognito-template.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
AWSTemplateFormatVersion: 2010-09-09
Description: Template to provision user pool
Parameters:
Environment:
Type: String
Description: The environment of the resources
DeployRegion:
Type: String
Description: The region in which this stack is deployed
Default: ap-southeast-2
CustomUIDomain:
Type: String
Description: Domain to host the custom UI
TheBirdAppRedirectURI:
Type: CommaDelimitedList
Description: Redirect URIs for your app
CustomUICss:
Type: String
Description: CSS for the CustomUI
DomainLambdaFunctionName:
Type: String
Description: Lambda Function to Create Domain
CustomMessageLambdaFunctionName:
Type: String
Description: Lambda Function to Generate Custom Message
ClientLambdaFunctionName:
Type: String
Description: Lambda Function to Generate Cognito Client
CustomUILambdaFunctionName:
Type: String
Description: Lambda Function to Set Custom UI
Resources:
InvokeLambdaPermission:
Type: 'AWS::Lambda::Permission'
Properties:
FunctionName:
!Join [
":",
[
"arn:aws:lambda",
!Ref DeployRegion,
!Ref "AWS::AccountId",
"function",
!Ref CustomMessageLambdaFunctionName,
],
]
Action: 'lambda:InvokeFunction'
Principal: cognito-idp.amazonaws.com
theBirdAppUserPool:
Type: "AWS::Cognito::UserPool"
Properties:
UsernameAttributes:
- email
AutoVerifiedAttributes:
- email
UserPoolName: !Join [ '-', [theBirdAppUserPool,!Ref Environment] ]
Schema:
- AttributeDataType: String
DeveloperOnlyAttribute: false
Mutable: true
Name: email
Required: true
- AttributeDataType: String
DeveloperOnlyAttribute: false
Mutable: true
Name: source
Required: false
StringAttributeConstraints:
MaxLength: 20
MinLength: 5
LambdaConfig:
CustomMessage:
!Join [
":",
[
"arn:aws:lambda",
!Ref DeployRegion,
!Ref "AWS::AccountId",
"function",
!Ref CustomMessageLambdaFunctionName,
],
]
Policies:
PasswordPolicy:
MinimumLength: 10
RequireLowercase: true
RequireNumbers: true
RequireSymbols: true
RequireUppercase: true
UserPoolTags:
Environment: !Ref Environment
theBirdAppClient:
Type: Custom::CognitoClient
Properties:
ServiceToken:
!Join [
":",
[
"arn:aws:lambda",
!Ref DeployRegion,
!Ref "AWS::AccountId",
"function",
!Ref ClientLambdaFunctionName,
],
]
UserPoolClient:
ClientName: theBirdApp
CallbackURLs: !Ref TheBirdAppRedirectURI
AllowedOAuthFlowsUserPoolClient: true
AllowedOAuthFlows:
- code
- implicit
AllowedOAuthScopes:
- email
- openid
- profile
SupportedIdentityProviders:
- COGNITO
UserPoolId: !Ref theBirdAppUserPool
CustomDomain:
Type: Custom::CognitoDomain
DependsOn:
- theBirdAppUserPool
Properties:
ServiceToken:
!Join [
":",
[
"arn:aws:lambda",
!Ref DeployRegion,
!Ref "AWS::AccountId",
"function",
!Ref DomainLambdaFunctionName,
],
]
UserPoolDomain:
Domain: !Ref CustomUIDomain
UserPoolId: !Ref theBirdAppUserPool
CustomUI:
Type: Custom::CognitoCustomUI
DependsOn:
- theBirdAppUserPool
- CustomDomain
Properties:
ServiceToken:
!Join [
":",
[
"arn:aws:lambda",
!Ref DeployRegion,
!Ref "AWS::AccountId",
"function",
!Ref CustomUILambdaFunctionName,
],
]
CustomUISettings:
CSS: !Ref CustomUICss
UserPoolId: !Ref theBirdAppUserPool
ImageFile: 