cloudstructs 0.6.30 → 0.6.32

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 CHANGED
@@ -3162,6 +3162,344 @@
3162
3162
  ],
3163
3163
  "symbolId": "src/codecommit-mirror/index:CodeCommitMirrorSourceRepository"
3164
3164
  },
3165
+ "cloudstructs.DmarcAlignment": {
3166
+ "assembly": "cloudstructs",
3167
+ "docs": {
3168
+ "stability": "stable",
3169
+ "summary": "The DMARC alignment mode."
3170
+ },
3171
+ "fqn": "cloudstructs.DmarcAlignment",
3172
+ "kind": "enum",
3173
+ "locationInModule": {
3174
+ "filename": "src/dmarc/index.ts",
3175
+ "line": 29
3176
+ },
3177
+ "members": [
3178
+ {
3179
+ "docs": {
3180
+ "stability": "stable",
3181
+ "summary": "Relaxed alignment mode."
3182
+ },
3183
+ "name": "RELAXED"
3184
+ },
3185
+ {
3186
+ "docs": {
3187
+ "stability": "stable",
3188
+ "summary": "Strict alignment mode."
3189
+ },
3190
+ "name": "STRICT"
3191
+ }
3192
+ ],
3193
+ "name": "DmarcAlignment",
3194
+ "symbolId": "src/dmarc/index:DmarcAlignment"
3195
+ },
3196
+ "cloudstructs.DmarcPolicy": {
3197
+ "assembly": "cloudstructs",
3198
+ "docs": {
3199
+ "stability": "stable",
3200
+ "summary": "The DMARC policy to apply to messages that fail DMARC compliance."
3201
+ },
3202
+ "fqn": "cloudstructs.DmarcPolicy",
3203
+ "kind": "enum",
3204
+ "locationInModule": {
3205
+ "filename": "src/dmarc/index.ts",
3206
+ "line": 11
3207
+ },
3208
+ "members": [
3209
+ {
3210
+ "docs": {
3211
+ "stability": "stable",
3212
+ "summary": "Do not apply any special handling to messages that fail DMARC compliance."
3213
+ },
3214
+ "name": "NONE"
3215
+ },
3216
+ {
3217
+ "docs": {
3218
+ "remarks": "(usually by sending them to spam)",
3219
+ "stability": "stable",
3220
+ "summary": "Quarantine messages that fail DMARC compliance."
3221
+ },
3222
+ "name": "QUARANTINE"
3223
+ },
3224
+ {
3225
+ "docs": {
3226
+ "remarks": "(usually by rejecting them outright)",
3227
+ "stability": "stable",
3228
+ "summary": "Reject messages that fail DMARC compliance."
3229
+ },
3230
+ "name": "REJECT"
3231
+ }
3232
+ ],
3233
+ "name": "DmarcPolicy",
3234
+ "symbolId": "src/dmarc/index:DmarcPolicy"
3235
+ },
3236
+ "cloudstructs.DmarcReporter": {
3237
+ "assembly": "cloudstructs",
3238
+ "base": "constructs.Construct",
3239
+ "docs": {
3240
+ "stability": "stable",
3241
+ "summary": "Creates a DMARC record in Route 53 and invokes a Lambda function to process incoming reports."
3242
+ },
3243
+ "fqn": "cloudstructs.DmarcReporter",
3244
+ "initializer": {
3245
+ "docs": {
3246
+ "stability": "stable"
3247
+ },
3248
+ "locationInModule": {
3249
+ "filename": "src/dmarc/index.ts",
3250
+ "line": 129
3251
+ },
3252
+ "parameters": [
3253
+ {
3254
+ "name": "scope",
3255
+ "type": {
3256
+ "fqn": "constructs.Construct"
3257
+ }
3258
+ },
3259
+ {
3260
+ "name": "id",
3261
+ "type": {
3262
+ "primitive": "string"
3263
+ }
3264
+ },
3265
+ {
3266
+ "name": "props",
3267
+ "type": {
3268
+ "fqn": "cloudstructs.DmarcReporterProps"
3269
+ }
3270
+ }
3271
+ ]
3272
+ },
3273
+ "kind": "class",
3274
+ "locationInModule": {
3275
+ "filename": "src/dmarc/index.ts",
3276
+ "line": 128
3277
+ },
3278
+ "name": "DmarcReporter",
3279
+ "symbolId": "src/dmarc/index:DmarcReporter"
3280
+ },
3281
+ "cloudstructs.DmarcReporterProps": {
3282
+ "assembly": "cloudstructs",
3283
+ "datatype": true,
3284
+ "docs": {
3285
+ "stability": "stable",
3286
+ "summary": "Properties for a DmarcReporter."
3287
+ },
3288
+ "fqn": "cloudstructs.DmarcReporterProps",
3289
+ "kind": "interface",
3290
+ "locationInModule": {
3291
+ "filename": "src/dmarc/index.ts",
3292
+ "line": 43
3293
+ },
3294
+ "name": "DmarcReporterProps",
3295
+ "properties": [
3296
+ {
3297
+ "abstract": true,
3298
+ "docs": {
3299
+ "remarks": "This can be one of the following values:\n- none: Do not apply any special handling to messages that fail DMARC compliance.\n- quarantine: Quarantine messages that fail DMARC compliance.\n- reject: Reject messages that fail DMARC compliance.",
3300
+ "stability": "stable",
3301
+ "summary": "The DMARC policy to apply to messages that fail DMARC compliance."
3302
+ },
3303
+ "immutable": true,
3304
+ "locationInModule": {
3305
+ "filename": "src/dmarc/index.ts",
3306
+ "line": 67
3307
+ },
3308
+ "name": "dmarcPolicy",
3309
+ "type": {
3310
+ "fqn": "cloudstructs.DmarcPolicy"
3311
+ }
3312
+ },
3313
+ {
3314
+ "abstract": true,
3315
+ "docs": {
3316
+ "remarks": "The Lambda\nfunction will be invoked with a SESMessage as event.",
3317
+ "stability": "stable",
3318
+ "summary": "A Lambda function to invoke after the message is saved to S3."
3319
+ },
3320
+ "immutable": true,
3321
+ "locationInModule": {
3322
+ "filename": "src/dmarc/index.ts",
3323
+ "line": 110
3324
+ },
3325
+ "name": "function",
3326
+ "type": {
3327
+ "fqn": "aws-cdk-lib.aws_lambda.IFunction"
3328
+ }
3329
+ },
3330
+ {
3331
+ "abstract": true,
3332
+ "docs": {
3333
+ "stability": "stable",
3334
+ "summary": "The Route 53 hosted zone to create the DMARC record in."
3335
+ },
3336
+ "immutable": true,
3337
+ "locationInModule": {
3338
+ "filename": "src/dmarc/index.ts",
3339
+ "line": 47
3340
+ },
3341
+ "name": "hostedZone",
3342
+ "type": {
3343
+ "fqn": "aws-cdk-lib.aws_route53.IHostedZone"
3344
+ }
3345
+ },
3346
+ {
3347
+ "abstract": true,
3348
+ "docs": {
3349
+ "stability": "stable",
3350
+ "summary": "The SES receipt rule set where a receipt rule will be added."
3351
+ },
3352
+ "immutable": true,
3353
+ "locationInModule": {
3354
+ "filename": "src/dmarc/index.ts",
3355
+ "line": 122
3356
+ },
3357
+ "name": "receiptRuleSet",
3358
+ "type": {
3359
+ "fqn": "aws-cdk-lib.aws_ses.IReceiptRuleSet"
3360
+ }
3361
+ },
3362
+ {
3363
+ "abstract": true,
3364
+ "docs": {
3365
+ "stability": "stable",
3366
+ "summary": "Additional email addresses to send DMARC reports to."
3367
+ },
3368
+ "immutable": true,
3369
+ "locationInModule": {
3370
+ "filename": "src/dmarc/index.ts",
3371
+ "line": 58
3372
+ },
3373
+ "name": "additionalEmailAddresses",
3374
+ "optional": true,
3375
+ "type": {
3376
+ "collection": {
3377
+ "elementtype": {
3378
+ "primitive": "string"
3379
+ },
3380
+ "kind": "array"
3381
+ }
3382
+ }
3383
+ },
3384
+ {
3385
+ "abstract": true,
3386
+ "docs": {
3387
+ "default": "- The new rule is inserted at the beginning of the rule list.",
3388
+ "stability": "stable",
3389
+ "summary": "An existing rule after which the new rule will be placed in the rule set."
3390
+ },
3391
+ "immutable": true,
3392
+ "locationInModule": {
3393
+ "filename": "src/dmarc/index.ts",
3394
+ "line": 117
3395
+ },
3396
+ "name": "afterRule",
3397
+ "optional": true,
3398
+ "type": {
3399
+ "fqn": "aws-cdk-lib.aws_ses.IReceiptRule"
3400
+ }
3401
+ },
3402
+ {
3403
+ "abstract": true,
3404
+ "docs": {
3405
+ "default": "relaxed",
3406
+ "remarks": "This can be one of the following values:\n- relaxed: Use relaxed alignment mode.\n- strict: Use strict alignment mode.",
3407
+ "stability": "stable",
3408
+ "summary": "The alignment mode to use for DKIM signatures."
3409
+ },
3410
+ "immutable": true,
3411
+ "locationInModule": {
3412
+ "filename": "src/dmarc/index.ts",
3413
+ "line": 94
3414
+ },
3415
+ "name": "dmarcDkimAlignment",
3416
+ "optional": true,
3417
+ "type": {
3418
+ "fqn": "cloudstructs.DmarcAlignment"
3419
+ }
3420
+ },
3421
+ {
3422
+ "abstract": true,
3423
+ "docs": {
3424
+ "default": "100",
3425
+ "remarks": "This is a value between 0 and 100.",
3426
+ "stability": "stable",
3427
+ "summary": "The percentage of messages that should be checked for DMARC compliance."
3428
+ },
3429
+ "immutable": true,
3430
+ "locationInModule": {
3431
+ "filename": "src/dmarc/index.ts",
3432
+ "line": 84
3433
+ },
3434
+ "name": "dmarcPercentage",
3435
+ "optional": true,
3436
+ "type": {
3437
+ "primitive": "number"
3438
+ }
3439
+ },
3440
+ {
3441
+ "abstract": true,
3442
+ "docs": {
3443
+ "default": "relaxed",
3444
+ "remarks": "This can be one of the following values:\n- relaxed: Use relaxed alignment mode.\n- strict: Use strict alignment mode.",
3445
+ "stability": "stable",
3446
+ "summary": "The alignment mode to use for SPF signatures."
3447
+ },
3448
+ "immutable": true,
3449
+ "locationInModule": {
3450
+ "filename": "src/dmarc/index.ts",
3451
+ "line": 104
3452
+ },
3453
+ "name": "dmarcSpfAlignment",
3454
+ "optional": true,
3455
+ "type": {
3456
+ "fqn": "cloudstructs.DmarcAlignment"
3457
+ }
3458
+ },
3459
+ {
3460
+ "abstract": true,
3461
+ "docs": {
3462
+ "default": "inherited from dmarcPolicy",
3463
+ "remarks": "This can be one of the following values:\n- none: Do not apply any special handling to messages that fail DMARC compliance.\n- quarantine: Quarantine messages that fail DMARC compliance.\n- reject: Reject messages that fail DMARC compliance.",
3464
+ "stability": "stable",
3465
+ "summary": "The DMARC policy to apply to messages that fail DMARC compliance for subdomains."
3466
+ },
3467
+ "immutable": true,
3468
+ "locationInModule": {
3469
+ "filename": "src/dmarc/index.ts",
3470
+ "line": 77
3471
+ },
3472
+ "name": "dmarcSubdomainPolicy",
3473
+ "optional": true,
3474
+ "type": {
3475
+ "fqn": "cloudstructs.DmarcPolicy"
3476
+ }
3477
+ },
3478
+ {
3479
+ "abstract": true,
3480
+ "docs": {
3481
+ "custom": {
3482
+ "$": "{hostedZone.zoneName}"
3483
+ },
3484
+ "default": "dmarc-reports",
3485
+ "remarks": "This email address must be verified in SES.",
3486
+ "stability": "stable",
3487
+ "summary": "The email address to send DMARC reports to."
3488
+ },
3489
+ "immutable": true,
3490
+ "locationInModule": {
3491
+ "filename": "src/dmarc/index.ts",
3492
+ "line": 53
3493
+ },
3494
+ "name": "emailAddress",
3495
+ "optional": true,
3496
+ "type": {
3497
+ "primitive": "string"
3498
+ }
3499
+ }
3500
+ ],
3501
+ "symbolId": "src/dmarc/index:DmarcReporterProps"
3502
+ },
3165
3503
  "cloudstructs.EcsServiceRoller": {
3166
3504
  "assembly": "cloudstructs",
3167
3505
  "base": "constructs.Construct",
@@ -6453,6 +6791,6 @@
6453
6791
  "symbolId": "src/url-shortener/index:UrlShortenerProps"
6454
6792
  }
6455
6793
  },
6456
- "version": "0.6.30",
6457
- "fingerprint": "mHShv556ppZ1LPJ95A8RZsExZzCQgzLIYLvvd6prILE="
6794
+ "version": "0.6.32",
6795
+ "fingerprint": "AwigQR11NLGwDzmJTFFLeJu1g1iRD762J1ZME6SopS8="
6458
6796
  }
package/API.md CHANGED
@@ -6,6 +6,7 @@ Name|Description
6
6
  ----|-----------
