forked from aws-samples/aws-refarch-drupal
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaws-refarch-drupal-master.yaml
476 lines (463 loc) · 16.9 KB
/
aws-refarch-drupal-master.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
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
---
AWSTemplateFormatVersion: 2010-09-09
Description: Stack to deploy a highly available, elastic, scalable Drupal environment. This master stack launches multiple nested stacks for different tiers. !! This can only be run in certain AWS Regions - 'us-east-1', 'us-east-2', 'us-west-2', 'eu-west-1'.
Metadata:
AWS::CloudFormation::Interface:
ParameterGroups:
- Label:
default: AWS Parameters
Parameters:
- KeyName
- SshAccessCidr
- Label:
default: Database Parameters
Parameters:
- DatabaseInstanceType
- DatabaseMasterUsername
- DatabaseMasterPassword
- DatabaseName
- UseElastiCacheBoolean
- ElastiCacheNodeType
- Label:
default: Web Tier Parameters
Parameters:
- UseRoute53Boolean
- UseCloudFrontBoolean
- CloudFrontAcmCertificate
- PublicAlbAcmCertificate
- WebInstanceType
- WebAsgMax
- WebAsgMin
- Label:
default: Drupal Parameters
Parameters:
- Title
- AdminUsername
- AdminPassword
- AdminEmail
- Directory
- DomainName
- Locale
ParameterLabels:
CloudFrontAcmCertificate:
default: CloudFront Certificate ARN
DatabaseInstanceType:
default: DB Instance Class
DatabaseMasterUsername:
default: DB Master Username
DatabaseMasterPassword:
default: DB Master Password
DatabaseName:
default: DB Name
ElastiCacheNodeType:
default: Cache Cluster Node Type
PublicAlbAcmCertificate:
default: ALB Certificate ARN
KeyName:
default: Existing Key Pair
SshAccessCidr:
default: SSH Access From
UseElastiCacheBoolean:
default: Use a Cache Cluster?
UseCloudFrontBoolean:
default: Use a CDN (CloudFront)?
UseRoute53Boolean:
default: Create record set (Route53)?
WebAsgMax:
default: Web ASG Max
WebAsgMin:
default: Web ASG Min
WebInstanceType:
default: Web Tier Instance Type
Title:
default: Site Title
AdminUsername:
default: Admin Username
AdminPassword:
default: Admin Password
AdminEmail:
default: Admin Email
Directory:
default: Site Directory
DomainName:
default: Site Domain
Locale:
default: Language Code
Parameters:
CloudFrontAcmCertificate:
AllowedPattern: ^$|(arn:aws:acm:)([a-z0-9/:-])*([a-z0-9])$
Description: '[ Optional ] The AWS Certification Manager certificate ARN for the CloudFront distribution certificate - this certificate should be created in the us-east-1 (N. Virginia) region and must reference the Drupal domain name you use below.'
Type: String
DatabaseInstanceType:
AllowedValues:
- db.t2.small
- db.t2.medium
- db.r3.large
- db.r3.xlarge
- db.r3.2xlarge
- db.r3.4xlarge
- db.r3.8xlarge
ConstraintDescription: Must be a valid RDS instance class.
Default: db.t2.medium
Description: The Amazon RDS database instance class.
Type: String
DatabaseMasterUsername:
AllowedPattern: ^([a-zA-Z0-9]*)$
Description: The Amazon RDS master username.
ConstraintDescription: Must contain only alphanumeric characters and be at least 8 characters.
MaxLength: 16
MinLength: 1
Type: String
DatabaseMasterPassword:
AllowedPattern: ^([a-zA-Z0-9`~!#$%^&*()_+,\\-])*$
ConstraintDescription: Must be letters (upper or lower), numbers, spaces, and these special characters `~!#$%^&*()_+,-
Description: The Amazon RDS master password. Letters, numbers, spaces, and these special characters `~!#$%^&*()_+,-
MaxLength: 41
MinLength: 8
NoEcho: true
Type: String
DatabaseName:
AllowedPattern: ^([a-zA-Z0-9]*)$
Description: The Amazon RDS master database name.
Type: String
ElastiCacheNodeType:
AllowedValues:
- cache.t2.micro
- cache.t2.small
- cache.t2.medium
- cache.m4.large
- cache.m4.xlarge
- cache.m4.2xlarge
- cache.m4.4xlarge
- cache.m4.10xlarge
- cache.m3.medium
- cache.m3.large
- cache.m3.xlarge
- cache.m3.2xlarge
- cache.r3.large
- cache.r3.xlarge
- cache.r3.2xlarge
- cache.r3.4xlarge
- cache.r3.8xlarge
ConstraintDescription: Must be a valid Amazon ElastiCache node type.
Default: cache.t2.medium
Description: The Amazon ElastiCache cluster node type.
Type: String
KeyName:
AllowedPattern: ^([a-zA-Z0-9 @.`~!#$%^&*()_+,\\-])*$
ConstraintDescription: Must be letters (upper or lower), numbers, and special characters.
Description: Name of an EC2 KeyPair. Your bastion & Web instances will launch with this KeyPair.
Type: AWS::EC2::KeyPair::KeyName
PublicAlbAcmCertificate:
AllowedPattern: ^$|(arn:aws:acm:)([a-z0-9/:-])*([a-z0-9])$
Description: '[ Optional ] The AWS Certification Manager certificate ARN for the ALB certificate - this certificate should be created in the region you wish to run the ALB and must reference the Drupal domain name you use below.'
Type: String
SshAccessCidr:
AllowedPattern: ^(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])(\/([0-9]|[1-2][0-9]|3[0-2]))$
Description: The CIDR IP range that is permitted to SSH to bastion instance. Note - a value of 0.0.0.0/0 will allow access from ANY IP address.
Type: String
Default: 0.0.0.0/0
UseCloudFrontBoolean:
AllowedValues:
- True
- False
Default: True
Description: Specifies whether a CloudFront Distribution should be created to serve the Drupal website content.
Type: String
UseElastiCacheBoolean:
AllowedValues:
- True
- False
Default: True
Description: Specifies whether an ElastiCache Cache Cluster should be created to cache Drupal database content.
Type: String
UseRoute53Boolean:
AllowedValues:
- True
- False
Default: True
Description: Specifies whether a record set should be created in Route 53 for your Drupal domain name.
Type: String
WebAsgMax:
AllowedPattern: ^((?!0$)[1-2]?[0-9]|30)$
ConstraintDescription: Must be a number between 1 and 30.
Default: 4
Description: Specifies the maximum number of EC2 instances in the Web Autoscaling Group.
Type: String
WebAsgMin:
AllowedPattern: ^([0-0]?[0-9]|10)$
ConstraintDescription: Must be a number between 0 and 10.
Default: 2
Description: Specifies the minimum number of EC2 instances in the Web Autoscaling Group.
Type: String
WebInstanceType:
AllowedValues:
- t2.micro
- t2.small
- t2.medium
- t2.large
- m4.large
- m4.xlarge
- m4.2xlarge
- m4.4xlarge
- m4.10xlarge
- m3.medium
- m3.large
- m3.xlarge
- m3.2xlarge
- r3.large
- r3.xlarge
- r3.2xlarge
- r3.4xlarge
- r3.8xlarge
ConstraintDescription: Must be a valid Amazon EC2 instance type.
Default: t2.large
Description: The Amazon EC2 instance type for your web instances.
Type: String
AdminEmail:
AllowedPattern: ^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$
Description: The Drupal admin email address.
Type: String
AdminPassword:
AllowedPattern: ^([a-zA-Z0-9`~!#$%^&*()_+,\\-])*$
ConstraintDescription: Must be letters (upper or lower), numbers, spaces, and these special characters `~!#$%^&*()_+,-
Description: The Drupal admin password. Letters, numbers, spaces, and these special characters `~!#$%^&*()_+,-
Type: String
NoEcho: true
AdminUsername:
AllowedPattern: ^([a-zA-Z0-9])([a-zA-Z0-9_-])*([a-zA-Z0-9])$
Description: The Drupal admin username.
Type: String
Directory:
AllowedPattern: ^([a-zA-Z0-9])([a-zA-Z0-9_-])*([a-zA-Z0-9])$
Description: The Drupal site directory.
Type: String
DomainName:
AllowedPattern: ^$|(([a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9\-]*[a-zA-Z0-9])\.)*([A-Za-z0-9]|[A-Za-z0-9][A-Za-z0-9\-]*[A-Za-z0-9])$
Description: '[ Optional ] The main domain name of the Drupal site (e.g. example.com).'
Type: String
Locale:
Description: "The main language of the Drupal site, as per https://codex.Drupal.org/Installing_Drupal_in_Your_Language. The default is 'en_GB'."
Type: String
Default: en_GB
Title:
Default: This is a new Drupal site on Amazon Web Services
AllowedPattern: ^([a-zA-Z0-9])([a-zA-Z0-9 _-]*)([a-zA-Z0-9])$
Description: The Drupal website title.
Type: String
Conditions:
AvailableAWSRegion:
!Or [
!Equals [ !Ref 'AWS::Region', ap-southeast-2 ],
!Equals [ !Ref 'AWS::Region', eu-west-1 ],
!Equals [ !Ref 'AWS::Region', us-east-1 ],
!Equals [ !Ref 'AWS::Region', us-east-2 ],
!Equals [ !Ref 'AWS::Region', us-west-2 ]
]
CreateRecordSet:
!Equals [ True, !Ref UseRoute53Boolean ]
DeployCloudFront:
!Equals [ True, !Ref UseCloudFrontBoolean ]
DeployElastiCache:
!Equals [ True, !Ref UseElastiCacheBoolean ]
Resources:
bastion:
Condition: AvailableAWSRegion
DependsOn: [ newvpc, securitygroups ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
BastionSecurityGroup:
!GetAtt [ securitygroups, Outputs.BastionSecurityGroup ]
KeyName:
!Ref KeyName
PublicSubnet0:
!GetAtt [ newvpc, Outputs.PublicSubnet0 ]
PublicSubnet1:
!GetAtt [ newvpc, Outputs.PublicSubnet1 ]
PublicSubnet2:
!GetAtt [ newvpc, Outputs.PublicSubnet2 ]
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-03-bastion.yaml
cloudfront:
Condition: AvailableAWSRegion
Condition: DeployCloudFront
DependsOn: [ publicalb, web ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
CloudFrontAcmCertificate:
!Ref CloudFrontAcmCertificate
PublicAlbDnsName:
!GetAtt [ publicalb, Outputs.PublicAlbDnsName ]
DomainName:
!Ref DomainName
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-04-cloudfront.yaml
efs:
Condition: AvailableAWSRegion
DependsOn: [ newvpc, securitygroups ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
EfsSecurityGroup:
!GetAtt [ securitygroups, Outputs.EfsSecurityGroup ]
DataSubnet0:
!GetAtt [ newvpc, Outputs.DataSubnet0 ]
DataSubnet1:
!GetAtt [ newvpc, Outputs.DataSubnet1 ]
DataSubnet2:
!GetAtt [ newvpc, Outputs.DataSubnet2 ]
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-03-efs.yaml
elasticache:
Condition: AvailableAWSRegion
Condition: DeployElastiCache
DependsOn: [ newvpc, securitygroups ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
DataSubnet0:
!GetAtt [ newvpc, Outputs.DataSubnet0 ]
DataSubnet1:
!GetAtt [ newvpc, Outputs.DataSubnet1 ]
DataSubnet2:
!GetAtt [ newvpc, Outputs.DataSubnet2 ]
ElastiCacheClusterName:
!Ref DatabaseName
ElastiCacheNodeType:
!Ref ElastiCacheNodeType
ElastiCacheSecurityGroup:
!GetAtt [ securitygroups, Outputs.ElastiCacheSecurityGroup ]
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-03-elasticache.yaml
newvpc:
Type: AWS::CloudFormation::Stack
Properties:
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-01-newvpc.yaml
publicalb:
Condition: AvailableAWSRegion
DependsOn: [ newvpc, securitygroups ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
PublicSubnet0:
!GetAtt [ newvpc, Outputs.PublicSubnet0 ]
PublicSubnet1:
!GetAtt [ newvpc, Outputs.PublicSubnet1 ]
PublicSubnet2:
!GetAtt [ newvpc, Outputs.PublicSubnet2 ]
PublicAlbAcmCertificate:
!Ref PublicAlbAcmCertificate
PublicAlbSecurityGroup:
!GetAtt [ securitygroups, Outputs.PublicAlbSecurityGroup ]
Vpc:
!GetAtt [ newvpc, Outputs.Vpc ]
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-03-publicalb.yaml
rds:
Condition: AvailableAWSRegion
DependsOn: [ newvpc, securitygroups ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
DatabaseInstanceType:
!Ref DatabaseInstanceType
DatabaseMasterUsername:
!Ref DatabaseMasterUsername
DatabaseMasterPassword:
!Ref DatabaseMasterPassword
DatabaseName:
!Ref DatabaseName
DatabaseSecurityGroup:
!GetAtt [ securitygroups, Outputs.DatabaseSecurityGroup ]
DataSubnet0:
!GetAtt [ newvpc, Outputs.DataSubnet0 ]
DataSubnet1:
!GetAtt [ newvpc, Outputs.DataSubnet1 ]
DataSubnet2:
!GetAtt [ newvpc, Outputs.DataSubnet2 ]
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-03-rds.yaml
route53:
Condition: AvailableAWSRegion
Condition: CreateRecordSet
DependsOn: [ publicalb, web ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
DnsEndpoint:
!If [ DeployCloudFront, !GetAtt [ cloudfront, Outputs.DnsEndpoint ], !GetAtt [ publicalb, Outputs.PublicAlbDnsName ] ]
DnsHostId:
!If [ DeployCloudFront, 'Z2FDTNDATAQYW2', !GetAtt [ publicalb, Outputs.PublicAlbCanonicalHostedZoneId ] ]
DomainName:
!Ref DomainName
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-05-route53.yaml
securitygroups:
Condition: AvailableAWSRegion
DependsOn: newvpc
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
SshAccessCidr:
!Ref SshAccessCidr
Vpc:
!GetAtt [ newvpc, Outputs.Vpc ]
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-02-securitygroups.yaml
web:
Condition: AvailableAWSRegion
DependsOn: [ efs, newvpc, publicalb, securitygroups ]
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
DatabaseClusterEndpointAddress:
!GetAtt [ rds, Outputs.DatabaseClusterEndpointAddress ]
DatabaseMasterUsername:
!Ref DatabaseMasterUsername
DatabaseMasterPassword:
!Ref DatabaseMasterPassword
DatabaseName:
!Ref DatabaseName
ElasticFileSystem:
!GetAtt [ efs, Outputs.ElasticFileSystem ]
KeyName:
!Ref KeyName
PublicAlbTargetGroupArn:
!GetAtt [ publicalb, Outputs.PublicAlbTargetGroupArn ]
PublicAlbHostname:
!GetAtt [ publicalb, Outputs.PublicAlbHostname ]
SslCertificate:
!GetAtt [ publicalb, Outputs.SslCertificate ]
WebAsgMax:
!Ref WebAsgMax
WebAsgMin:
!Ref WebAsgMin
WebInstanceType:
!Ref WebInstanceType
WebSecurityGroup:
!GetAtt [ securitygroups, Outputs.WebSecurityGroup ]
WebSubnet0:
!GetAtt [ newvpc, Outputs.WebSubnet0 ]
WebSubnet1:
!GetAtt [ newvpc, Outputs.WebSubnet1 ]
WebSubnet2:
!GetAtt [ newvpc, Outputs.WebSubnet2 ]
AdminEmail:
!Ref AdminEmail
AdminPassword:
!Ref AdminPassword
AdminUsername:
!Ref AdminUsername
Directory:
!Ref Directory
DomainName:
!Ref DomainName
Locale:
!Ref Locale
Title:
!Ref Title
TemplateURL: https://s3.amazonaws.com/aws-refarch/drupal/latest/templates/aws-refarch-drupal-04-web.yaml
Outputs:
StackStatus:
Description: Master Stack Status
Value: !If [ AvailableAWSRegion, !Join [ '', [ 'Stack created in an available region: ', !Ref 'AWS::Region' ] ], "!!ERROR!!! - Nothing to do! - unavailable AWS Region. You must create this stack in an available AWS Region: 'us-east-1', 'us-east-2', 'us-west-2', 'eu-west-1', 'ap-southeast-2'." ]
SiteUrl:
Description: The URL of the Drupal site
Value: !Join [ '', [ !If [ CreateRecordSet, !Join [ '', [ 'http://www.', !Ref DomainName ] ], !If [ DeployCloudFront, !GetAtt [ cloudfront, Outputs.DnsHostname ], !GetAtt [ publicalb, Outputs.PublicAlbHostname ] ] ], '/drupal' ] ]
OpCacheValidationUrl:
Description: A page to validate OpCache has been enabled for each instance in the ASG. Refresh the page to see the status of each instance in the ASG.
Value: !Join [ '', [ !If [ CreateRecordSet, !Join [ '', [ 'http://www.', !Ref DomainName ] ], !If [ DeployCloudFront, !GetAtt [ cloudfront, Outputs.DnsHostname ], !GetAtt [ publicalb, Outputs.PublicAlbHostname ] ] ], '/opcache-instanceid.php' ] ]