@orcabus/platform-cdk-constructs 0.0.104 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +286 -31
- package/api-gateway/api-gateway.js +1 -1
- package/api-gateway/config.js +8 -4
- package/deployment-stack-pipeline/artifact-bucket.js +1 -1
- package/deployment-stack-pipeline/pipeline.d.ts +80 -1
- package/deployment-stack-pipeline/pipeline.js +149 -18
- package/dynamodb/index.js +2 -2
- package/ecs/index.js +1 -1
- package/eventbridge-rules/sfn-slack-notification.js +1 -1
- package/lambda/index.js +1 -1
- package/monitored-queue/index.js +1 -1
- package/named-lambda-role/index.js +1 -1
- package/package.json +1 -1
- package/provider-function/index.js +1 -1
- package/shared-config/networking.js +2 -2
- package/shared-config/slack.js +1 -1
package/.jsii
CHANGED
|
@@ -4604,6 +4604,67 @@
|
|
|
4604
4604
|
],
|
|
4605
4605
|
"symbolId": "api-gateway/api-gateway:OrcaBusApiGatewayProps"
|
|
4606
4606
|
},
|
|
4607
|
+
"@orcabus/platform-cdk-constructs.deploymentPipeline.CodeBuildStepProps": {
|
|
4608
|
+
"assembly": "@orcabus/platform-cdk-constructs",
|
|
4609
|
+
"datatype": true,
|
|
4610
|
+
"docs": {
|
|
4611
|
+
"stability": "experimental"
|
|
4612
|
+
},
|
|
4613
|
+
"fqn": "@orcabus/platform-cdk-constructs.deploymentPipeline.CodeBuildStepProps",
|
|
4614
|
+
"kind": "interface",
|
|
4615
|
+
"locationInModule": {
|
|
4616
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4617
|
+
"line": 106
|
|
4618
|
+
},
|
|
4619
|
+
"name": "CodeBuildStepProps",
|
|
4620
|
+
"namespace": "deploymentPipeline",
|
|
4621
|
+
"properties": [
|
|
4622
|
+
{
|
|
4623
|
+
"abstract": true,
|
|
4624
|
+
"docs": {
|
|
4625
|
+
"stability": "experimental",
|
|
4626
|
+
"summary": "the main command for the build step to run."
|
|
4627
|
+
},
|
|
4628
|
+
"immutable": true,
|
|
4629
|
+
"locationInModule": {
|
|
4630
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4631
|
+
"line": 110
|
|
4632
|
+
},
|
|
4633
|
+
"name": "command",
|
|
4634
|
+
"type": {
|
|
4635
|
+
"collection": {
|
|
4636
|
+
"elementtype": {
|
|
4637
|
+
"primitive": "string"
|
|
4638
|
+
},
|
|
4639
|
+
"kind": "array"
|
|
4640
|
+
}
|
|
4641
|
+
}
|
|
4642
|
+
},
|
|
4643
|
+
{
|
|
4644
|
+
"abstract": true,
|
|
4645
|
+
"docs": {
|
|
4646
|
+
"stability": "experimental",
|
|
4647
|
+
"summary": "Partial buildspec for this CodeBuildStep."
|
|
4648
|
+
},
|
|
4649
|
+
"immutable": true,
|
|
4650
|
+
"locationInModule": {
|
|
4651
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4652
|
+
"line": 114
|
|
4653
|
+
},
|
|
4654
|
+
"name": "partialBuildSpec",
|
|
4655
|
+
"optional": true,
|
|
4656
|
+
"type": {
|
|
4657
|
+
"collection": {
|
|
4658
|
+
"elementtype": {
|
|
4659
|
+
"primitive": "any"
|
|
4660
|
+
},
|
|
4661
|
+
"kind": "map"
|
|
4662
|
+
}
|
|
4663
|
+
}
|
|
4664
|
+
}
|
|
4665
|
+
],
|
|
4666
|
+
"symbolId": "deployment-stack-pipeline/pipeline:CodeBuildStepProps"
|
|
4667
|
+
},
|
|
4607
4668
|
"@orcabus/platform-cdk-constructs.deploymentPipeline.CrossDeploymentArtifactBucket": {
|
|
4608
4669
|
"assembly": "@orcabus/platform-cdk-constructs",
|
|
4609
4670
|
"base": "constructs.Construct",
|
|
@@ -4726,7 +4787,7 @@
|
|
|
4726
4787
|
},
|
|
4727
4788
|
"locationInModule": {
|
|
4728
4789
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4729
|
-
"line":
|
|
4790
|
+
"line": 244
|
|
4730
4791
|
},
|
|
4731
4792
|
"parameters": [
|
|
4732
4793
|
{
|
|
@@ -4752,7 +4813,7 @@
|
|
|
4752
4813
|
"kind": "class",
|
|
4753
4814
|
"locationInModule": {
|
|
4754
4815
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4755
|
-
"line":
|
|
4816
|
+
"line": 238
|
|
4756
4817
|
},
|
|
4757
4818
|
"name": "DeploymentStackPipeline",
|
|
4758
4819
|
"namespace": "deploymentPipeline",
|
|
@@ -4765,7 +4826,7 @@
|
|
|
4765
4826
|
"immutable": true,
|
|
4766
4827
|
"locationInModule": {
|
|
4767
4828
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4768
|
-
"line":
|
|
4829
|
+
"line": 242
|
|
4769
4830
|
},
|
|
4770
4831
|
"name": "pipeline",
|
|
4771
4832
|
"type": {
|
|
@@ -4785,7 +4846,7 @@
|
|
|
4785
4846
|
"kind": "interface",
|
|
4786
4847
|
"locationInModule": {
|
|
4787
4848
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4788
|
-
"line":
|
|
4849
|
+
"line": 117
|
|
4789
4850
|
},
|
|
4790
4851
|
"name": "DeploymentStackPipelineProps",
|
|
4791
4852
|
"namespace": "deploymentPipeline",
|
|
@@ -4793,14 +4854,14 @@
|
|
|
4793
4854
|
{
|
|
4794
4855
|
"abstract": true,
|
|
4795
4856
|
"docs": {
|
|
4796
|
-
"remarks": "e.g. [\"
|
|
4857
|
+
"remarks": "e.g. [\"pnpm install --frozen-lockfile\", \"pnpm cdk synth\"]",
|
|
4797
4858
|
"stability": "experimental",
|
|
4798
4859
|
"summary": "The command to run to synth the cdk stack which also installing the cdk dependencies."
|
|
4799
4860
|
},
|
|
4800
4861
|
"immutable": true,
|
|
4801
4862
|
"locationInModule": {
|
|
4802
4863
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4803
|
-
"line":
|
|
4864
|
+
"line": 163
|
|
4804
4865
|
},
|
|
4805
4866
|
"name": "cdkSynthCmd",
|
|
4806
4867
|
"type": {
|
|
@@ -4825,7 +4886,7 @@
|
|
|
4825
4886
|
"immutable": true,
|
|
4826
4887
|
"locationInModule": {
|
|
4827
4888
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4828
|
-
"line":
|
|
4889
|
+
"line": 124
|
|
4829
4890
|
},
|
|
4830
4891
|
"name": "githubBranch",
|
|
4831
4892
|
"type": {
|
|
@@ -4842,7 +4903,7 @@
|
|
|
4842
4903
|
"immutable": true,
|
|
4843
4904
|
"locationInModule": {
|
|
4844
4905
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4845
|
-
"line":
|
|
4906
|
+
"line": 128
|
|
4846
4907
|
},
|
|
4847
4908
|
"name": "githubRepo",
|
|
4848
4909
|
"type": {
|
|
@@ -4858,7 +4919,7 @@
|
|
|
4858
4919
|
"immutable": true,
|
|
4859
4920
|
"locationInModule": {
|
|
4860
4921
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4861
|
-
"line":
|
|
4922
|
+
"line": 145
|
|
4862
4923
|
},
|
|
4863
4924
|
"name": "pipelineName",
|
|
4864
4925
|
"type": {
|
|
@@ -4874,7 +4935,7 @@
|
|
|
4874
4935
|
"immutable": true,
|
|
4875
4936
|
"locationInModule": {
|
|
4876
4937
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4877
|
-
"line":
|
|
4938
|
+
"line": 132
|
|
4878
4939
|
},
|
|
4879
4940
|
"name": "stack",
|
|
4880
4941
|
"type": {
|
|
@@ -4890,7 +4951,7 @@
|
|
|
4890
4951
|
"immutable": true,
|
|
4891
4952
|
"locationInModule": {
|
|
4892
4953
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4893
|
-
"line":
|
|
4954
|
+
"line": 141
|
|
4894
4955
|
},
|
|
4895
4956
|
"name": "stackConfig",
|
|
4896
4957
|
"type": {
|
|
@@ -4907,13 +4968,30 @@
|
|
|
4907
4968
|
"immutable": true,
|
|
4908
4969
|
"locationInModule": {
|
|
4909
4970
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4910
|
-
"line":
|
|
4971
|
+
"line": 137
|
|
4911
4972
|
},
|
|
4912
4973
|
"name": "stackName",
|
|
4913
4974
|
"type": {
|
|
4914
4975
|
"primitive": "string"
|
|
4915
4976
|
}
|
|
4916
4977
|
},
|
|
4978
|
+
{
|
|
4979
|
+
"abstract": true,
|
|
4980
|
+
"docs": {
|
|
4981
|
+
"remarks": "This step will execute in parallel with {@link unitIacTestConfig} as part of the synth stage dependencies.\nBoth must succeed before the synth step runs.\n\nensure your command includes 'cd' to the main app directory, as the build context starts from the root.",
|
|
4982
|
+
"stability": "experimental",
|
|
4983
|
+
"summary": "Configuration for the CodeBuild step that runs unit tests for the main application code."
|
|
4984
|
+
},
|
|
4985
|
+
"immutable": true,
|
|
4986
|
+
"locationInModule": {
|
|
4987
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4988
|
+
"line": 183
|
|
4989
|
+
},
|
|
4990
|
+
"name": "unitAppTestConfig",
|
|
4991
|
+
"type": {
|
|
4992
|
+
"fqn": "@orcabus/platform-cdk-constructs.deploymentPipeline.CodeBuildStepProps"
|
|
4993
|
+
}
|
|
4994
|
+
},
|
|
4917
4995
|
{
|
|
4918
4996
|
"abstract": true,
|
|
4919
4997
|
"docs": {
|
|
@@ -4924,7 +5002,7 @@
|
|
|
4924
5002
|
"immutable": true,
|
|
4925
5003
|
"locationInModule": {
|
|
4926
5004
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4927
|
-
"line":
|
|
5005
|
+
"line": 169
|
|
4928
5006
|
},
|
|
4929
5007
|
"name": "cdkOut",
|
|
4930
5008
|
"optional": true,
|
|
@@ -4932,6 +5010,24 @@
|
|
|
4932
5010
|
"primitive": "string"
|
|
4933
5011
|
}
|
|
4934
5012
|
},
|
|
5013
|
+
{
|
|
5014
|
+
"abstract": true,
|
|
5015
|
+
"docs": {
|
|
5016
|
+
"remarks": "If specified, the pipeline will check for CloudFormation drift and fail if detected.",
|
|
5017
|
+
"stability": "experimental",
|
|
5018
|
+
"summary": "Configuration for drift detection checks before deployment."
|
|
5019
|
+
},
|
|
5020
|
+
"immutable": true,
|
|
5021
|
+
"locationInModule": {
|
|
5022
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5023
|
+
"line": 229
|
|
5024
|
+
},
|
|
5025
|
+
"name": "driftCheckConfig",
|
|
5026
|
+
"optional": true,
|
|
5027
|
+
"type": {
|
|
5028
|
+
"fqn": "@orcabus/platform-cdk-constructs.deploymentPipeline.DriftCheckConfig"
|
|
5029
|
+
}
|
|
5030
|
+
},
|
|
4935
5031
|
{
|
|
4936
5032
|
"abstract": true,
|
|
4937
5033
|
"docs": {
|
|
@@ -4942,7 +5038,7 @@
|
|
|
4942
5038
|
"immutable": true,
|
|
4943
5039
|
"locationInModule": {
|
|
4944
5040
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4945
|
-
"line":
|
|
5041
|
+
"line": 200
|
|
4946
5042
|
},
|
|
4947
5043
|
"name": "enableSlackNotification",
|
|
4948
5044
|
"optional": true,
|
|
@@ -4960,7 +5056,7 @@
|
|
|
4960
5056
|
"immutable": true,
|
|
4961
5057
|
"locationInModule": {
|
|
4962
5058
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4963
|
-
"line":
|
|
5059
|
+
"line": 159
|
|
4964
5060
|
},
|
|
4965
5061
|
"name": "excludedFilePaths",
|
|
4966
5062
|
"optional": true,
|
|
@@ -4983,7 +5079,7 @@
|
|
|
4983
5079
|
"immutable": true,
|
|
4984
5080
|
"locationInModule": {
|
|
4985
5081
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
4986
|
-
"line":
|
|
5082
|
+
"line": 152
|
|
4987
5083
|
},
|
|
4988
5084
|
"name": "includedFilePaths",
|
|
4989
5085
|
"optional": true,
|
|
@@ -5007,7 +5103,7 @@
|
|
|
5007
5103
|
"immutable": true,
|
|
5008
5104
|
"locationInModule": {
|
|
5009
5105
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5010
|
-
"line":
|
|
5106
|
+
"line": 208
|
|
5011
5107
|
},
|
|
5012
5108
|
"name": "notificationEvents",
|
|
5013
5109
|
"optional": true,
|
|
@@ -5031,7 +5127,7 @@
|
|
|
5031
5127
|
"immutable": true,
|
|
5032
5128
|
"locationInModule": {
|
|
5033
5129
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5034
|
-
"line":
|
|
5130
|
+
"line": 216
|
|
5035
5131
|
},
|
|
5036
5132
|
"name": "reuseExistingArtifactBucket",
|
|
5037
5133
|
"optional": true,
|
|
@@ -5048,7 +5144,7 @@
|
|
|
5048
5144
|
"immutable": true,
|
|
5049
5145
|
"locationInModule": {
|
|
5050
5146
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5051
|
-
"line":
|
|
5147
|
+
"line": 195
|
|
5052
5148
|
},
|
|
5053
5149
|
"name": "stageEnv",
|
|
5054
5150
|
"optional": true,
|
|
@@ -5067,7 +5163,7 @@
|
|
|
5067
5163
|
"immutable": true,
|
|
5068
5164
|
"locationInModule": {
|
|
5069
5165
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5070
|
-
"line":
|
|
5166
|
+
"line": 224
|
|
5071
5167
|
},
|
|
5072
5168
|
"name": "stripAssemblyAssets",
|
|
5073
5169
|
"optional": true,
|
|
@@ -5086,7 +5182,7 @@
|
|
|
5086
5182
|
"immutable": true,
|
|
5087
5183
|
"locationInModule": {
|
|
5088
5184
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5089
|
-
"line":
|
|
5185
|
+
"line": 175
|
|
5090
5186
|
},
|
|
5091
5187
|
"name": "synthBuildSpec",
|
|
5092
5188
|
"optional": true,
|
|
@@ -5098,10 +5194,169 @@
|
|
|
5098
5194
|
"kind": "map"
|
|
5099
5195
|
}
|
|
5100
5196
|
}
|
|
5197
|
+
},
|
|
5198
|
+
{
|
|
5199
|
+
"abstract": true,
|
|
5200
|
+
"docs": {
|
|
5201
|
+
"remarks": "This step will execute in parallel with {@link unitAppTestConfig} as part of the synth stage dependencies.\nBoth must succeed before the synth step runs.\n\nThe default command will be from the root of the repo: [\"npm install --global corepack@latest\", \"corepack enable\", \"make install\", \"make test\"]",
|
|
5202
|
+
"stability": "experimental",
|
|
5203
|
+
"summary": "Configuration for the CodeBuild step that runs unit tests for Infrastructure-as-Code (IaC) at the repository root."
|
|
5204
|
+
},
|
|
5205
|
+
"immutable": true,
|
|
5206
|
+
"locationInModule": {
|
|
5207
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5208
|
+
"line": 191
|
|
5209
|
+
},
|
|
5210
|
+
"name": "unitIacTestConfig",
|
|
5211
|
+
"optional": true,
|
|
5212
|
+
"type": {
|
|
5213
|
+
"fqn": "@orcabus/platform-cdk-constructs.deploymentPipeline.CodeBuildStepProps"
|
|
5214
|
+
}
|
|
5101
5215
|
}
|
|
5102
5216
|
],
|
|
5103
5217
|
"symbolId": "deployment-stack-pipeline/pipeline:DeploymentStackPipelineProps"
|
|
5104
5218
|
},
|
|
5219
|
+
"@orcabus/platform-cdk-constructs.deploymentPipeline.DriftCheckConfig": {
|
|
5220
|
+
"assembly": "@orcabus/platform-cdk-constructs",
|
|
5221
|
+
"datatype": true,
|
|
5222
|
+
"docs": {
|
|
5223
|
+
"stability": "experimental",
|
|
5224
|
+
"summary": "Configuration for pre-deployment drift detection checks."
|
|
5225
|
+
},
|
|
5226
|
+
"fqn": "@orcabus/platform-cdk-constructs.deploymentPipeline.DriftCheckConfig",
|
|
5227
|
+
"kind": "interface",
|
|
5228
|
+
"locationInModule": {
|
|
5229
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5230
|
+
"line": 89
|
|
5231
|
+
},
|
|
5232
|
+
"name": "DriftCheckConfig",
|
|
5233
|
+
"namespace": "deploymentPipeline",
|
|
5234
|
+
"properties": [
|
|
5235
|
+
{
|
|
5236
|
+
"abstract": true,
|
|
5237
|
+
"docs": {
|
|
5238
|
+
"remarks": "Examples: \"pnpm cdk\", \"pnpm cdk-stateful\", \"pnpm cdk-stateless\".\nMust support: \"drift <stackId>\".",
|
|
5239
|
+
"stability": "experimental",
|
|
5240
|
+
"summary": "CDK CLI entrypoint used to run the drift command."
|
|
5241
|
+
},
|
|
5242
|
+
"immutable": true,
|
|
5243
|
+
"locationInModule": {
|
|
5244
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5245
|
+
"line": 95
|
|
5246
|
+
},
|
|
5247
|
+
"name": "cdkCommand",
|
|
5248
|
+
"type": {
|
|
5249
|
+
"primitive": "string"
|
|
5250
|
+
}
|
|
5251
|
+
},
|
|
5252
|
+
{
|
|
5253
|
+
"abstract": true,
|
|
5254
|
+
"docs": {
|
|
5255
|
+
"remarks": "If your app is in a subdirectory, prefix with \"cd <dir> &&\".\nExample: \"cd dev && pnpm install --frozen-lockfile --ignore-scripts\"\n\nDefault: \"pnpm install --frozen-lockfile --ignore-scripts\"",
|
|
5256
|
+
"stability": "experimental",
|
|
5257
|
+
"summary": "Command to install dependencies before running CDK."
|
|
5258
|
+
},
|
|
5259
|
+
"immutable": true,
|
|
5260
|
+
"locationInModule": {
|
|
5261
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5262
|
+
"line": 103
|
|
5263
|
+
},
|
|
5264
|
+
"name": "installCommand",
|
|
5265
|
+
"optional": true,
|
|
5266
|
+
"type": {
|
|
5267
|
+
"primitive": "string"
|
|
5268
|
+
}
|
|
5269
|
+
}
|
|
5270
|
+
],
|
|
5271
|
+
"symbolId": "deployment-stack-pipeline/pipeline:DriftCheckConfig"
|
|
5272
|
+
},
|
|
5273
|
+
"@orcabus/platform-cdk-constructs.deploymentPipeline.FailOnDriftBuildStepProps": {
|
|
5274
|
+
"assembly": "@orcabus/platform-cdk-constructs",
|
|
5275
|
+
"datatype": true,
|
|
5276
|
+
"docs": {
|
|
5277
|
+
"stability": "experimental"
|
|
5278
|
+
},
|
|
5279
|
+
"fqn": "@orcabus/platform-cdk-constructs.deploymentPipeline.FailOnDriftBuildStepProps",
|
|
5280
|
+
"kind": "interface",
|
|
5281
|
+
"locationInModule": {
|
|
5282
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5283
|
+
"line": 638
|
|
5284
|
+
},
|
|
5285
|
+
"name": "FailOnDriftBuildStepProps",
|
|
5286
|
+
"namespace": "deploymentPipeline",
|
|
5287
|
+
"properties": [
|
|
5288
|
+
{
|
|
5289
|
+
"abstract": true,
|
|
5290
|
+
"docs": {
|
|
5291
|
+
"remarks": "Used to assume the CDK lookup role and set AWS_DEFAULT_REGION.",
|
|
5292
|
+
"stability": "experimental",
|
|
5293
|
+
"summary": "AWS account and region where the drift check runs."
|
|
5294
|
+
},
|
|
5295
|
+
"immutable": true,
|
|
5296
|
+
"locationInModule": {
|
|
5297
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5298
|
+
"line": 643
|
|
5299
|
+
},
|
|
5300
|
+
"name": "accountEnv",
|
|
5301
|
+
"type": {
|
|
5302
|
+
"fqn": "aws-cdk-lib.Environment"
|
|
5303
|
+
}
|
|
5304
|
+
},
|
|
5305
|
+
{
|
|
5306
|
+
"abstract": true,
|
|
5307
|
+
"docs": {
|
|
5308
|
+
"remarks": "Examples: \"pnpm cdk\", \"pnpm cdk-stateful\", \"pnpm cdk-stateless\".\nMust support: \"drift <stackId>\".",
|
|
5309
|
+
"stability": "experimental",
|
|
5310
|
+
"summary": "CDK CLI entrypoint used to run the drift command."
|
|
5311
|
+
},
|
|
5312
|
+
"immutable": true,
|
|
5313
|
+
"locationInModule": {
|
|
5314
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5315
|
+
"line": 657
|
|
5316
|
+
},
|
|
5317
|
+
"name": "cdkCommand",
|
|
5318
|
+
"type": {
|
|
5319
|
+
"primitive": "string"
|
|
5320
|
+
}
|
|
5321
|
+
},
|
|
5322
|
+
{
|
|
5323
|
+
"abstract": true,
|
|
5324
|
+
"docs": {
|
|
5325
|
+
"remarks": "Format: `<rootStack>/<constructId>/<envName>/<stackName>`\n\nExample: `DevStack/DeploymentPipeline/OrcaBusBeta/TestStack`",
|
|
5326
|
+
"stability": "experimental",
|
|
5327
|
+
"summary": "Fully qualified CDK stack ID to check for drift."
|
|
5328
|
+
},
|
|
5329
|
+
"immutable": true,
|
|
5330
|
+
"locationInModule": {
|
|
5331
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5332
|
+
"line": 651
|
|
5333
|
+
},
|
|
5334
|
+
"name": "stackId",
|
|
5335
|
+
"type": {
|
|
5336
|
+
"primitive": "string"
|
|
5337
|
+
}
|
|
5338
|
+
},
|
|
5339
|
+
{
|
|
5340
|
+
"abstract": true,
|
|
5341
|
+
"docs": {
|
|
5342
|
+
"remarks": "If your app is in a subdirectory, prefix with \"cd <dir> &&\".\nExample: \"cd dev && pnpm install --frozen-lockfile --ignore-scripts\"\n\nDefault: \"pnpm install --frozen-lockfile --ignore-scripts\"",
|
|
5343
|
+
"stability": "experimental",
|
|
5344
|
+
"summary": "Command to install dependencies before running CDK."
|
|
5345
|
+
},
|
|
5346
|
+
"immutable": true,
|
|
5347
|
+
"locationInModule": {
|
|
5348
|
+
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5349
|
+
"line": 665
|
|
5350
|
+
},
|
|
5351
|
+
"name": "installCommand",
|
|
5352
|
+
"optional": true,
|
|
5353
|
+
"type": {
|
|
5354
|
+
"primitive": "string"
|
|
5355
|
+
}
|
|
5356
|
+
}
|
|
5357
|
+
],
|
|
5358
|
+
"symbolId": "deployment-stack-pipeline/pipeline:FailOnDriftBuildStepProps"
|
|
5359
|
+
},
|
|
5105
5360
|
"@orcabus/platform-cdk-constructs.deploymentPipeline.ICrossDeploymentArtifactBucket": {
|
|
5106
5361
|
"assembly": "@orcabus/platform-cdk-constructs",
|
|
5107
5362
|
"docs": {
|
|
@@ -5161,7 +5416,7 @@
|
|
|
5161
5416
|
"kind": "interface",
|
|
5162
5417
|
"locationInModule": {
|
|
5163
5418
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5164
|
-
"line":
|
|
5419
|
+
"line": 71
|
|
5165
5420
|
},
|
|
5166
5421
|
"name": "StackConfigProps",
|
|
5167
5422
|
"namespace": "deploymentPipeline",
|
|
@@ -5175,7 +5430,7 @@
|
|
|
5175
5430
|
"immutable": true,
|
|
5176
5431
|
"locationInModule": {
|
|
5177
5432
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5178
|
-
"line":
|
|
5433
|
+
"line": 75
|
|
5179
5434
|
},
|
|
5180
5435
|
"name": "beta",
|
|
5181
5436
|
"type": {
|
|
@@ -5196,7 +5451,7 @@
|
|
|
5196
5451
|
"immutable": true,
|
|
5197
5452
|
"locationInModule": {
|
|
5198
5453
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5199
|
-
"line":
|
|
5454
|
+
"line": 79
|
|
5200
5455
|
},
|
|
5201
5456
|
"name": "gamma",
|
|
5202
5457
|
"type": {
|
|
@@ -5217,7 +5472,7 @@
|
|
|
5217
5472
|
"immutable": true,
|
|
5218
5473
|
"locationInModule": {
|
|
5219
5474
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5220
|
-
"line":
|
|
5475
|
+
"line": 83
|
|
5221
5476
|
},
|
|
5222
5477
|
"name": "prod",
|
|
5223
5478
|
"type": {
|
|
@@ -5242,7 +5497,7 @@
|
|
|
5242
5497
|
"kind": "interface",
|
|
5243
5498
|
"locationInModule": {
|
|
5244
5499
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5245
|
-
"line":
|
|
5500
|
+
"line": 56
|
|
5246
5501
|
},
|
|
5247
5502
|
"name": "StageEnvProps",
|
|
5248
5503
|
"namespace": "deploymentPipeline",
|
|
@@ -5256,7 +5511,7 @@
|
|
|
5256
5511
|
"immutable": true,
|
|
5257
5512
|
"locationInModule": {
|
|
5258
5513
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5259
|
-
"line":
|
|
5514
|
+
"line": 60
|
|
5260
5515
|
},
|
|
5261
5516
|
"name": "beta",
|
|
5262
5517
|
"type": {
|
|
@@ -5272,7 +5527,7 @@
|
|
|
5272
5527
|
"immutable": true,
|
|
5273
5528
|
"locationInModule": {
|
|
5274
5529
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5275
|
-
"line":
|
|
5530
|
+
"line": 64
|
|
5276
5531
|
},
|
|
5277
5532
|
"name": "gamma",
|
|
5278
5533
|
"type": {
|
|
@@ -5288,7 +5543,7 @@
|
|
|
5288
5543
|
"immutable": true,
|
|
5289
5544
|
"locationInModule": {
|
|
5290
5545
|
"filename": "deployment-stack-pipeline/pipeline.ts",
|
|
5291
|
-
"line":
|
|
5546
|
+
"line": 68
|
|
5292
5547
|
},
|
|
5293
5548
|
"name": "prod",
|
|
5294
5549
|
"type": {
|
|
@@ -7163,6 +7418,6 @@
|
|
|
7163
7418
|
"symbolId": "shared-config/slack:SlackAlerts"
|
|
7164
7419
|
}
|
|
7165
7420
|
},
|
|
7166
|
-
"version": "
|
|
7167
|
-
"fingerprint": "
|
|
7421
|
+
"version": "1.0.1",
|
|
7422
|
+
"fingerprint": "hQx69zKup+4mWchHaR83j+DeI6JgfjMNK/P/+Aq5FjY="
|
|
7168
7423
|
}
|
|
@@ -15,7 +15,7 @@ const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
|
|
15
15
|
const aws_route53_targets_1 = require("aws-cdk-lib/aws-route53-targets");
|
|
16
16
|
const config_1 = require("./config");
|
|
17
17
|
class OrcaBusApiGateway extends constructs_1.Construct {
|
|
18
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.apigateway.OrcaBusApiGateway", version: "
|
|
18
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.apigateway.OrcaBusApiGateway", version: "1.0.1" };
|
|
19
19
|
/**
|
|
20
20
|
* The AWS region where the API Gateway is deployed.
|
|
21
21
|
*/
|
package/api-gateway/config.js
CHANGED
|
@@ -18,9 +18,13 @@ exports.DEFAULT_LOGS_CONFIG = {
|
|
|
18
18
|
},
|
|
19
19
|
};
|
|
20
20
|
exports.DEFAULT_ALLOW_CORS_ORIGINS = {
|
|
21
|
-
BETA: [
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
BETA: [
|
|
22
|
+
"https://orcaui.dev.umccr.org",
|
|
23
|
+
"https://portal.dev.umccr.org",
|
|
24
|
+
"http://localhost:3000",
|
|
25
|
+
],
|
|
26
|
+
GAMMA: ["https://orcaui.stg.umccr.org", "https://portal.stg.umccr.org"],
|
|
27
|
+
PROD: ["https://orcaui.umccr.org", "https://portal.umccr.org"],
|
|
24
28
|
};
|
|
25
29
|
// portal - TokenServiceStack
|
|
26
30
|
exports.COGNITO_PORTAL_APP_CLIENT_ID_PARAMETER_NAME = "/data_portal/client/data2/cog_app_client_id_stage";
|
|
@@ -57,4 +61,4 @@ exports.getDefaultApiGatewayConfiguration = getDefaultApiGatewayConfiguration;
|
|
|
57
61
|
* The SSM parameter name for the HTTP Lambda authorizer ARN.
|
|
58
62
|
*/
|
|
59
63
|
exports.AUTH_STACK_HTTP_LAMBDA_AUTHORIZER_PARAMETER_NAME = "/orcabus/authorization-stack/http-lambda-authorization-arn";
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1EQUFxRDtBQUNyRCw2Q0FBNEM7QUFlL0IsUUFBQSxtQkFBbUIsR0FBdUM7SUFDckUsSUFBSSxFQUFFO1FBQ0osU0FBUyxFQUFFLHdCQUFhLENBQUMsU0FBUztRQUNsQyxhQUFhLEVBQUUsMkJBQWEsQ0FBQyxPQUFPO0tBQ3JDO0lBQ0QsS0FBSyxFQUFFO1FBQ0wsU0FBUyxFQUFFLHdCQUFhLENBQUMsU0FBUztRQUNsQyxhQUFhLEVBQUUsMkJBQWEsQ0FBQyxPQUFPO0tBQ3JDO0lBQ0QsSUFBSSxFQUFFO1FBQ0osU0FBUyxFQUFFLHdCQUFhLENBQUMsU0FBUztRQUNsQyxhQUFhLEVBQUUsMkJBQWEsQ0FBQyxNQUFNO0tBQ3BDO0NBQ0YsQ0FBQztBQUVXLFFBQUEsMEJBQTBCLEdBQWdDO0lBQ3JFLElBQUksRUFBRTtRQUNKLDhCQUE4QjtRQUM5Qiw4QkFBOEI7UUFDOUIsdUJBQXVCO0tBQ3hCO0lBQ0QsS0FBSyxFQUFFLENBQUMsOEJBQThCLEVBQUUsOEJBQThCLENBQUM7SUFDdkUsSUFBSSxFQUFFLENBQUMsMEJBQTBCLEVBQUUsMEJBQTBCLENBQUM7Q0FDL0QsQ0FBQztBQUVGLDZCQUE2QjtBQUNoQixRQUFBLDJDQUEyQyxHQUN0RCxtREFBbUQsQ0FBQztBQUV6QyxRQUFBLDJDQUEyQyxHQUN0RCxpQ0FBaUMsQ0FBQztBQUVwQyx3QkFBd0I7QUFDWCxRQUFBLDBDQUEwQyxHQUNyRCw2Q0FBNkMsQ0FBQztBQUVoRCwrQ0FBK0M7QUFDL0MsTUFBTSxzQ0FBc0MsR0FBRztJQUM3QyxtREFBMkM7SUFDM0MsbURBQTJDO0NBQzVDLENBQUM7QUFFRix3Q0FBd0M7QUFDM0IsUUFBQSxzQ0FBc0MsR0FHL0M7SUFDRixJQUFJLEVBQUU7UUFDSixHQUFHLHNDQUFzQztRQUN6QyxrREFBMEM7S0FDM0M7SUFDRCxLQUFLLEVBQUUsc0NBQXNDO0lBQzdDLElBQUksRUFBRSxzQ0FBc0M7Q0FDN0MsQ0FBQztBQUVXLFFBQUEsMkNBQTJDLEdBQ3RELHNDQUFzQyxDQUFDO0FBRTVCLFFBQUEsOEJBQThCLEdBQUcsd0JBQXdCLENBQUM7QUFDMUQsUUFBQSxpQ0FBaUMsR0FBRyx5QkFBeUIsQ0FBQztBQUM5RCxRQUFBLDZCQUE2QixHQUFHLHVCQUF1QixDQUFDO0FBRTlELE1BQU0saUNBQWlDLEdBQUcsQ0FBQyxLQUFnQixFQUFFLEVBQUU7SUFDcEUsT0FBTztRQUNMLGlDQUFpQyxFQUMvQiw4Q0FBc0MsQ0FBQyxLQUFLLENBQUM7UUFDL0MsZ0JBQWdCLEVBQUUsa0NBQTBCLENBQUMsS0FBSyxDQUFDO1FBQ25ELGVBQWUsRUFBRSwyQkFBbUIsQ0FBQyxLQUFLLENBQUM7S0FDNUMsQ0FBQztBQUNKLENBQUMsQ0FBQztBQVBXLFFBQUEsaUNBQWlDLHFDQU81QztBQUVGOztHQUVHO0FBQ1UsUUFBQSxnREFBZ0QsR0FDM0QsNERBQTRELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZXRlbnRpb25EYXlzIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1sb2dzXCI7XG5pbXBvcnQgeyBSZW1vdmFsUG9saWN5IH0gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBTdGFnZU5hbWUgfSBmcm9tIFwiLi4vc2hhcmVkLWNvbmZpZy9hY2NvdW50c1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIExvZ3NDb25maWdQcm9wcyB7XG4gIC8qKlxuICAgKiBSZXRlbnRpb24gcG9saWN5IGZvciB0aGUgQVBJIEdhdGV3YXkgbG9ncy5cbiAgICovXG4gIHJlYWRvbmx5IHJldGVudGlvbjogUmV0ZW50aW9uRGF5cztcblxuICAvKipcbiAgICogUmVtb3ZhbCBwb2xpY3kgZm9yIHRoZSBsb2cgZ3JvdXBcbiAgICovXG4gIHJlYWRvbmx5IHJlbW92YWxQb2xpY3k6IFJlbW92YWxQb2xpY3k7XG59XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0xPR1NfQ09ORklHOiBSZWNvcmQ8U3RhZ2VOYW1lLCBMb2dzQ29uZmlnUHJvcHM+ID0ge1xuICBCRVRBOiB7XG4gICAgcmV0ZW50aW9uOiBSZXRlbnRpb25EYXlzLlRXT19XRUVLUyxcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1ksXG4gIH0sXG4gIEdBTU1BOiB7XG4gICAgcmV0ZW50aW9uOiBSZXRlbnRpb25EYXlzLlRXT19XRUVLUyxcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1ksXG4gIH0sXG4gIFBST0Q6IHtcbiAgICByZXRlbnRpb246IFJldGVudGlvbkRheXMuVFdPX1lFQVJTLFxuICAgIHJlbW92YWxQb2xpY3k6IFJlbW92YWxQb2xpY3kuUkVUQUlOLFxuICB9LFxufTtcblxuZXhwb3J0IGNvbnN0IERFRkFVTFRfQUxMT1dfQ09SU19PUklHSU5TOiBSZWNvcmQ8U3RhZ2VOYW1lLCBzdHJpbmdbXT4gPSB7XG4gIEJFVEE6IFtcbiAgICBcImh0dHBzOi8vb3JjYXVpLmRldi51bWNjci5vcmdcIixcbiAgICBcImh0dHBzOi8vcG9ydGFsLmRldi51bWNjci5vcmdcIixcbiAgICBcImh0dHA6Ly9sb2NhbGhvc3Q6MzAwMFwiLFxuICBdLFxuICBHQU1NQTogW1wiaHR0cHM6Ly9vcmNhdWkuc3RnLnVtY2NyLm9yZ1wiLCBcImh0dHBzOi8vcG9ydGFsLnN0Zy51bWNjci5vcmdcIl0sXG4gIFBST0Q6IFtcImh0dHBzOi8vb3JjYXVpLnVtY2NyLm9yZ1wiLCBcImh0dHBzOi8vcG9ydGFsLnVtY2NyLm9yZ1wiXSxcbn07XG5cbi8vIHBvcnRhbCAtIFRva2VuU2VydmljZVN0YWNrXG5leHBvcnQgY29uc3QgQ09HTklUT19QT1JUQUxfQVBQX0NMSUVOVF9JRF9QQVJBTUVURVJfTkFNRSA9XG4gIFwiL2RhdGFfcG9ydGFsL2NsaWVudC9kYXRhMi9jb2dfYXBwX2NsaWVudF9pZF9zdGFnZVwiO1xuXG5leHBvcnQgY29uc3QgQ09HTklUT19PUkNBVUlfQVBQX0NMSUVOVF9JRF9QQVJBTUVURVJfTkFNRSA9XG4gIFwiL29yY2F1aS9jb2dfYXBwX2NsaWVudF9pZF9zdGFnZVwiO1xuXG4vLyBsb2NhbGhvc3QgZGV2ZWxvcG1lbnRcbmV4cG9ydCBjb25zdCBDT0dOSVRPX0xPQ0FMX0FQUF9DTElFTlRfSURfUEFSQU1FVEVSX05BTUUgPVxuICBcIi9kYXRhX3BvcnRhbC9jbGllbnQvY29nX2FwcF9jbGllbnRfaWRfbG9jYWxcIjtcblxuLy8gQmFzZSBjbGllbnQgSURzIHVzZWQgYWNyb3NzIGFsbCBlbnZpcm9ubWVudHNcbmNvbnN0IEJBU0VfQ09HTklUT19DTElFTlRfSURfUEFSQU1FVEVSX05BTUVTID0gW1xuICBDT0dOSVRPX1BPUlRBTF9BUFBfQ0xJRU5UX0lEX1BBUkFNRVRFUl9OQU1FLFxuICBDT0dOSVRPX09SQ0FVSV9BUFBfQ0xJRU5UX0lEX1BBUkFNRVRFUl9OQU1FLFxuXTtcblxuLy8gRW52aXJvbm1lbnQtc3BlY2lmaWMgY2xpZW50IElEIGFycmF5c1xuZXhwb3J0IGNvbnN0IENPR05JVE9fQ0xJRU5UX0lEX1BBUkFNRVRFUl9OQU1FX0FSUkFZOiBSZWNvcmQ8XG4gIFN0YWdlTmFtZSxcbiAgc3RyaW5nW11cbj4gPSB7XG4gIEJFVEE6IFtcbiAgICAuLi5CQVNFX0NPR05JVE9fQ0xJRU5UX0lEX1BBUkFNRVRFUl9OQU1FUyxcbiAgICBDT0dOSVRPX0xPQ0FMX0FQUF9DTElFTlRfSURfUEFSQU1FVEVSX05BTUUsXG4gIF0sXG4gIEdBTU1BOiBCQVNFX0NPR05JVE9fQ0xJRU5UX0lEX1BBUkFNRVRFUl9OQU1FUyxcbiAgUFJPRDogQkFTRV9DT0dOSVRPX0NMSUVOVF9JRF9QQVJBTUVURVJfTkFNRVMsXG59O1xuXG5leHBvcnQgY29uc3QgREVGQVVMVF9DT0dOSVRPX1VTRVJfUE9PTF9JRF9QQVJBTUVURVJfTkFNRSA9XG4gIFwiL2RhdGFfcG9ydGFsL2NsaWVudC9jb2dfdXNlcl9wb29sX2lkXCI7XG5cbmV4cG9ydCBjb25zdCBDRVJUSUZJQ0FURV9BUk5fUEFSQU1FVEVSX05BTUUgPSBcIi91bWNjci9jZXJ0aWZpY2F0ZV9hcm5cIjtcbmV4cG9ydCBjb25zdCBIT1NURURfWk9ORV9ET01BSU5fUEFSQU1FVEVSX05BTUUgPSBcIi9ob3N0ZWRfem9uZS91bWNjci9uYW1lXCI7XG5leHBvcnQgY29uc3QgSE9TVEVEX1pPTkVfSURfUEFSQU1FVEVSX05BTUUgPSBcIi9ob3N0ZWRfem9uZS91bWNjci9pZFwiO1xuXG5leHBvcnQgY29uc3QgZ2V0RGVmYXVsdEFwaUdhdGV3YXlDb25maWd1cmF0aW9uID0gKHN0YWdlOiBTdGFnZU5hbWUpID0+IHtcbiAgcmV0dXJuIHtcbiAgICBjb2duaXRvQ2xpZW50SWRQYXJhbWV0ZXJOYW1lQXJyYXk6XG4gICAgICBDT0dOSVRPX0NMSUVOVF9JRF9QQVJBTUVURVJfTkFNRV9BUlJBWVtzdGFnZV0sXG4gICAgY29yc0FsbG93T3JpZ2luczogREVGQVVMVF9BTExPV19DT1JTX09SSUdJTlNbc3RhZ2VdLFxuICAgIGFwaUd3TG9nc0NvbmZpZzogREVGQVVMVF9MT0dTX0NPTkZJR1tzdGFnZV0sXG4gIH07XG59O1xuXG4vKipcbiAqIFRoZSBTU00gcGFyYW1ldGVyIG5hbWUgZm9yIHRoZSBIVFRQIExhbWJkYSBhdXRob3JpemVyIEFSTi5cbiAqL1xuZXhwb3J0IGNvbnN0IEFVVEhfU1RBQ0tfSFRUUF9MQU1CREFfQVVUSE9SSVpFUl9QQVJBTUVURVJfTkFNRSA9XG4gIFwiL29yY2FidXMvYXV0aG9yaXphdGlvbi1zdGFjay9odHRwLWxhbWJkYS1hdXRob3JpemF0aW9uLWFyblwiO1xuIl19
|
|
@@ -13,7 +13,7 @@ exports.CROSS_DEPLOYMENT_ARTIFACT_BUCKET_NAME = "orcabus-cross-deployment-codepi
|
|
|
13
13
|
exports.CROSS_DEPLOYMENT_ARTIFACT_KMS_ALIAS = "orcabus-cross-deployment-codepipeline-artifact";
|
|
14
14
|
exports.CROSS_DEPLOYMENT_ARTIFACT_KMS_ARN_SSM_PARAMETER_NAME = "/orcabus/deployment-stack-pipeline/artifact-bucket/kms-key-arn";
|
|
15
15
|
class CrossDeploymentArtifactBucket extends constructs_1.Construct {
|
|
16
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.deploymentPipeline.CrossDeploymentArtifactBucket", version: "
|
|
16
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.deploymentPipeline.CrossDeploymentArtifactBucket", version: "1.0.1" };
|
|
17
17
|
/**
|
|
18
18
|
* The S3 bucket used to store artifacts for cross-deployment pipelines.
|
|
19
19
|
*/
|
|
@@ -41,6 +41,35 @@ export interface StackConfigProps {
|
|
|
41
41
|
*/
|
|
42
42
|
readonly prod: Record<string, any>;
|
|
43
43
|
}
|
|
44
|
+
/**
|
|
45
|
+
* Configuration for pre-deployment drift detection checks.
|
|
46
|
+
*/
|
|
47
|
+
export interface DriftCheckConfig {
|
|
48
|
+
/**
|
|
49
|
+
* CDK CLI entrypoint used to run the drift command.
|
|
50
|
+
* Examples: "pnpm cdk", "pnpm cdk-stateful", "pnpm cdk-stateless".
|
|
51
|
+
* Must support: "drift <stackId>".
|
|
52
|
+
*/
|
|
53
|
+
readonly cdkCommand: string;
|
|
54
|
+
/**
|
|
55
|
+
* Command to install dependencies before running CDK.
|
|
56
|
+
* If your app is in a subdirectory, prefix with "cd <dir> &&".
|
|
57
|
+
* Example: "cd dev && pnpm install --frozen-lockfile --ignore-scripts"
|
|
58
|
+
*
|
|
59
|
+
* Default: "pnpm install --frozen-lockfile --ignore-scripts"
|
|
60
|
+
*/
|
|
61
|
+
readonly installCommand?: string;
|
|
62
|
+
}
|
|
63
|
+
export interface CodeBuildStepProps {
|
|
64
|
+
/**
|
|
65
|
+
* the main command for the build step to run
|
|
66
|
+
*/
|
|
67
|
+
readonly command: string[];
|
|
68
|
+
/**
|
|
69
|
+
* Partial buildspec for this CodeBuildStep
|
|
70
|
+
*/
|
|
71
|
+
readonly partialBuildSpec?: Record<string, any>;
|
|
72
|
+
}
|
|
44
73
|
export interface DeploymentStackPipelineProps {
|
|
45
74
|
/**
|
|
46
75
|
* The GitHub branch name the pipeline will listen to.
|
|
@@ -85,7 +114,7 @@ export interface DeploymentStackPipelineProps {
|
|
|
85
114
|
*/
|
|
86
115
|
readonly excludedFilePaths?: string[];
|
|
87
116
|
/**
|
|
88
|
-
* The command to run to synth the cdk stack which also installing the cdk dependencies. e.g. ["
|
|
117
|
+
* The command to run to synth the cdk stack which also installing the cdk dependencies. e.g. ["pnpm install --frozen-lockfile", "pnpm cdk synth"]
|
|
89
118
|
*/
|
|
90
119
|
readonly cdkSynthCmd: string[];
|
|
91
120
|
/**
|
|
@@ -100,6 +129,22 @@ export interface DeploymentStackPipelineProps {
|
|
|
100
129
|
* @default DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC
|
|
101
130
|
*/
|
|
102
131
|
readonly synthBuildSpec?: Record<string, any>;
|
|
132
|
+
/**
|
|
133
|
+
* Configuration for the CodeBuild step that runs unit tests for the main application code.
|
|
134
|
+
* This step will execute in parallel with {@link unitIacTestConfig} as part of the synth stage dependencies.
|
|
135
|
+
* Both must succeed before the synth step runs.
|
|
136
|
+
*
|
|
137
|
+
* ensure your command includes 'cd' to the main app directory, as the build context starts from the root.
|
|
138
|
+
*/
|
|
139
|
+
readonly unitAppTestConfig: CodeBuildStepProps;
|
|
140
|
+
/**
|
|
141
|
+
* Configuration for the CodeBuild step that runs unit tests for Infrastructure-as-Code (IaC) at the repository root.
|
|
142
|
+
* This step will execute in parallel with {@link unitAppTestConfig} as part of the synth stage dependencies.
|
|
143
|
+
* Both must succeed before the synth step runs.
|
|
144
|
+
*
|
|
145
|
+
* The default command will be from the root of the repo: ["npm install --global corepack@latest", "corepack enable", "make install", "make test"]
|
|
146
|
+
*/
|
|
147
|
+
readonly unitIacTestConfig?: CodeBuildStepProps;
|
|
103
148
|
/**
|
|
104
149
|
* The stage environment for the deployment stack
|
|
105
150
|
*/
|
|
@@ -131,6 +176,11 @@ export interface DeploymentStackPipelineProps {
|
|
|
131
176
|
* @see https://github.com/aws/aws-cdk/issues/9917
|
|
132
177
|
*/
|
|
133
178
|
readonly stripAssemblyAssets?: boolean;
|
|
179
|
+
/**
|
|
180
|
+
* Configuration for drift detection checks before deployment.
|
|
181
|
+
* If specified, the pipeline will check for CloudFormation drift and fail if detected.
|
|
182
|
+
*/
|
|
183
|
+
readonly driftCheckConfig?: DriftCheckConfig;
|
|
134
184
|
}
|
|
135
185
|
/**
|
|
136
186
|
* A CDK construct that creates a deployment pipeline across environments for the OrcaBus project.
|
|
@@ -145,3 +195,32 @@ export declare class DeploymentStackPipeline extends Construct {
|
|
|
145
195
|
readonly pipeline: Pipeline;
|
|
146
196
|
constructor(scope: Construct, id: string, props: DeploymentStackPipelineProps);
|
|
147
197
|
}
|
|
198
|
+
export interface FailOnDriftBuildStepProps {
|
|
199
|
+
/**
|
|
200
|
+
* AWS account and region where the drift check runs.
|
|
201
|
+
* Used to assume the CDK lookup role and set AWS_DEFAULT_REGION.
|
|
202
|
+
*/
|
|
203
|
+
readonly accountEnv: Environment;
|
|
204
|
+
/**
|
|
205
|
+
* Fully qualified CDK stack ID to check for drift.
|
|
206
|
+
*
|
|
207
|
+
* Format: `<rootStack>/<constructId>/<envName>/<stackName>`
|
|
208
|
+
*
|
|
209
|
+
* Example: `DevStack/DeploymentPipeline/OrcaBusBeta/TestStack`
|
|
210
|
+
*/
|
|
211
|
+
readonly stackId: string;
|
|
212
|
+
/**
|
|
213
|
+
* CDK CLI entrypoint used to run the drift command.
|
|
214
|
+
* Examples: "pnpm cdk", "pnpm cdk-stateful", "pnpm cdk-stateless".
|
|
215
|
+
* Must support: "drift <stackId>".
|
|
216
|
+
*/
|
|
217
|
+
readonly cdkCommand: string;
|
|
218
|
+
/**
|
|
219
|
+
* Command to install dependencies before running CDK.
|
|
220
|
+
* If your app is in a subdirectory, prefix with "cd <dir> &&".
|
|
221
|
+
* Example: "cd dev && pnpm install --frozen-lockfile --ignore-scripts"
|
|
222
|
+
*
|
|
223
|
+
* Default: "pnpm install --frozen-lockfile --ignore-scripts"
|
|
224
|
+
*/
|
|
225
|
+
readonly installCommand?: string;
|
|
226
|
+
}
|
|
@@ -13,6 +13,7 @@ const aws_chatbot_1 = require("aws-cdk-lib/aws-chatbot");
|
|
|
13
13
|
const aws_codestarnotifications_1 = require("aws-cdk-lib/aws-codestarnotifications");
|
|
14
14
|
const artifact_bucket_1 = require("./artifact-bucket");
|
|
15
15
|
const aws_codepipeline_actions_1 = require("aws-cdk-lib/aws-codepipeline-actions");
|
|
16
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
16
17
|
/**
|
|
17
18
|
* The default partial build spec for the synth step in the pipeline.
|
|
18
19
|
*/
|
|
@@ -32,14 +33,14 @@ exports.DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC = {
|
|
|
32
33
|
* before using this construct.
|
|
33
34
|
*/
|
|
34
35
|
class DeploymentStackPipeline extends constructs_1.Construct {
|
|
35
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.deploymentPipeline.DeploymentStackPipeline", version: "
|
|
36
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.deploymentPipeline.DeploymentStackPipeline", version: "1.0.1" };
|
|
36
37
|
/**
|
|
37
38
|
* The code pipeline construct that is created.
|
|
38
39
|
*/
|
|
39
40
|
pipeline;
|
|
40
41
|
constructor(scope, id, props) {
|
|
41
42
|
super(scope, id);
|
|
42
|
-
const codeStarArn = aws_ssm_1.StringParameter.valueForStringParameter(this, "
|
|
43
|
+
const codeStarArn = aws_ssm_1.StringParameter.valueForStringParameter(this, "codestar_github_arn");
|
|
43
44
|
const codeStarSourceActionName = "pipeline-src";
|
|
44
45
|
const sourceFile = pipelines_1.CodePipelineSource.connection(`OrcaBus/${props.githubRepo}`, props.githubBranch, {
|
|
45
46
|
connectionArn: codeStarArn,
|
|
@@ -55,6 +56,9 @@ class DeploymentStackPipeline extends constructs_1.Construct {
|
|
|
55
56
|
pipelineType: aws_codepipeline_1.PipelineType.V2,
|
|
56
57
|
pipelineName: props.pipelineName,
|
|
57
58
|
crossAccountKeys: true,
|
|
59
|
+
// enable restartExecutionOnUpdate
|
|
60
|
+
// https://stackoverflow.com/questions/75701776/updatepipeline-stage-in-cdk-pipeline-is-cancelled
|
|
61
|
+
restartExecutionOnUpdate: true,
|
|
58
62
|
});
|
|
59
63
|
if (props.includedFilePaths || props.excludedFilePaths) {
|
|
60
64
|
const filePaths = {};
|
|
@@ -83,21 +87,67 @@ class DeploymentStackPipeline extends constructs_1.Construct {
|
|
|
83
87
|
},
|
|
84
88
|
]);
|
|
85
89
|
}
|
|
90
|
+
// Add unit test for IaC at the root of the
|
|
91
|
+
const { command: unitIacTestCommand = [
|
|
92
|
+
"npm install --global corepack@latest",
|
|
93
|
+
"corepack enable",
|
|
94
|
+
"make install",
|
|
95
|
+
"make test",
|
|
96
|
+
], partialBuildSpec: unitIacPartialBuildSpec = undefined, } = props.unitIacTestConfig || {};
|
|
97
|
+
const unitIacTest = new pipelines_1.CodeBuildStep("UnitIacTest", {
|
|
98
|
+
commands: unitIacTestCommand,
|
|
99
|
+
input: sourceFile,
|
|
100
|
+
buildEnvironment: {
|
|
101
|
+
privileged: true,
|
|
102
|
+
computeType: aws_codebuild_1.ComputeType.LARGE,
|
|
103
|
+
buildImage: aws_codebuild_1.LinuxArmBuildImage.AMAZON_LINUX_2_STANDARD_3_0,
|
|
104
|
+
environmentVariables: {
|
|
105
|
+
NODE_OPTIONS: {
|
|
106
|
+
value: "--max-old-space-size=8192",
|
|
107
|
+
},
|
|
108
|
+
},
|
|
109
|
+
},
|
|
110
|
+
partialBuildSpec: unitIacPartialBuildSpec
|
|
111
|
+
? aws_codebuild_1.BuildSpec.fromObject(unitIacPartialBuildSpec)
|
|
112
|
+
: undefined,
|
|
113
|
+
});
|
|
114
|
+
// Adding unit test for the main app
|
|
115
|
+
const { command: unitAppTestCommand, partialBuildSpec: unitAppPartialBuildSpec = undefined, } = props.unitAppTestConfig;
|
|
116
|
+
const unitAppTest = new pipelines_1.CodeBuildStep("UnitAppTest", {
|
|
117
|
+
commands: unitAppTestCommand,
|
|
118
|
+
input: sourceFile,
|
|
119
|
+
buildEnvironment: {
|
|
120
|
+
privileged: true,
|
|
121
|
+
computeType: aws_codebuild_1.ComputeType.LARGE,
|
|
122
|
+
buildImage: aws_codebuild_1.LinuxArmBuildImage.AMAZON_LINUX_2_STANDARD_3_0,
|
|
123
|
+
environmentVariables: {
|
|
124
|
+
NODE_OPTIONS: {
|
|
125
|
+
value: "--max-old-space-size=8192",
|
|
126
|
+
},
|
|
127
|
+
},
|
|
128
|
+
},
|
|
129
|
+
partialBuildSpec: unitAppPartialBuildSpec
|
|
130
|
+
? aws_codebuild_1.BuildSpec.fromObject(unitAppPartialBuildSpec)
|
|
131
|
+
: undefined,
|
|
132
|
+
});
|
|
86
133
|
const { synthBuildSpec = exports.DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC } = props;
|
|
134
|
+
const synthStep = new pipelines_1.CodeBuildStep("CdkSynth", {
|
|
135
|
+
installCommands: [
|
|
136
|
+
"node -v",
|
|
137
|
+
"npm install --global corepack@latest",
|
|
138
|
+
"corepack --version",
|
|
139
|
+
"corepack enable",
|
|
140
|
+
],
|
|
141
|
+
commands: props.cdkSynthCmd,
|
|
142
|
+
input: sourceFile,
|
|
143
|
+
primaryOutputDirectory: props.cdkOut || "cdk.out",
|
|
144
|
+
partialBuildSpec: aws_codebuild_1.BuildSpec.fromObject(synthBuildSpec),
|
|
145
|
+
});
|
|
146
|
+
synthStep.addStepDependency(unitIacTest);
|
|
147
|
+
synthStep.addStepDependency(unitAppTest);
|
|
87
148
|
const cdkPipeline = new pipelines_1.CodePipeline(this, "CDKCodePipeline", {
|
|
88
149
|
codePipeline: this.pipeline,
|
|
89
|
-
synth:
|
|
90
|
-
installCommands: [
|
|
91
|
-
"node -v",
|
|
92
|
-
"npm install --global corepack@latest",
|
|
93
|
-
"corepack --version",
|
|
94
|
-
"corepack enable",
|
|
95
|
-
],
|
|
96
|
-
commands: props.cdkSynthCmd,
|
|
97
|
-
input: sourceFile,
|
|
98
|
-
primaryOutputDirectory: props.cdkOut || "cdk.out",
|
|
99
|
-
partialBuildSpec: aws_codebuild_1.BuildSpec.fromObject(synthBuildSpec),
|
|
100
|
-
}),
|
|
150
|
+
synth: synthStep,
|
|
101
151
|
selfMutation: true,
|
|
102
152
|
codeBuildDefaults: {
|
|
103
153
|
buildEnvironment: {
|
|
@@ -140,8 +190,43 @@ class DeploymentStackPipeline extends constructs_1.Construct {
|
|
|
140
190
|
pre: [stripAssetsFromAssembly],
|
|
141
191
|
});
|
|
142
192
|
}
|
|
143
|
-
|
|
144
|
-
|
|
193
|
+
// Construct function to get StackId for drift check
|
|
194
|
+
const rootStackName = aws_cdk_lib_1.Stack.of(this).stackName;
|
|
195
|
+
const constructId = this.node.id;
|
|
196
|
+
const getStackId = (envName) => `${rootStackName}/${constructId}/${envName}/${props.stackName}`;
|
|
197
|
+
// Drift check config
|
|
198
|
+
const isDriftCheckStep = !!props.driftCheckConfig;
|
|
199
|
+
const cdkInstallCmd = props.driftCheckConfig?.installCommand ??
|
|
200
|
+
"pnpm install --frozen-lockfile --ignore-scripts";
|
|
201
|
+
const cdkRunCmd = props.driftCheckConfig?.cdkCommand ?? ``;
|
|
202
|
+
const betaEnvName = "OrcaBusBeta";
|
|
203
|
+
cdkPipeline.addStage(new DeploymentStage(this, betaEnvName, stageEnv.beta, props.stackName, props.stack, props.stackConfig.beta, props.githubRepo, props.githubBranch), {
|
|
204
|
+
pre: isDriftCheckStep
|
|
205
|
+
? [
|
|
206
|
+
new FailOnDriftBuildStep("DriftOnFailBetaCheck", {
|
|
207
|
+
accountEnv: stageEnv.beta,
|
|
208
|
+
stackId: getStackId(betaEnvName),
|
|
209
|
+
cdkCommand: cdkRunCmd,
|
|
210
|
+
installCommand: cdkInstallCmd,
|
|
211
|
+
}),
|
|
212
|
+
]
|
|
213
|
+
: undefined,
|
|
214
|
+
});
|
|
215
|
+
/**
|
|
216
|
+
* GAMMA
|
|
217
|
+
*/
|
|
218
|
+
const gammaEnvName = "OrcaBusGamma";
|
|
219
|
+
cdkPipeline.addStage(new DeploymentStage(this, gammaEnvName, stageEnv.gamma, props.stackName, props.stack, props.stackConfig.gamma, props.githubRepo, props.githubBranch), {
|
|
220
|
+
pre: isDriftCheckStep
|
|
221
|
+
? [
|
|
222
|
+
new FailOnDriftBuildStep("DriftOnFailGammaCheck", {
|
|
223
|
+
accountEnv: stageEnv.gamma,
|
|
224
|
+
stackId: getStackId(gammaEnvName),
|
|
225
|
+
cdkCommand: cdkRunCmd,
|
|
226
|
+
installCommand: cdkInstallCmd,
|
|
227
|
+
}),
|
|
228
|
+
]
|
|
229
|
+
: undefined,
|
|
145
230
|
post: [
|
|
146
231
|
new ManualApprovalActionStep("PromoteToProd", {
|
|
147
232
|
actionName: "PromoteToProd",
|
|
@@ -154,7 +239,22 @@ class DeploymentStackPipeline extends constructs_1.Construct {
|
|
|
154
239
|
}),
|
|
155
240
|
],
|
|
156
241
|
});
|
|
157
|
-
|
|
242
|
+
/**
|
|
243
|
+
* PROD
|
|
244
|
+
*/
|
|
245
|
+
const prodEnvName = "OrcaBusProd";
|
|
246
|
+
cdkPipeline.addStage(new DeploymentStage(this, prodEnvName, stageEnv.prod, props.stackName, props.stack, props.stackConfig.prod, props.githubRepo, props.githubBranch), {
|
|
247
|
+
pre: isDriftCheckStep
|
|
248
|
+
? [
|
|
249
|
+
new FailOnDriftBuildStep("DriftOnFailProdCheck", {
|
|
250
|
+
accountEnv: stageEnv.prod,
|
|
251
|
+
stackId: getStackId(prodEnvName),
|
|
252
|
+
cdkCommand: cdkRunCmd,
|
|
253
|
+
installCommand: cdkInstallCmd,
|
|
254
|
+
}),
|
|
255
|
+
]
|
|
256
|
+
: undefined,
|
|
257
|
+
});
|
|
158
258
|
cdkPipeline.buildPipeline();
|
|
159
259
|
if (stripAssetsFromAssembly) {
|
|
160
260
|
cdkPipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsFromAssembly.project);
|
|
@@ -212,4 +312,35 @@ class DeploymentStage extends aws_cdk_lib_1.Stage {
|
|
|
212
312
|
});
|
|
213
313
|
}
|
|
214
314
|
}
|
|
215
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["pipeline.ts"],"names":[],"mappings":";;;;AAAA,2CAAuC;AACvC,6CAAkE;AAClE,6DAImC;AACnC,iDAAsD;AACtD,qDAS+B;AAC/B,mEAMsC;AACtC,qCAIkB;AAClB,yDAAoE;AACpE,qFAAmE;AACnE,uDAAkE;AAClE,mFAG8C;AAE9C;;GAEG;AACU,QAAA,qCAAqC,GAAG;IACnD,MAAM,EAAE;QACN,OAAO,EAAE;YACP,kBAAkB,EAAE;gBAClB,MAAM,EAAE,MAAM;aACf;SACF;KACF;CACF,CAAC;AA8HF;;;;;GAKG;AACH,MAAa,uBAAwB,SAAQ,sBAAS;;IACpD;;OAEG;IACM,QAAQ,CAAW;IAE5B,YACE,KAAgB,EAChB,EAAU,EACV,KAAmC;QAEnC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,WAAW,GAAG,yBAAe,CAAC,uBAAuB,CACzD,IAAI,EACJ,8BAA8B,CAC/B,CAAC;QACF,MAAM,wBAAwB,GAAG,cAAc,CAAC;QAChD,MAAM,UAAU,GAAG,8BAAkB,CAAC,UAAU,CAC9C,WAAW,KAAK,CAAC,UAAU,EAAE,EAC7B,KAAK,CAAC,YAAY,EAClB;YACE,aAAa,EAAE,WAAW;YAC1B,UAAU,EAAE,wBAAwB;YACpC,aAAa,EAAE,IAAI;SACpB,CACF,CAAC;QAEF,MAAM,+BAA+B,GACnC,KAAK,CAAC,2BAA2B,IAAI,IAAI,CAAC;QAC5C,MAAM,cAAc,GAAG,+BAA+B;YACpD,CAAC,CAAC,+CAA6B,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,cAAc;YAC/D,CAAC,CAAC,SAAS,CAAC;QAEd,IAAI,CAAC,QAAQ,GAAG,IAAI,2BAAQ,CAAC,IAAI,EAAE,wBAAwB,EAAE;YAC3D,cAAc,EAAE,cAAc;YAC9B,YAAY,EAAE,+BAAY,CAAC,EAAE;YAC7B,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;QAEH,IAAI,KAAK,CAAC,iBAAiB,IAAI,KAAK,CAAC,iBAAiB,EAAE,CAAC;YACvD,MAAM,SAAS,GAA6B,EAAE,CAAC;YAE/C,IAAI,KAAK,CAAC,iBAAiB,EAAE,CAAC;gBAC5B,SAAS,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC,iBAAiB,CAAC;YAClD,CAAC;YACD,IAAI,KAAK,CAAC,iBAAiB,EAAE,CAAC;gBAC5B,SAAS,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC,iBAAiB,CAAC;YAClD,CAAC;YAED,gFAAgF;YAChF,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,YAA2B,CAAC;YACnE,WAAW,CAAC,mBAAmB,CAAC,UAAU,EAAE;gBAC1C;oBACE,gBAAgB,EAAE;wBAChB,IAAI,EAAE;4BACJ;gCACE,QAAQ,EAAE;oCACR,QAAQ,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC;iCAC/B;gCACD,SAAS,EAAE,SAAS;6BACrB;yBACF;wBACD,gBAAgB,EAAE,wBAAwB;qBAC3C;oBACD,YAAY,EAAE,0BAA0B;iBACzC;aACF,CAAC,CAAC;QACL,CAAC;QAED,MAAM,EAAE,cAAc,GAAG,6CAAqC,EAAE,GAAG,KAAK,CAAC;QACzE,MAAM,WAAW,GAAG,IAAI,wBAAY,CAAC,IAAI,EAAE,iBAAiB,EAAE;YAC5D,YAAY,EAAE,IAAI,CAAC,QAAQ;YAC3B,KAAK,EAAE,IAAI,yBAAa,CAAC,UAAU,EAAE;gBACnC,eAAe,EAAE;oBACf,SAAS;oBACT,sCAAsC;oBACtC,oBAAoB;oBACpB,iBAAiB;iBAClB;gBACD,QAAQ,EAAE,KAAK,CAAC,WAAW;gBAC3B,KAAK,EAAE,UAAU;gBACjB,sBAAsB,EAAE,KAAK,CAAC,MAAM,IAAI,SAAS;gBACjD,gBAAgB,EAAE,yBAAS,CAAC,UAAU,CAAC,cAAc,CAAC;aACvD,CAAC;YACF,YAAY,EAAE,IAAI;YAClB,iBAAiB,EAAE;gBACjB,gBAAgB,EAAE;oBAChB,WAAW,EAAE,2BAAW,CAAC,KAAK;oBAC9B,UAAU,EAAE,kCAAkB,CAAC,2BAA2B;oBAC1D,oBAAoB,EAAE;wBACpB,YAAY,EAAE;4BACZ,KAAK,EAAE,2BAA2B;yBACnC;qBACF;iBACF;aACF;SACF,CAAC,CAAC;QAEH,MAAM,eAAe,GAAkB;YACrC,IAAI,EAAE,yBAAgB;YACtB,KAAK,EAAE,0BAAiB;YACxB,IAAI,EAAE,yBAAgB;SACvB,CAAC;QACF,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,eAAe,CAAC;QAEnD,8EAA8E;QAC9E,2DAA2D;QAC3D,6CAA6C;QAC7C,IAAI,uBAAkD,CAAC;QACvD,IAAI,KAAK,CAAC,mBAAmB,EAAE,CAAC;YAC9B,uBAAuB,GAAG,IAAI,yBAAa,CAAC,yBAAyB,EAAE;gBACrE,KAAK,EAAE,WAAW,CAAC,oBAAoB;gBACvC,QAAQ,EAAE;oBACR,qDAAqD;oBACrD,kCAAkC;oBAClC,eAAe;oBACf,mBAAmB;oBACnB,IAAI;oBACJ,iBAAiB;oBACjB,6BAA6B;oBAC7B,IAAI;oBACJ,sCAAsC;iBACvC;aACF,CAAC,CAAC;YAEH,WAAW,CAAC,OAAO,CAAC,uBAAuB,EAAE;gBAC3C,GAAG,EAAE,CAAC,uBAAuB,CAAC;aAC/B,CAAC,CAAC;QACL,CAAC;QAED,WAAW,CAAC,QAAQ,CAClB,IAAI,eAAe,CACjB,IAAI,EACJ,aAAa,EACb,QAAQ,CAAC,IAAI,EACb,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,KAAK,EACX,KAAK,CAAC,WAAW,CAAC,IAAI,EACtB,KAAK,CAAC,UAAU,EAChB,KAAK,CAAC,YAAY,CACnB,CACF,CAAC;QAEF,WAAW,CAAC,QAAQ,CAClB,IAAI,eAAe,CACjB,IAAI,EACJ,cAAc,EACd,QAAQ,CAAC,KAAK,EACd,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,KAAK,EACX,KAAK,CAAC,WAAW,CAAC,KAAK,EACvB,KAAK,CAAC,UAAU,EAChB,KAAK,CAAC,YAAY,CACnB,EACD;YACE,IAAI,EAAE;gBACJ,IAAI,wBAAwB,CAAC,eAAe,EAAE;oBAC5C,UAAU,EAAE,eAAe;oBAC3B,mFAAmF;oBACnF,4EAA4E;oBAC5E,2EAA2E;oBAC3E,QAAQ,EAAE,CAAC;oBACX,qFAAqF;oBACrF,OAAO,EAAE,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;iBAC9B,CAAC;aACH;SACF,CACF,CAAC;QAEF,WAAW,CAAC,QAAQ,CAClB,IAAI,eAAe,CACjB,IAAI,EACJ,aAAa,EACb,QAAQ,CAAC,IAAI,EACb,KAAK,CAAC,SAAS,EACf,KAAK,CAAC,KAAK,EACX,KAAK,CAAC,WAAW,CAAC,IAAI,EACtB,KAAK,CAAC,UAAU,EAChB,KAAK,CAAC,YAAY,CACnB,CACF,CAAC;QAEF,WAAW,CAAC,aAAa,EAAE,CAAC;QAE5B,IAAI,uBAAuB,EAAE,CAAC;YAC5B,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAChD,uBAAuB,CAAC,OAAO,CAChC,CAAC;QACJ,CAAC;QAED,IAAI,KAAK,CAAC,uBAAuB,IAAI,IAAI,EAAE,CAAC;YAC1C,MAAM,yBAAyB,GAAG,yBAAe,CAAC,uBAAuB,CACvE,IAAI,EACJ,iCAAiC,CAClC,CAAC;YACF,MAAM,MAAM,GAAG,uCAAyB,CAAC,gCAAgC,CACvE,IAAI,EACJ,2BAA2B,EAC3B,yBAAyB,CAC1B,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,2BAA2B,EAAE,MAAM,EAAE;gBAC1D,MAAM,EAAE,KAAK,CAAC,kBAAkB,IAAI;oBAClC,6CAA0B,CAAC,yBAAyB;iBACrD;gBACD,UAAU,EAAE,sCAAU,CAAC,IAAI;gBAC3B,oBAAoB,EAAE,WAAW,KAAK,CAAC,YAAY,EAAE;aACtD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;;AAnNH,0DAoNC;AAYD;;;;;;;;GAQG;AACH,MAAM,wBACJ,SAAQ,gBAAI;IAGK,yBAAyB,CAAgC;IAC1E,YAAY,EAAU,EAAE,OAAsC;QAC5D,KAAK,CAAC,EAAE,CAAC,CAAC;QACV,IAAI,CAAC,yBAAyB,GAAG,OAAO,CAAC;IAC3C,CAAC;IAEM,aAAa,CAClB,KAAa,EACb,OAA6B;QAE7B,KAAK,CAAC,SAAS,CAAC,IAAI,+CAAoB,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC,CAAC;QAE1E,OAAO,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAC;IAClC,CAAC;CACF;AAED,MAAM,eAAgB,SAAQ,mBAAK;IACjC,YACE,KAAgB,EAChB,eAAuB,EACvB,GAAgB,EAChB,SAAiB,EACjB,UAAmE,EACnE,aAAkB,EAClB,UAAkB,EAClB,YAAqB;QAErB,KAAK,CAAC,KAAK,EAAE,eAAe,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;QAE5C,IAAI,MAAM,GAAG,8BAA8B,UAAU,EAAE,CAAC;QACxD,IAAI,YAAY,KAAK,SAAS,IAAI,YAAY,KAAK,MAAM,EAAE,CAAC;YAC1D,MAAM,GAAG,GAAG,MAAM,SAAS,YAAY,EAAE,CAAC;QAC5C,CAAC;QAED,IAAI,UAAU,CAAC,IAAI,EAAE,SAAS,EAAE;YAC9B,GAAG,EAAE,GAAG;YACR,IAAI,EAAE;gBACJ,mBAAmB,EAAE,SAAS;gBAC9B,mBAAmB,EAAE,KAAK;gBAC1B,mBAAmB,EAAE,SAAS;gBAC9B,kBAAkB,EAAE,MAAM;aAC3B;YACD,GAAG,aAAa;SACjB,CAAC,CAAC;IACL,CAAC;CACF","sourcesContent":["import { Construct } from \"constructs\";\nimport { Duration, Environment, Stack, Stage } from \"aws-cdk-lib\";\nimport {\n  BuildSpec,\n  ComputeType,\n  LinuxArmBuildImage,\n} from \"aws-cdk-lib/aws-codebuild\";\nimport { StringParameter } from \"aws-cdk-lib/aws-ssm\";\nimport {\n  CodeBuildStep,\n  CodePipeline,\n  CodePipelineActionFactoryResult,\n  CodePipelineSource,\n  ICodePipelineActionFactory,\n  ManualApprovalStep,\n  ProduceActionOptions,\n  Step,\n} from \"aws-cdk-lib/pipelines\";\nimport {\n  Pipeline,\n  CfnPipeline,\n  PipelineType,\n  PipelineNotificationEvents,\n  IStage,\n} from \"aws-cdk-lib/aws-codepipeline\";\nimport {\n  BETA_ENVIRONMENT,\n  GAMMA_ENVIRONMENT,\n  PROD_ENVIRONMENT,\n} from \"./config\";\nimport { SlackChannelConfiguration } from \"aws-cdk-lib/aws-chatbot\";\nimport { DetailType } from \"aws-cdk-lib/aws-codestarnotifications\";\nimport { CrossDeploymentArtifactBucket } from \"./artifact-bucket\";\nimport {\n  ManualApprovalAction,\n  ManualApprovalActionProps,\n} from \"aws-cdk-lib/aws-codepipeline-actions\";\n\n/**\n * The default partial build spec for the synth step in the pipeline.\n */\nexport const DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC = {\n  phases: {\n    install: {\n      \"runtime-versions\": {\n        nodejs: \"22.x\",\n      },\n    },\n  },\n};\n\nexport interface StageEnvProps {\n  /**\n   * The environment for the beta stage\n   */\n  readonly beta: Environment;\n  /**\n   * The environment for the gamma stage\n   */\n  readonly gamma: Environment;\n  /**\n   * The environment for the prod stage\n   */\n  readonly prod: Environment;\n}\n\nexport interface StackConfigProps {\n  /**\n   * The configuration for the beta (dev) stage\n   */\n  readonly beta: Record<string, any>;\n  /**\n   * The configuration for the gamma (stg) stage\n   */\n  readonly gamma: Record<string, any>;\n  /**\n   * The configuration for the prod stage\n   */\n  readonly prod: Record<string, any>;\n}\n\nexport interface DeploymentStackPipelineProps {\n  /**\n   * The GitHub branch name the pipeline will listen to.\n   * Avoid using branch names that contain special characters such as parentheses.\n   * Allowed special characters are: \"+ - = . _ : / @\".\n   * This restriction is due to AWS resource tagging requirements.\n   */\n  readonly githubBranch: string;\n  /**\n   * The repository name that exist in the 'OrcaBus' github organisation. e.g. `a-micro-service-repo`\n   */\n  readonly githubRepo: string;\n  /**\n   * The stack to which the pipeline will be deploying to its respective account\n   */\n  readonly stack: any;\n  /**\n   * The stack name (in cloudformation) for the stack defined in `stack`. The stack name will prepend with the stage\n   * name e.g. `OrcaBusBeta-<stackName>`, `OrcaBusGamma-<stackName>`, `OrcaBusProd-<stackName>`\n   */\n  readonly stackName: string;\n  /**\n   * The stack configuration/constants that will be passed to the stack props.\n   */\n  readonly stackConfig: StackConfigProps;\n  /**\n   * The pipeline name in the bastion account.\n   */\n  readonly pipelineName: string;\n  /**\n   * The list of patterns of Git repository file paths that, when a commit is pushed, are to be INCLUDED as criteria that starts the pipeline.\n   *\n   * https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-codepipeline-pipeline-gitfilepathfiltercriteria.html\n   *\n   */\n  readonly includedFilePaths?: string[];\n  /**\n   * The list of patterns of Git repository file paths that, when a commit is pushed, are to be EXCLUDED from starting the pipeline.\n   *\n   * https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-codepipeline-pipeline-gitfilepathfiltercriteria.html\n   *\n   */\n  readonly excludedFilePaths?: string[];\n  /**\n   * The command to run to synth the cdk stack which also installing the cdk dependencies. e.g. [\"yarn install --immutable\", \"yarn cdk synth\"]\n   */\n  readonly cdkSynthCmd: string[];\n  /**\n   * The location where the cdk output will be stored.\n   *\n   * @default cdk.out\n   */\n  readonly cdkOut?: string;\n  /**\n   * Additional configuration for the CodeBuild step during the CDK synth phase. It will passed as the `partialBuildSpec` to the `CodeBuildStep`.\n   *\n   * @default DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC\n   */\n  readonly synthBuildSpec?: Record<string, any>;\n  /**\n   * The stage environment for the deployment stack\n   */\n  readonly stageEnv?: StageEnvProps;\n  /**\n   * Enable notification to the 'alerts-build' slack channel.\n   * @default True\n   */\n  readonly enableSlackNotification?: boolean;\n  /**\n   * The pipeline notification events that will trigger a Slack channel notification.\n   * Only applies if `enableSlackNotification` is set to true.\n   *\n   * @default [PipelineNotificationEvents.PIPELINE_EXECUTION_FAILED] –\n   *   Only failed pipeline executions will trigger a notification.\n   */\n  readonly notificationEvents?: PipelineNotificationEvents[];\n\n  /**\n   * Whether to reuse the existing artifact bucket for cross-deployment pipelines.\n   * If set to true, it will look up the existing artifact bucket in the TOOLCHAIN account.\n   *\n   * @default True\n   */\n  readonly reuseExistingArtifactBucket?: boolean;\n\n  /**\n   * Remove assets from the CDK assembly pre-deployment to prevent hitting CodePipeline's 256 MB artifact size limit.\n   * Useful when CDK assets (Lambda code, Docker images, etc.) are large.\n   *\n   * @see https://github.com/aws/aws-cdk/issues/9917\n   */\n  readonly stripAssemblyAssets?: boolean;\n}\n\n/**\n * A CDK construct that creates a deployment pipeline across environments for the OrcaBus project.\n *\n * Prerequisite: Ensure that the \"CrossDeploymentArtifactBucket\" stack is deployed in the TOOLCHAIN account\n * before using this construct.\n */\nexport class DeploymentStackPipeline extends Construct {\n  /**\n   * The code pipeline construct that is created.\n   */\n  readonly pipeline: Pipeline;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: DeploymentStackPipelineProps,\n  ) {\n    super(scope, id);\n\n    const codeStarArn = StringParameter.valueForStringParameter(\n      this,\n      \"/orcabus/codestar_github_arn\",\n    );\n    const codeStarSourceActionName = \"pipeline-src\";\n    const sourceFile = CodePipelineSource.connection(\n      `OrcaBus/${props.githubRepo}`,\n      props.githubBranch,\n      {\n        connectionArn: codeStarArn,\n        actionName: codeStarSourceActionName,\n        triggerOnPush: true,\n      },\n    );\n\n    const isReusingExistingArtifactBucket =\n      props.reuseExistingArtifactBucket ?? true;\n    const artifactBucket = isReusingExistingArtifactBucket\n      ? CrossDeploymentArtifactBucket.fromLookup(this).artifactBucket\n      : undefined;\n\n    this.pipeline = new Pipeline(this, \"DeploymentCodePipeline\", {\n      artifactBucket: artifactBucket,\n      pipelineType: PipelineType.V2,\n      pipelineName: props.pipelineName,\n      crossAccountKeys: true,\n    });\n\n    if (props.includedFilePaths || props.excludedFilePaths) {\n      const filePaths: Record<string, string[]> = {};\n\n      if (props.includedFilePaths) {\n        filePaths[\"Includes\"] = props.includedFilePaths;\n      }\n      if (props.excludedFilePaths) {\n        filePaths[\"Excludes\"] = props.excludedFilePaths;\n      }\n\n      // Add event filter to only trigger if the push event is from `deploy` directory\n      const cfnPipeline = this.pipeline.node.defaultChild as CfnPipeline;\n      cfnPipeline.addPropertyOverride(\"Triggers\", [\n        {\n          GitConfiguration: {\n            Push: [\n              {\n                Branches: {\n                  Includes: [props.githubBranch],\n                },\n                FilePaths: filePaths,\n              },\n            ],\n            SourceActionName: codeStarSourceActionName,\n          },\n          ProviderType: \"CodeStarSourceConnection\",\n        },\n      ]);\n    }\n\n    const { synthBuildSpec = DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC } = props;\n    const cdkPipeline = new CodePipeline(this, \"CDKCodePipeline\", {\n      codePipeline: this.pipeline,\n      synth: new CodeBuildStep(\"CdkSynth\", {\n        installCommands: [\n          \"node -v\",\n          \"npm install --global corepack@latest\",\n          \"corepack --version\",\n          \"corepack enable\",\n        ],\n        commands: props.cdkSynthCmd,\n        input: sourceFile,\n        primaryOutputDirectory: props.cdkOut || \"cdk.out\",\n        partialBuildSpec: BuildSpec.fromObject(synthBuildSpec),\n      }),\n      selfMutation: true,\n      codeBuildDefaults: {\n        buildEnvironment: {\n          computeType: ComputeType.LARGE,\n          buildImage: LinuxArmBuildImage.AMAZON_LINUX_2_STANDARD_3_0,\n          environmentVariables: {\n            NODE_OPTIONS: {\n              value: \"--max-old-space-size=8192\",\n            },\n          },\n        },\n      },\n    });\n\n    const defaultStageEnv: StageEnvProps = {\n      beta: BETA_ENVIRONMENT,\n      gamma: GAMMA_ENVIRONMENT,\n      prod: PROD_ENVIRONMENT,\n    };\n    const stageEnv = props.stageEnv || defaultStageEnv;\n\n    // After assets are published, they can be removed from the assembly directory\n    // to help prevent hitting the CodePipeline artifact limit.\n    // https://github.com/aws/aws-cdk/issues/9917\n    let stripAssetsFromAssembly: CodeBuildStep | undefined;\n    if (props.stripAssemblyAssets) {\n      stripAssetsFromAssembly = new CodeBuildStep(\"StripAssetsFromAssembly\", {\n        input: cdkPipeline.cloudAssemblyFileSet,\n        commands: [\n          'S3_PATH=${CODEBUILD_SOURCE_VERSION#\"arn:aws:s3:::\"}',\n          \"ZIP_ARCHIVE=$(basename $S3_PATH)\",\n          \"echo $S3_PATH\",\n          \"echo $ZIP_ARCHIVE\",\n          \"ls\",\n          \"rm -rfv asset.*\",\n          \"zip -r -q -A $ZIP_ARCHIVE *\",\n          \"ls\",\n          \"aws s3 cp $ZIP_ARCHIVE s3://$S3_PATH\",\n        ],\n      });\n\n      cdkPipeline.addWave(\"BeforeStageDeployment\", {\n        pre: [stripAssetsFromAssembly],\n      });\n    }\n\n    cdkPipeline.addStage(\n      new DeploymentStage(\n        this,\n        \"OrcaBusBeta\",\n        stageEnv.beta,\n        props.stackName,\n        props.stack,\n        props.stackConfig.beta,\n        props.githubRepo,\n        props.githubBranch,\n      ),\n    );\n\n    cdkPipeline.addStage(\n      new DeploymentStage(\n        this,\n        \"OrcaBusGamma\",\n        stageEnv.gamma,\n        props.stackName,\n        props.stack,\n        props.stackConfig.gamma,\n        props.githubRepo,\n        props.githubBranch,\n      ),\n      {\n        post: [\n          new ManualApprovalActionStep(\"PromoteToProd\", {\n            actionName: \"PromoteToProd\",\n            // Custom steps bypass stage pre/post ordering, so runOrder must be explicitly set.\n            // Set to 5 to ensure this runs after all OrcaBusGamma stage steps complete.\n            // (Gamma deployment typically uses 2 steps, so 5 provides adequate buffer)\n            runOrder: 5,\n            // 60-minute timeout allows queued pipeline executions to proceed if approval expires\n            timeout: Duration.minutes(60),\n          }),\n        ],\n      },\n    );\n\n    cdkPipeline.addStage(\n      new DeploymentStage(\n        this,\n        \"OrcaBusProd\",\n        stageEnv.prod,\n        props.stackName,\n        props.stack,\n        props.stackConfig.prod,\n        props.githubRepo,\n        props.githubBranch,\n      ),\n    );\n\n    cdkPipeline.buildPipeline();\n\n    if (stripAssetsFromAssembly) {\n      cdkPipeline.pipeline.artifactBucket.grantReadWrite(\n        stripAssetsFromAssembly.project,\n      );\n    }\n\n    if (props.enableSlackNotification ?? true) {\n      const alertsBuildSlackConfigArn = StringParameter.valueForStringParameter(\n        this,\n        \"/chatbot_arn/slack/alerts-build\",\n      );\n      const target = SlackChannelConfiguration.fromSlackChannelConfigurationArn(\n        this,\n        \"SlackChannelConfiguration\",\n        alertsBuildSlackConfigArn,\n      );\n\n      this.pipeline.notifyOn(\"PipelineSlackNotification\", target, {\n        events: props.notificationEvents || [\n          PipelineNotificationEvents.PIPELINE_EXECUTION_FAILED,\n        ],\n        detailType: DetailType.FULL,\n        notificationRuleName: `OrcaBus-${props.pipelineName}`,\n      });\n    }\n  }\n}\n\n/**\n * Properties for ManualApprovalActionStep with required runOrder.\n */\ninterface ManualApprovalActionStepProps extends ManualApprovalActionProps {\n  /**\n   * The run order for this action in the pipeline stage. The stage Pre/Post order does not apply to this custom\n   * step/action, you need to explicitly set the runOrder.\n   */\n  runOrder: number;\n}\n/**\n * Custom manual approval step for CDK CodePipeline.\n *\n * This class bridges the gap to enable using ManualApprovalAction within a Step class,\n * making it compatible with cdk.pipelines constructs.\n *\n * @param id - The unique identifier for the step.\n * @param options - The properties for the manual approval action, including\n */\nclass ManualApprovalActionStep\n  extends Step\n  implements ICodePipelineActionFactory\n{\n  private readonly manualApprovalActionProps: ManualApprovalActionStepProps;\n  constructor(id: string, options: ManualApprovalActionStepProps) {\n    super(id);\n    this.manualApprovalActionProps = options;\n  }\n\n  public produceAction(\n    stage: IStage,\n    options: ProduceActionOptions,\n  ): CodePipelineActionFactoryResult {\n    stage.addAction(new ManualApprovalAction(this.manualApprovalActionProps));\n\n    return { runOrdersConsumed: 1 };\n  }\n}\n\nclass DeploymentStage extends Stage {\n  constructor(\n    scope: Construct,\n    environmentName: string,\n    env: Environment,\n    stackName: string,\n    stackClass: new (scope: Construct, id: string, props: any) => Stack,\n    appStackProps: any,\n    githubRepo: string,\n    githubBranch?: string,\n  ) {\n    super(scope, environmentName, { env: env });\n\n    let source = `https://github.com/OrcaBus/${githubRepo}`;\n    if (githubBranch !== undefined && githubBranch !== \"main\") {\n      source = `${source}/tree/${githubBranch}`;\n    }\n\n    new stackClass(this, stackName, {\n      env: env,\n      tags: {\n        \"umccr-org:Product\": \"OrcaBus\",\n        \"umccr-org:Creator\": \"CDK\",\n        \"umccr-org:Service\": stackName,\n        \"umccr-org:Source\": source,\n      },\n      ...appStackProps,\n    });\n  }\n}\n"]}
|
|
315
|
+
class FailOnDriftBuildStep extends pipelines_1.CodeBuildStep {
|
|
316
|
+
constructor(id, { accountEnv, stackId, cdkCommand, installCommand, }) {
|
|
317
|
+
const cdkInstall = installCommand
|
|
318
|
+
? installCommand
|
|
319
|
+
: "pnpm install --frozen-lockfile --ignore-scripts";
|
|
320
|
+
super(id, {
|
|
321
|
+
commands: [
|
|
322
|
+
"node -v",
|
|
323
|
+
"npm install --global corepack@latest",
|
|
324
|
+
"corepack --version",
|
|
325
|
+
"corepack enable",
|
|
326
|
+
cdkInstall,
|
|
327
|
+
`LOOKUP_ROLE_ARN="arn:aws:iam::${accountEnv.account}:role/cdk-hnb659fds-lookup-role-${accountEnv.account}-${accountEnv.region}"`,
|
|
328
|
+
'SESSION_NAME="drift-check"',
|
|
329
|
+
'read AWS_ACCESS_KEY_ID AWS_SECRET_ACCESS_KEY AWS_SESSION_TOKEN < <(aws sts assume-role --role-arn "$LOOKUP_ROLE_ARN" --role-session-name "$SESSION_NAME" --duration-seconds 900 --query \'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]\' --output text)',
|
|
330
|
+
"export AWS_ACCESS_KEY_ID AWS_SECRET_ACCESS_KEY AWS_SESSION_TOKEN",
|
|
331
|
+
`export AWS_DEFAULT_REGION="${accountEnv.region}"`,
|
|
332
|
+
"aws sts get-caller-identity",
|
|
333
|
+
`if ${cdkCommand} ls | grep -Fq "${stackId}"; then echo "Stack ${stackId} found; checking for drift..."; ${cdkCommand} drift "${stackId}" -e --fail; else echo "Stack not found in cdk ls; skipping drift check."; fi`,
|
|
334
|
+
],
|
|
335
|
+
rolePolicyStatements: [
|
|
336
|
+
new aws_iam_1.PolicyStatement({
|
|
337
|
+
actions: ["sts:AssumeRole"],
|
|
338
|
+
resources: [
|
|
339
|
+
`arn:aws:iam::${accountEnv.account}:role/cdk-hnb659fds-lookup-role-${accountEnv.account}-${accountEnv.region}`,
|
|
340
|
+
],
|
|
341
|
+
}),
|
|
342
|
+
],
|
|
343
|
+
});
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline.js","sourceRoot":"","sources":["pipeline.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport { Duration, Environment, Stack, Stage } from \"aws-cdk-lib\";\nimport {\n  BuildSpec,\n  ComputeType,\n  IProject,\n  LinuxArmBuildImage,\n  PipelineProject,\n} from \"aws-cdk-lib/aws-codebuild\";\nimport { StringParameter } from \"aws-cdk-lib/aws-ssm\";\nimport {\n  CodeBuildStep,\n  CodePipeline,\n  CodePipelineActionFactoryResult,\n  CodePipelineSource,\n  ICodePipelineActionFactory,\n  ProduceActionOptions,\n  Step,\n} from \"aws-cdk-lib/pipelines\";\nimport {\n  Pipeline,\n  CfnPipeline,\n  PipelineType,\n  PipelineNotificationEvents,\n  IStage,\n  Artifact,\n} from \"aws-cdk-lib/aws-codepipeline\";\nimport {\n  BETA_ENVIRONMENT,\n  GAMMA_ENVIRONMENT,\n  PROD_ENVIRONMENT,\n} from \"./config\";\nimport { SlackChannelConfiguration } from \"aws-cdk-lib/aws-chatbot\";\nimport { DetailType } from \"aws-cdk-lib/aws-codestarnotifications\";\nimport { CrossDeploymentArtifactBucket } from \"./artifact-bucket\";\nimport {\n  CodeBuildAction,\n  ManualApprovalAction,\n  ManualApprovalActionProps,\n} from \"aws-cdk-lib/aws-codepipeline-actions\";\nimport { PolicyStatement } from \"aws-cdk-lib/aws-iam\";\n\n/**\n * The default partial build spec for the synth step in the pipeline.\n */\nexport const DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC = {\n  phases: {\n    install: {\n      \"runtime-versions\": {\n        nodejs: \"22.x\",\n      },\n    },\n  },\n};\n\nexport interface StageEnvProps {\n  /**\n   * The environment for the beta stage\n   */\n  readonly beta: Environment;\n  /**\n   * The environment for the gamma stage\n   */\n  readonly gamma: Environment;\n  /**\n   * The environment for the prod stage\n   */\n  readonly prod: Environment;\n}\n\nexport interface StackConfigProps {\n  /**\n   * The configuration for the beta (dev) stage\n   */\n  readonly beta: Record<string, any>;\n  /**\n   * The configuration for the gamma (stg) stage\n   */\n  readonly gamma: Record<string, any>;\n  /**\n   * The configuration for the prod stage\n   */\n  readonly prod: Record<string, any>;\n}\n\n/**\n * Configuration for pre-deployment drift detection checks.\n */\nexport interface DriftCheckConfig {\n  /**\n   * CDK CLI entrypoint used to run the drift command.\n   * Examples: \"pnpm cdk\", \"pnpm cdk-stateful\", \"pnpm cdk-stateless\".\n   * Must support: \"drift <stackId>\".\n   */\n  readonly cdkCommand: string;\n  /**\n   * Command to install dependencies before running CDK.\n   * If your app is in a subdirectory, prefix with \"cd <dir> &&\".\n   * Example: \"cd dev && pnpm install --frozen-lockfile --ignore-scripts\"\n   *\n   * Default: \"pnpm install --frozen-lockfile --ignore-scripts\"\n   */\n  readonly installCommand?: string;\n}\n\nexport interface CodeBuildStepProps {\n  /**\n   * the main command for the build step to run\n   */\n  readonly command: string[];\n  /**\n   * Partial buildspec for this CodeBuildStep\n   */\n  readonly partialBuildSpec?: Record<string, any>;\n}\n\nexport interface DeploymentStackPipelineProps {\n  /**\n   * The GitHub branch name the pipeline will listen to.\n   * Avoid using branch names that contain special characters such as parentheses.\n   * Allowed special characters are: \"+ - = . _ : / @\".\n   * This restriction is due to AWS resource tagging requirements.\n   */\n  readonly githubBranch: string;\n  /**\n   * The repository name that exist in the 'OrcaBus' github organisation. e.g. `a-micro-service-repo`\n   */\n  readonly githubRepo: string;\n  /**\n   * The stack to which the pipeline will be deploying to its respective account\n   */\n  readonly stack: any;\n  /**\n   * The stack name (in cloudformation) for the stack defined in `stack`. The stack name will prepend with the stage\n   * name e.g. `OrcaBusBeta-<stackName>`, `OrcaBusGamma-<stackName>`, `OrcaBusProd-<stackName>`\n   */\n  readonly stackName: string;\n  /**\n   * The stack configuration/constants that will be passed to the stack props.\n   */\n  readonly stackConfig: StackConfigProps;\n  /**\n   * The pipeline name in the bastion account.\n   */\n  readonly pipelineName: string;\n  /**\n   * The list of patterns of Git repository file paths that, when a commit is pushed, are to be INCLUDED as criteria that starts the pipeline.\n   *\n   * https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-codepipeline-pipeline-gitfilepathfiltercriteria.html\n   *\n   */\n  readonly includedFilePaths?: string[];\n  /**\n   * The list of patterns of Git repository file paths that, when a commit is pushed, are to be EXCLUDED from starting the pipeline.\n   *\n   * https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-codepipeline-pipeline-gitfilepathfiltercriteria.html\n   *\n   */\n  readonly excludedFilePaths?: string[];\n  /**\n   * The command to run to synth the cdk stack which also installing the cdk dependencies. e.g. [\"pnpm install --frozen-lockfile\", \"pnpm cdk synth\"]\n   */\n  readonly cdkSynthCmd: string[];\n  /**\n   * The location where the cdk output will be stored.\n   *\n   * @default cdk.out\n   */\n  readonly cdkOut?: string;\n  /**\n   * Additional configuration for the CodeBuild step during the CDK synth phase. It will passed as the `partialBuildSpec` to the `CodeBuildStep`.\n   *\n   * @default DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC\n   */\n  readonly synthBuildSpec?: Record<string, any>;\n  /**\n   * Configuration for the CodeBuild step that runs unit tests for the main application code.\n   * This step will execute in parallel with {@link unitIacTestConfig} as part of the synth stage dependencies.\n   * Both must succeed before the synth step runs.\n   *\n   * ensure your command includes 'cd' to the main app directory, as the build context starts from the root.\n   */\n  readonly unitAppTestConfig: CodeBuildStepProps;\n  /**\n   * Configuration for the CodeBuild step that runs unit tests for Infrastructure-as-Code (IaC) at the repository root.\n   * This step will execute in parallel with {@link unitAppTestConfig} as part of the synth stage dependencies.\n   * Both must succeed before the synth step runs.\n   *\n   * The default command will be from the root of the repo: [\"npm install --global corepack@latest\", \"corepack enable\", \"make install\", \"make test\"]\n   */\n  readonly unitIacTestConfig?: CodeBuildStepProps;\n  /**\n   * The stage environment for the deployment stack\n   */\n  readonly stageEnv?: StageEnvProps;\n  /**\n   * Enable notification to the 'alerts-build' slack channel.\n   * @default True\n   */\n  readonly enableSlackNotification?: boolean;\n  /**\n   * The pipeline notification events that will trigger a Slack channel notification.\n   * Only applies if `enableSlackNotification` is set to true.\n   *\n   * @default [PipelineNotificationEvents.PIPELINE_EXECUTION_FAILED] –\n   *   Only failed pipeline executions will trigger a notification.\n   */\n  readonly notificationEvents?: PipelineNotificationEvents[];\n\n  /**\n   * Whether to reuse the existing artifact bucket for cross-deployment pipelines.\n   * If set to true, it will look up the existing artifact bucket in the TOOLCHAIN account.\n   *\n   * @default True\n   */\n  readonly reuseExistingArtifactBucket?: boolean;\n\n  /**\n   * Remove assets from the CDK assembly pre-deployment to prevent hitting CodePipeline's 256 MB artifact size limit.\n   * Useful when CDK assets (Lambda code, Docker images, etc.) are large.\n   *\n   * @see https://github.com/aws/aws-cdk/issues/9917\n   */\n  readonly stripAssemblyAssets?: boolean;\n  /**\n   * Configuration for drift detection checks before deployment.\n   * If specified, the pipeline will check for CloudFormation drift and fail if detected.\n   */\n  readonly driftCheckConfig?: DriftCheckConfig;\n}\n\n/**\n * A CDK construct that creates a deployment pipeline across environments for the OrcaBus project.\n *\n * Prerequisite: Ensure that the \"CrossDeploymentArtifactBucket\" stack is deployed in the TOOLCHAIN account\n * before using this construct.\n */\nexport class DeploymentStackPipeline extends Construct {\n  /**\n   * The code pipeline construct that is created.\n   */\n  readonly pipeline: Pipeline;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: DeploymentStackPipelineProps,\n  ) {\n    super(scope, id);\n\n    const codeStarArn = StringParameter.valueForStringParameter(\n      this,\n      \"codestar_github_arn\",\n    );\n    const codeStarSourceActionName = \"pipeline-src\";\n    const sourceFile = CodePipelineSource.connection(\n      `OrcaBus/${props.githubRepo}`,\n      props.githubBranch,\n      {\n        connectionArn: codeStarArn,\n        actionName: codeStarSourceActionName,\n        triggerOnPush: true,\n      },\n    );\n\n    const isReusingExistingArtifactBucket =\n      props.reuseExistingArtifactBucket ?? true;\n    const artifactBucket = isReusingExistingArtifactBucket\n      ? CrossDeploymentArtifactBucket.fromLookup(this).artifactBucket\n      : undefined;\n\n    this.pipeline = new Pipeline(this, \"DeploymentCodePipeline\", {\n      artifactBucket: artifactBucket,\n      pipelineType: PipelineType.V2,\n      pipelineName: props.pipelineName,\n      crossAccountKeys: true,\n      // enable restartExecutionOnUpdate\n      // https://stackoverflow.com/questions/75701776/updatepipeline-stage-in-cdk-pipeline-is-cancelled\n      restartExecutionOnUpdate: true,\n    });\n\n    if (props.includedFilePaths || props.excludedFilePaths) {\n      const filePaths: Record<string, string[]> = {};\n\n      if (props.includedFilePaths) {\n        filePaths[\"Includes\"] = props.includedFilePaths;\n      }\n      if (props.excludedFilePaths) {\n        filePaths[\"Excludes\"] = props.excludedFilePaths;\n      }\n\n      // Add event filter to only trigger if the push event is from `deploy` directory\n      const cfnPipeline = this.pipeline.node.defaultChild as CfnPipeline;\n      cfnPipeline.addPropertyOverride(\"Triggers\", [\n        {\n          GitConfiguration: {\n            Push: [\n              {\n                Branches: {\n                  Includes: [props.githubBranch],\n                },\n                FilePaths: filePaths,\n              },\n            ],\n            SourceActionName: codeStarSourceActionName,\n          },\n          ProviderType: \"CodeStarSourceConnection\",\n        },\n      ]);\n    }\n\n    // Add unit test for IaC at the root of the\n    const {\n      command: unitIacTestCommand = [\n        \"npm install --global corepack@latest\",\n        \"corepack enable\",\n        \"make install\",\n        \"make test\",\n      ],\n      partialBuildSpec: unitIacPartialBuildSpec = undefined,\n    } = props.unitIacTestConfig || {};\n    const unitIacTest = new CodeBuildStep(\"UnitIacTest\", {\n      commands: unitIacTestCommand,\n      input: sourceFile,\n      buildEnvironment: {\n        privileged: true,\n        computeType: ComputeType.LARGE,\n        buildImage: LinuxArmBuildImage.AMAZON_LINUX_2_STANDARD_3_0,\n        environmentVariables: {\n          NODE_OPTIONS: {\n            value: \"--max-old-space-size=8192\",\n          },\n        },\n      },\n      partialBuildSpec: unitIacPartialBuildSpec\n        ? BuildSpec.fromObject(unitIacPartialBuildSpec)\n        : undefined,\n    });\n\n    // Adding unit test for the main app\n    const {\n      command: unitAppTestCommand,\n      partialBuildSpec: unitAppPartialBuildSpec = undefined,\n    } = props.unitAppTestConfig;\n    const unitAppTest = new CodeBuildStep(\"UnitAppTest\", {\n      commands: unitAppTestCommand,\n      input: sourceFile,\n      buildEnvironment: {\n        privileged: true,\n        computeType: ComputeType.LARGE,\n        buildImage: LinuxArmBuildImage.AMAZON_LINUX_2_STANDARD_3_0,\n        environmentVariables: {\n          NODE_OPTIONS: {\n            value: \"--max-old-space-size=8192\",\n          },\n        },\n      },\n      partialBuildSpec: unitAppPartialBuildSpec\n        ? BuildSpec.fromObject(unitAppPartialBuildSpec)\n        : undefined,\n    });\n\n    const { synthBuildSpec = DEFAULT_SYNTH_STEP_PARTIAL_BUILD_SPEC } = props;\n    const synthStep = new CodeBuildStep(\"CdkSynth\", {\n      installCommands: [\n        \"node -v\",\n        \"npm install --global corepack@latest\",\n        \"corepack --version\",\n        \"corepack enable\",\n      ],\n      commands: props.cdkSynthCmd,\n      input: sourceFile,\n      primaryOutputDirectory: props.cdkOut || \"cdk.out\",\n      partialBuildSpec: BuildSpec.fromObject(synthBuildSpec),\n    });\n    synthStep.addStepDependency(unitIacTest);\n    synthStep.addStepDependency(unitAppTest);\n\n    const cdkPipeline = new CodePipeline(this, \"CDKCodePipeline\", {\n      codePipeline: this.pipeline,\n      synth: synthStep,\n      selfMutation: true,\n      codeBuildDefaults: {\n        buildEnvironment: {\n          computeType: ComputeType.LARGE,\n          buildImage: LinuxArmBuildImage.AMAZON_LINUX_2_STANDARD_3_0,\n          environmentVariables: {\n            NODE_OPTIONS: {\n              value: \"--max-old-space-size=8192\",\n            },\n          },\n        },\n      },\n    });\n\n    const defaultStageEnv: StageEnvProps = {\n      beta: BETA_ENVIRONMENT,\n      gamma: GAMMA_ENVIRONMENT,\n      prod: PROD_ENVIRONMENT,\n    };\n    const stageEnv = props.stageEnv || defaultStageEnv;\n\n    // After assets are published, they can be removed from the assembly directory\n    // to help prevent hitting the CodePipeline artifact limit.\n    // https://github.com/aws/aws-cdk/issues/9917\n    let stripAssetsFromAssembly: CodeBuildStep | undefined;\n    if (props.stripAssemblyAssets) {\n      stripAssetsFromAssembly = new CodeBuildStep(\"StripAssetsFromAssembly\", {\n        input: cdkPipeline.cloudAssemblyFileSet,\n        commands: [\n          'S3_PATH=${CODEBUILD_SOURCE_VERSION#\"arn:aws:s3:::\"}',\n          \"ZIP_ARCHIVE=$(basename $S3_PATH)\",\n          \"echo $S3_PATH\",\n          \"echo $ZIP_ARCHIVE\",\n          \"ls\",\n          \"rm -rfv asset.*\",\n          \"zip -r -q -A $ZIP_ARCHIVE *\",\n          \"ls\",\n          \"aws s3 cp $ZIP_ARCHIVE s3://$S3_PATH\",\n        ],\n      });\n\n      cdkPipeline.addWave(\"BeforeStageDeployment\", {\n        pre: [stripAssetsFromAssembly],\n      });\n    }\n\n    // Construct function to get StackId for drift check\n    const rootStackName = Stack.of(this).stackName;\n    const constructId = this.node.id;\n    const getStackId = (envName: string) =>\n      `${rootStackName}/${constructId}/${envName}/${props.stackName}`;\n\n    // Drift check config\n    const isDriftCheckStep = !!props.driftCheckConfig;\n    const cdkInstallCmd =\n      props.driftCheckConfig?.installCommand ??\n      \"pnpm install --frozen-lockfile --ignore-scripts\";\n    const cdkRunCmd = props.driftCheckConfig?.cdkCommand ?? ``;\n\n    const betaEnvName = \"OrcaBusBeta\";\n    cdkPipeline.addStage(\n      new DeploymentStage(\n        this,\n        betaEnvName,\n        stageEnv.beta,\n        props.stackName,\n        props.stack,\n        props.stackConfig.beta,\n        props.githubRepo,\n        props.githubBranch,\n      ),\n      {\n        pre: isDriftCheckStep\n          ? [\n              new FailOnDriftBuildStep(\"DriftOnFailBetaCheck\", {\n                accountEnv: stageEnv.beta,\n                stackId: getStackId(betaEnvName),\n                cdkCommand: cdkRunCmd,\n                installCommand: cdkInstallCmd,\n              }),\n            ]\n          : undefined,\n      },\n    );\n\n    /**\n     * GAMMA\n     */\n    const gammaEnvName = \"OrcaBusGamma\";\n\n    cdkPipeline.addStage(\n      new DeploymentStage(\n        this,\n        gammaEnvName,\n        stageEnv.gamma,\n        props.stackName,\n        props.stack,\n        props.stackConfig.gamma,\n        props.githubRepo,\n        props.githubBranch,\n      ),\n      {\n        pre: isDriftCheckStep\n          ? [\n              new FailOnDriftBuildStep(\"DriftOnFailGammaCheck\", {\n                accountEnv: stageEnv.gamma,\n                stackId: getStackId(gammaEnvName),\n                cdkCommand: cdkRunCmd,\n                installCommand: cdkInstallCmd,\n              }),\n            ]\n          : undefined,\n        post: [\n          new ManualApprovalActionStep(\"PromoteToProd\", {\n            actionName: \"PromoteToProd\",\n            // Custom steps bypass stage pre/post ordering, so runOrder must be explicitly set.\n            // Set to 5 to ensure this runs after all OrcaBusGamma stage steps complete.\n            // (Gamma deployment typically uses 2 steps, so 5 provides adequate buffer)\n            runOrder: 5,\n            // 60-minute timeout allows queued pipeline executions to proceed if approval expires\n            timeout: Duration.minutes(60),\n          }),\n        ],\n      },\n    );\n\n    /**\n     * PROD\n     */\n    const prodEnvName = \"OrcaBusProd\";\n\n    cdkPipeline.addStage(\n      new DeploymentStage(\n        this,\n        prodEnvName,\n        stageEnv.prod,\n        props.stackName,\n        props.stack,\n        props.stackConfig.prod,\n        props.githubRepo,\n        props.githubBranch,\n      ),\n      {\n        pre: isDriftCheckStep\n          ? [\n              new FailOnDriftBuildStep(\"DriftOnFailProdCheck\", {\n                accountEnv: stageEnv.prod,\n                stackId: getStackId(prodEnvName),\n                cdkCommand: cdkRunCmd,\n                installCommand: cdkInstallCmd,\n              }),\n            ]\n          : undefined,\n      },\n    );\n\n    cdkPipeline.buildPipeline();\n\n    if (stripAssetsFromAssembly) {\n      cdkPipeline.pipeline.artifactBucket.grantReadWrite(\n        stripAssetsFromAssembly.project,\n      );\n    }\n\n    if (props.enableSlackNotification ?? true) {\n      const alertsBuildSlackConfigArn = StringParameter.valueForStringParameter(\n        this,\n        \"/chatbot_arn/slack/alerts-build\",\n      );\n      const target = SlackChannelConfiguration.fromSlackChannelConfigurationArn(\n        this,\n        \"SlackChannelConfiguration\",\n        alertsBuildSlackConfigArn,\n      );\n\n      this.pipeline.notifyOn(\"PipelineSlackNotification\", target, {\n        events: props.notificationEvents || [\n          PipelineNotificationEvents.PIPELINE_EXECUTION_FAILED,\n        ],\n        detailType: DetailType.FULL,\n        notificationRuleName: `OrcaBus-${props.pipelineName}`,\n      });\n    }\n  }\n}\n\n/**\n * Properties for ManualApprovalActionStep with required runOrder.\n */\ninterface ManualApprovalActionStepProps extends ManualApprovalActionProps {\n  /**\n   * The run order for this action in the pipeline stage. The stage Pre/Post order does not apply to this custom\n   * step/action, you need to explicitly set the runOrder.\n   */\n  runOrder: number;\n}\n/**\n * Custom manual approval step for CDK CodePipeline.\n *\n * This class bridges the gap to enable using ManualApprovalAction within a Step class,\n * making it compatible with cdk.pipelines constructs.\n *\n * @param id - The unique identifier for the step.\n * @param options - The properties for the manual approval action, including\n */\nclass ManualApprovalActionStep\n  extends Step\n  implements ICodePipelineActionFactory\n{\n  private readonly manualApprovalActionProps: ManualApprovalActionStepProps;\n  constructor(id: string, options: ManualApprovalActionStepProps) {\n    super(id);\n    this.manualApprovalActionProps = options;\n  }\n\n  public produceAction(\n    stage: IStage,\n    options: ProduceActionOptions,\n  ): CodePipelineActionFactoryResult {\n    stage.addAction(new ManualApprovalAction(this.manualApprovalActionProps));\n\n    return { runOrdersConsumed: 1 };\n  }\n}\n\nclass DeploymentStage extends Stage {\n  constructor(\n    scope: Construct,\n    environmentName: string,\n    env: Environment,\n    stackName: string,\n    stackClass: new (scope: Construct, id: string, props: any) => Stack,\n    appStackProps: any,\n    githubRepo: string,\n    githubBranch?: string,\n  ) {\n    super(scope, environmentName, { env: env });\n\n    let source = `https://github.com/OrcaBus/${githubRepo}`;\n    if (githubBranch !== undefined && githubBranch !== \"main\") {\n      source = `${source}/tree/${githubBranch}`;\n    }\n\n    new stackClass(this, stackName, {\n      env: env,\n      tags: {\n        \"umccr-org:Product\": \"OrcaBus\",\n        \"umccr-org:Creator\": \"CDK\",\n        \"umccr-org:Service\": stackName,\n        \"umccr-org:Source\": source,\n      },\n      ...appStackProps,\n    });\n  }\n}\n\nexport interface FailOnDriftBuildStepProps {\n  /**\n   * AWS account and region where the drift check runs.\n   * Used to assume the CDK lookup role and set AWS_DEFAULT_REGION.\n   */\n  readonly accountEnv: Environment;\n  /**\n   * Fully qualified CDK stack ID to check for drift.\n   *\n   * Format: `<rootStack>/<constructId>/<envName>/<stackName>`\n   *\n   * Example: `DevStack/DeploymentPipeline/OrcaBusBeta/TestStack`\n   */\n  readonly stackId: string;\n  /**\n   * CDK CLI entrypoint used to run the drift command.\n   * Examples: \"pnpm cdk\", \"pnpm cdk-stateful\", \"pnpm cdk-stateless\".\n   * Must support: \"drift <stackId>\".\n   */\n  readonly cdkCommand: string;\n  /**\n   * Command to install dependencies before running CDK.\n   * If your app is in a subdirectory, prefix with \"cd <dir> &&\".\n   * Example: \"cd dev && pnpm install --frozen-lockfile --ignore-scripts\"\n   *\n   * Default: \"pnpm install --frozen-lockfile --ignore-scripts\"\n   */\n  readonly installCommand?: string;\n}\n\nclass FailOnDriftBuildStep extends CodeBuildStep {\n  constructor(\n    id: string,\n    {\n      accountEnv,\n      stackId,\n      cdkCommand,\n      installCommand,\n    }: FailOnDriftBuildStepProps,\n  ) {\n    const cdkInstall = installCommand\n      ? installCommand\n      : \"pnpm install --frozen-lockfile --ignore-scripts\";\n\n    super(id, {\n      commands: [\n        \"node -v\",\n        \"npm install --global corepack@latest\",\n        \"corepack --version\",\n        \"corepack enable\",\n        cdkInstall,\n\n        `LOOKUP_ROLE_ARN=\"arn:aws:iam::${accountEnv.account}:role/cdk-hnb659fds-lookup-role-${accountEnv.account}-${accountEnv.region}\"`,\n        'SESSION_NAME=\"drift-check\"',\n        'read AWS_ACCESS_KEY_ID AWS_SECRET_ACCESS_KEY AWS_SESSION_TOKEN < <(aws sts assume-role --role-arn \"$LOOKUP_ROLE_ARN\" --role-session-name \"$SESSION_NAME\" --duration-seconds 900 --query \\'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]\\' --output text)',\n        \"export AWS_ACCESS_KEY_ID AWS_SECRET_ACCESS_KEY AWS_SESSION_TOKEN\",\n        `export AWS_DEFAULT_REGION=\"${accountEnv.region}\"`,\n        \"aws sts get-caller-identity\",\n\n        `if ${cdkCommand} ls | grep -Fq \"${stackId}\"; then echo \"Stack ${stackId} found; checking for drift...\"; ${cdkCommand} drift \"${stackId}\" -e --fail; else echo \"Stack not found in cdk ls; skipping drift check.\"; fi`,\n      ],\n      rolePolicyStatements: [\n        new PolicyStatement({\n          actions: [\"sts:AssumeRole\"],\n          resources: [\n            `arn:aws:iam::${accountEnv.account}:role/cdk-hnb659fds-lookup-role-${accountEnv.account}-${accountEnv.region}`,\n          ],\n        }),\n      ],\n    });\n  }\n}\n"]}
|
package/dynamodb/index.js
CHANGED
|
@@ -40,7 +40,7 @@ const dynamodb = __importStar(require("aws-cdk-lib/aws-dynamodb"));
|
|
|
40
40
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
41
41
|
const config_1 = require("./config");
|
|
42
42
|
class DynamoDbPartitionedConstruct extends constructs_1.Construct {
|
|
43
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.dynamodb.DynamoDbPartitionedConstruct", version: "
|
|
43
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.dynamodb.DynamoDbPartitionedConstruct", version: "1.0.1" };
|
|
44
44
|
table;
|
|
45
45
|
constructor(scope, id, props) {
|
|
46
46
|
super(scope, id);
|
|
@@ -75,7 +75,7 @@ class DynamoDbPartitionedConstruct extends constructs_1.Construct {
|
|
|
75
75
|
}
|
|
76
76
|
exports.DynamoDbPartitionedConstruct = DynamoDbPartitionedConstruct;
|
|
77
77
|
class DynamoDbNonPartitionedConstruct extends constructs_1.Construct {
|
|
78
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.dynamodb.DynamoDbNonPartitionedConstruct", version: "
|
|
78
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.dynamodb.DynamoDbNonPartitionedConstruct", version: "1.0.1" };
|
|
79
79
|
table;
|
|
80
80
|
constructor(scope, id, props) {
|
|
81
81
|
super(scope, id);
|
package/ecs/index.js
CHANGED
|
@@ -55,7 +55,7 @@ exports.LAMBDA_ARCHITECTURE_MAP = {
|
|
|
55
55
|
['ARM64']: lambda.Architecture.ARM_64
|
|
56
56
|
};
|
|
57
57
|
class EcsFargateTaskConstruct extends constructs_1.Construct {
|
|
58
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.ecs.EcsFargateTaskConstruct", version: "
|
|
58
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.ecs.EcsFargateTaskConstruct", version: "1.0.1" };
|
|
59
59
|
cluster;
|
|
60
60
|
taskDefinition;
|
|
61
61
|
taskExecutionRole;
|
|
@@ -17,7 +17,7 @@ var SfnEventStatus;
|
|
|
17
17
|
SfnEventStatus["ABORTED"] = "ABORTED";
|
|
18
18
|
})(SfnEventStatus || (exports.SfnEventStatus = SfnEventStatus = {}));
|
|
19
19
|
class SfnSlackNotification extends constructs_1.Construct {
|
|
20
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.eventbridgeRule.SfnSlackNotification", version: "
|
|
20
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.eventbridgeRule.SfnSlackNotification", version: "1.0.1" };
|
|
21
21
|
rule;
|
|
22
22
|
constructor(scope, id, props) {
|
|
23
23
|
super(scope, id);
|
package/lambda/index.js
CHANGED
|
@@ -57,7 +57,7 @@ function getPythonUvDockerImage() {
|
|
|
57
57
|
return aws_cdk_lib_1.DockerImage.fromBuild(path_1.default.join(__dirname, 'build_python'));
|
|
58
58
|
}
|
|
59
59
|
class PythonUvFunction extends aws_lambda_python_alpha_1.PythonFunction {
|
|
60
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.lambda.PythonUvFunction", version: "
|
|
60
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.lambda.PythonUvFunction", version: "1.0.1" };
|
|
61
61
|
// Class constructs, to be used for caching the layers
|
|
62
62
|
// This means that if there are multiple lambdas throughout the stack
|
|
63
63
|
// They will all use the same layer
|
package/monitored-queue/index.js
CHANGED
|
@@ -13,7 +13,7 @@ const aws_cloudwatch_actions_1 = require("aws-cdk-lib/aws-cloudwatch-actions");
|
|
|
13
13
|
* SNS topic.
|
|
14
14
|
*/
|
|
15
15
|
class MonitoredQueue extends constructs_1.Construct {
|
|
16
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.monitoredQueue.MonitoredQueue", version: "
|
|
16
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.monitoredQueue.MonitoredQueue", version: "1.0.1" };
|
|
17
17
|
queue;
|
|
18
18
|
deadLetterQueue;
|
|
19
19
|
alarm;
|
|
@@ -7,7 +7,7 @@ const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
|
7
7
|
* A construct which represents a named role that a Lambda function can assume.
|
|
8
8
|
*/
|
|
9
9
|
class NamedLambdaRole extends aws_iam_1.Role {
|
|
10
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.namedLambdaRole.NamedLambdaRole", version: "
|
|
10
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.namedLambdaRole.NamedLambdaRole", version: "1.0.1" };
|
|
11
11
|
constructor(scope, id, props) {
|
|
12
12
|
super(scope, id, {
|
|
13
13
|
assumedBy: new aws_iam_1.ServicePrincipal("lambda.amazonaws.com"),
|
package/package.json
CHANGED
|
@@ -15,7 +15,7 @@ const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
|
15
15
|
* to the provider framework.
|
|
16
16
|
*/
|
|
17
17
|
class ProviderFunction extends constructs_1.Construct {
|
|
18
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.provider.ProviderFunction", version: "
|
|
18
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.provider.ProviderFunction", version: "1.0.1" };
|
|
19
19
|
_function;
|
|
20
20
|
_response;
|
|
21
21
|
constructor(scope, id, props) {
|
|
@@ -23,7 +23,7 @@ exports.VPC_LOOKUP_PROPS = {
|
|
|
23
23
|
* Helper for looking up the shared OrcaBus VPC.
|
|
24
24
|
*/
|
|
25
25
|
class OrcaBusVpc {
|
|
26
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.sharedConfig.networking.OrcaBusVpc", version: "
|
|
26
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.sharedConfig.networking.OrcaBusVpc", version: "1.0.1" };
|
|
27
27
|
/**
|
|
28
28
|
* The shared VPC that is used by OrcaBus.
|
|
29
29
|
* @param scope
|
|
@@ -42,7 +42,7 @@ exports.SHARED_SECURITY_GROUP_NAME = "OrcaBusSharedComputeSecurityGroup";
|
|
|
42
42
|
* Helper for looking up the shared compute security group by name.
|
|
43
43
|
*/
|
|
44
44
|
class OrcaBusSharedComputeSecurityGroup {
|
|
45
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.sharedConfig.networking.OrcaBusSharedComputeSecurityGroup", version: "
|
|
45
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.sharedConfig.networking.OrcaBusSharedComputeSecurityGroup", version: "1.0.1" };
|
|
46
46
|
/**
|
|
47
47
|
* The shared security group that is used by compute resources to access the database.
|
|
48
48
|
* @param scope
|
package/shared-config/slack.js
CHANGED
|
@@ -11,7 +11,7 @@ exports.SLACK_ALERTS_SNS_TOPIC = "AwsChatBotTopic-alerts";
|
|
|
11
11
|
* A helper class to construct the arn for the slack SNS topic.
|
|
12
12
|
*/
|
|
13
13
|
class SlackAlerts {
|
|
14
|
-
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.sharedConfig.slack.SlackAlerts", version: "
|
|
14
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@orcabus/platform-cdk-constructs.sharedConfig.slack.SlackAlerts", version: "1.0.1" };
|
|
15
15
|
/**
|
|
16
16
|
* Format the ARN for the slack alerts SNS topic for the current stack.
|
|
17
17
|
* @param stack
|