7
7
  [CodeCommitMirror](#cloudstructs-codecommitmirror)|Mirror a repository to AWS CodeCommit on schedule.
8
8
  [CodeCommitMirrorSourceRepository](#cloudstructs-codecommitmirrorsourcerepository)|A source repository for AWS CodeCommit mirroring.
9
+ [DmarcReporter](#cloudstructs-dmarcreporter)|Creates a DMARC record in Route 53 and invokes a Lambda function to process incoming reports.
9
10
  [EcsServiceRoller](#cloudstructs-ecsserviceroller)|Roll your ECS service tasks on schedule or with a rule.
10
11
  [EmailReceiver](#cloudstructs-emailreceiver)|Receive emails through SES, save them to S3 and invokes a Lambda function.
11
12
  [RollTrigger](#cloudstructs-rolltrigger)|The rule or schedule that should trigger a roll.
@@ -28,6 +29,7 @@ Name|Description
28
29
  Name|Description
29
30
  ----|-----------
30
31
  [CodeCommitMirrorProps](#cloudstructs-codecommitmirrorprops)|Properties for a CodeCommitMirror.
32
+ [DmarcReporterProps](#cloudstructs-dmarcreporterprops)|Properties for a DmarcReporter.
31
33
  [EcsServiceRollerProps](#cloudstructs-ecsservicerollerprops)|Properties for a EcsServiceRoller.
32
34
  [EmailReceiverProps](#cloudstructs-emailreceiverprops)|Properties for an EmailReceiver.
33
35
  [SamlIdentityProviderProps](#cloudstructs-samlidentityproviderprops)|Properties for a SamlProvider.
@@ -62,6 +64,8 @@ Name|Description
62
64
 
63
65
  Name|Description
64
66
  ----|-----------
67
+ [DmarcAlignment](#cloudstructs-dmarcalignment)|The DMARC alignment mode.
68
+ [DmarcPolicy](#cloudstructs-dmarcpolicy)|The DMARC policy to apply to messages that fail DMARC compliance.
65
69
  [SlackAppManifestShortcutType](#cloudstructs-slackappmanifestshortcuttype)|Type of shortcuts.
66
70
  [SslServerTestGrade](#cloudstructs-sslservertestgrade)|SSL Server test grade.
67
71
 
@@ -153,6 +157,40 @@ __Returns__:
153
157
 
154
158
 
155
159
 
160
+ ## class DmarcReporter <a id="cloudstructs-dmarcreporter"></a>
161
+
162
+ Creates a DMARC record in Route 53 and invokes a Lambda function to process incoming reports.
163
+
164
+ __Implements__: [IConstruct](#constructs-iconstruct), [IDependable](#constructs-idependable)
165
+ __Extends__: [Construct](#constructs-construct)
166
+
167
+ ### Initializer
168
+
169
+
170
+
171
+
172
+ ```ts
173
+ new DmarcReporter(scope: Construct, id: string, props: DmarcReporterProps)
174
+ ```
175
+
176
+ * **scope** (<code>[Construct](#constructs-construct)</code>) *No description*
177
+ * **id** (<code>string</code>) *No description*
178
+ * **props** (<code>[DmarcReporterProps](#cloudstructs-dmarcreporterprops)</code>) *No description*
179
+ * **dmarcPolicy** (<code>[DmarcPolicy](#cloudstructs-dmarcpolicy)</code>) The DMARC policy to apply to messages that fail DMARC compliance.
180
+ * **function** (<code>[aws_lambda.IFunction](#aws-cdk-lib-aws-lambda-ifunction)</code>) A Lambda function to invoke after the message is saved to S3.
181
+ * **hostedZone** (<code>[aws_route53.IHostedZone](#aws-cdk-lib-aws-route53-ihostedzone)</code>) The Route 53 hosted zone to create the DMARC record in.
182
+ * **receiptRuleSet** (<code>[aws_ses.IReceiptRuleSet](#aws-cdk-lib-aws-ses-ireceiptruleset)</code>) The SES receipt rule set where a receipt rule will be added.
183
+ * **additionalEmailAddresses** (<code>Array<string></code>) Additional email addresses to send DMARC reports to. __*Optional*__
184
+ * **afterRule** (<code>[aws_ses.IReceiptRule](#aws-cdk-lib-aws-ses-ireceiptrule)</code>) An existing rule after which the new rule will be placed in the rule set. __*Default*__: The new rule is inserted at the beginning of the rule list.
185
+ * **dmarcDkimAlignment** (<code>[DmarcAlignment](#cloudstructs-dmarcalignment)</code>) The alignment mode to use for DKIM signatures. __*Default*__: relaxed
186
+ * **dmarcPercentage** (<code>number</code>) The percentage of messages that should be checked for DMARC compliance. __*Default*__: 100
187
+ * **dmarcSpfAlignment** (<code>[DmarcAlignment](#cloudstructs-dmarcalignment)</code>) The alignment mode to use for SPF signatures. __*Default*__: relaxed
188
+ * **dmarcSubdomainPolicy** (<code>[DmarcPolicy](#cloudstructs-dmarcpolicy)</code>) The DMARC policy to apply to messages that fail DMARC compliance for subdomains. __*Default*__: inherited from dmarcPolicy
189
+ * **emailAddress** (<code>string</code>) The email address to send DMARC reports to. __*Default*__: dmarc-reports
190
+
191
+
192
+
193
+
156
194
  ## class EcsServiceRoller <a id="cloudstructs-ecsserviceroller"></a>
157
195
 
158
196
  Roll your ECS service tasks on schedule or with a rule.
@@ -766,6 +804,29 @@ Name | Type | Description
766
804
 
767
805
 
768
806
 
807
+ ## struct DmarcReporterProps <a id="cloudstructs-dmarcreporterprops"></a>
808
+
809
+
810
+ Properties for a DmarcReporter.
811
+
812
+
813
+
814
+ Name | Type | Description
815
+ -----|------|-------------
816
+ **dmarcPolicy** | <code>[DmarcPolicy](#cloudstructs-dmarcpolicy)</code> | The DMARC policy to apply to messages that fail DMARC compliance.
817
+ **function** | <code>[aws_lambda.IFunction](#aws-cdk-lib-aws-lambda-ifunction)</code> | A Lambda function to invoke after the message is saved to S3.
818
+ **hostedZone** | <code>[aws_route53.IHostedZone](#aws-cdk-lib-aws-route53-ihostedzone)</code> | The Route 53 hosted zone to create the DMARC record in.
819
+ **receiptRuleSet** | <code>[aws_ses.IReceiptRuleSet](#aws-cdk-lib-aws-ses-ireceiptruleset)</code> | The SES receipt rule set where a receipt rule will be added.
820
+ **additionalEmailAddresses**? | <code>Array<string></code> | Additional email addresses to send DMARC reports to.<br/>__*Optional*__
821
+ **afterRule**? | <code>[aws_ses.IReceiptRule](#aws-cdk-lib-aws-ses-ireceiptrule)</code> | An existing rule after which the new rule will be placed in the rule set.<br/>__*Default*__: The new rule is inserted at the beginning of the rule list.
822
+ **dmarcDkimAlignment**? | <code>[DmarcAlignment](#cloudstructs-dmarcalignment)</code> | The alignment mode to use for DKIM signatures.<br/>__*Default*__: relaxed
823
+ **dmarcPercentage**? | <code>number</code> | The percentage of messages that should be checked for DMARC compliance.<br/>__*Default*__: 100
824
+ **dmarcSpfAlignment**? | <code>[DmarcAlignment](#cloudstructs-dmarcalignment)</code> | The alignment mode to use for SPF signatures.<br/>__*Default*__: relaxed
825
+ **dmarcSubdomainPolicy**? | <code>[DmarcPolicy](#cloudstructs-dmarcpolicy)</code> | The DMARC policy to apply to messages that fail DMARC compliance for subdomains.<br/>__*Default*__: inherited from dmarcPolicy
826
+ **emailAddress**? | <code>string</code> | The email address to send DMARC reports to.<br/>__*Default*__: dmarc-reports
827
+
828
+
829
+
769
830
  ## struct EcsServiceRollerProps <a id="cloudstructs-ecsservicerollerprops"></a>
770
831
 
771
832
 
@@ -1123,6 +1184,27 @@ Name | Type | Description
1123
1184
 
1124
1185
 
1125
1186
 
1187
+ ## enum DmarcAlignment <a id="cloudstructs-dmarcalignment"></a>
1188
+
1189
+ The DMARC alignment mode.
1190
+
1191
+ Name | Description
1192
+ -----|-----
1193
+ **RELAXED** |Relaxed alignment mode.
1194
+ **STRICT** |Strict alignment mode.
1195
+
1196
+
1197
+ ## enum DmarcPolicy <a id="cloudstructs-dmarcpolicy"></a>
1198
+
1199
+ The DMARC policy to apply to messages that fail DMARC compliance.
1200
+
1201
+ Name | Description
1202
+ -----|-----
1203
+ **NONE** |Do not apply any special handling to messages that fail DMARC compliance.
1204
+ **QUARANTINE** |Quarantine messages that fail DMARC compliance.
1205
+ **REJECT** |Reject messages that fail DMARC compliance.
1206
+
1207
+
1126
1208
  ## enum SlackAppManifestShortcutType <a id="cloudstructs-slackappmanifestshortcuttype"></a>
1127
1209
 
1128
1210
  Type of shortcuts.
@@ -24,7 +24,6 @@ __export(redirect_edge_lambda_exports, {
24
24
  });
25
25
  module.exports = __toCommonJS(redirect_edge_lambda_exports);
26
26
  var import_client_s3 = require("@aws-sdk/client-s3");
27
- var s3Client = new import_client_s3.S3Client({});
28
27
  async function handler(event) {
29
28
  const request = event.Records[0].cf.request;
30
29
  try {
@@ -32,6 +31,7 @@ async function handler(event) {
32
31
  if (!s3Origin) {
33
32
  throw new Error("No S3 origin");
34
33
  }
34
+ const s3Client = new import_client_s3.S3Client({ region: s3Origin.region });
35
35
  const bucket = s3Origin.domainName.replace(new RegExp(`.s3.${s3Origin.region}.amazonaws.com$`), "");
36
36
  const key = request.uri.substring(1);
37
37
  const data = await s3Client.send(new import_client_s3.GetObjectCommand({
@@ -41,7 +41,7 @@ async function handler(event) {
41
41
  if (!data.Body) {
42
42
  throw new Error("No body");
43
43
  }
44
- const redirect = JSON.parse(data.Body.toString());
44
+ const redirect = JSON.parse(await data.Body.transformToString());
45
45
  return {
46
46
  status: "301",
47
47
  statusDescription: "Moved Permanently",
@@ -41,7 +41,7 @@ class CodeCommitMirrorSourceRepository {
41
41
  }
42
42
  exports.CodeCommitMirrorSourceRepository = CodeCommitMirrorSourceRepository;
43
43
  _a = JSII_RTTI_SYMBOL_1;
44
- CodeCommitMirrorSourceRepository[_a] = { fqn: "cloudstructs.CodeCommitMirrorSourceRepository", version: "0.6.30" };
44
+ CodeCommitMirrorSourceRepository[_a] = { fqn: "cloudstructs.CodeCommitMirrorSourceRepository", version: "0.6.32" };
45
45
  /**
46
46
  * Mirror a repository to AWS CodeCommit on schedule
47
47
  */
@@ -89,5 +89,5 @@ class CodeCommitMirror extends constructs_1.Construct {
89
89
  }
90
90
  exports.CodeCommitMirror = CodeCommitMirror;
91
91
  _b = JSII_RTTI_SYMBOL_1;
92
- CodeCommitMirror[_b] = { fqn: "cloudstructs.CodeCommitMirror", version: "0.6.30" };
92
+ CodeCommitMirror[_b] = { fqn: "cloudstructs.CodeCommitMirror", version: "0.6.32" };
93
93
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/codecommit-mirror/index.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as codecommit from 'aws-cdk-lib/aws-codecommit';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport { Construct } from 'constructs';\n\n/**\n * Properties for a CodeCommitMirror\n */\nexport interface CodeCommitMirrorProps {\n  /**\n   * The source repository\n   */\n  readonly repository: CodeCommitMirrorSourceRepository;\n\n  /**\n   * The ECS cluster where to run the mirroring operation\n   */\n  readonly cluster: ecs.ICluster;\n\n  /**\n   * The schedule for the mirroring operation\n   *\n   * @default - everyday at midnight\n   */\n  readonly schedule?: events.Schedule;\n\n  /**\n   * Where to run the mirroring Fargate tasks\n   *\n   * @default - public subnets\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n}\n\n/**\n * A source repository for AWS CodeCommit mirroring\n */\nexport abstract class CodeCommitMirrorSourceRepository {\n  /**\n   * Public GitHub repository\n   */\n  public static gitHub(owner: string, name: string): CodeCommitMirrorSourceRepository {\n    return {\n      name,\n      plainTextUrl: `https://github.com/${owner}/${name}`,\n    };\n  }\n\n  /**\n   * Private repository with HTTPS clone URL stored in a AWS Secrets Manager secret or\n   * a AWS Systems Manager secure string parameter.\n   *\n   * @param name the repository name\n   * @param url the secret containing the HTTPS clone URL\n   */\n  public static private(name: string, url: ecs.Secret): CodeCommitMirrorSourceRepository {\n    return {\n      name,\n      secretUrl: url,\n    };\n  }\n\n  /**\n   * The name of the repository\n   */\n  public abstract readonly name: string;\n\n  /** The HTTPS clone URL in plain text, used for a public repository */\n  public abstract readonly plainTextUrl?: string;\n\n  /**\n   * The HTTPS clone URL if the repository is private.\n   *\n   * The secret should contain the username and/or token.\n   *\n   * @example\n   * `https://TOKEN@github.com/owner/name`\n   * `https://USERNAME:TOKEN@bitbucket.org/owner/name.git`\n   */\n  public abstract readonly secretUrl?: ecs.Secret;\n}\n\n/**\n * Mirror a repository to AWS CodeCommit on schedule\n */\nexport class CodeCommitMirror extends Construct {\n  constructor(scope: Construct, id: string, props: CodeCommitMirrorProps) {\n    super(scope, id);\n\n    const destination = new codecommit.Repository(this, 'Repository', {\n      repositoryName: props.repository.name,\n      description: `Mirror of ${props.repository.name}`,\n    });\n\n    const taskDefinition = new ecs.FargateTaskDefinition(this, 'TaskDefinition');\n\n    taskDefinition.addContainer('Container', {\n      image: ecs.ContainerImage.fromAsset(path.join(__dirname, '..', '..', 'assets', 'codecommit-mirror', 'docker')),\n      logging: new ecs.AwsLogDriver({\n        streamPrefix: props.repository.name,\n        logRetention: logs.RetentionDays.TWO_MONTHS,\n      }),\n      environment: {\n        NAME: props.repository.name,\n        DESTINATION: destination.repositoryCloneUrlGrc,\n        ...props.repository.plainTextUrl\n          ? { SOURCE: props.repository.plainTextUrl }\n          : {},\n      },\n      secrets: props.repository.secretUrl\n        ? { SOURCE: props.repository.secretUrl }\n        : undefined,\n    });\n\n    taskDefinition.addToTaskRolePolicy(new iam.PolicyStatement({\n      actions: ['codecommit:GitPush'],\n      resources: [destination.repositoryArn],\n    }));\n\n    const rule = new events.Rule(this, 'Rule', {\n      schedule: props.schedule ?? events.Schedule.cron({\n        minute: '0',\n        hour: '0',\n      }),\n    });\n\n    rule.addTarget(new targets.EcsTask({\n      cluster: props.cluster,\n      taskDefinition,\n      subnetSelection: props.subnetSelection ?? { subnetType: ec2.SubnetType.PUBLIC },\n    }));\n  }\n}\n"]}
@@ -0,0 +1,115 @@
1
+ import * as lambda from 'aws-cdk-lib/aws-lambda';
2
+ import * as route53 from 'aws-cdk-lib/aws-route53';
3
+ import * as ses from 'aws-cdk-lib/aws-ses';
4
+ import { Construct } from 'constructs';
5
+ /**
6
+ * The DMARC policy to apply to messages that fail DMARC compliance.
7
+ */
8
+ export declare enum DmarcPolicy {
9
+ /**
10
+ * Do not apply any special handling to messages that fail DMARC compliance.
11
+ */
12
+ NONE = "none",
13
+ /**
14
+ * Quarantine messages that fail DMARC compliance. (usually by sending them to spam)
15
+ */
16
+ QUARANTINE = "quarantine",
17
+ /**
18
+ * Reject messages that fail DMARC compliance. (usually by rejecting them outright)
19
+ */
20
+ REJECT = "reject"
21
+ }
22
+ /**
23
+ * The DMARC alignment mode.
24
+ */
25
+ export declare enum DmarcAlignment {
26
+ /**
27
+ * Relaxed alignment mode.
28
+ */
29
+ RELAXED = "relaxed",
30
+ /**
31
+ * Strict alignment mode.
32
+ */
33
+ STRICT = "strict"
34
+ }
35
+ /**
36
+ * Properties for a DmarcReporter
37
+ */
38
+ export interface DmarcReporterProps {
39
+ /**
40
+ * The Route 53 hosted zone to create the DMARC record in.
41
+ */
42
+ readonly hostedZone: route53.IHostedZone;
43
+ /**
44
+ * The email address to send DMARC reports to.
45
+ * This email address must be verified in SES.
46
+ * @default dmarc-reports@${hostedZone.zoneName}
47
+ */
48
+ readonly emailAddress?: string;
49
+ /**
50
+ * Additional email addresses to send DMARC reports to.
51
+ */
52
+ readonly additionalEmailAddresses?: string[];
53
+ /**
54
+ * The DMARC policy to apply to messages that fail DMARC compliance.
55
+ * This can be one of the following values:
56
+ * - none: Do not apply any special handling to messages that fail DMARC compliance.
57
+ * - quarantine: Quarantine messages that fail DMARC compliance.
58
+ * - reject: Reject messages that fail DMARC compliance.
59
+ */
60
+ readonly dmarcPolicy: DmarcPolicy;
61
+ /**
62
+ * The DMARC policy to apply to messages that fail DMARC compliance for subdomains.
63
+ * This can be one of the following values:
64
+ * - none: Do not apply any special handling to messages that fail DMARC compliance.
65
+ * - quarantine: Quarantine messages that fail DMARC compliance.
66
+ * - reject: Reject messages that fail DMARC compliance.
67
+ * @default inherited from dmarcPolicy
68
+ */
69
+ readonly dmarcSubdomainPolicy?: DmarcPolicy;
70
+ /**
71
+ * The percentage of messages that should be checked for DMARC compliance.
72
+ * This is a value between 0 and 100.
73
+ * @default 100
74
+ */
75
+ readonly dmarcPercentage?: number;
76
+ /**
77
+ * The alignment mode to use for DKIM signatures.
78
+ * This can be one of the following values:
79
+ * - relaxed: Use relaxed alignment mode.
80
+ * - strict: Use strict alignment mode.
81
+ *
82
+ * @default relaxed
83
+ */
84
+ readonly dmarcDkimAlignment?: DmarcAlignment;
85
+ /**
86
+ * The alignment mode to use for SPF signatures.
87
+ * This can be one of the following values:
88
+ * - relaxed: Use relaxed alignment mode.
89
+ * - strict: Use strict alignment mode.
90
+ *
91
+ * @default relaxed
92
+ */
93
+ readonly dmarcSpfAlignment?: DmarcAlignment;
94
+ /**
95
+ * A Lambda function to invoke after the message is saved to S3. The Lambda
96
+ * function will be invoked with a SESMessage as event.
97
+ */
98
+ readonly function: lambda.IFunction;
99
+ /**
100
+ * An existing rule after which the new rule will be placed in the rule set.
101
+ *
102
+ * @default - The new rule is inserted at the beginning of the rule list.
103
+ */
104
+ readonly afterRule?: ses.IReceiptRule;
105
+ /**
106
+ * The SES receipt rule set where a receipt rule will be added
107
+ */
108
+ readonly receiptRuleSet: ses.IReceiptRuleSet;
109
+ }
110
+ /**
111
+ * Creates a DMARC record in Route 53 and invokes a Lambda function to process incoming reports.
112
+ */
113
+ export declare class DmarcReporter extends Construct {
114
+ constructor(scope: Construct, id: string, props: DmarcReporterProps);
115
+ }
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.DmarcReporter = exports.DmarcAlignment = exports.DmarcPolicy = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const route53 = require("aws-cdk-lib/aws-route53");
7
+ const constructs_1 = require("constructs");
8
+ const receiver_1 = require("../email-receiver/receiver");
9
+ /**
10
+ * The DMARC policy to apply to messages that fail DMARC compliance.
11
+ */
12
+ var DmarcPolicy;
13
+ (function (DmarcPolicy) {
14
+ /**
15
+ * Do not apply any special handling to messages that fail DMARC compliance.
16
+ */
17
+ DmarcPolicy["NONE"] = "none";
18
+ /**
19
+ * Quarantine messages that fail DMARC compliance. (usually by sending them to spam)
20
+ */
21
+ DmarcPolicy["QUARANTINE"] = "quarantine";
22
+ /**
23
+ * Reject messages that fail DMARC compliance. (usually by rejecting them outright)
24
+ */
25
+ DmarcPolicy["REJECT"] = "reject";
26
+ })(DmarcPolicy = exports.DmarcPolicy || (exports.DmarcPolicy = {}));
27
+ /**
28
+ * The DMARC alignment mode.
29
+ */
30
+ var DmarcAlignment;
31
+ (function (DmarcAlignment) {
32
+ /**
33
+ * Relaxed alignment mode.
34
+ */
35
+ DmarcAlignment["RELAXED"] = "relaxed";
36
+ /**
37
+ * Strict alignment mode.
38
+ */
39
+ DmarcAlignment["STRICT"] = "strict";
40
+ })(DmarcAlignment = exports.DmarcAlignment || (exports.DmarcAlignment = {}));
41
+ /**
42
+ * Creates a DMARC record in Route 53 and invokes a Lambda function to process incoming reports.
43
+ */
44
+ class DmarcReporter extends constructs_1.Construct {
45
+ constructor(scope, id, props) {
46
+ super(scope, id);
47
+ const emailAddress = props.emailAddress ?? `dmarc-reports@${props.hostedZone.zoneName}`;
48
+ new receiver_1.EmailReceiver(this, 'EmailReceiver', {
49
+ recipients: [emailAddress],
50
+ function: props.function,
51
+ afterRule: props.afterRule,
52
+ receiptRuleSet: props.receiptRuleSet,
53
+ });
54
+ const dmarcRecordValue = [
55
+ 'v=DMARC1',
56
+ `p=${props.dmarcPolicy}`,
57
+ `rua=${[emailAddress, ...(props.additionalEmailAddresses ?? [])]
58
+ .map((address) => `mailto:${address}`)
59
+ .join(',')}`,
60
+ ];
61
+ if (props.dmarcSubdomainPolicy) {
62
+ dmarcRecordValue.push(`sp=${props.dmarcSubdomainPolicy}`);
63
+ }
64
+ if (props.dmarcPercentage) {
65
+ dmarcRecordValue.push(`pct=${props.dmarcPercentage}`);
66
+ }
67
+ if (props.dmarcDkimAlignment) {
68
+ dmarcRecordValue.push(`adkim=${props.dmarcDkimAlignment === DmarcAlignment.RELAXED ? 'r' : 's'}`);
69
+ }
70
+ if (props.dmarcSpfAlignment) {
71
+ dmarcRecordValue.push(`aspf=${props.dmarcSpfAlignment === DmarcAlignment.RELAXED ? 'r' : 's'}`);
72
+ }
73
+ // Create Route 53 DMARC Record
74
+ new route53.TxtRecord(this, 'DmarcRecord', {
75
+ zone: props.hostedZone,
76
+ recordName: `_dmarc.${props.hostedZone.zoneName}`,
77
+ values: [dmarcRecordValue.join('; ')],
78
+ });
79
+ }
80
+ }
81
+ exports.DmarcReporter = DmarcReporter;
82
+ _a = JSII_RTTI_SYMBOL_1;
83
+ DmarcReporter[_a] = { fqn: "cloudstructs.DmarcReporter", version: "0.6.32" };
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/dmarc/index.ts"],"names":[],"mappings":";;;;;AACA,mDAAmD;AAGnD,2CAAuC;AACvC,yDAA2D;AAE3D;;GAEG;AACH,IAAY,WAaX;AAbD,WAAY,WAAW;IACrB;;OAEG;IACH,4BAAa,CAAA;IACb;;OAEG;IACH,wCAAyB,CAAA;IACzB;;OAEG;IACH,gCAAiB,CAAA;AACnB,CAAC,EAbW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAatB;AAED;;GAEG;AACH,IAAY,cASX;AATD,WAAY,cAAc;IACxB;;OAEG;IACH,qCAAmB,CAAA;IACnB;;OAEG;IACH,mCAAiB,CAAA;AACnB,CAAC,EATW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QASzB;AAuFD;;GAEG;AACH,MAAa,aAAc,SAAQ,sBAAS;IAC1C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAyB;QACjE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,YAAY,GAChB,KAAK,CAAC,YAAY,IAAI,iBAAiB,KAAK,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAErE,IAAI,wBAAa,CAAC,IAAI,EAAE,eAAe,EAAE;YACvC,UAAU,EAAE,CAAC,YAAY,CAAC;YAC1B,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,cAAc,EAAE,KAAK,CAAC,cAAc;SACrC,CAAC,CAAC;QAEH,MAAM,gBAAgB,GAAG;YACvB,UAAU;YACV,KAAK,KAAK,CAAC,WAAW,EAAE;YACxB,OAAO,CAAC,YAAY,EAAE,GAAG,CAAC,KAAK,CAAC,wBAAwB,IAAI,EAAE,CAAC,CAAC;iBAC7D,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,OAAO,EAAE,CAAC;iBACrC,IAAI,CAAC,GAAG,CAAC,EAAE;SACf,CAAC;QAEF,IAAI,KAAK,CAAC,oBAAoB,EAAE;YAC9B,gBAAgB,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,oBAAoB,EAAE,CAAC,CAAC;SAC3D;QACD,IAAI,KAAK,CAAC,eAAe,EAAE;YACzB,gBAAgB,CAAC,IAAI,CAAC,OAAO,KAAK,CAAC,eAAe,EAAE,CAAC,CAAC;SACvD;QACD,IAAI,KAAK,CAAC,kBAAkB,EAAE;YAC5B,gBAAgB,CAAC,IAAI,CACnB,SACE,KAAK,CAAC,kBAAkB,KAAK,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAC9D,EAAE,CACH,CAAC;SACH;QACD,IAAI,KAAK,CAAC,iBAAiB,EAAE;YAC3B,gBAAgB,CAAC,IAAI,CACnB,QAAQ,KAAK,CAAC,iBAAiB,KAAK,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CACzE,CAAC;SACH;QAED,+BAA+B;QAC/B,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,aAAa,EAAE;YACzC,IAAI,EAAE,KAAK,CAAC,UAAU;YACtB,UAAU,EAAE,UAAU,KAAK,CAAC,UAAU,CAAC,QAAQ,EAAE;YACjD,MAAM,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACtC,CAAC,CAAC;IACL,CAAC;;AA/CH,sCAgDC","sourcesContent":["import * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as route53 from 'aws-cdk-lib/aws-route53';\nimport * as ses from 'aws-cdk-lib/aws-ses';\n\nimport { Construct } from 'constructs';\nimport { EmailReceiver } from '../email-receiver/receiver';\n\n/**\n * The DMARC policy to apply to messages that fail DMARC compliance.\n */\nexport enum DmarcPolicy {\n  /**\n   * Do not apply any special handling to messages that fail DMARC compliance.\n   */\n  NONE = 'none',\n  /**\n   * Quarantine messages that fail DMARC compliance. (usually by sending them to spam)\n   */\n  QUARANTINE = 'quarantine',\n  /**\n   * Reject messages that fail DMARC compliance. (usually by rejecting them outright)\n   */\n  REJECT = 'reject',\n}\n\n/**\n * The DMARC alignment mode.\n */\nexport enum DmarcAlignment {\n  /**\n   * Relaxed alignment mode.\n   */\n  RELAXED = 'relaxed',\n  /**\n   * Strict alignment mode.\n   */\n  STRICT = 'strict',\n}\n\n/**\n * Properties for a DmarcReporter\n */\nexport interface DmarcReporterProps {\n  /**\n   * The Route 53 hosted zone to create the DMARC record in.\n   */\n  readonly hostedZone: route53.IHostedZone;\n  /**\n   * The email address to send DMARC reports to.\n   * This email address must be verified in SES.\n   * @default dmarc-reports@${hostedZone.zoneName}\n   */\n  readonly emailAddress?: string;\n\n  /**\n   * Additional email addresses to send DMARC reports to.\n   */\n  readonly additionalEmailAddresses?: string[];\n\n  /**\n   * The DMARC policy to apply to messages that fail DMARC compliance.\n   * This can be one of the following values:\n   * - none: Do not apply any special handling to messages that fail DMARC compliance.\n   * - quarantine: Quarantine messages that fail DMARC compliance.\n   * - reject: Reject messages that fail DMARC compliance.\n   */\n  readonly dmarcPolicy: DmarcPolicy;\n\n  /**\n   * The DMARC policy to apply to messages that fail DMARC compliance for subdomains.\n   * This can be one of the following values:\n   * - none: Do not apply any special handling to messages that fail DMARC compliance.\n   * - quarantine: Quarantine messages that fail DMARC compliance.\n   * - reject: Reject messages that fail DMARC compliance.\n   * @default inherited from dmarcPolicy\n   */\n  readonly dmarcSubdomainPolicy?: DmarcPolicy;\n\n  /**\n   * The percentage of messages that should be checked for DMARC compliance.\n   * This is a value between 0 and 100.\n   * @default 100\n   */\n  readonly dmarcPercentage?: number;\n\n  /**\n   * The alignment mode to use for DKIM signatures.\n   * This can be one of the following values:\n   * - relaxed: Use relaxed alignment mode.\n   * - strict: Use strict alignment mode.\n   *\n   * @default relaxed\n   */\n  readonly dmarcDkimAlignment?: DmarcAlignment;\n\n  /**\n   * The alignment mode to use for SPF signatures.\n   * This can be one of the following values:\n   * - relaxed: Use relaxed alignment mode.\n   * - strict: Use strict alignment mode.\n   *\n   * @default relaxed\n   */\n  readonly dmarcSpfAlignment?: DmarcAlignment;\n\n  /**\n   * A Lambda function to invoke after the message is saved to S3. The Lambda\n   * function will be invoked with a SESMessage as event.\n   */\n  readonly function: lambda.IFunction;\n\n  /**\n   * An existing rule after which the new rule will be placed in the rule set.\n   *\n   * @default - The new rule is inserted at the beginning of the rule list.\n   */\n  readonly afterRule?: ses.IReceiptRule;\n\n  /**\n   * The SES receipt rule set where a receipt rule will be added\n   */\n  readonly receiptRuleSet: ses.IReceiptRuleSet;\n}\n\n/**\n * Creates a DMARC record in Route 53 and invokes a Lambda function to process incoming reports.\n */\nexport class DmarcReporter extends Construct {\n  constructor(scope: Construct, id: string, props: DmarcReporterProps) {\n    super(scope, id);\n\n    const emailAddress =\n      props.emailAddress ?? `dmarc-reports@${props.hostedZone.zoneName}`;\n\n    new EmailReceiver(this, 'EmailReceiver', {\n      recipients: [emailAddress],\n      function: props.function,\n      afterRule: props.afterRule,\n      receiptRuleSet: props.receiptRuleSet,\n    });\n\n    const dmarcRecordValue = [\n      'v=DMARC1',\n      `p=${props.dmarcPolicy}`,\n      `rua=${[emailAddress, ...(props.additionalEmailAddresses ?? [])]\n        .map((address) => `mailto:${address}`)\n        .join(',')}`,\n    ];\n\n    if (props.dmarcSubdomainPolicy) {\n      dmarcRecordValue.push(`sp=${props.dmarcSubdomainPolicy}`);\n    }\n    if (props.dmarcPercentage) {\n      dmarcRecordValue.push(`pct=${props.dmarcPercentage}`);\n    }\n    if (props.dmarcDkimAlignment) {\n      dmarcRecordValue.push(\n        `adkim=${\n          props.dmarcDkimAlignment === DmarcAlignment.RELAXED ? 'r' : 's'\n        }`,\n      );\n    }\n    if (props.dmarcSpfAlignment) {\n      dmarcRecordValue.push(\n        `aspf=${props.dmarcSpfAlignment === DmarcAlignment.RELAXED ? 'r' : 's'}`,\n      );\n    }\n\n    // Create Route 53 DMARC Record\n    new route53.TxtRecord(this, 'DmarcRecord', {\n      zone: props.hostedZone,\n      recordName: `_dmarc.${props.hostedZone.zoneName}`,\n      values: [dmarcRecordValue.join('; ')],\n    });\n  }\n}\n"]}
@@ -27,7 +27,7 @@ class RollTrigger {
27
27
  }
28
28
  exports.RollTrigger = RollTrigger;
29
29
  _a = JSII_RTTI_SYMBOL_1;
30
- RollTrigger[_a] = { fqn: "cloudstructs.RollTrigger", version: "0.6.30" };
30
+ RollTrigger[_a] = { fqn: "cloudstructs.RollTrigger", version: "0.6.32" };
31
31
  /**
32
32
  * Roll your ECS service tasks on schedule or with a rule
33
33
  */
@@ -64,5 +64,5 @@ class EcsServiceRoller extends constructs_1.Construct {
64
64
  }
65
65
  exports.EcsServiceRoller = EcsServiceRoller;
66
66
  _b = JSII_RTTI_SYMBOL_1;
67
- EcsServiceRoller[_b] = { fqn: "cloudstructs.EcsServiceRoller", version: "0.6.30" };
67
+ EcsServiceRoller[_b] = { fqn: "cloudstructs.EcsServiceRoller", version: "0.6.32" };
68
68
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZWNzLXNlcnZpY2Utcm9sbGVyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQ0EsNkNBQW9DO0FBRXBDLGlEQUFpRDtBQUNqRCwwREFBMEQ7QUFDMUQsMkNBQTJDO0FBQzNDLDJDQUF1QztBQXdCdkM7O0dBRUc7QUFDSCxNQUFzQixXQUFXO0lBQy9COztPQUVHO0lBQ0ksTUFBTSxDQUFDLFlBQVksQ0FBQyxRQUF5QjtRQUNsRCxPQUFPLEVBQUUsUUFBUSxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFpQjtRQUN0QyxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7SUFDbEIsQ0FBQzs7QUFiSCxrQ0E0QkM7OztBQUVEOztHQUVHO0FBQ0gsTUFBYSxnQkFBaUIsU0FBUSxzQkFBUztJQUM3QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQTRCO1FBQ3BFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLE9BQU8sRUFBRSxJQUFJLElBQUksSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUU7WUFDaEUsUUFBUSxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUUsUUFBUSxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO2dCQUN4RCxNQUFNLEVBQUUsR0FBRztnQkFDWCxJQUFJLEVBQUUsR0FBRzthQUNWLENBQUM7U0FDSCxDQUFDLENBQUM7UUFHSCxNQUFNLFVBQVUsR0FBOEI7WUFDNUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBVztZQUNsQyxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU8sQ0FBQyxXQUFXO1lBQ2xDLGtCQUFrQixFQUFFLElBQUk7U0FDekIsQ0FBQztRQUNGLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDO1lBQ2hDLE9BQU8sRUFBRSxLQUFLO1lBQ2QsTUFBTSxFQUFFLGVBQWU7WUFDdkIsVUFBVTtZQUNWLHVHQUF1RztZQUN2Ryx1RUFBdUU7WUFDdkUsZUFBZSxFQUFFLElBQUksR0FBRyxDQUFDLGVBQWUsQ0FBQztnQkFDdkMsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7Z0JBQzlCLFNBQVMsRUFBRSxDQUFDLG1CQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsQ0FBQzt3QkFDbkMsT0FBTyxFQUFFLEtBQUs7d0JBQ2QsUUFBUSxFQUFFLFNBQVM7d0JBQ25CLFlBQVksRUFBRSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBVyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFO3FCQUMxRSxDQUFDLENBQUM7YUFDSixDQUFDO1NBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTixDQUFDOztBQWhDSCw0Q0FpQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFVwZGF0ZVNlcnZpY2VDb21tYW5kSW5wdXQgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtZWNzJztcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgZWNzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1lY3MnO1xuaW1wb3J0ICogYXMgZXZlbnRzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1ldmVudHMnO1xuaW1wb3J0ICogYXMgdGFyZ2V0cyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZXZlbnRzLXRhcmdldHMnO1xuaW1wb3J0ICogYXMgaWFtIGZyb20gJ2F3cy1jZGstbGliL2F3cy1pYW0nO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgYSBFY3NTZXJ2aWNlUm9sbGVyXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRWNzU2VydmljZVJvbGxlclByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBFQ1MgY2x1c3RlciB3aGVyZSB0aGUgc2VydmljZXMgcnVuXG4gICAqL1xuICByZWFkb25seSBjbHVzdGVyOiBlY3MuSUNsdXN0ZXI7XG5cbiAgLyoqXG4gICAqIFRoZSBFQ1Mgc2VydmljZSBmb3Igd2hpY2ggdGFza3Mgc2hvdWxkIGJlIHJvbGxlZFxuICAgKi9cbiAgcmVhZG9ubHkgc2VydmljZTogZWNzLklTZXJ2aWNlO1xuXG4gIC8qKlxuICAgKiBUaGUgcnVsZSBvciBzY2hlZHVsZSB0aGF0IHNob3VsZCB0cmlnZ2VyIGEgcm9sbFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIHJvbGwgZXZlcnlkYXkgYXQgbWlkbmlnaHRcbiAgICovXG4gIHJlYWRvbmx5IHRyaWdnZXI/OiBSb2xsVHJpZ2dlcjtcbn1cblxuLyoqXG4gKiBUaGUgcnVsZSBvciBzY2hlZHVsZSB0aGF0IHNob3VsZCB0cmlnZ2VyIGEgcm9sbFxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUm9sbFRyaWdnZXIge1xuICAvKipcbiAgICogU2NoZWR1bGUgdGhhdCBzaG91bGQgdHJpZ2dlciBhIHJvbGxcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZnJvbVNjaGVkdWxlKHNjaGVkdWxlOiBldmVudHMuU2NoZWR1bGUpOiBSb2xsVHJpZ2dlciB7XG4gICAgcmV0dXJuIHsgc2NoZWR1bGUgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSdWxlIHRoYXQgc2hvdWxkIHRyaWdnZXIgYSByb2xsXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGZyb21SdWxlKHJ1bGU6IGV2ZW50cy5SdWxlKTogUm9sbFRyaWdnZXIge1xuICAgIHJldHVybiB7IHJ1bGUgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSb2xsIHNjaGVkdWxlXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gcm9sbCBldmVyeWRheSBhdCBtaWRuaWdodFxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHJlYWRvbmx5IHNjaGVkdWxlPzogZXZlbnRzLlNjaGVkdWxlO1xuXG4gIC8qKlxuICAgKiBSb2xsIHJ1bGVcbiAgICpcbiAgICogQGRlZmF1bHQgLSByb2xsIGV2ZXJ5ZGF5IGF0IG1pZG5pZ2h0XG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgcmVhZG9ubHkgcnVsZT86IGV2ZW50cy5SdWxlO1xufVxuXG4vKipcbiAqIFJvbGwgeW91ciBFQ1Mgc2VydmljZSB0YXNrcyBvbiBzY2hlZHVsZSBvciB3aXRoIGEgcnVsZVxuICovXG5leHBvcnQgY2xhc3MgRWNzU2VydmljZVJvbGxlciBleHRlbmRzIENvbnN0cnVjdCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBFY3NTZXJ2aWNlUm9sbGVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgcnVsZSA9IHByb3BzLnRyaWdnZXI/LnJ1bGUgPz8gbmV3IGV2ZW50cy5SdWxlKHRoaXMsICdSdWxlJywge1xuICAgICAgc2NoZWR1bGU6IHByb3BzLnRyaWdnZXI/LnNjaGVkdWxlID8/IGV2ZW50cy5TY2hlZHVsZS5jcm9uKHtcbiAgICAgICAgbWludXRlOiAnMCcsXG4gICAgICAgIGhvdXI6ICcwJyxcbiAgICAgIH0pLFxuICAgIH0pO1xuXG5cbiAgICBjb25zdCBwYXJhbWV0ZXJzOiBVcGRhdGVTZXJ2aWNlQ29tbWFuZElucHV0ID0ge1xuICAgICAgc2VydmljZTogcHJvcHMuc2VydmljZS5zZXJ2aWNlTmFtZSxcbiAgICAgIGNsdXN0ZXI6IHByb3BzLmNsdXN0ZXIuY2x1c3Rlck5hbWUsXG4gICAgICBmb3JjZU5ld0RlcGxveW1lbnQ6IHRydWUsXG4gICAgfTtcbiAgICBydWxlLmFkZFRhcmdldChuZXcgdGFyZ2V0cy5Bd3NBcGkoe1xuICAgICAgc2VydmljZTogJ0VDUycsXG4gICAgICBhY3Rpb246ICd1cGRhdGVTZXJ2aWNlJyxcbiAgICAgIHBhcmFtZXRlcnMsXG4gICAgICAvLyBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQW1hem9uRUNTL2xhdGVzdC9kZXZlbG9wZXJndWlkZS9lY3Mtc3VwcG9ydGVkLWlhbS1hY3Rpb25zLXJlc291cmNlcy5odG1sXG4gICAgICAvLyBhcm46YXdzOmVjczo8cmVnaW9uPjo8YWNjb3VudD46c2VydmljZS88Y2x1c3Rlci1uYW1lPi88c2VydmljZS1uYW1lPlxuICAgICAgcG9saWN5U3RhdGVtZW50OiBuZXcgaWFtLlBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgIGFjdGlvbnM6IFsnZWNzOlVwZGF0ZVNlcnZpY2UnXSxcbiAgICAgICAgcmVzb3VyY2VzOiBbU3RhY2sub2YodGhpcykuZm9ybWF0QXJuKHtcbiAgICAgICAgICBzZXJ2aWNlOiAnZWNzJyxcbiAgICAgICAgICByZXNvdXJjZTogJ3NlcnZpY2UnLFxuICAgICAgICAgIHJlc291cmNlTmFtZTogYCR7cHJvcHMuY2x1c3Rlci5jbHVzdGVyTmFtZX0vJHtwcm9wcy5zZXJ2aWNlLnNlcnZpY2VOYW1lfWAsXG4gICAgICAgIH0pXSxcbiAgICAgIH0pLFxuICAgIH0pKTtcbiAgfVxufVxuIl19
@@ -62,5 +62,5 @@ class EmailReceiver extends constructs_1.Construct {
62
62
  }
63
63
  exports.EmailReceiver = EmailReceiver;
64
64
  _a = JSII_RTTI_SYMBOL_1;
65
- EmailReceiver[_a] = { fqn: "cloudstructs.EmailReceiver", version: "0.6.30" };
65
+ EmailReceiver[_a] = { fqn: "cloudstructs.EmailReceiver", version: "0.6.32" };
66
66
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjZWl2ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZW1haWwtcmVjZWl2ZXIvcmVjZWl2ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2Q0FBdUM7QUFFdkMsb0VBQW9FO0FBQ3BFLDZDQUE2QztBQUM3Qyx5Q0FBeUM7QUFDekMsMkNBQTJDO0FBQzNDLHVEQUF1RDtBQUN2RCwyQ0FBMkM7QUFDM0MsbUVBQW1FO0FBQ25FLDJDQUF1QztBQUN2QywrQ0FBMkM7QUFDM0MsNkRBQXlEO0FBNEN6RDs7O0dBR0c7QUFDSCxNQUFhLGFBQWMsU0FBUSxzQkFBUztJQUMxQyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXlCO1FBQ2pFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsTUFBTSxXQUFXLEdBQUcsSUFBSSxHQUFHLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUU7WUFDM0QsT0FBTyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQzdCLFVBQVUsRUFBRSxLQUFLLENBQUMsVUFBVTtZQUM1QixLQUFLLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDdEIsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPO1NBQ3ZCLENBQUMsQ0FBQztRQUVILE1BQU0sTUFBTSxHQUFHLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsUUFBUSxFQUFFO1lBQzNDLGlCQUFpQixFQUFFLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTO1lBQ2pELFVBQVUsRUFBRSxFQUFFLENBQUMsZ0JBQWdCLENBQUMsVUFBVTtZQUMxQyxjQUFjLEVBQUUsQ0FBQyxFQUFFLFVBQVUsRUFBRSxzQkFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1NBQ25ELENBQUMsQ0FBQztRQUNILE1BQU0sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsaUJBQWlCO1FBRW5ELE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFM0MsVUFBVTtRQUNWLElBQUksS0FBSyxDQUFDLGVBQWUsRUFBRTtZQUN6QixNQUFNLGdCQUFnQixHQUFHLElBQUksc0NBQWlCLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRTtnQkFDaEUsV0FBVyxFQUFFO29CQUNYLGdCQUFnQixFQUFFLEtBQUssQ0FBQyxlQUFlO2lCQUN4QztnQkFDRCxZQUFZLEVBQUUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTO2FBQzNDLENBQUMsQ0FBQztZQUVILFdBQVcsQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDO2dCQUN2QyxRQUFRLEVBQUUsZ0JBQWdCO2dCQUMxQixjQUFjLEVBQUUsT0FBTyxDQUFDLG9CQUFvQixDQUFDLGdCQUFnQjthQUM5RCxDQUFDLENBQUMsQ0FBQztTQUNMO1FBRUQsV0FBVyxDQUFDLFNBQVMsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDbkMsTUFBTTtZQUNOLEtBQUs7U0FDTixDQUFDLENBQUMsQ0FBQztRQUVKLE1BQU0sU0FBUyxHQUFHLElBQUksd0JBQVUsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFO1lBQzNDLFlBQVksRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVM7WUFDMUMsU0FBUyxFQUFFLElBQUksWUFBWSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUU7Z0JBQzVELFlBQVksRUFBRSxJQUFJO2FBQ25CLENBQUM7U0FDSCxDQUFDLENBQUM7UUFFSCxLQUFLLENBQUMsZUFBZSxDQUFDLElBQUksYUFBYSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTO0lBQ25GLENBQUM7O0FBaERILHNDQWlEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgbGFtYmRhIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0ICogYXMgZGVzdGluYXRpb25zIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEtZGVzdGluYXRpb25zJztcbmltcG9ydCAqIGFzIGxvZ3MgZnJvbSAnYXdzLWNkay1saWIvYXdzLWxvZ3MnO1xuaW1wb3J0ICogYXMgczMgZnJvbSAnYXdzLWNkay1saWIvYXdzLXMzJztcbmltcG9ydCAqIGFzIHNlcyBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc2VzJztcbmltcG9ydCAqIGFzIGFjdGlvbnMgZnJvbSAnYXdzLWNkay1saWIvYXdzLXNlcy1hY3Rpb25zJztcbmltcG9ydCAqIGFzIHNucyBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc25zJztcbmltcG9ydCAqIGFzIHN1YnNjcmlwdGlvbnMgZnJvbSAnYXdzLWNkay1saWIvYXdzLXNucy1zdWJzY3JpcHRpb25zJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgUzNGdW5jdGlvbiB9IGZyb20gJy4vczMtZnVuY3Rpb24nO1xuaW1wb3J0IHsgV2hpdGVsaXN0RnVuY3Rpb24gfSBmcm9tICcuL3doaXRlbGlzdC1mdW5jdGlvbic7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgYW4gRW1haWxSZWNlaXZlclxuICovXG5leHBvcnQgaW50ZXJmYWNlIEVtYWlsUmVjZWl2ZXJQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgU0VTIHJlY2VpcHQgcnVsZSBzZXQgd2hlcmUgYSByZWNlaXB0IHJ1bGUgd2lsbCBiZSBhZGRlZFxuICAgKi9cbiAgcmVhZG9ubHkgcmVjZWlwdFJ1bGVTZXQ6IHNlcy5JUmVjZWlwdFJ1bGVTZXQ7XG5cbiAgLyoqXG4gICAqIFRoZSByZWNpcGllbnRzIGZvciB3aGljaCBlbWFpbHMgc2hvdWxkIGJlIHJlY2VpdmVkXG4gICAqL1xuICByZWFkb25seSByZWNpcGllbnRzOiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogQSBMYW1iZGEgZnVuY3Rpb24gdG8gaW52b2tlIGFmdGVyIHRoZSBtZXNzYWdlIGlzIHNhdmVkIHRvIFMzLiBUaGUgTGFtYmRhXG4gICAqIGZ1bmN0aW9uIHdpbGwgYmUgaW52b2tlZCB3aXRoIGEgU0VTTWVzc2FnZSBhcyBldmVudC5cbiAgICovXG4gIHJlYWRvbmx5IGZ1bmN0aW9uOiBsYW1iZGEuSUZ1bmN0aW9uO1xuXG4gIC8qKlxuICAgKiBBIHJlZ3VsYXIgZXhwcmVzc2lvbiB0byB3aGl0ZWxpc3Qgc291cmNlIGVtYWlsIGFkZHJlc3Nlc1xuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIHdoaXRlbGlzdGluZyBvZiBzb3VyY2UgZW1haWwgYWRkcmVzc2VzXG4gICAqL1xuICByZWFkb25seSBzb3VyY2VXaGl0ZWxpc3Q/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEFuIGV4aXN0aW5nIHJ1bGUgYWZ0ZXIgd2hpY2ggdGhlIG5ldyBydWxlIHdpbGwgYmUgcGxhY2VkIGluIHRoZSBydWxlIHNldC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBUaGUgbmV3IHJ1bGUgaXMgaW5zZXJ0ZWQgYXQgdGhlIGJlZ2lubmluZyBvZiB0aGUgcnVsZSBsaXN0LlxuICAgKi9cbiAgcmVhZG9ubHkgYWZ0ZXJSdWxlPzogc2VzLklSZWNlaXB0UnVsZTtcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgcmVjZWl2ZXIgaXMgYWN0aXZlLlxuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICByZWFkb25seSBlbmFibGVkPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBSZWNlaXZlIGVtYWlscyB0aHJvdWdoIFNFUywgc2F2ZSB0aGVtIHRvIFMzIGFuZCBpbnZva2VzIGFcbiAqIExhbWJkYSBmdW5jdGlvblxuICovXG5leHBvcnQgY2xhc3MgRW1haWxSZWNlaXZlciBleHRlbmRzIENvbnN0cnVjdCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBFbWFpbFJlY2VpdmVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgcmVjZWlwdFJ1bGUgPSBuZXcgc2VzLlJlY2VpcHRSdWxlKHRoaXMsICdSZWNlaXB0UnVsZScsIHtcbiAgICAgIHJ1bGVTZXQ6IHByb3BzLnJlY2VpcHRSdWxlU2V0LFxuICAgICAgcmVjaXBpZW50czogcHJvcHMucmVjaXBpZW50cyxcbiAgICAgIGFmdGVyOiBwcm9wcy5hZnRlclJ1bGUsXG4gICAgICBlbmFibGVkOiBwcm9wcy5lbmFibGVkLFxuICAgIH0pO1xuXG4gICAgY29uc3QgYnVja2V0ID0gbmV3IHMzLkJ1Y2tldCh0aGlzLCAnQnVja2V0Jywge1xuICAgICAgYmxvY2tQdWJsaWNBY2Nlc3M6IHMzLkJsb2NrUHVibGljQWNjZXNzLkJMT0NLX0FMTCxcbiAgICAgIGVuY3J5cHRpb246IHMzLkJ1Y2tldEVuY3J5cHRpb24uUzNfTUFOQUdFRCxcbiAgICAgIGxpZmVjeWNsZVJ1bGVzOiBbeyBleHBpcmF0aW9uOiBEdXJhdGlvbi5kYXlzKDEpIH1dLFxuICAgIH0pO1xuICAgIGJ1Y2tldC5ncmFudFJlYWQocHJvcHMuZnVuY3Rpb24pOyAvLyBEb3dubG9hZCBlbWFpbFxuXG4gICAgY29uc3QgdG9waWMgPSBuZXcgc25zLlRvcGljKHRoaXMsICdUb3BpYycpO1xuXG4gICAgLy8gQWN0aW9uc1xuICAgIGlmIChwcm9wcy5zb3VyY2VXaGl0ZWxpc3QpIHtcbiAgICAgIGNvbnN0IHdoaXRlbGlzdEhhbmRsZXIgPSBuZXcgV2hpdGVsaXN0RnVuY3Rpb24odGhpcywgJ3doaXRlbGlzdCcsIHtcbiAgICAgICAgZW52aXJvbm1lbnQ6IHtcbiAgICAgICAgICBTT1VSQ0VfV0hJVEVMSVNUOiBwcm9wcy5zb3VyY2VXaGl0ZWxpc3QsXG4gICAgICAgIH0sXG4gICAgICAgIGxvZ1JldGVudGlvbjogbG9ncy5SZXRlbnRpb25EYXlzLk9ORV9NT05USCxcbiAgICAgIH0pO1xuXG4gICAgICByZWNlaXB0UnVsZS5hZGRBY3Rpb24obmV3IGFjdGlvbnMuTGFtYmRhKHtcbiAgICAgICAgZnVuY3Rpb246IHdoaXRlbGlzdEhhbmRsZXIsXG4gICAgICAgIGludm9jYXRpb25UeXBlOiBhY3Rpb25zLkxhbWJkYUludm9jYXRpb25UeXBlLlJFUVVFU1RfUkVTUE9OU0UsXG4gICAgICB9KSk7XG4gICAgfVxuXG4gICAgcmVjZWlwdFJ1bGUuYWRkQWN0aW9uKG5ldyBhY3Rpb25zLlMzKHtcbiAgICAgIGJ1Y2tldCxcbiAgICAgIHRvcGljLFxuICAgIH0pKTtcblxuICAgIGNvbnN0IHMzSGFuZGxlciA9IG5ldyBTM0Z1bmN0aW9uKHRoaXMsICdzMycsIHtcbiAgICAgIGxvZ1JldGVudGlvbjogbG9ncy5SZXRlbnRpb25EYXlzLk9ORV9NT05USCxcbiAgICAgIG9uU3VjY2VzczogbmV3IGRlc3RpbmF0aW9ucy5MYW1iZGFEZXN0aW5hdGlvbihwcm9wcy5mdW5jdGlvbiwge1xuICAgICAgICByZXNwb25zZU9ubHk6IHRydWUsXG4gICAgICB9KSxcbiAgICB9KTtcblxuICAgIHRvcGljLmFkZFN1YnNjcmlwdGlvbihuZXcgc3Vic2NyaXB0aW9ucy5MYW1iZGFTdWJzY3JpcHRpb24oczNIYW5kbGVyKSk7IC8vIE5vdGlmeVxuICB9XG59XG4iXX0=
package/lib/index.d.ts CHANGED
@@ -10,3 +10,4 @@ export * from './codecommit-mirror';
10
10
  export * from './slack-app';
11
11
  export * from './toolkit-cleaner';
12
12
  export * from './ssl-server-test';
13
+ export * from './dmarc';
package/lib/index.js CHANGED
@@ -22,4 +22,5 @@ __exportStar(require("./codecommit-mirror"), exports);
22
22
  __exportStar(require("./slack-app"), exports);
23
23
  __exportStar(require("./toolkit-cleaner"), exports);
24
24
  __exportStar(require("./ssl-server-test"), exports);
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsaURBQStCO0FBQy9CLG1EQUFpQztBQUNqQyxtREFBaUM7QUFDakMsOERBQTRDO0FBQzVDLG1EQUFpQztBQUNqQyx1REFBcUM7QUFDckMsa0RBQWdDO0FBQ2hDLDJEQUF5QztBQUN6QyxzREFBb0M7QUFDcEMsOENBQTRCO0FBQzVCLG9EQUFrQztBQUNsQyxvREFBa0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NsYWNrLWV2ZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3NsYWNrLXRleHRyYWN0JztcbmV4cG9ydCAqIGZyb20gJy4vc3RhdGljLXdlYnNpdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zdGF0ZS1tYWNoaW5lLWNyLXByb3ZpZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZW1haWwtcmVjZWl2ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9lY3Mtc2VydmljZS1yb2xsZXInO1xuZXhwb3J0ICogZnJvbSAnLi91cmwtc2hvcnRlbmVyJztcbmV4cG9ydCAqIGZyb20gJy4vc2FtbC1pZGVudGl0eS1wcm92aWRlcic7XG5leHBvcnQgKiBmcm9tICcuL2NvZGVjb21taXQtbWlycm9yJztcbmV4cG9ydCAqIGZyb20gJy4vc2xhY2stYXBwJztcbmV4cG9ydCAqIGZyb20gJy4vdG9vbGtpdC1jbGVhbmVyJztcbmV4cG9ydCAqIGZyb20gJy4vc3NsLXNlcnZlci10ZXN0JztcbiJdfQ==
25
+ __exportStar(require("./dmarc"), exports);
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsaURBQStCO0FBQy9CLG1EQUFpQztBQUNqQyxtREFBaUM7QUFDakMsOERBQTRDO0FBQzVDLG1EQUFpQztBQUNqQyx1REFBcUM7QUFDckMsa0RBQWdDO0FBQ2hDLDJEQUF5QztBQUN6QyxzREFBb0M7QUFDcEMsOENBQTRCO0FBQzVCLG9EQUFrQztBQUNsQyxvREFBa0M7QUFDbEMsMENBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zbGFjay1ldmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9zbGFjay10ZXh0cmFjdCc7XG5leHBvcnQgKiBmcm9tICcuL3N0YXRpYy13ZWJzaXRlJztcbmV4cG9ydCAqIGZyb20gJy4vc3RhdGUtbWFjaGluZS1jci1wcm92aWRlcic7XG5leHBvcnQgKiBmcm9tICcuL2VtYWlsLXJlY2VpdmVyJztcbmV4cG9ydCAqIGZyb20gJy4vZWNzLXNlcnZpY2Utcm9sbGVyJztcbmV4cG9ydCAqIGZyb20gJy4vdXJsLXNob3J0ZW5lcic7XG5leHBvcnQgKiBmcm9tICcuL3NhbWwtaWRlbnRpdHktcHJvdmlkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9jb2RlY29tbWl0LW1pcnJvcic7XG5leHBvcnQgKiBmcm9tICcuL3NsYWNrLWFwcCc7XG5leHBvcnQgKiBmcm9tICcuL3Rvb2xraXQtY2xlYW5lcic7XG5leHBvcnQgKiBmcm9tICcuL3NzbC1zZXJ2ZXItdGVzdCc7XG5leHBvcnQgKiBmcm9tICcuL2RtYXJjJzsiXX0=
@@ -65,7 +65,7 @@ class SamlIdentityProvider extends constructs_1.Construct {
65
65
  }
66
66
  exports.SamlIdentityProvider = SamlIdentityProvider;
67
67
  _a = JSII_RTTI_SYMBOL_1;
68
- SamlIdentityProvider[_a] = { fqn: "cloudstructs.SamlIdentityProvider", version: "0.6.30" };
68
+ SamlIdentityProvider[_a] = { fqn: "cloudstructs.SamlIdentityProvider", version: "0.6.32" };
69
69
  /**
70
70
  * Principal entity that represents a SAML federated identity provider.
71
71
  *
@@ -82,5 +82,5 @@ class SamlFederatedPrincipal extends iam.FederatedPrincipal {
82
82
  }
83
83
  exports.SamlFederatedPrincipal = SamlFederatedPrincipal;
84
84
  _b = JSII_RTTI_SYMBOL_1;
85
- SamlFederatedPrincipal[_b] = { fqn: "cloudstructs.SamlFederatedPrincipal", version: "0.6.30" };
85
+ SamlFederatedPrincipal[_b] = { fqn: "cloudstructs.SamlFederatedPrincipal", version: "0.6.32" };
86
86
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2FtbC1pZGVudGl0eS1wcm92aWRlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLDZDQUEyQztBQUMzQywyQ0FBMkM7QUFDM0MsbURBQW1EO0FBQ25ELDJDQUF1QztBQTBCdkM7Ozs7R0FJRztBQUNILE1BQWEsb0JBQXFCLFNBQVEsc0JBQVM7SUFNakQsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFnQztRQUN4RSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLElBQUksR0FBRyxtQkFBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUM7UUFFckUsTUFBTSxHQUFHLEdBQUcsbUJBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsU0FBUyxDQUFDO1lBQ25DLE9BQU8sRUFBRSxLQUFLO1lBQ2QsTUFBTSxFQUFFLEVBQUU7WUFDVixRQUFRLEVBQUUsZUFBZTtZQUN6QixZQUFZLEVBQUUsSUFBSTtTQUNuQixDQUFDLENBQUM7UUFFSCxNQUFNLEdBQUcsR0FBRyxJQUFJLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ3JELFlBQVksRUFBRSw4QkFBOEI7WUFDNUMsUUFBUSxFQUFFO2dCQUNSLE9BQU8sRUFBRSxLQUFLO2dCQUNkLE1BQU0sRUFBRSxvQkFBb0I7Z0JBQzVCLFVBQVUsRUFBRTtvQkFDVixJQUFJLEVBQUUsSUFBSTtvQkFDVixvQkFBb0IsRUFBRSxLQUFLLENBQUMsZ0JBQWdCO2lCQUNYO2dCQUNuQyxrQkFBa0IsRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsWUFBWSxDQUFDLGlCQUFpQixDQUFDO2FBQzFFO1lBQ0QsUUFBUSxFQUFFO2dCQUNSLE9BQU8sRUFBRSxLQUFLO2dCQUNkLE1BQU0sRUFBRSxvQkFBb0I7Z0JBQzVCLFVBQVUsRUFBRTtvQkFDVixlQUFlLEVBQUUsSUFBSSxFQUFFLENBQUMsMkJBQTJCLEVBQUUsQ0FBQyxNQUFNLEVBQUU7b0JBQzlELG9CQUFvQixFQUFFLEtBQUssQ0FBQyxnQkFBZ0I7aUJBQ1g7Z0JBQ25DLGtCQUFrQixFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxZQUFZLENBQUMsaUJBQWlCLENBQUM7YUFDMUU7WUFDRCxRQUFRLEVBQUU7Z0JBQ1IsT0FBTyxFQUFFLEtBQUs7Z0JBQ2QsTUFBTSxFQUFFLG9CQUFvQjtnQkFDNUIsVUFBVSxFQUFFO29CQUNWLGVBQWUsRUFBRSxJQUFJLEVBQUUsQ0FBQywyQkFBMkIsRUFBRSxDQUFDLE1BQU0sRUFBRTtpQkFDN0I7YUFDcEM7WUFDRCxNQUFNLEVBQUUsRUFBRSxDQUFDLHVCQUF1QixDQUFDLGNBQWMsQ0FBQztnQkFDaEQsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDO29CQUN0QixPQUFPLEVBQUU7d0JBQ1Asd0JBQXdCO3dCQUN4Qix3QkFBd0I7d0JBQ3hCLHdCQUF3QjtxQkFDekI7b0JBQ0QsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDO2lCQUNqQixDQUFDO2FBQ0gsQ0FBQztTQUNILENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyx1QkFBdUIsR0FBRyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUN6RSxDQUFDOztBQTFESCxvREEyREM7OztBQUVEOzs7O0dBSUc7QUFDSCxNQUFhLHNCQUF1QixTQUFRLEdBQUcsQ0FBQyxrQkFBa0I7SUFDaEUsWUFBWSxnQkFBc0M7UUFDaEQsS0FBSyxDQUNILGdCQUFnQixDQUFDLHVCQUF1QixFQUN4QztZQUNFLFlBQVksRUFBRTtnQkFDWixVQUFVLEVBQUUsb0NBQW9DO2FBQ2pEO1NBQ0YsRUFDRCx3QkFBd0IsQ0FDekIsQ0FBQztJQUNKLENBQUM7O0FBWEgsd0RBWUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENyZWF0ZVNBTUxQcm92aWRlckNvbW1hbmRJbnB1dCwgVXBkYXRlU0FNTFByb3ZpZGVyQ29tbWFuZElucHV0LCBEZWxldGVTQU1MUHJvdmlkZXJDb21tYW5kSW5wdXQgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtaWFtJztcbmltcG9ydCB7IE5hbWVzLCBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCAqIGFzIGNyIGZyb20gJ2F3cy1jZGstbGliL2N1c3RvbS1yZXNvdXJjZXMnO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgYSBTYW1sUHJvdmlkZXJcbiAqXG4gKiBAZGVwcmVjYXRlZCB1c2UgYFNhbWxQcm92aWRlclByb3BzYCBmcm9tIGBhd3MtY2RrLWxpYi9hd3MtaWFtYFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNhbWxJZGVudGl0eVByb3ZpZGVyUHJvcHMge1xuICAvKipcbiAgICogQSBuYW1lIGZvciB0aGUgU0FNTCBpZGVudGl0eSBwcm92aWRlclxuICAgKlxuICAgKiBAZGVmYXVsdCAtIGRlcml2ZWQgZm9yIHRoZSBub2RlJ3MgdW5pcXVlIGlkXG4gICAqL1xuICByZWFkb25seSBuYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBbiBYTUwgZG9jdW1lbnQgZ2VuZXJhdGVkIGJ5IGFuIGlkZW50aXR5IHByb3ZpZGVyIChJZFApIHRoYXQgc3VwcG9ydHMgU0FNTCAyLjAuXG4gICAqXG4gICAqIFRoZSBkb2N1bWVudCBpbmNsdWRlcyB0aGUgaXNzdWVyJ3MgbmFtZSwgZXhwaXJhdGlvbiBpbmZvcm1hdGlvbiwgYW5kIGtleXMgdGhhdFxuICAgKiBjYW4gYmUgdXNlZCB0byB2YWxpZGF0ZSB0aGUgU0FNTCBhdXRoZW50aWNhdGlvbiByZXNwb25zZSAoYXNzZXJ0aW9ucykgdGhhdCBhcmVcbiAgICogcmVjZWl2ZWQgZnJvbSB0aGUgSWRQLiBZb3UgbXVzdCBnZW5lcmF0ZSB0aGUgbWV0YWRhdGEgZG9jdW1lbnQgdXNpbmcgdGhlIGlkZW50aXR5XG4gICAqIG1hbmFnZW1lbnQgc29mdHdhcmUgdGhhdCBpcyB1c2VkIGFzIHlvdXIgb3JnYW5pemF0aW9uJ3MgSWRQLlxuICAgKi9cbiAgcmVhZG9ubHkgbWV0YWRhdGFEb2N1bWVudDogc3RyaW5nO1xufVxuXG4vKipcbiAqIENyZWF0ZSBhIFNBTUwgaWRlbnRpdHkgcHJvdmlkZXJcbiAqXG4gKiBAZGVwcmVjYXRlZCB1c2UgYFNhbWxQcm92aWRlcmAgZnJvbSBgYXdzLWNkay1saWIvYXdzLWlhbWBcbiAqL1xuZXhwb3J0IGNsYXNzIFNhbWxJZGVudGl0eVByb3ZpZGVyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIFNBTUwgaWRlbnRpdHkgcHJvdmlkZXJcbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBzYW1sSWRlbnRpdHlQcm92aWRlckFybjogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTYW1sSWRlbnRpdHlQcm92aWRlclByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGNvbnN0IG5hbWUgPSBwcm9wcy5uYW1lID8/IGAke05hbWVzLnVuaXF1ZUlkKHRoaXMpfUlkZW50aXR5UHJvdmlkZXJgO1xuXG4gICAgY29uc3QgYXJuID0gU3RhY2sub2YodGhpcykuZm9ybWF0QXJuKHtcbiAgICAgIHNlcnZpY2U6ICdpYW0nLFxuICAgICAgcmVnaW9uOiAnJyxcbiAgICAgIHJlc291cmNlOiAnc2FtbC1wcm92aWRlcicsXG4gICAgICByZXNvdXJjZU5hbWU6IG5hbWUsXG4gICAgfSk7XG5cbiAgICBjb25zdCBpZHAgPSBuZXcgY3IuQXdzQ3VzdG9tUmVzb3VyY2UodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgcmVzb3VyY2VUeXBlOiAnQ3VzdG9tOjpTYW1sSWRlbnRpdHlQcm92aWRlcicsXG4gICAgICBvbkNyZWF0ZToge1xuICAgICAgICBzZXJ2aWNlOiAnSUFNJyxcbiAgICAgICAgYWN0aW9uOiAnY3JlYXRlU0FNTFByb3ZpZGVyJyxcbiAgICAgICAgcGFyYW1ldGVyczoge1xuICAgICAgICAgIE5hbWU6IG5hbWUsXG4gICAgICAgICAgU0FNTE1ldGFkYXRhRG9jdW1lbnQ6IHByb3BzLm1ldGFkYXRhRG9jdW1lbnQsXG4gICAgICAgIH0gYXMgQ3JlYXRlU0FNTFByb3ZpZGVyQ29tbWFuZElucHV0LFxuICAgICAgICBwaHlzaWNhbFJlc291cmNlSWQ6IGNyLlBoeXNpY2FsUmVzb3VyY2VJZC5mcm9tUmVzcG9uc2UoJ1NBTUxQcm92aWRlckFybicpLFxuICAgICAgfSxcbiAgICAgIG9uVXBkYXRlOiB7XG4gICAgICAgIHNlcnZpY2U6ICdJQU0nLFxuICAgICAgICBhY3Rpb246ICd1cGRhdGVTQU1MUHJvdmlkZXInLFxuICAgICAgICBwYXJhbWV0ZXJzOiB7XG4gICAgICAgICAgU0FNTFByb3ZpZGVyQXJuOiBuZXcgY3IuUGh5c2ljYWxSZXNvdXJjZUlkUmVmZXJlbmNlKCkudG9KU09OKCksXG4gICAgICAgICAgU0FNTE1ldGFkYXRhRG9jdW1lbnQ6IHByb3BzLm1ldGFkYXRhRG9jdW1lbnQsXG4gICAgICAgIH0gYXMgVXBkYXRlU0FNTFByb3ZpZGVyQ29tbWFuZElucHV0LFxuICAgICAgICBwaHlzaWNhbFJlc291cmNlSWQ6IGNyLlBoeXNpY2FsUmVzb3VyY2VJZC5mcm9tUmVzcG9uc2UoJ1NBTUxQcm92aWRlckFybicpLFxuICAgICAgfSxcbiAgICAgIG9uRGVsZXRlOiB7XG4gICAgICAgIHNlcnZpY2U6ICdJQU0nLFxuICAgICAgICBhY3Rpb246ICdkZWxldGVTQU1MUHJvdmlkZXInLFxuICAgICAgICBwYXJhbWV0ZXJzOiB7XG4gICAgICAgICAgU0FNTFByb3ZpZGVyQXJuOiBuZXcgY3IuUGh5c2ljYWxSZXNvdXJjZUlkUmVmZXJlbmNlKCkudG9KU09OKCksXG4gICAgICAgIH0gYXMgRGVsZXRlU0FNTFByb3ZpZGVyQ29tbWFuZElucHV0LFxuICAgICAgfSxcbiAgICAgIHBvbGljeTogY3IuQXdzQ3VzdG9tUmVzb3VyY2VQb2xpY3kuZnJvbVN0YXRlbWVudHMoW1xuICAgICAgICBuZXcgaWFtLlBvbGljeVN0YXRlbWVudCh7XG4gICAgICAgICAgYWN0aW9uczogW1xuICAgICAgICAgICAgJ2lhbTpjcmVhdGVTQU1MUHJvdmlkZXInLFxuICAgICAgICAgICAgJ2lhbTp1cGRhdGVTQU1MUHJvdmlkZXInLFxuICAgICAgICAgICAgJ2lhbTpkZWxldGVTQU1MUHJvdmlkZXInLFxuICAgICAgICAgIF0sXG4gICAgICAgICAgcmVzb3VyY2VzOiBbYXJuXSxcbiAgICAgICAgfSksXG4gICAgICBdKSxcbiAgICB9KTtcblxuICAgIHRoaXMuc2FtbElkZW50aXR5UHJvdmlkZXJBcm4gPSBpZHAuZ2V0UmVzcG9uc2VGaWVsZCgnU0FNTFByb3ZpZGVyQXJuJyk7XG4gIH1cbn1cblxuLyoqXG4gKiBQcmluY2lwYWwgZW50aXR5IHRoYXQgcmVwcmVzZW50cyBhIFNBTUwgZmVkZXJhdGVkIGlkZW50aXR5IHByb3ZpZGVyLlxuICpcbiAqIEBkZXByZWNhdGVkIHVzZSBgU2FtbFByaW5jaXBhbGAgZnJvbSBgYXdzLWNkay1saWIvYXdzLWlhbWBcbiAqL1xuZXhwb3J0IGNsYXNzIFNhbWxGZWRlcmF0ZWRQcmluY2lwYWwgZXh0ZW5kcyBpYW0uRmVkZXJhdGVkUHJpbmNpcGFsIHtcbiAgY29uc3RydWN0b3IoaWRlbnRpdHlQcm92aWRlcjogU2FtbElkZW50aXR5UHJvdmlkZXIpIHtcbiAgICBzdXBlcihcbiAgICAgIGlkZW50aXR5UHJvdmlkZXIuc2FtbElkZW50aXR5UHJvdmlkZXJBcm4sXG4gICAgICB7XG4gICAgICAgIFN0cmluZ0VxdWFsczoge1xuICAgICAgICAgICdTQU1MOmF1ZCc6ICdodHRwczovL3NpZ25pbi5hd3MuYW1hem9uLmNvbS9zYW1sJyxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgICAnc3RzOkFzc3VtZVJvbGVXaXRoU0FNTCcsXG4gICAgKTtcbiAgfVxufVxuIl19
@@ -143,7 +143,7 @@ class SlackAppManifest {
143
143
  }
144
144
  exports.SlackAppManifest = SlackAppManifest;
145
145
  _a = JSII_RTTI_SYMBOL_1;
146
- SlackAppManifest[_a] = { fqn: "cloudstructs.SlackAppManifest", version: "0.6.30" };
146
+ SlackAppManifest[_a] = { fqn: "cloudstructs.SlackAppManifest", version: "0.6.32" };
147
147
  function prefixWith(prefix, string) {
148
148
  if (!string) {
149
149
  return undefined;
@@ -34,7 +34,7 @@ class SlackAppManifestDefinition {
34
34
  }
35
35
  exports.SlackAppManifestDefinition = SlackAppManifestDefinition;
36
36
  _a = JSII_RTTI_SYMBOL_1;
37
- SlackAppManifestDefinition[_a] = { fqn: "cloudstructs.SlackAppManifestDefinition", version: "0.6.30" };
37
+ SlackAppManifestDefinition[_a] = { fqn: "cloudstructs.SlackAppManifestDefinition", version: "0.6.32" };
38
38
  class StringManifest extends SlackAppManifestDefinition {
39
39
  constructor(manifest) {
40
40
  super();
@@ -86,5 +86,5 @@ class SlackApp extends constructs_1.Construct {
86
86
  }
87
87
  exports.SlackApp = SlackApp;
88
88
  _b = JSII_RTTI_SYMBOL_1;
89
- SlackApp[_b] = { fqn: "cloudstructs.SlackApp", version: "0.6.30" };
89
+ SlackApp[_b] = { fqn: "cloudstructs.SlackApp", version: "0.6.32" };
90
90
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slack-app.js","sourceRoot":"","sources":["../../src/slack-app/slack-app.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport { CustomResource } from 'aws-cdk-lib';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport { Construct, IConstruct } from 'constructs';\nimport { SlackAppManifest, SlackAppManifestProps } from './manifest';\nimport { SlackAppProvider } from './provider';\n\n/**\n * Properties for a SlackApp\n */\nexport interface SlackAppProps {\n  /**\n   * The definition of the app manifest\n   *\n   * @see https://api.slack.com/reference/manifests\n   */\n  readonly manifest: SlackAppManifestDefinition;\n\n  /**\n   * An AWS Secrets Manager secret containing the app configuration token\n   *\n   * Must use the following JSON format:\n   *\n   * ```\n   * {\n   *   \"refreshToken\": \"<token>\"\n   * }\n   * ```\n   */\n  readonly configurationTokenSecret: secretsmanager.ISecret;\n\n  /**\n   * The AWS Secrets Manager secret where to store the app credentials\n   *\n   * @default - a new secret is created\n   */\n  readonly credentialsSecret?: secretsmanager.ISecret;\n}\n\n/**\n * A Slack app manifest definition\n */\nexport abstract class SlackAppManifestDefinition {\n  /**\n   * Create a Slack app manifest from a JSON app manifest encoded as a string\n   */\n  public static fromString(manifest: string): SlackAppManifestDefinition {\n    return new StringManifest(manifest);\n  }\n\n  /**\n   * Creates a Slack app manifest from a file containg a JSON app manifest\n   */\n  public static fromFile(file: string): SlackAppManifestDefinition {\n    return new FileManifest(file);\n  }\n\n  /**\n   * Creates a Slack app manifest by specifying properties\n   */\n  public static fromManifest(props: SlackAppManifestProps): SlackAppManifestDefinition {\n    return new SlackAppManifest(props);\n  }\n\n  /**\n   * Renders the JSON app manifest encoded as a string\n   */\n  public abstract render(construct: IConstruct): string;\n}\n\nclass StringManifest extends SlackAppManifestDefinition {\n  constructor(private readonly manifest: string) {\n    super();\n  }\n\n  public render(_construct: IConstruct): string {\n    return this.manifest;\n  }\n}\n\nclass FileManifest extends SlackAppManifestDefinition {\n  constructor(private readonly file: string) {\n    super();\n  }\n\n  public render(_construct: IConstruct): string {\n    return fs.readFileSync(this.file, 'utf8');\n  }\n}\n\n/**\n * A Slack application deployed with a manifest\n *\n * @see https://api.slack.com/reference/manifests\n */\nexport class SlackApp extends Construct {\n  /**\n   * The ID of the application\n   */\n  public readonly appId: string;\n\n  /**\n   * An AWS Secrets Manager secret containing the credentials of the application.\n   *\n   * ```\n   * {\n   *   \"appId\": \"...\",\n   *   \"clientId\": \"...\",\n   *   \"clientSecret\": \"...\",\n   *   \"verificationToken\": \"...\",\n   *   \"signingSecret\": \"...\"\n   * }\n   * ```\n   */\n  public readonly credentials: secretsmanager.ISecret;\n\n  /**\n   * A dynamic reference to the client ID of the app\n   */\n  public readonly clientId: string;\n\n  /**\n   * A dynamic reference to the client secret of the app\n   */\n  public readonly clientSecret: string;\n\n  /**\n   * A dynamic reference to the verification token of the app\n   */\n  public readonly verificationToken: string;\n\n  /**\n   * A dynamic reference to the signing secret of the app\n   */\n  public readonly signingSecret: string;\n\n  constructor(scope: Construct, id: string, props: SlackAppProps) {\n    super(scope, id);\n\n    const provider = SlackAppProvider.getOrCreate(this);\n    props.configurationTokenSecret.grantRead(provider.handler);\n    props.configurationTokenSecret.grantWrite(provider.handler);\n\n    this.credentials = props.credentialsSecret ?? new secretsmanager.Secret(this, 'Credentials', {\n      description: `Credentials for Slack App ${this.node.id}`,\n    });\n    this.credentials.grantWrite(provider.handler);\n\n    const resource = new CustomResource(this, 'Resource', {\n      serviceToken: provider.serviceToken,\n      resourceType: 'Custom::SlackApp',\n      properties: {\n        manifest: props.manifest.render(this),\n        configurationTokenSecretArn: props.configurationTokenSecret.secretArn,\n        credentialsSecretArn: this.credentials.secretArn,\n      },\n    });\n\n    this.appId = resource.getAttString('appId');\n    this.clientId = this.credentials.secretValueFromJson('clientId').toString();\n    this.clientSecret = this.credentials.secretValueFromJson('clientSecret').toString();\n    this.verificationToken = this.credentials.secretValueFromJson('verificationToken').toString();\n    this.signingSecret = this.credentials.secretValueFromJson('signingSecret').toString();\n  }\n}\n"]}
@@ -42,5 +42,5 @@ class SlackEvents extends constructs_1.Construct {
42
42
  }
43
43
  exports.SlackEvents = SlackEvents;
44
44
  _a = JSII_RTTI_SYMBOL_1;
45
- SlackEvents[_a] = { fqn: "cloudstructs.SlackEvents", version: "0.6.30" };
45
+ SlackEvents[_a] = { fqn: "cloudstructs.SlackEvents", version: "0.6.32" };
46
46
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2xhY2stZXZlbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsZ0VBQWdFO0FBQ2hFLDZFQUE2RTtBQUM3RSxtQ0FBbUM7QUFDbkMsaURBQWlEO0FBQ2pELDZDQUE2QztBQUM3QywyQ0FBdUM7QUFDdkMsdURBQW1EO0FBMEJuRDs7R0FFRztBQUNILE1BQWEsV0FBWSxTQUFRLHNCQUFTO0lBTXhDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBdUI7UUFDL0QsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLEtBQUssQ0FBQyxjQUFjLEVBQUU7WUFDeEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1NBQ3ZEO1FBRUQsOEJBQThCO1FBQzlCLE1BQU0sT0FBTyxHQUFHLElBQUksZ0NBQWMsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQ2xELFlBQVksRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVM7WUFDMUMsV0FBVyxFQUFFO2dCQUNYLG9CQUFvQixFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsUUFBUSxFQUFFO2FBQ3JEO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLE9BQU8sQ0FBQyxjQUFjLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQztTQUN0RTtRQUVELE1BQU0sQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFM0MsV0FBVztRQUNYLE1BQU0sT0FBTyxHQUFHLElBQUksWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsZ0JBQWdCLEVBQUU7WUFDL0Qsa0JBQWtCLEVBQUUsSUFBSSxZQUFZLENBQUMscUJBQXFCLENBQUMsYUFBYSxFQUFFLE9BQU8sQ0FBQztZQUNsRixPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87U0FDdkIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxHQUFHLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUU7WUFDckMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxXQUFXO1NBQzNCLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBcENILGtDQXFDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGFwaWdhdGV3YXl2MiBmcm9tICdAYXdzLWNkay9hd3MtYXBpZ2F0ZXdheXYyLWFscGhhJztcbmltcG9ydCAqIGFzIGludGVncmF0aW9ucyBmcm9tICdAYXdzLWNkay9hd3MtYXBpZ2F0ZXdheXYyLWludGVncmF0aW9ucy1hbHBoYSc7XG5pbXBvcnQgKiBhcyBjZGsgZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgZXZlbnRzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1ldmVudHMnO1xuaW1wb3J0ICogYXMgbG9ncyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbG9ncyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEV2ZW50c0Z1bmN0aW9uIH0gZnJvbSAnLi9ldmVudHMtZnVuY3Rpb24nO1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGEgU2xhY2tFdmVudHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTbGFja0V2ZW50c1Byb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBzaWduaW5nIHNlY3JldCBvZiB0aGUgU2xhY2sgYXBwXG4gICAqL1xuICByZWFkb25seSBzaWduaW5nU2VjcmV0OiBjZGsuU2VjcmV0VmFsdWU7XG5cbiAgLyoqXG4gICAqIEEgbmFtZSBmb3IgdGhlIEFQSSBHYXRld2F5IHJlc291cmNlXG4gICAqXG4gICAqIEBkZWZhdWx0IFNsYWNrRXZlbnRzQXBpXG4gICAqL1xuICByZWFkb25seSBhcGlOYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIHVzZSBhIGN1c3RvbSBldmVudCBidXNcbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IGN1c3RvbUV2ZW50QnVzPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBTZW5kIFNsYWNrIGV2ZW50cyB0byBBbWF6b24gRXZlbnRCcmlkZ2VcbiAqL1xuZXhwb3J0IGNsYXNzIFNsYWNrRXZlbnRzIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgLyoqXG4gICAqIFRoZSBjdXN0b20gZXZlbnQgYnVzIHdoZXJlIFNsYWNrIGV2ZW50cyBhcmUgc2VudFxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGV2ZW50QnVzPzogZXZlbnRzLkV2ZW50QnVzO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTbGFja0V2ZW50c1Byb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGlmIChwcm9wcy5jdXN0b21FdmVudEJ1cykge1xuICAgICAgdGhpcy5ldmVudEJ1cyA9IG5ldyBldmVudHMuRXZlbnRCdXModGhpcywgJ0V2ZW50QnVzJyk7XG4gICAgfVxuXG4gICAgLy8gU2VuZCBldmVudCB0byB0aGUgZXZlbnQgYnVzXG4gICAgY29uc3QgaGFuZGxlciA9IG5ldyBFdmVudHNGdW5jdGlvbih0aGlzLCAnaGFuZGxlcicsIHtcbiAgICAgIGxvZ1JldGVudGlvbjogbG9ncy5SZXRlbnRpb25EYXlzLk9ORV9NT05USCxcbiAgICAgIGVudmlyb25tZW50OiB7XG4gICAgICAgIFNMQUNLX1NJR05JTkdfU0VDUkVUOiBwcm9wcy5zaWduaW5nU2VjcmV0LnRvU3RyaW5nKCksXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgaWYgKHRoaXMuZXZlbnRCdXMpIHtcbiAgICAgIGhhbmRsZXIuYWRkRW52aXJvbm1lbnQoJ0VWRU5UX0JVU19OQU1FJywgdGhpcy5ldmVudEJ1cy5ldmVudEJ1c05hbWUpO1xuICAgIH1cblxuICAgIGV2ZW50cy5FdmVudEJ1cy5ncmFudEFsbFB1dEV2ZW50cyhoYW5kbGVyKTtcblxuICAgIC8vIEhUVFAgQVBJXG4gICAgY29uc3QgaHR0cEFwaSA9IG5ldyBhcGlnYXRld2F5djIuSHR0cEFwaSh0aGlzLCAnU2xhY2tFdmVudHNBcGknLCB7XG4gICAgICBkZWZhdWx0SW50ZWdyYXRpb246IG5ldyBpbnRlZ3JhdGlvbnMuSHR0cExhbWJkYUludGVncmF0aW9uKCdJbnRlZ3JhdGlvbicsIGhhbmRsZXIpLFxuICAgICAgYXBpTmFtZTogcHJvcHMuYXBpTmFtZSxcbiAgICB9KTtcblxuICAgIG5ldyBjZGsuQ2ZuT3V0cHV0KHRoaXMsICdBcGlFbmRwb2ludCcsIHtcbiAgICAgIHZhbHVlOiBodHRwQXBpLmFwaUVuZHBvaW50LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -49,5 +49,5 @@ class SlackTextract extends constructs_1.Construct {
49
49
  }
50
50
  exports.SlackTextract = SlackTextract;
51
51
  _a = JSII_RTTI_SYMBOL_1;
52
- SlackTextract[_a] = { fqn: "cloudstructs.SlackTextract", version: "0.6.30" };
52
+ SlackTextract[_a] = { fqn: "cloudstructs.SlackTextract", version: "0.6.32" };
53
53
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2xhY2stdGV4dHJhY3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2Q0FBb0Q7QUFDcEQsaURBQWlEO0FBQ2pELDBEQUEwRDtBQUMxRCwyQ0FBMkM7QUFDM0MsNkNBQTZDO0FBQzdDLDJDQUF1QztBQUN2Qyx1REFBbUQ7QUFDbkQsa0RBQThDO0FBd0I5Qzs7R0FFRztBQUNILE1BQWEsYUFBYyxTQUFRLHNCQUFTO0lBQzFDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBeUI7UUFDakUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixNQUFNLE9BQU8sR0FBRyxJQUFJLGdDQUFjLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRTtZQUNsRCxPQUFPLEVBQUUsc0JBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQzdCLFlBQVksRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVM7WUFDMUMsV0FBVyxFQUFFO2dCQUNYLFdBQVcsRUFBRSxLQUFLLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRTthQUN2QztTQUNGLENBQUMsQ0FBQztRQUVILE9BQU8sQ0FBQyxlQUFlLENBQUMsSUFBSSxHQUFHLENBQUMsZUFBZSxDQUFDO1lBQzlDLE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO1lBQ3hDLFNBQVMsRUFBRSxDQUFDLEdBQUcsQ0FBQztTQUNqQixDQUFDLENBQUMsQ0FBQztRQUVKLElBQUksMEJBQVcsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQ25DLGFBQWEsRUFBRSxLQUFLLENBQUMsYUFBYTtTQUNuQyxDQUFDLENBQUM7UUFFSCxNQUFNLGNBQWMsR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLGlCQUFpQixFQUFFO1lBQzlELFlBQVksRUFBRTtnQkFDWixNQUFNLEVBQUU7b0JBQ04sS0FBSyxFQUFFO3dCQUNMLElBQUksRUFBRSxDQUFDLGFBQWEsQ0FBQztxQkFDdEI7aUJBQ0Y7Z0JBQ0QsU0FBUyxFQUFFLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQztnQkFDeEIsTUFBTSxFQUFFLENBQUMsT0FBTyxDQUFDO2FBQ2xCO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsY0FBYyxDQUFDLFNBQVMsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFO1lBQzNELEtBQUssRUFBRSxNQUFNLENBQUMsZUFBZSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQztTQUM5RCxDQUFDLENBQUMsQ0FBQztJQUNOLENBQUM7O0FBcENILHNDQXFDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER1cmF0aW9uLCBTZWNyZXRWYWx1ZSB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGV2ZW50cyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZXZlbnRzJztcbmltcG9ydCAqIGFzIHRhcmdldHMgZnJvbSAnYXdzLWNkay1saWIvYXdzLWV2ZW50cy10YXJnZXRzJztcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCAqIGFzIGxvZ3MgZnJvbSAnYXdzLWNkay1saWIvYXdzLWxvZ3MnO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5pbXBvcnQgeyBEZXRlY3RGdW5jdGlvbiB9IGZyb20gJy4vZGV0ZWN0LWZ1bmN0aW9uJztcbmltcG9ydCB7IFNsYWNrRXZlbnRzIH0gZnJvbSAnLi4vc2xhY2stZXZlbnRzJztcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBhIFNsYWNrVGV4dHJhY3RcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTbGFja1RleHRyYWN0UHJvcHMge1xuICAvKipcbiAgICogVGhlIHNpZ25pbmcgc2VjcmV0IG9mIHRoZSBTbGFjayBhcHBcbiAgICovXG4gIHJlYWRvbmx5IHNpZ25pbmdTZWNyZXQ6IFNlY3JldFZhbHVlO1xuXG4gIC8qKlxuICAgKiBUaGUgKipib3QqKiB0b2tlbiBvZiB0aGUgU2xhY2sgYXBwLlxuICAgKlxuICAgKiBUaGUgZm9sbG93aW5nIHNjb3BlcyBhcmUgcmVxdWlyZWQ6IGBjaGF0OndyaXRlYCBhbmQgYGZpbGVzOnJlYWRgXG4gICAqL1xuICByZWFkb25seSBib3RUb2tlbjogU2VjcmV0VmFsdWU7XG5cbiAgLyoqXG4gICAqIFRoZSBhcHBsaWNhdGlvbiBpZCBvZiB0aGUgU2xhY2sgYXBwLlxuICAgKi9cbiAgcmVhZG9ubHkgYXBwSWQ6IHN0cmluZztcbn1cblxuLyoqXG4gKiBFeHRyYWN0IHRleHQgZnJvbSBpbWFnZXMgcG9zdGVkIHRvIFNsYWNrIHVzaW5nIEFtYXpvbiBUZXh0cmFjdFxuICovXG5leHBvcnQgY2xhc3MgU2xhY2tUZXh0cmFjdCBleHRlbmRzIENvbnN0cnVjdCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTbGFja1RleHRyYWN0UHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgY29uc3QgaGFuZGxlciA9IG5ldyBEZXRlY3RGdW5jdGlvbih0aGlzLCAnaGFuZGxlcicsIHtcbiAgICAgIHRpbWVvdXQ6IER1cmF0aW9uLnNlY29uZHMoMzApLFxuICAgICAgbG9nUmV0ZW50aW9uOiBsb2dzLlJldGVudGlvbkRheXMuT05FX01PTlRILFxuICAgICAgZW52aXJvbm1lbnQ6IHtcbiAgICAgICAgU0xBQ0tfVE9LRU46IHByb3BzLmJvdFRva2VuLnRvU3RyaW5nKCksXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgaGFuZGxlci5hZGRUb1JvbGVQb2xpY3kobmV3IGlhbS5Qb2xpY3lTdGF0ZW1lbnQoe1xuICAgICAgYWN0aW9uczogWyd0ZXh0cmFjdDpEZXRlY3REb2N1bWVudFRleHQnXSxcbiAgICAgIHJlc291cmNlczogWycqJ10sXG4gICAgfSkpO1xuXG4gICAgbmV3IFNsYWNrRXZlbnRzKHRoaXMsICdTbGFja0V2ZW50cycsIHtcbiAgICAgIHNpZ25pbmdTZWNyZXQ6IHByb3BzLnNpZ25pbmdTZWNyZXQsXG4gICAgfSk7XG5cbiAgICBjb25zdCBmaWxlU2hhcmVkUnVsZSA9IG5ldyBldmVudHMuUnVsZSh0aGlzLCAnU2xhY2tFdmVudHNSdWxlJywge1xuICAgICAgZXZlbnRQYXR0ZXJuOiB7XG4gICAgICAgIGRldGFpbDoge1xuICAgICAgICAgIGV2ZW50OiB7XG4gICAgICAgICAgICB0eXBlOiBbJ2ZpbGVfc2hhcmVkJ10sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgcmVzb3VyY2VzOiBbcHJvcHMuYXBwSWRdLFxuICAgICAgICBzb3VyY2U6IFsnc2xhY2snXSxcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICBmaWxlU2hhcmVkUnVsZS5hZGRUYXJnZXQobmV3IHRhcmdldHMuTGFtYmRhRnVuY3Rpb24oaGFuZGxlciwge1xuICAgICAgZXZlbnQ6IGV2ZW50cy5SdWxlVGFyZ2V0SW5wdXQuZnJvbUV2ZW50UGF0aCgnJC5kZXRhaWwuZXZlbnQnKSxcbiAgICB9KSk7XG4gIH1cbn1cbiJdfQ==
@@ -49,7 +49,7 @@ class SslServerTest extends constructs_1.Construct {
49
49
  }
50
50
  exports.SslServerTest = SslServerTest;
51
51
  _a = JSII_RTTI_SYMBOL_1;
52
- SslServerTest[_a] = { fqn: "cloudstructs.SslServerTest", version: "0.6.30" };
52
+ SslServerTest[_a] = { fqn: "cloudstructs.SslServerTest", version: "0.6.32" };
53
53
  class SslServerTestStateMachine extends constructs_1.Construct {
54
54
  constructor(scope, id) {
55
55
  super(scope, id);
@@ -105,5 +105,5 @@ class StateMachineCustomResourceProvider extends constructs_1.Construct {
105
105
  }
106
106
  exports.StateMachineCustomResourceProvider = StateMachineCustomResourceProvider;
107
107
  _a = JSII_RTTI_SYMBOL_1;
108
- StateMachineCustomResourceProvider[_a] = { fqn: "cloudstructs.StateMachineCustomResourceProvider", version: "0.6.30" };
108
+ StateMachineCustomResourceProvider[_a] = { fqn: "cloudstructs.StateMachineCustomResourceProvider", version: "0.6.32" };
109
109
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/state-machine-cr-provider/index.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { ArnFormat, CfnResource, Duration, Stack } from 'aws-cdk-lib';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\n\n/**\n * A State Machine\n */\nexport interface IStateMachine {\n  /**\n   * The ARN of the state machine\n   */\n  readonly stateMachineArn: string;\n}\n\n/**\n * Properties for a StateMachineCustomResourceProvider\n */\nexport interface StateMachineCustomResourceProviderProps {\n  /**\n   * The state machine\n   */\n  readonly stateMachine: IStateMachine;\n\n  /**\n   * Timeout\n   *\n   * @default Duration.minutes(30)\n   */\n  readonly timeout?: Duration;\n}\n\n/**\n * A state machine custom resource provider\n */\nexport class StateMachineCustomResourceProvider extends Construct {\n  /**\n   * The service token\n   */\n  public readonly serviceToken: string;\n\n  constructor(scope: Construct, id: string, props: StateMachineCustomResourceProviderProps) {\n    super(scope, id);\n\n    const cfnResponseSuccessFn = this.createCfnResponseFn('Success');\n    const cfnResponseFailedFn = this.createCfnResponseFn('Failed');\n\n    const role = new iam.Role(this, 'Role', {\n      assumedBy: new iam.ServicePrincipal('states.amazonaws.com'),\n    });\n    role.addToPolicy(new iam.PolicyStatement({\n      actions: ['lambda:InvokeFunction'],\n      resources: [cfnResponseSuccessFn.functionArn, cfnResponseFailedFn.functionArn],\n    }));\n    // https://docs.aws.amazon.com/step-functions/latest/dg/stepfunctions-iam.html\n    // https://docs.aws.amazon.com/step-functions/latest/dg/concept-create-iam-advanced.html#concept-create-iam-advanced-execution\n    role.addToPolicy(new iam.PolicyStatement({\n      actions: ['states:StartExecution'],\n      resources: [props.stateMachine.stateMachineArn],\n    }));\n    role.addToPolicy(new iam.PolicyStatement({\n      actions: ['states:DescribeExecution', 'states:StopExecution'],\n      resources: [Stack.of(this).formatArn({\n        service: 'states',\n        resource: 'execution',\n        arnFormat: ArnFormat.COLON_RESOURCE_NAME,\n        resourceName: `${Stack.of(this).splitArn(props.stateMachine.stateMachineArn, ArnFormat.COLON_RESOURCE_NAME).resourceName}*`,\n      })],\n    }));\n    role.addToPolicy(new iam.PolicyStatement({\n      actions: ['events:PutTargets', 'events:PutRule', 'events:DescribeRule'],\n      resources: [Stack.of(this).formatArn({\n        service: 'events',\n        resource: 'rule',\n        resourceName: 'StepFunctionsGetEventsForStepFunctionsExecutionRule',\n      })],\n    }));\n\n    const definition = Stack.of(this).toJsonString({\n      StartAt: 'StartExecution',\n      States: {\n        StartExecution: {\n          Type: 'Task',\n          Resource: 'arn:aws:states:::states:startExecution.sync:2', // with sync:2 the Output is JSON parsed\n          Parameters: {\n            'Input.$': '$',\n            'StateMachineArn': props.stateMachine.stateMachineArn,\n          },\n          TimeoutSeconds: (props.timeout ?? Duration.minutes(30)).toSeconds(),\n          Next: 'CfnResponseSuccess',\n          Catch: [{\n            ErrorEquals: ['States.ALL'],\n            Next: 'CfnResponseFailed',\n          }],\n        },\n        CfnResponseSuccess: {\n          Type: 'Task',\n          Resource: cfnResponseSuccessFn.functionArn,\n          End: true,\n        },\n        CfnResponseFailed: {\n          Type: 'Task',\n          Resource: cfnResponseFailedFn.functionArn,\n          End: true,\n        },\n      },\n    });\n\n    const stateMachine = new CfnResource(this, 'StateMachine', {\n      type: 'AWS::StepFunctions::StateMachine',\n      properties: {\n        DefinitionString: definition,\n        RoleArn: role.roleArn,\n      },\n    });\n    stateMachine.node.addDependency(role);\n\n    const startExecution = new lambda.Function(this, 'StartExecution', {\n      code: lambda.Code.fromAsset(path.join(__dirname, 'runtime')),\n      handler: 'index.startExecution',\n      runtime: new lambda.Runtime('nodejs18.x', lambda.RuntimeFamily.NODEJS),\n    });\n    startExecution.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['states:StartExecution'],\n      resources: [stateMachine.ref],\n    }));\n    startExecution.addEnvironment('STATE_MACHINE_ARN', stateMachine.ref);\n\n    this.serviceToken = startExecution.functionArn;\n  }\n\n  private createCfnResponseFn(status: string) {\n    return new lambda.Function(this, `CfnResponse${status}`, {\n      code: lambda.Code.fromAsset(path.join(__dirname, 'runtime')),\n      handler: `index.cfnResponse${status}`,\n      runtime: new lambda.Runtime('nodejs18.x', lambda.RuntimeFamily.NODEJS),\n    });\n  }\n}\n"]}
@@ -97,7 +97,7 @@ class StaticWebsite extends constructs_1.Construct {
97
97
  }
98
98
  exports.StaticWebsite = StaticWebsite;
99
99
  _a = JSII_RTTI_SYMBOL_1;
100
- StaticWebsite[_a] = { fqn: "cloudstructs.StaticWebsite", version: "0.6.30" };
100
+ StaticWebsite[_a] = { fqn: "cloudstructs.StaticWebsite", version: "0.6.32" };
101
101
  /**
102
102
  * Best practice security headers used as default
103
103
  */
@@ -112,5 +112,5 @@ class ToolkitCleaner extends constructs_1.Construct {
112
112
  }
113
113
  exports.ToolkitCleaner = ToolkitCleaner;
114
114
  _a = JSII_RTTI_SYMBOL_1;
115
- ToolkitCleaner[_a] = { fqn: "cloudstructs.ToolkitCleaner", version: "0.6.30" };
115
+ ToolkitCleaner[_a] = { fqn: "cloudstructs.ToolkitCleaner", version: "0.6.32" };
116
116
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/toolkit-cleaner/index.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { Duration } from 'aws-cdk-lib';\nimport { DockerImageAsset } from 'aws-cdk-lib/aws-ecr-assets';\nimport { Rule, Schedule } from 'aws-cdk-lib/aws-events';\nimport { SfnStateMachine } from 'aws-cdk-lib/aws-events-targets';\nimport { PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { Asset } from 'aws-cdk-lib/aws-s3-assets';\nimport * as sfn from 'aws-cdk-lib/aws-stepfunctions';\nimport * as tasks from 'aws-cdk-lib/aws-stepfunctions-tasks';\nimport { Construct } from 'constructs';\nimport { CleanImagesFunction } from './clean-images-function';\nimport { CleanObjectsFunction } from './clean-objects-function';\nimport { ExtractTemplateHashesFunction } from './extract-template-hashes-function';\nimport { GetStackNamesFunction } from './get-stack-names-function';\n\n/**\n * Properties for a ToolkitCleaner\n */\nexport interface ToolkitCleanerProps {\n  /**\n   * The schedule for the cleaner.\n   *\n   * @default - every day\n   */\n  readonly schedule?: Schedule;\n\n  /**\n   * Whether to clean on schedule. If you'd like to run the cleanup manually\n   * via the console, set to `false`.\n   *\n   * @default true\n   */\n  readonly scheduleEnabled?: boolean;\n\n  /**\n   * Only output number of assets and total size that would be deleted\n   * but without actually deleting assets.\n   */\n  readonly dryRun?: boolean;\n\n  /**\n   * Retain unused assets that were created recently\n   *\n   * @default - all unused assets are removed\n   */\n  readonly retainAssetsNewerThan?: Duration;\n}\n\n/**\n * Clean unused S3 and ECR assets from your CDK Toolkit.\n */\nexport class ToolkitCleaner extends Construct {\n  constructor(scope: Construct, id: string, props: ToolkitCleanerProps = {}) {\n    super(scope, id);\n\n    // Dummy assets to reference S3 bucket and ECR repository\n    const fileAsset = new Asset(this, 'FileAsset', {\n      path: path.join(__dirname, '..', '..', 'assets', 'toolkit-cleaner', 'docker', 'dummy.txt'),\n    });\n    const dockerImageAsset = new DockerImageAsset(this, 'DockerImageAsset', {\n      directory: path.join(__dirname, '..', '..', 'assets', 'toolkit-cleaner', 'docker'),\n    });\n\n    const getStackNamesFunction = new GetStackNamesFunction(this, 'GetStackNamesFunction', {\n      timeout: Duration.seconds(30),\n    });\n    getStackNamesFunction.addToRolePolicy(new PolicyStatement({\n      actions: ['cloudformation:DescribeStacks', 'cloudformation:ListStacks'],\n      resources: ['*'],\n    }));\n    const getStackNames = new tasks.LambdaInvoke(this, 'GetStackNames', {\n      lambdaFunction: getStackNamesFunction,\n      payloadResponseOnly: true,\n    });\n\n    const stacksMap = new sfn.Map(this, 'StacksMap', {\n      maxConcurrency: 1, // Avoid \"Rate exceeded\" error from CloudFormation\n      resultSelector: {\n        AssetHashes: sfn.JsonPath.stringAt('$'),\n      },\n    });\n\n    const extractTemplateHashesFunction = new ExtractTemplateHashesFunction(this, 'ExtractTemplateHashesFunction', {\n      timeout: Duration.seconds(30),\n    });\n    extractTemplateHashesFunction.addToRolePolicy(new PolicyStatement({\n      actions: ['cloudformation:GetTemplate'],\n      resources: ['*'],\n    }));\n    const extractTemplateHashes = new tasks.LambdaInvoke(this, 'ExtractTemplateHashes', {\n      lambdaFunction: extractTemplateHashesFunction,\n      payloadResponseOnly: true,\n    }).addRetry({\n      errors: ['Throttling'], // Avoid \"Rate exceeded\" error from CloudFormation\n    });\n\n    const flattenHashes = new tasks.EvaluateExpression(this, 'FlattenHashes', {\n      expression: '[...new Set(($.AssetHashes).flat())]',\n    });\n\n    const cleanObjectsFunction = new CleanObjectsFunction(this, 'CleanObjectsFunction', {\n      timeout: Duration.minutes(5),\n    });\n    cleanObjectsFunction.addEnvironment('BUCKET_NAME', fileAsset.bucket.bucketName);\n    fileAsset.bucket.grantRead(cleanObjectsFunction);\n    fileAsset.bucket.grantDelete(cleanObjectsFunction);\n    const cleanObjects = new tasks.LambdaInvoke(this, 'CleanObjects', {\n      lambdaFunction: cleanObjectsFunction,\n      payloadResponseOnly: true,\n    });\n\n    const cleanImagesFunction = new CleanImagesFunction(this, 'CleanImagesFunction', {\n      timeout: Duration.minutes(5),\n    });\n    cleanImagesFunction.addEnvironment('REPOSITORY_NAME', dockerImageAsset.repository.repositoryName);\n    dockerImageAsset.repository.grant(cleanImagesFunction, 'ecr:DescribeImages', 'ecr:BatchDeleteImage');\n    const cleanImages = new tasks.LambdaInvoke(this, 'CleanImages', {\n      lambdaFunction: cleanImagesFunction,\n      payloadResponseOnly: true,\n    });\n\n    if (!props.dryRun) {\n      cleanObjectsFunction.addEnvironment('RUN', 'true');\n      cleanImagesFunction.addEnvironment('RUN', 'true');\n    }\n\n    if (props.retainAssetsNewerThan) {\n      const retainMilliseconds = props.retainAssetsNewerThan.toMilliseconds().toString();\n      cleanObjectsFunction.addEnvironment('RETAIN_MILLISECONDS', retainMilliseconds);\n      cleanImagesFunction.addEnvironment('RETAIN_MILLISECONDS', retainMilliseconds);\n    }\n\n    const sumReclaimed = new tasks.EvaluateExpression(this, 'SumReclaimed', {\n      expression: '({ Deleted: $[0].Deleted + $[1].Deleted, Reclaimed: $[0].Reclaimed + $[1].Reclaimed })',\n    });\n\n    const stateMachine = new sfn.StateMachine(this, 'Resource', {\n      definition: getStackNames\n        .next(stacksMap.iterator(extractTemplateHashes))\n        .next(flattenHashes)\n        .next(new sfn.Parallel(this, 'Clean')\n          .branch(cleanObjects)\n          .branch(cleanImages))\n        .next(sumReclaimed),\n    });\n\n    const rule = new Rule(this, 'Rule', {\n      enabled: props.scheduleEnabled ?? true,\n      schedule: props.schedule ?? Schedule.rate(Duration.days(1)),\n    });\n    rule.addTarget(new SfnStateMachine(stateMachine));\n  }\n}\n"]}
@@ -143,5 +143,5 @@ class UrlShortener extends constructs_1.Construct {
143
143
  }
144
144
  exports.UrlShortener = UrlShortener;
145
145
  _a = JSII_RTTI_SYMBOL_1;
146
- UrlShortener[_a] = { fqn: "cloudstructs.UrlShortener", version: "0.6.30" };
146
+ UrlShortener[_a] = { fqn: "cloudstructs.UrlShortener", version: "0.6.32" };
147
147
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/url-shortener/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Fn, RemovalPolicy } from 'aws-cdk-lib';\nimport * as apigateway from 'aws-cdk-lib/aws-apigateway';\nimport * as acm from 'aws-cdk-lib/aws-certificatemanager';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as origins from 'aws-cdk-lib/aws-cloudfront-origins';\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as route53 from 'aws-cdk-lib/aws-route53';\nimport * as targets from 'aws-cdk-lib/aws-route53-targets';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { Construct } from 'constructs';\nimport { RedirectFunction } from './redirect-function';\nimport { ShortenerFunction } from './shortener-function';\n\n/**\n * Properties for a UrlShortener\n */\nexport interface UrlShortenerProps {\n  /**\n   * The hosted zone for the short URLs domain\n   */\n  readonly hostedZone: route53.IHostedZone;\n\n  /**\n   * The record name to use in the hosted zone\n   *\n   * @default - zone root\n   */\n  readonly recordName?: string;\n\n  /**\n   * Expiration for short urls\n   *\n   * @default cdk.Duration.days(365)\n   */\n  readonly expiration?: Duration;\n\n  /**\n   * An interface VPC endpoint for API gateway. Specifying this property will\n   * make the API private.\n   *\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-private-apis.html\n   *\n   * @default - API is public\n   */\n  readonly apiGatewayEndpoint?: ec2.IInterfaceVpcEndpoint;\n\n  /**\n   * Authorizer for API gateway.\n   *\n   * @default - do not use an authorizer for the API\n   */\n  readonly apiGatewayAuthorizer?: apigateway.IAuthorizer;\n\n  /**\n   * Whether to use IAM authorization\n   *\n   * @default - do not use IAM authorization\n   */\n  readonly iamAuthorization?: boolean;\n\n  /**\n   * Allowed origins for CORS\n   *\n   * @default - CORS is not enabled\n   */\n  readonly corsAllowOrigins?: string[];\n\n  /**\n   * A name for the bucket saving the redirects\n   *\n   * @default - derived from short link domain name\n   */\n  readonly bucketName?: string;\n}\n\n/**\n * URL shortener\n */\nexport class UrlShortener extends Construct {\n  /**\n   * The endpoint of the URL shortener API\n   */\n  public readonly apiEndpoint: string;\n\n  /**\n   * The underlying API Gateway REST API\n   */\n  public readonly api: apigateway.RestApi;\n\n  private readonly iamAuthorization?: boolean;\n\n  constructor(scope: Construct, id: string, props: UrlShortenerProps) {\n    super(scope, id);\n\n    const domainName = props.recordName ? `${props.recordName}.${props.hostedZone.zoneName}` : props.hostedZone.zoneName;\n\n    // Table to save a counter\n    const table = new dynamodb.Table(this, 'Table', {\n      partitionKey: {\n        name: 'key',\n        type: dynamodb.AttributeType.STRING,\n      },\n      billingMode: dynamodb.BillingMode.PAY_PER_REQUEST,\n      removalPolicy: RemovalPolicy.DESTROY,\n    });\n\n    // Bucket to save redirects\n    const bucket = new s3.Bucket(this, 'Bucket', {\n      lifecycleRules: [{\n        expiration: props.expiration ?? Duration.days(365),\n      }],\n      blockPublicAccess: s3.BlockPublicAccess.BLOCK_ALL,\n      bucketName: props.bucketName ?? `cloudstructs-url-shortener-${domainName}`,\n    });\n\n    // Redirect function\n    const redirectFunction = new RedirectFunction(this, 'Redirect');\n    bucket.grantRead(redirectFunction);\n\n    // CloudFront distribution\n    const certificate = new acm.DnsValidatedCertificate(this, 'Certificate', {\n      domainName,\n      hostedZone: props.hostedZone,\n      region: 'us-east-1',\n    });\n    const distribution = new cloudfront.Distribution(this, 'Distribution', {\n      defaultBehavior: {\n        origin: new origins.S3Origin(bucket),\n        edgeLambdas: [\n          {\n            eventType: cloudfront.LambdaEdgeEventType.ORIGIN_REQUEST,\n            functionVersion: redirectFunction,\n          },\n        ],\n      },\n      certificate,\n      domainNames: [domainName],\n      httpVersion: 'http2and3' as cloudfront.HttpVersion,\n    });\n\n    // Route53 records\n    new route53.ARecord(this, 'ARecord', {\n      zone: props.hostedZone,\n      target: route53.RecordTarget.fromAlias(new targets.CloudFrontTarget(distribution)),\n      recordName: props.recordName,\n    });\n    new route53.AaaaRecord(this, 'AaaaRecord', {\n      zone: props.hostedZone,\n      target: route53.RecordTarget.fromAlias(new targets.CloudFrontTarget(distribution)),\n      recordName: props.recordName,\n    });\n\n    // Lambda function to increment counter and write redirect in bucket\n    const shortenerFunction = new ShortenerFunction(this, 'Shortener', {\n      logRetention: logs.RetentionDays.ONE_MONTH,\n      environment: {\n        DOMAIN_NAME: domainName,\n        BUCKET_NAME: bucket.bucketName,\n        TABLE_NAME: table.tableName,\n      },\n    });\n    if (props.corsAllowOrigins) {\n      shortenerFunction.addEnvironment('CORS_ALLOW_ORIGINS', props.corsAllowOrigins.join(' '));\n    }\n    bucket.grantPut(shortenerFunction);\n    table.grant(shortenerFunction, 'dynamodb:UpdateItem');\n\n    // API\n    this.api = new apigateway.RestApi(this, `UrlShortener${props.hostedZone.zoneName}`, {\n      endpointTypes: props.apiGatewayEndpoint ? [apigateway.EndpointType.PRIVATE] : undefined,\n      policy: props.apiGatewayEndpoint\n        ? new iam.PolicyDocument({\n          statements: [\n            new iam.PolicyStatement({\n              effect: iam.Effect.ALLOW,\n              actions: ['execute-api:Invoke'],\n              principals: [new iam.AnyPrincipal()],\n              resources: [Fn.join('', ['execute-api:/', '*'])],\n              conditions: {\n                StringEquals: { 'aws:SourceVpce': props.apiGatewayEndpoint.vpcEndpointId },\n              },\n            }),\n          ],\n        })\n        : undefined,\n      defaultCorsPreflightOptions: props.corsAllowOrigins\n        ? { allowOrigins: props.corsAllowOrigins }\n        : undefined,\n    });\n\n    if (props.iamAuthorization && props.apiGatewayAuthorizer) {\n      throw new Error('Cannot use both IAM authorization and an authorizer');\n    }\n\n    this.iamAuthorization = props.iamAuthorization;\n\n    this.api.root.addMethod('POST', new apigateway.LambdaIntegration(shortenerFunction), {\n      authorizer: props.apiGatewayAuthorizer,\n      authorizationType: props.iamAuthorization ? apigateway.AuthorizationType.IAM : undefined,\n    });\n    this.api.root\n      .addResource('{proxy+}')\n      .addMethod('POST', new apigateway.LambdaIntegration(shortenerFunction), {\n        authorizer: props.apiGatewayAuthorizer,\n        authorizationType: this.iamAuthorization ? apigateway.AuthorizationType.IAM : undefined,\n      });\n\n    this.apiEndpoint = this.api.url;\n  }\n\n  /**\n   * Grant access to invoke the URL shortener if protected by IAM authorization\n   */\n  public grantInvoke(grantee: iam.IGrantable): iam.Grant {\n    if (this.iamAuthorization === false) {\n      throw new Error('The URL shortener is not protected by IAM authorization');\n    }\n\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['execute-api:Invoke'],\n      resourceArns: [`arn:aws:execute-api:${this.api.env.region}:${this.api.env.account}:${this.api.restApiId}/${this.api.deploymentStage.stageName}/POST/*`],\n    });\n  }\n}\n"]}
@@ -2,7 +2,6 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.handler = void 0;
4
4
  const client_s3_1 = require("@aws-sdk/client-s3");
5
- const s3Client = new client_s3_1.S3Client({});
6
5
  async function handler(event) {
7
6
  const request = event.Records[0].cf.request;
8
7
  try {
@@ -10,6 +9,7 @@ async function handler(event) {
10
9
  if (!s3Origin) {
11
10
  throw new Error('No S3 origin');
12
11
  }
12
+ const s3Client = new client_s3_1.S3Client({ region: s3Origin.region });
13
13
  const bucket = s3Origin.domainName.replace(new RegExp(`.s3.${s3Origin.region}.amazonaws.com$`), '');
14
14
  const key = request.uri.substring(1); // remove first slash
15
15
  const data = await s3Client.send(new client_s3_1.GetObjectCommand({
@@ -19,7 +19,7 @@ async function handler(event) {
19
19
  if (!data.Body) {
20
20
  throw new Error('No body');
21
21
  }
22
- const redirect = JSON.parse(data.Body.toString());
22
+ const redirect = JSON.parse(await data.Body.transformToString());
23
23
  return {
24
24
  status: '301',
25
25
  statusDescription: 'Moved Permanently',
@@ -40,4 +40,4 @@ async function handler(event) {
40
40
  }
41
41
  }
42
42
  exports.handler = handler;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVkaXJlY3QuZWRnZS1sYW1iZGEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXJsLXNob3J0ZW5lci9yZWRpcmVjdC5lZGdlLWxhbWJkYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxrREFBZ0U7QUFFaEUsTUFBTSxRQUFRLEdBQUcsSUFBSSxvQkFBUSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBRTNCLEtBQUssVUFBVSxPQUFPLENBQUMsS0FBdUM7SUFDbkUsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDO0lBRTVDLElBQUk7UUFDRixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQztRQUVwQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2IsTUFBTSxJQUFJLEtBQUssQ0FBQyxjQUFjLENBQUMsQ0FBQztTQUNqQztRQUVELE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sUUFBUSxDQUFDLE1BQU0saUJBQWlCLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNwRyxNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLHFCQUFxQjtRQUUzRCxNQUFNLElBQUksR0FBRyxNQUFNLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSw0QkFBZ0IsQ0FBQztZQUNwRCxNQUFNLEVBQUUsTUFBTTtZQUNkLEdBQUcsRUFBRSxHQUFHO1NBQ1QsQ0FBQyxDQUFDLENBQUM7UUFFSixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNkLE1BQU0sSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDNUI7UUFFRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUVsRCxPQUFPO1lBQ0wsTUFBTSxFQUFFLEtBQUs7WUFDYixpQkFBaUIsRUFBRSxtQkFBbUI7WUFDdEMsT0FBTyxFQUFFO2dCQUNQLFFBQVEsRUFBRSxDQUFDO3dCQUNULEdBQUcsRUFBRSxVQUFVO3dCQUNmLEtBQUssRUFBRSxRQUFRLENBQUMsR0FBRztxQkFDcEIsQ0FBQzthQUNIO1NBQ0YsQ0FBQztLQUNIO0lBQUMsT0FBTyxHQUFHLEVBQUU7UUFDWixPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRWpCLE9BQU87WUFDTCxNQUFNLEVBQUUsS0FBSztZQUNiLGlCQUFpQixFQUFFLFdBQVc7U0FDL0IsQ0FBQztLQUNIO0FBQ0gsQ0FBQztBQTFDRCwwQkEwQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHZXRPYmplY3RDb21tYW5kLCBTM0NsaWVudCB9IGZyb20gJ0Bhd3Mtc2RrL2NsaWVudC1zMyc7XG5cbmNvbnN0IHMzQ2xpZW50ID0gbmV3IFMzQ2xpZW50KHt9KTtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGhhbmRsZXIoZXZlbnQ6IEFXU0xhbWJkYS5DbG91ZEZyb250UmVxdWVzdEV2ZW50KTogUHJvbWlzZTxBV1NMYW1iZGEuQ2xvdWRGcm9udFJlcXVlc3RSZXN1bHQ+IHtcbiAgY29uc3QgcmVxdWVzdCA9IGV2ZW50LlJlY29yZHNbMF0uY2YucmVxdWVzdDtcblxuICB0cnkge1xuICAgIGNvbnN0IHMzT3JpZ2luID0gcmVxdWVzdC5vcmlnaW4/LnMzO1xuXG4gICAgaWYgKCFzM09yaWdpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdObyBTMyBvcmlnaW4nKTtcbiAgICB9XG5cbiAgICBjb25zdCBidWNrZXQgPSBzM09yaWdpbi5kb21haW5OYW1lLnJlcGxhY2UobmV3IFJlZ0V4cChgLnMzLiR7czNPcmlnaW4ucmVnaW9ufS5hbWF6b25hd3MuY29tJGApLCAnJyk7XG4gICAgY29uc3Qga2V5ID0gcmVxdWVzdC51cmkuc3Vic3RyaW5nKDEpOyAvLyByZW1vdmUgZmlyc3Qgc2xhc2hcblxuICAgIGNvbnN0IGRhdGEgPSBhd2FpdCBzM0NsaWVudC5zZW5kKG5ldyBHZXRPYmplY3RDb21tYW5kKHtcbiAgICAgIEJ1Y2tldDogYnVja2V0LFxuICAgICAgS2V5OiBrZXksXG4gICAgfSkpO1xuXG4gICAgaWYgKCFkYXRhLkJvZHkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignTm8gYm9keScpO1xuICAgIH1cblxuICAgIGNvbnN0IHJlZGlyZWN0ID0gSlNPTi5wYXJzZShkYXRhLkJvZHkudG9TdHJpbmcoKSk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgc3RhdHVzOiAnMzAxJyxcbiAgICAgIHN0YXR1c0Rlc2NyaXB0aW9uOiAnTW92ZWQgUGVybWFuZW50bHknLFxuICAgICAgaGVhZGVyczoge1xuICAgICAgICBsb2NhdGlvbjogW3tcbiAgICAgICAgICBrZXk6ICdMb2NhdGlvbicsXG4gICAgICAgICAgdmFsdWU6IHJlZGlyZWN0LnVybCxcbiAgICAgICAgfV0sXG4gICAgICB9LFxuICAgIH07XG4gIH0gY2F0Y2ggKGVycikge1xuICAgIGNvbnNvbGUubG9nKGVycik7XG5cbiAgICByZXR1cm4ge1xuICAgICAgc3RhdHVzOiAnNDA0JyxcbiAgICAgIHN0YXR1c0Rlc2NyaXB0aW9uOiAnTm90IEZvdW5kJyxcbiAgICB9O1xuICB9XG59XG4iXX0=
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVkaXJlY3QuZWRnZS1sYW1iZGEuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXJsLXNob3J0ZW5lci9yZWRpcmVjdC5lZGdlLWxhbWJkYS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxrREFBZ0U7QUFFekQsS0FBSyxVQUFVLE9BQU8sQ0FBQyxLQUF1QztJQUNuRSxNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUM7SUFFNUMsSUFBSTtRQUNGLE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDO1FBRXBDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixNQUFNLElBQUksS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1NBQ2pDO1FBRUQsTUFBTSxRQUFRLEdBQUcsSUFBSSxvQkFBUSxDQUFDLEVBQUUsTUFBTSxFQUFFLFFBQVEsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO1FBQzNELE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksTUFBTSxDQUFDLE9BQU8sUUFBUSxDQUFDLE1BQU0saUJBQWlCLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNwRyxNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLHFCQUFxQjtRQUUzRCxNQUFNLElBQUksR0FBRyxNQUFNLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSw0QkFBZ0IsQ0FBQztZQUNwRCxNQUFNLEVBQUUsTUFBTTtZQUNkLEdBQUcsRUFBRSxHQUFHO1NBQ1QsQ0FBQyxDQUFDLENBQUM7UUFFSixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRTtZQUNkLE1BQU0sSUFBSSxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDNUI7UUFFRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLENBQUM7UUFFakUsT0FBTztZQUNMLE1BQU0sRUFBRSxLQUFLO1lBQ2IsaUJBQWlCLEVBQUUsbUJBQW1CO1lBQ3RDLE9BQU8sRUFBRTtnQkFDUCxRQUFRLEVBQUUsQ0FBQzt3QkFDVCxHQUFHLEVBQUUsVUFBVTt3QkFDZixLQUFLLEVBQUUsUUFBUSxDQUFDLEdBQUc7cUJBQ3BCLENBQUM7YUFDSDtTQUNGLENBQUM7S0FDSDtJQUFDLE9BQU8sR0FBRyxFQUFFO1FBQ1osT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUVqQixPQUFPO1lBQ0wsTUFBTSxFQUFFLEtBQUs7WUFDYixpQkFBaUIsRUFBRSxXQUFXO1NBQy9CLENBQUM7S0FDSDtBQUNILENBQUM7QUEzQ0QsMEJBMkNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgR2V0T2JqZWN0Q29tbWFuZCwgUzNDbGllbnQgfSBmcm9tICdAYXdzLXNkay9jbGllbnQtczMnO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaGFuZGxlcihldmVudDogQVdTTGFtYmRhLkNsb3VkRnJvbnRSZXF1ZXN0RXZlbnQpOiBQcm9taXNlPEFXU0xhbWJkYS5DbG91ZEZyb250UmVxdWVzdFJlc3VsdD4ge1xuICBjb25zdCByZXF1ZXN0ID0gZXZlbnQuUmVjb3Jkc1swXS5jZi5yZXF1ZXN0O1xuXG4gIHRyeSB7XG4gICAgY29uc3QgczNPcmlnaW4gPSByZXF1ZXN0Lm9yaWdpbj8uczM7XG5cbiAgICBpZiAoIXMzT3JpZ2luKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ05vIFMzIG9yaWdpbicpO1xuICAgIH1cblxuICAgIGNvbnN0IHMzQ2xpZW50ID0gbmV3IFMzQ2xpZW50KHsgcmVnaW9uOiBzM09yaWdpbi5yZWdpb24gfSk7XG4gICAgY29uc3QgYnVja2V0ID0gczNPcmlnaW4uZG9tYWluTmFtZS5yZXBsYWNlKG5ldyBSZWdFeHAoYC5zMy4ke3MzT3JpZ2luLnJlZ2lvbn0uYW1hem9uYXdzLmNvbSRgKSwgJycpO1xuICAgIGNvbnN0IGtleSA9IHJlcXVlc3QudXJpLnN1YnN0cmluZygxKTsgLy8gcmVtb3ZlIGZpcnN0IHNsYXNoXG5cbiAgICBjb25zdCBkYXRhID0gYXdhaXQgczNDbGllbnQuc2VuZChuZXcgR2V0T2JqZWN0Q29tbWFuZCh7XG4gICAgICBCdWNrZXQ6IGJ1Y2tldCxcbiAgICAgIEtleToga2V5LFxuICAgIH0pKTtcblxuICAgIGlmICghZGF0YS5Cb2R5KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ05vIGJvZHknKTtcbiAgICB9XG5cbiAgICBjb25zdCByZWRpcmVjdCA9IEpTT04ucGFyc2UoYXdhaXQgZGF0YS5Cb2R5LnRyYW5zZm9ybVRvU3RyaW5nKCkpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHN0YXR1czogJzMwMScsXG4gICAgICBzdGF0dXNEZXNjcmlwdGlvbjogJ01vdmVkIFBlcm1hbmVudGx5JyxcbiAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgbG9jYXRpb246IFt7XG4gICAgICAgICAga2V5OiAnTG9jYXRpb24nLFxuICAgICAgICAgIHZhbHVlOiByZWRpcmVjdC51cmwsXG4gICAgICAgIH1dLFxuICAgICAgfSxcbiAgICB9O1xuICB9IGNhdGNoIChlcnIpIHtcbiAgICBjb25zb2xlLmxvZyhlcnIpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHN0YXR1czogJzQwNCcsXG4gICAgICBzdGF0dXNEZXNjcmlwdGlvbjogJ05vdCBGb3VuZCcsXG4gICAgfTtcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -154,7 +154,7 @@
154
154
  ],
155
155
  "main": "lib/index.js",
156
156
  "license": "Apache-2.0",
157
- "version": "0.6.30",
157
+ "version": "0.6.32",
158
158
  "jest": {
159
159
  "testMatch": [
160
160
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",
@@ -225,6 +225,7 @@
225
225
  "./package.json": "./package.json",
226
226
  "./.jsii": "./.jsii",
227
227
  "./lib/codecommit-mirror": "./lib/codecommit-mirror/index.js",
228
+ "./lib/dmarc": "./lib/dmarc/index.js",
228
229
  "./lib/ecs-service-roller": "./lib/ecs-service-roller/index.js",
229
230
  "./lib/email-receiver": "./lib/email-receiver/index.js",
230
231
  "./lib/saml-identity-provider": "./lib/saml-identity-provider/index.js",