@btc-embedded/cdk-extensions 0.5.3 → 0.5.5

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.
Files changed (40) hide show
  1. package/.jsii +170 -2
  2. package/API.md +202 -0
  3. package/CHANGELOG.md +19 -0
  4. package/lib/constructs/SecureRestApi.d.ts +7 -3
  5. package/lib/constructs/SecureRestApi.js +13 -15
  6. package/lib/constructs/index.d.ts +1 -0
  7. package/lib/constructs/index.js +18 -0
  8. package/lib/extensions/ApiGatewayExtension.js +1 -1
  9. package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
  10. package/lib/extensions/CloudMapExtension.js +1 -1
  11. package/lib/extensions/DocumentDbAccessExtension.js +1 -1
  12. package/lib/extensions/DomainEventMessagingExtension.js +1 -1
  13. package/lib/extensions/ExtraContainerExtension.js +1 -1
  14. package/lib/extensions/ImportValue.d.ts +2 -0
  15. package/lib/extensions/ImportValue.js +12 -0
  16. package/lib/extensions/LogExtension.js +1 -1
  17. package/lib/extensions/ModifyContainerDefinitionExtension.d.ts +13 -0
  18. package/lib/extensions/ModifyContainerDefinitionExtension.js +41 -0
  19. package/lib/extensions/ModifyTaskDefinitionExtension.d.ts +13 -0
  20. package/lib/extensions/ModifyTaskDefinitionExtension.js +28 -0
  21. package/lib/extensions/PostgresDbAccessExtension.js +1 -1
  22. package/lib/extensions/S3BucketAccessExtension.d.ts +13 -0
  23. package/lib/extensions/S3BucketAccessExtension.js +32 -0
  24. package/lib/extensions/SharedVolumeExtension.js +1 -1
  25. package/lib/extensions/TcpKeepAliveExtension.js +1 -1
  26. package/lib/index.d.ts +1 -0
  27. package/lib/index.js +2 -1
  28. package/lib/platform/ApiGateway.js +1 -1
  29. package/lib/platform/ApplicationLoadBalancer.js +1 -1
  30. package/lib/platform/AuthenticationStack.d.ts +19 -0
  31. package/lib/platform/AuthenticationStack.js +92 -0
  32. package/lib/platform/CloudMap.d.ts +16 -0
  33. package/lib/platform/CloudMap.js +48 -0
  34. package/lib/platform/DefaultUserPoolClients.js +1 -1
  35. package/lib/platform/DocumentDB.js +1 -1
  36. package/lib/platform/MessageQueue.d.ts +23 -0
  37. package/lib/platform/MessageQueue.js +166 -0
  38. package/lib/platform/PrivateDnsNamespace.js +1 -1
  39. package/lib/platform/Vpc.js +1 -1
  40. package/package.json +1 -1
package/.jsii CHANGED
@@ -6487,6 +6487,174 @@
6487
6487
  ],
6488
6488
  "symbolId": "src/platform/PrivateDnsNamespace:PrivateDnsNamespaceProps"
6489
6489
  },
6490
+ "@btc-embedded/cdk-extensions.SecureRestApi": {
6491
+ "assembly": "@btc-embedded/cdk-extensions",
6492
+ "base": "constructs.Construct",
6493
+ "docs": {
6494
+ "stability": "experimental"
6495
+ },
6496
+ "fqn": "@btc-embedded/cdk-extensions.SecureRestApi",
6497
+ "initializer": {
6498
+ "docs": {
6499
+ "stability": "experimental"
6500
+ },
6501
+ "locationInModule": {
6502
+ "filename": "src/constructs/SecureRestApi.ts",
6503
+ "line": 45
6504
+ },
6505
+ "parameters": [
6506
+ {
6507
+ "name": "scope",
6508
+ "type": {
6509
+ "fqn": "constructs.Construct"
6510
+ }
6511
+ },
6512
+ {
6513
+ "name": "id",
6514
+ "type": {
6515
+ "primitive": "string"
6516
+ }
6517
+ },
6518
+ {
6519
+ "name": "props",
6520
+ "type": {
6521
+ "fqn": "@btc-embedded/cdk-extensions.SecureRestApiProps"
6522
+ }
6523
+ }
6524
+ ]
6525
+ },
6526
+ "kind": "class",
6527
+ "locationInModule": {
6528
+ "filename": "src/constructs/SecureRestApi.ts",
6529
+ "line": 37
6530
+ },
6531
+ "name": "SecureRestApi",
6532
+ "properties": [
6533
+ {
6534
+ "docs": {
6535
+ "stability": "experimental"
6536
+ },
6537
+ "locationInModule": {
6538
+ "filename": "src/constructs/SecureRestApi.ts",
6539
+ "line": 40
6540
+ },
6541
+ "name": "defaultAuthorizer",
6542
+ "type": {
6543
+ "fqn": "aws-cdk-lib.aws_apigateway.CognitoUserPoolsAuthorizer"
6544
+ }
6545
+ },
6546
+ {
6547
+ "docs": {
6548
+ "stability": "experimental"
6549
+ },
6550
+ "locationInModule": {
6551
+ "filename": "src/constructs/SecureRestApi.ts",
6552
+ "line": 39
6553
+ },
6554
+ "name": "domainName",
6555
+ "type": {
6556
+ "primitive": "string"
6557
+ }
6558
+ },
6559
+ {
6560
+ "docs": {
6561
+ "stability": "experimental"
6562
+ },
6563
+ "locationInModule": {
6564
+ "filename": "src/constructs/SecureRestApi.ts",
6565
+ "line": 43
6566
+ },
6567
+ "name": "restApi",
6568
+ "type": {
6569
+ "fqn": "aws-cdk-lib.aws_apigateway.RestApi"
6570
+ }
6571
+ }
6572
+ ],
6573
+ "symbolId": "src/constructs/SecureRestApi:SecureRestApi"
6574
+ },
6575
+ "@btc-embedded/cdk-extensions.SecureRestApiProps": {
6576
+ "assembly": "@btc-embedded/cdk-extensions",
6577
+ "datatype": true,
6578
+ "docs": {
6579
+ "stability": "experimental"
6580
+ },
6581
+ "fqn": "@btc-embedded/cdk-extensions.SecureRestApiProps",
6582
+ "kind": "interface",
6583
+ "locationInModule": {
6584
+ "filename": "src/constructs/SecureRestApi.ts",
6585
+ "line": 15
6586
+ },
6587
+ "name": "SecureRestApiProps",
6588
+ "properties": [
6589
+ {
6590
+ "abstract": true,
6591
+ "docs": {
6592
+ "stability": "experimental",
6593
+ "summary": "Subdomain that is used for REST API props."
6594
+ },
6595
+ "immutable": true,
6596
+ "locationInModule": {
6597
+ "filename": "src/constructs/SecureRestApi.ts",
6598
+ "line": 23
6599
+ },
6600
+ "name": "apiSubDomain",
6601
+ "type": {
6602
+ "primitive": "string"
6603
+ }
6604
+ },
6605
+ {
6606
+ "abstract": true,
6607
+ "docs": {
6608
+ "stability": "experimental",
6609
+ "summary": "The name of the Base platform Stack."
6610
+ },
6611
+ "immutable": true,
6612
+ "locationInModule": {
6613
+ "filename": "src/constructs/SecureRestApi.ts",
6614
+ "line": 19
6615
+ },
6616
+ "name": "basePlatformStackName",
6617
+ "type": {
6618
+ "primitive": "string"
6619
+ }
6620
+ },
6621
+ {
6622
+ "abstract": true,
6623
+ "docs": {
6624
+ "stability": "experimental",
6625
+ "summary": "Props forwarded to the RestApi construct."
6626
+ },
6627
+ "immutable": true,
6628
+ "locationInModule": {
6629
+ "filename": "src/constructs/SecureRestApi.ts",
6630
+ "line": 34
6631
+ },
6632
+ "name": "restApiProps",
6633
+ "type": {
6634
+ "fqn": "aws-cdk-lib.aws_apigateway.RestApiProps"
6635
+ }
6636
+ },
6637
+ {
6638
+ "abstract": true,
6639
+ "docs": {
6640
+ "default": "- fqdn output of base platform stack is used to import the hosted zone",
6641
+ "stability": "experimental",
6642
+ "summary": "hosted zone for the subdomain An optional parameter."
6643
+ },
6644
+ "immutable": true,
6645
+ "locationInModule": {
6646
+ "filename": "src/constructs/SecureRestApi.ts",
6647
+ "line": 29
6648
+ },
6649
+ "name": "hostedZone",
6650
+ "optional": true,
6651
+ "type": {
6652
+ "fqn": "aws-cdk-lib.aws_route53.IHostedZone"
6653
+ }
6654
+ }
6655
+ ],
6656
+ "symbolId": "src/constructs/SecureRestApi:SecureRestApiProps"
6657
+ },
6490
6658
  "@btc-embedded/cdk-extensions.SharedVolumeExtension": {
6491
6659
  "assembly": "@btc-embedded/cdk-extensions",
6492
6660
  "base": "@aws-cdk-containers/ecs-service-extensions.ServiceExtension",
@@ -6967,6 +7135,6 @@
6967
7135
  "symbolId": "src/platform/Vpc:VpcProps"
6968
7136
  }
6969
7137
  },
6970
- "version": "0.5.3",
6971
- "fingerprint": "4cV8tx/ZFr0/VyQ865i3Ge3xgOj7bjV5mPFHNH3WzUg="
7138
+ "version": "0.5.5",
7139
+ "fingerprint": "Cm65p4Abvglg8eohdj/YNdXdXrCdb+Qw8wC/qd50bEM="
6972
7140
  }
package/API.md CHANGED
@@ -565,6 +565,138 @@ public readonly namespace: IPrivateDnsNamespace;
565
565
  ---
566
566
 
567
567
 
568
+ ### SecureRestApi <a name="SecureRestApi" id="@btc-embedded/cdk-extensions.SecureRestApi"></a>
569
+
570
+ #### Initializers <a name="Initializers" id="@btc-embedded/cdk-extensions.SecureRestApi.Initializer"></a>
571
+
572
+ ```typescript
573
+ import { SecureRestApi } from '@btc-embedded/cdk-extensions'
574
+
575
+ new SecureRestApi(scope: Construct, id: string, props: SecureRestApiProps)
576
+ ```
577
+
578
+ | **Name** | **Type** | **Description** |
579
+ | --- | --- | --- |
580
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.Initializer.parameter.scope">scope</a></code> | <code>constructs.Construct</code> | *No description.* |
581
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.Initializer.parameter.id">id</a></code> | <code>string</code> | *No description.* |
582
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.Initializer.parameter.props">props</a></code> | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApiProps">SecureRestApiProps</a></code> | *No description.* |
583
+
584
+ ---
585
+
586
+ ##### `scope`<sup>Required</sup> <a name="scope" id="@btc-embedded/cdk-extensions.SecureRestApi.Initializer.parameter.scope"></a>
587
+
588
+ - *Type:* constructs.Construct
589
+
590
+ ---
591
+
592
+ ##### `id`<sup>Required</sup> <a name="id" id="@btc-embedded/cdk-extensions.SecureRestApi.Initializer.parameter.id"></a>
593
+
594
+ - *Type:* string
595
+
596
+ ---
597
+
598
+ ##### `props`<sup>Required</sup> <a name="props" id="@btc-embedded/cdk-extensions.SecureRestApi.Initializer.parameter.props"></a>
599
+
600
+ - *Type:* <a href="#@btc-embedded/cdk-extensions.SecureRestApiProps">SecureRestApiProps</a>
601
+
602
+ ---
603
+
604
+ #### Methods <a name="Methods" id="Methods"></a>
605
+
606
+ | **Name** | **Description** |
607
+ | --- | --- |
608
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.toString">toString</a></code> | Returns a string representation of this construct. |
609
+
610
+ ---
611
+
612
+ ##### `toString` <a name="toString" id="@btc-embedded/cdk-extensions.SecureRestApi.toString"></a>
613
+
614
+ ```typescript
615
+ public toString(): string
616
+ ```
617
+
618
+ Returns a string representation of this construct.
619
+
620
+ #### Static Functions <a name="Static Functions" id="Static Functions"></a>
621
+
622
+ | **Name** | **Description** |
623
+ | --- | --- |
624
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
625
+
626
+ ---
627
+
628
+ ##### ~~`isConstruct`~~ <a name="isConstruct" id="@btc-embedded/cdk-extensions.SecureRestApi.isConstruct"></a>
629
+
630
+ ```typescript
631
+ import { SecureRestApi } from '@btc-embedded/cdk-extensions'
632
+
633
+ SecureRestApi.isConstruct(x: any)
634
+ ```
635
+
636
+ Checks if `x` is a construct.
637
+
638
+ ###### `x`<sup>Required</sup> <a name="x" id="@btc-embedded/cdk-extensions.SecureRestApi.isConstruct.parameter.x"></a>
639
+
640
+ - *Type:* any
641
+
642
+ Any object.
643
+
644
+ ---
645
+
646
+ #### Properties <a name="Properties" id="Properties"></a>
647
+
648
+ | **Name** | **Type** | **Description** |
649
+ | --- | --- | --- |
650
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
651
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.property.defaultAuthorizer">defaultAuthorizer</a></code> | <code>aws-cdk-lib.aws_apigateway.CognitoUserPoolsAuthorizer</code> | *No description.* |
652
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.property.domainName">domainName</a></code> | <code>string</code> | *No description.* |
653
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApi.property.restApi">restApi</a></code> | <code>aws-cdk-lib.aws_apigateway.RestApi</code> | *No description.* |
654
+
655
+ ---
656
+
657
+ ##### `node`<sup>Required</sup> <a name="node" id="@btc-embedded/cdk-extensions.SecureRestApi.property.node"></a>
658
+
659
+ ```typescript
660
+ public readonly node: Node;
661
+ ```
662
+
663
+ - *Type:* constructs.Node
664
+
665
+ The tree node.
666
+
667
+ ---
668
+
669
+ ##### `defaultAuthorizer`<sup>Required</sup> <a name="defaultAuthorizer" id="@btc-embedded/cdk-extensions.SecureRestApi.property.defaultAuthorizer"></a>
670
+
671
+ ```typescript
672
+ public readonly defaultAuthorizer: CognitoUserPoolsAuthorizer;
673
+ ```
674
+
675
+ - *Type:* aws-cdk-lib.aws_apigateway.CognitoUserPoolsAuthorizer
676
+
677
+ ---
678
+
679
+ ##### `domainName`<sup>Required</sup> <a name="domainName" id="@btc-embedded/cdk-extensions.SecureRestApi.property.domainName"></a>
680
+
681
+ ```typescript
682
+ public readonly domainName: string;
683
+ ```
684
+
685
+ - *Type:* string
686
+
687
+ ---
688
+
689
+ ##### `restApi`<sup>Required</sup> <a name="restApi" id="@btc-embedded/cdk-extensions.SecureRestApi.property.restApi"></a>
690
+
691
+ ```typescript
692
+ public readonly restApi: RestApi;
693
+ ```
694
+
695
+ - *Type:* aws-cdk-lib.aws_apigateway.RestApi
696
+
697
+ ---
698
+
699
+
568
700
  ### Vpc <a name="Vpc" id="@btc-embedded/cdk-extensions.Vpc"></a>
569
701
 
570
702
  #### Initializers <a name="Initializers" id="@btc-embedded/cdk-extensions.Vpc.Initializer"></a>
@@ -2208,6 +2340,76 @@ public readonly namespaceName: string;
2208
2340
 
2209
2341
  ---
2210
2342
 
2343
+ ### SecureRestApiProps <a name="SecureRestApiProps" id="@btc-embedded/cdk-extensions.SecureRestApiProps"></a>
2344
+
2345
+ #### Initializer <a name="Initializer" id="@btc-embedded/cdk-extensions.SecureRestApiProps.Initializer"></a>
2346
+
2347
+ ```typescript
2348
+ import { SecureRestApiProps } from '@btc-embedded/cdk-extensions'
2349
+
2350
+ const secureRestApiProps: SecureRestApiProps = { ... }
2351
+ ```
2352
+
2353
+ #### Properties <a name="Properties" id="Properties"></a>
2354
+
2355
+ | **Name** | **Type** | **Description** |
2356
+ | --- | --- | --- |
2357
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApiProps.property.apiSubDomain">apiSubDomain</a></code> | <code>string</code> | Subdomain that is used for REST API props. |
2358
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApiProps.property.basePlatformStackName">basePlatformStackName</a></code> | <code>string</code> | The name of the Base platform Stack. |
2359
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApiProps.property.restApiProps">restApiProps</a></code> | <code>aws-cdk-lib.aws_apigateway.RestApiProps</code> | Props forwarded to the RestApi construct. |
2360
+ | <code><a href="#@btc-embedded/cdk-extensions.SecureRestApiProps.property.hostedZone">hostedZone</a></code> | <code>aws-cdk-lib.aws_route53.IHostedZone</code> | hosted zone for the subdomain An optional parameter. |
2361
+
2362
+ ---
2363
+
2364
+ ##### `apiSubDomain`<sup>Required</sup> <a name="apiSubDomain" id="@btc-embedded/cdk-extensions.SecureRestApiProps.property.apiSubDomain"></a>
2365
+
2366
+ ```typescript
2367
+ public readonly apiSubDomain: string;
2368
+ ```
2369
+
2370
+ - *Type:* string
2371
+
2372
+ Subdomain that is used for REST API props.
2373
+
2374
+ ---
2375
+
2376
+ ##### `basePlatformStackName`<sup>Required</sup> <a name="basePlatformStackName" id="@btc-embedded/cdk-extensions.SecureRestApiProps.property.basePlatformStackName"></a>
2377
+
2378
+ ```typescript
2379
+ public readonly basePlatformStackName: string;
2380
+ ```
2381
+
2382
+ - *Type:* string
2383
+
2384
+ The name of the Base platform Stack.
2385
+
2386
+ ---
2387
+
2388
+ ##### `restApiProps`<sup>Required</sup> <a name="restApiProps" id="@btc-embedded/cdk-extensions.SecureRestApiProps.property.restApiProps"></a>
2389
+
2390
+ ```typescript
2391
+ public readonly restApiProps: RestApiProps;
2392
+ ```
2393
+
2394
+ - *Type:* aws-cdk-lib.aws_apigateway.RestApiProps
2395
+
2396
+ Props forwarded to the RestApi construct.
2397
+
2398
+ ---
2399
+
2400
+ ##### `hostedZone`<sup>Optional</sup> <a name="hostedZone" id="@btc-embedded/cdk-extensions.SecureRestApiProps.property.hostedZone"></a>
2401
+
2402
+ ```typescript
2403
+ public readonly hostedZone: IHostedZone;
2404
+ ```
2405
+
2406
+ - *Type:* aws-cdk-lib.aws_route53.IHostedZone
2407
+ - *Default:* fqdn output of base platform stack is used to import the hosted zone
2408
+
2409
+ hosted zone for the subdomain An optional parameter.
2410
+
2411
+ ---
2412
+
2211
2413
  ### SharedVolumeExtensionProps <a name="SharedVolumeExtensionProps" id="@btc-embedded/cdk-extensions.SharedVolumeExtensionProps"></a>
2212
2414
 
2213
2415
  Properties for defining an ephermal shared volume.
package/CHANGELOG.md CHANGED
@@ -1,4 +1,23 @@
1
1
 
2
+ ## [0.5.4](https://github.com/btc-embedded/cdk-extensions/compare/v0.5.3...v0.5.4) (2025-02-11)
3
+
4
+
5
+ ### Bug Fixes
6
+
7
+ * export of constructs ([a835fa7](https://github.com/btc-embedded/cdk-extensions/commit/a835fa77b0b877d2eafb3a61806d43179033aa38))
8
+
9
+ ## [0.5.3](https://github.com/btc-embedded/cdk-extensions/compare/v0.5.2...v0.5.3) (2025-02-11)
10
+
11
+
12
+ ### Features
13
+
14
+ * add SecureRestApi Construt ([e212545](https://github.com/btc-embedded/cdk-extensions/commit/e2125457345456c107352e19f4db5d024d1d2393))
15
+
16
+
17
+ ### Bug Fixes
18
+
19
+ * add subdomain to the RestApi ([9b7077b](https://github.com/btc-embedded/cdk-extensions/commit/9b7077b36fff53b2982449dec28279cce47d3740))
20
+
2
21
  ## [0.5.2](https://github.com/btc-embedded/cdk-extensions/compare/v0.5.1...v0.5.2) (2025-01-28)
3
22
 
4
23
 
@@ -1,4 +1,4 @@
1
- import { CognitoUserPoolsAuthorizer, DomainName, RestApiProps } from "aws-cdk-lib/aws-apigateway";
1
+ import { CognitoUserPoolsAuthorizer, RestApi, RestApiProps } from "aws-cdk-lib/aws-apigateway";
2
2
  import { IHostedZone } from "aws-cdk-lib/aws-route53";
3
3
  import { Construct } from "constructs/lib/construct";
4
4
  export interface SecureRestApiProps {
@@ -16,11 +16,15 @@ export interface SecureRestApiProps {
16
16
  * @default - fqdn output of base platform stack is used to import the hosted zone
17
17
  */
18
18
  readonly hostedZone?: IHostedZone;
19
+ /**
20
+ * Props forwarded to the RestApi construct.
21
+ */
22
+ readonly restApiProps: RestApiProps;
19
23
  }
20
24
  export declare class SecureRestApi extends Construct {
21
- restApiDomainName: DomainName;
25
+ domainName: string;
22
26
  defaultAuthorizer: CognitoUserPoolsAuthorizer;
23
27
  private certificate;
28
+ restApi: RestApi;
24
29
  constructor(scope: Construct, id: string, props: SecureRestApiProps);
25
- withSecureRestApiProps(props: RestApiProps): RestApiProps;
26
30
  }
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
+ var _a;
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  exports.SecureRestApi = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
4
6
  const aws_apigateway_1 = require("aws-cdk-lib/aws-apigateway");
5
7
  const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
6
8
  const aws_cognito_1 = require("aws-cdk-lib/aws-cognito");
@@ -21,33 +23,29 @@ class SecureRestApi extends construct_1.Construct {
21
23
  aws_route53_1.HostedZone.fromLookup(this, "HostedZone", {
22
24
  domainName: basePlatformFqdn,
23
25
  });
24
- const domainName = `${props.apiSubDomain}.${hostedZone.zoneName}`;
26
+ this.domainName = `${props.apiSubDomain}.${hostedZone.zoneName}`;
25
27
  this.certificate = new aws_certificatemanager_1.Certificate(this, "Certificate", {
26
- domainName,
28
+ domainName: this.domainName,
27
29
  validation: aws_certificatemanager_1.CertificateValidation.fromDns(hostedZone),
28
30
  });
29
- this.restApiDomainName = new aws_apigateway_1.DomainName(this, "DomainName", {
30
- domainName,
31
- certificate: this.certificate,
32
- });
33
31
  this.defaultAuthorizer = new aws_apigateway_1.CognitoUserPoolsAuthorizer(this, "defaultAuthorizer", {
34
32
  cognitoUserPools: [userPoolRef],
35
33
  });
36
- }
37
- withSecureRestApiProps(props) {
38
- return {
39
- ...props,
34
+ this.restApi = new aws_apigateway_1.RestApi(this, "RestApi", {
35
+ ...props.restApiProps,
40
36
  defaultMethodOptions: {
41
- ...props.defaultMethodOptions,
37
+ ...props.restApiProps.defaultMethodOptions,
42
38
  authorizer: this.defaultAuthorizer,
43
39
  },
44
40
  domainName: {
45
- ...props.domainName,
46
- domainName: this.restApiDomainName.domainName,
41
+ ...props.restApiProps.domainName,
42
+ domainName: this.domainName,
47
43
  certificate: this.certificate,
48
44
  },
49
- };
45
+ });
50
46
  }
51
47
  }
52
48
  exports.SecureRestApi = SecureRestApi;
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdHJ1Y3RzL1NlY3VyZVJlc3RBcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0RBSW9DO0FBQ3BDLCtFQUc0QztBQUM1Qyx5REFBbUQ7QUFDbkQseURBQWtFO0FBQ2xFLHdEQUFxRDtBQUNyRCxzREFBbUQ7QUFtQm5ELE1BQWEsYUFBYyxTQUFRLHFCQUFTO0lBSzFDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBeUI7UUFDakUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixvQkFBb0I7UUFDcEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUN4RCxNQUFNLElBQUksS0FBSyxDQUFDLGdEQUFnRCxDQUFDLENBQUM7UUFDcEUsQ0FBQztRQUVELE1BQU0saUJBQWlCLEdBQUcsSUFBQSx5QkFBVyxFQUNuQyxLQUFLLENBQUMscUJBQXFCLEVBQzNCLFNBQVMsRUFDVCxjQUFjLENBQ2YsQ0FBQztRQUNGLE1BQU0sV0FBVyxHQUFHLHNCQUFRLENBQUMsY0FBYyxDQUN6QyxJQUFJLEVBQ0osYUFBYSxFQUNiLGlCQUFpQixDQUNsQixDQUFDO1FBQ0YsTUFBTSxnQkFBZ0IsR0FBRyxJQUFBLHlCQUFXLEVBQUMsS0FBSyxDQUFDLHFCQUFxQixFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQzFFLE1BQU0sVUFBVSxHQUNkLEtBQUssQ0FBQyxVQUFVO1lBQ2hCLHdCQUFVLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUU7Z0JBQ3hDLFVBQVUsRUFBRSxnQkFBZ0I7YUFDN0IsQ0FBQyxDQUFDO1FBQ0wsTUFBTSxVQUFVLEdBQUcsR0FBRyxLQUFLLENBQUMsWUFBWSxJQUFJLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUVsRSxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksb0NBQVcsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQ3RELFVBQVU7WUFDVixVQUFVLEVBQUUsOENBQXFCLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQztTQUN0RCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSwyQkFBVSxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUU7WUFDMUQsVUFBVTtZQUNWLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVztTQUM5QixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSwyQ0FBMEIsQ0FDckQsSUFBSSxFQUNKLG1CQUFtQixFQUNuQjtZQUNFLGdCQUFnQixFQUFFLENBQUMsV0FBVyxDQUFDO1NBQ2hDLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFDTSxzQkFBc0IsQ0FBQyxLQUFtQjtRQUMvQyxPQUFPO1lBQ0wsR0FBRyxLQUFLO1lBQ1Isb0JBQW9CLEVBQUU7Z0JBQ3BCLEdBQUcsS0FBSyxDQUFDLG9CQUFvQjtnQkFDN0IsVUFBVSxFQUFFLElBQUksQ0FBQyxpQkFBaUI7YUFDbkM7WUFDRCxVQUFVLEVBQUU7Z0JBQ1YsR0FBRyxLQUFLLENBQUMsVUFBVTtnQkFDbkIsVUFBVSxFQUFFLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxVQUFVO2dCQUM3QyxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7YUFDOUI7U0FDRixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBOURELHNDQThEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyLFxuICBEb21haW5OYW1lLFxuICBSZXN0QXBpUHJvcHMsXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7IFVzZXJQb29sIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jb2duaXRvXCI7XG5pbXBvcnQgeyBIb3N0ZWRab25lLCBJSG9zdGVkWm9uZSB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHMvbGliL2NvbnN0cnVjdFwiO1xuaW1wb3J0IHsgaW1wb3J0VmFsdWUgfSBmcm9tIFwiLi4vdXRpbHMvSW1wb3J0VmFsdWVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTZWN1cmVSZXN0QXBpUHJvcHMge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIEJhc2UgcGxhdGZvcm0gU3RhY2tcbiAgICovXG4gIHJlYWRvbmx5IGJhc2VQbGF0Zm9ybVN0YWNrTmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogU3ViZG9tYWluIHRoYXQgaXMgdXNlZCBmb3IgUkVTVCBBUEkgcHJvcHNcbiAgICovXG4gIHJlYWRvbmx5IGFwaVN1YkRvbWFpbjogc3RyaW5nO1xuICAvKipcbiAgICogaG9zdGVkIHpvbmUgZm9yIHRoZSBzdWJkb21haW5cbiAgICogQW4gb3B0aW9uYWwgcGFyYW1ldGVyXG4gICAqIEBkZWZhdWx0IC0gZnFkbiBvdXRwdXQgb2YgYmFzZSBwbGF0Zm9ybSBzdGFjayBpcyB1c2VkIHRvIGltcG9ydCB0aGUgaG9zdGVkIHpvbmVcbiAgICovXG4gIHJlYWRvbmx5IGhvc3RlZFpvbmU/OiBJSG9zdGVkWm9uZTtcbn1cblxuZXhwb3J0IGNsYXNzIFNlY3VyZVJlc3RBcGkgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwdWJsaWMgcmVzdEFwaURvbWFpbk5hbWU6IERvbWFpbk5hbWU7XG4gIHB1YmxpYyBkZWZhdWx0QXV0aG9yaXplcjogQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXI7XG4gIHByaXZhdGUgY2VydGlmaWNhdGU6IENlcnRpZmljYXRlO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTZWN1cmVSZXN0QXBpUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIC8vdmFsaWRhdGUgdGhlIHByb3BzXG4gICAgaWYgKCFwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUgJiYgIXByb3BzLmFwaVN1YkRvbWFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwicGxhdGZvcm1TdGFja05hbWUgYW5kIEFwaVN1YkRvbWFpbiBpcyByZXF1aXJlZFwiKTtcbiAgICB9XG5cbiAgICBjb25zdCBjb2duaXRvVXNlclBvb2xJZCA9IGltcG9ydFZhbHVlKFxuICAgICAgcHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lLFxuICAgICAgXCJjb2duaXRvXCIsXG4gICAgICBcInVzZXItcG9vbC1pZFwiLFxuICAgICk7XG4gICAgY29uc3QgdXNlclBvb2xSZWYgPSBVc2VyUG9vbC5mcm9tVXNlclBvb2xJZChcbiAgICAgIHRoaXMsXG4gICAgICBcIlVzZXJQb29sUmVmXCIsXG4gICAgICBjb2duaXRvVXNlclBvb2xJZCxcbiAgICApO1xuICAgIGNvbnN0IGJhc2VQbGF0Zm9ybUZxZG4gPSBpbXBvcnRWYWx1ZShwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsIFwiZnFkblwiKTtcbiAgICBjb25zdCBob3N0ZWRab25lID1cbiAgICAgIHByb3BzLmhvc3RlZFpvbmUgPz9cbiAgICAgIEhvc3RlZFpvbmUuZnJvbUxvb2t1cCh0aGlzLCBcIkhvc3RlZFpvbmVcIiwge1xuICAgICAgICBkb21haW5OYW1lOiBiYXNlUGxhdGZvcm1GcWRuLFxuICAgICAgfSk7XG4gICAgY29uc3QgZG9tYWluTmFtZSA9IGAke3Byb3BzLmFwaVN1YkRvbWFpbn0uJHtob3N0ZWRab25lLnpvbmVOYW1lfWA7XG5cbiAgICB0aGlzLmNlcnRpZmljYXRlID0gbmV3IENlcnRpZmljYXRlKHRoaXMsIFwiQ2VydGlmaWNhdGVcIiwge1xuICAgICAgZG9tYWluTmFtZSxcbiAgICAgIHZhbGlkYXRpb246IENlcnRpZmljYXRlVmFsaWRhdGlvbi5mcm9tRG5zKGhvc3RlZFpvbmUpLFxuICAgIH0pO1xuXG4gICAgdGhpcy5yZXN0QXBpRG9tYWluTmFtZSA9IG5ldyBEb21haW5OYW1lKHRoaXMsIFwiRG9tYWluTmFtZVwiLCB7XG4gICAgICBkb21haW5OYW1lLFxuICAgICAgY2VydGlmaWNhdGU6IHRoaXMuY2VydGlmaWNhdGUsXG4gICAgfSk7XG5cbiAgICB0aGlzLmRlZmF1bHRBdXRob3JpemVyID0gbmV3IENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyKFxuICAgICAgdGhpcyxcbiAgICAgIFwiZGVmYXVsdEF1dGhvcml6ZXJcIixcbiAgICAgIHtcbiAgICAgICAgY29nbml0b1VzZXJQb29sczogW3VzZXJQb29sUmVmXSxcbiAgICAgIH0sXG4gICAgKTtcbiAgfVxuICBwdWJsaWMgd2l0aFNlY3VyZVJlc3RBcGlQcm9wcyhwcm9wczogUmVzdEFwaVByb3BzKTogUmVzdEFwaVByb3BzIHtcbiAgICByZXR1cm4ge1xuICAgICAgLi4ucHJvcHMsXG4gICAgICBkZWZhdWx0TWV0aG9kT3B0aW9uczoge1xuICAgICAgICAuLi5wcm9wcy5kZWZhdWx0TWV0aG9kT3B0aW9ucyxcbiAgICAgICAgYXV0aG9yaXplcjogdGhpcy5kZWZhdWx0QXV0aG9yaXplcixcbiAgICAgIH0sXG4gICAgICBkb21haW5OYW1lOiB7XG4gICAgICAgIC4uLnByb3BzLmRvbWFpbk5hbWUsXG4gICAgICAgIGRvbWFpbk5hbWU6IHRoaXMucmVzdEFwaURvbWFpbk5hbWUuZG9tYWluTmFtZSxcbiAgICAgICAgY2VydGlmaWNhdGU6IHRoaXMuY2VydGlmaWNhdGUsXG4gICAgICB9LFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
49
+ _a = JSII_RTTI_SYMBOL_1;
50
+ SecureRestApi[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApi", version: "0.5.5" };
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdHJ1Y3RzL1NlY3VyZVJlc3RBcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrREFJb0M7QUFDcEMsK0VBRzRDO0FBQzVDLHlEQUFtRDtBQUNuRCx5REFBa0U7QUFDbEUsd0RBQXFEO0FBQ3JELHNEQUFtRDtBQXdCbkQsTUFBYSxhQUFjLFNBQVEscUJBQVM7SUFRMUMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUF5QjtRQUNqRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLG9CQUFvQjtRQUNwQixJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3hELE1BQU0sSUFBSSxLQUFLLENBQUMsZ0RBQWdELENBQUMsQ0FBQztRQUNwRSxDQUFDO1FBRUQsTUFBTSxpQkFBaUIsR0FBRyxJQUFBLHlCQUFXLEVBQ25DLEtBQUssQ0FBQyxxQkFBcUIsRUFDM0IsU0FBUyxFQUNULGNBQWMsQ0FDZixDQUFDO1FBQ0YsTUFBTSxXQUFXLEdBQUcsc0JBQVEsQ0FBQyxjQUFjLENBQ3pDLElBQUksRUFDSixhQUFhLEVBQ2IsaUJBQWlCLENBQ2xCLENBQUM7UUFDRixNQUFNLGdCQUFnQixHQUFHLElBQUEseUJBQVcsRUFBQyxLQUFLLENBQUMscUJBQXFCLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDMUUsTUFBTSxVQUFVLEdBQ2QsS0FBSyxDQUFDLFVBQVU7WUFDaEIsd0JBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRTtnQkFDeEMsVUFBVSxFQUFFLGdCQUFnQjthQUM3QixDQUFDLENBQUM7UUFDTCxJQUFJLENBQUMsVUFBVSxHQUFHLEdBQUcsS0FBSyxDQUFDLFlBQVksSUFBSSxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakUsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLG9DQUFXLENBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRTtZQUN0RCxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDM0IsVUFBVSxFQUFFLDhDQUFxQixDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUM7U0FDdEQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGlCQUFpQixHQUFHLElBQUksMkNBQTBCLENBQ3JELElBQUksRUFDSixtQkFBbUIsRUFDbkI7WUFDRSxnQkFBZ0IsRUFBRSxDQUFDLFdBQVcsQ0FBQztTQUNoQyxDQUNGLENBQUM7UUFFRixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksd0JBQU8sQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQzFDLEdBQUcsS0FBSyxDQUFDLFlBQVk7WUFDckIsb0JBQW9CLEVBQUU7Z0JBQ3BCLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxvQkFBb0I7Z0JBQzFDLFVBQVUsRUFBRSxJQUFJLENBQUMsaUJBQWlCO2FBQ25DO1lBQ0QsVUFBVSxFQUFFO2dCQUNWLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxVQUFVO2dCQUNoQyxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7Z0JBQzNCLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVzthQUM5QjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBMURILHNDQTJEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyLFxuICBSZXN0QXBpLFxuICBSZXN0QXBpUHJvcHMsXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7IFVzZXJQb29sIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jb2duaXRvXCI7XG5pbXBvcnQgeyBIb3N0ZWRab25lLCBJSG9zdGVkWm9uZSB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHMvbGliL2NvbnN0cnVjdFwiO1xuaW1wb3J0IHsgaW1wb3J0VmFsdWUgfSBmcm9tIFwiLi4vdXRpbHMvSW1wb3J0VmFsdWVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTZWN1cmVSZXN0QXBpUHJvcHMge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIEJhc2UgcGxhdGZvcm0gU3RhY2tcbiAgICovXG4gIHJlYWRvbmx5IGJhc2VQbGF0Zm9ybVN0YWNrTmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogU3ViZG9tYWluIHRoYXQgaXMgdXNlZCBmb3IgUkVTVCBBUEkgcHJvcHNcbiAgICovXG4gIHJlYWRvbmx5IGFwaVN1YkRvbWFpbjogc3RyaW5nO1xuICAvKipcbiAgICogaG9zdGVkIHpvbmUgZm9yIHRoZSBzdWJkb21haW5cbiAgICogQW4gb3B0aW9uYWwgcGFyYW1ldGVyXG4gICAqIEBkZWZhdWx0IC0gZnFkbiBvdXRwdXQgb2YgYmFzZSBwbGF0Zm9ybSBzdGFjayBpcyB1c2VkIHRvIGltcG9ydCB0aGUgaG9zdGVkIHpvbmVcbiAgICovXG4gIHJlYWRvbmx5IGhvc3RlZFpvbmU/OiBJSG9zdGVkWm9uZTtcblxuICAvKipcbiAgICogUHJvcHMgZm9yd2FyZGVkIHRvIHRoZSBSZXN0QXBpIGNvbnN0cnVjdC5cbiAgICovXG4gIHJlYWRvbmx5IHJlc3RBcGlQcm9wczogUmVzdEFwaVByb3BzO1xufVxuXG5leHBvcnQgY2xhc3MgU2VjdXJlUmVzdEFwaSBleHRlbmRzIENvbnN0cnVjdCB7XG4gIC8vcHVibGljIHJlc3RBcGlEb21haW5OYW1lOiBEb21haW5OYW1lO1xuICBwdWJsaWMgZG9tYWluTmFtZTogc3RyaW5nO1xuICBwdWJsaWMgZGVmYXVsdEF1dGhvcml6ZXI6IENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyO1xuICBwcml2YXRlIGNlcnRpZmljYXRlOiBDZXJ0aWZpY2F0ZTtcblxuICBwdWJsaWMgcmVzdEFwaTogUmVzdEFwaTtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU2VjdXJlUmVzdEFwaVByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcbiAgICAvL3ZhbGlkYXRlIHRoZSBwcm9wc1xuICAgIGlmICghcHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lICYmICFwcm9wcy5hcGlTdWJEb21haW4pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcInBsYXRmb3JtU3RhY2tOYW1lIGFuZCBBcGlTdWJEb21haW4gaXMgcmVxdWlyZWRcIik7XG4gICAgfVxuXG4gICAgY29uc3QgY29nbml0b1VzZXJQb29sSWQgPSBpbXBvcnRWYWx1ZShcbiAgICAgIHByb3BzLmJhc2VQbGF0Zm9ybVN0YWNrTmFtZSxcbiAgICAgIFwiY29nbml0b1wiLFxuICAgICAgXCJ1c2VyLXBvb2wtaWRcIixcbiAgICApO1xuICAgIGNvbnN0IHVzZXJQb29sUmVmID0gVXNlclBvb2wuZnJvbVVzZXJQb29sSWQoXG4gICAgICB0aGlzLFxuICAgICAgXCJVc2VyUG9vbFJlZlwiLFxuICAgICAgY29nbml0b1VzZXJQb29sSWQsXG4gICAgKTtcbiAgICBjb25zdCBiYXNlUGxhdGZvcm1GcWRuID0gaW1wb3J0VmFsdWUocHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lLCBcImZxZG5cIik7XG4gICAgY29uc3QgaG9zdGVkWm9uZSA9XG4gICAgICBwcm9wcy5ob3N0ZWRab25lID8/XG4gICAgICBIb3N0ZWRab25lLmZyb21Mb29rdXAodGhpcywgXCJIb3N0ZWRab25lXCIsIHtcbiAgICAgICAgZG9tYWluTmFtZTogYmFzZVBsYXRmb3JtRnFkbixcbiAgICAgIH0pO1xuICAgIHRoaXMuZG9tYWluTmFtZSA9IGAke3Byb3BzLmFwaVN1YkRvbWFpbn0uJHtob3N0ZWRab25lLnpvbmVOYW1lfWA7XG5cbiAgICB0aGlzLmNlcnRpZmljYXRlID0gbmV3IENlcnRpZmljYXRlKHRoaXMsIFwiQ2VydGlmaWNhdGVcIiwge1xuICAgICAgZG9tYWluTmFtZTogdGhpcy5kb21haW5OYW1lLFxuICAgICAgdmFsaWRhdGlvbjogQ2VydGlmaWNhdGVWYWxpZGF0aW9uLmZyb21EbnMoaG9zdGVkWm9uZSksXG4gICAgfSk7XG5cbiAgICB0aGlzLmRlZmF1bHRBdXRob3JpemVyID0gbmV3IENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyKFxuICAgICAgdGhpcyxcbiAgICAgIFwiZGVmYXVsdEF1dGhvcml6ZXJcIixcbiAgICAgIHtcbiAgICAgICAgY29nbml0b1VzZXJQb29sczogW3VzZXJQb29sUmVmXSxcbiAgICAgIH0sXG4gICAgKTtcblxuICAgIHRoaXMucmVzdEFwaSA9IG5ldyBSZXN0QXBpKHRoaXMsIFwiUmVzdEFwaVwiLCB7XG4gICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMsXG4gICAgICBkZWZhdWx0TWV0aG9kT3B0aW9uczoge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZGVmYXVsdE1ldGhvZE9wdGlvbnMsXG4gICAgICAgIGF1dGhvcml6ZXI6IHRoaXMuZGVmYXVsdEF1dGhvcml6ZXIsXG4gICAgICB9LFxuICAgICAgZG9tYWluTmFtZToge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZG9tYWluTmFtZSxcbiAgICAgICAgZG9tYWluTmFtZTogdGhpcy5kb21haW5OYW1lLFxuICAgICAgICBjZXJ0aWZpY2F0ZTogdGhpcy5jZXJ0aWZpY2F0ZSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1 @@
1
+ export * from "./SecureRestApi";
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./SecureRestApi"), exports);
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29uc3RydWN0cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsa0RBQWdDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vU2VjdXJlUmVzdEFwaVwiO1xuIl19
@@ -64,5 +64,5 @@ class ApiGatewayExtension extends ecs_service_extensions_1.ServiceExtension {
64
64
  }
65
65
  exports.ApiGatewayExtension = ApiGatewayExtension;
66
66
  _a = JSII_RTTI_SYMBOL_1;
67
- ApiGatewayExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayExtension", version: "0.5.3" };
67
+ ApiGatewayExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayExtension", version: "0.5.5" };
68
68
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApiGatewayExtension.js","sourceRoot":"","sources":["../../src/extensions/ApiGatewayExtension.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Container,\n  ServiceExtension,\n} from \"@aws-cdk-containers/ecs-service-extensions\";\nimport {\n  HttpApi,\n  HttpMethod,\n  HttpRoute,\n  HttpRouteKey,\n  MappingValue,\n  ParameterMapping,\n  VpcLink,\n} from \"aws-cdk-lib/aws-apigatewayv2\";\nimport { HttpUserPoolAuthorizer } from \"aws-cdk-lib/aws-apigatewayv2-authorizers\";\nimport { HttpServiceDiscoveryIntegration } from \"aws-cdk-lib/aws-apigatewayv2-integrations\";\nimport { UserPool, UserPoolClient } from \"aws-cdk-lib/aws-cognito\";\nimport { Port, SecurityGroup } from \"aws-cdk-lib/aws-ec2\";\nimport { Ec2Service, FargateService } from \"aws-cdk-lib/aws-ecs\";\nimport { createImporter } from \"../utils/ImportValue\";\n\nexport interface ApiGatewayExtensionProps {\n  /**\n   * The prefix for the API Gateway endpoint.\n   */\n  readonly prefix: string;\n\n  /**\n   * The name of the base platform stack.\n   */\n  readonly platformStackName: string;\n\n  /**\n   * The security group ID of the API Gateway which should be allowed to connect to the service.\n   */\n  readonly securityGroupId: string;\n}\n\n/**\n * Configures the service to be reachable via an API Gateway.\n */\nexport class ApiGatewayExtension extends ServiceExtension {\n  readonly props: ApiGatewayExtensionProps;\n\n  /**\n   *\n   * @param props\n   */\n  constructor(props: ApiGatewayExtensionProps) {\n    super(\"api-gateway-extension\");\n    this.props = props;\n  }\n\n  useService(service: Ec2Service | FargateService): void {\n    const importValue = createImporter(\n      this.props.platformStackName,\n      \"api-gateway\",\n    );\n\n    const importCognito = createImporter(\n      this.props.platformStackName,\n      \"cognito\",\n    );\n\n    if (!service.cloudMapService) {\n      throw new Error(\n        \"This extension requires the CloudMap extension to be added\",\n      );\n    }\n\n    const container = this.parentService.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n    if (!container || !container.trafficPort) {\n      throw new Error(\n        \"Cannot apply API Gateway Extension, no main app container found\",\n      );\n    }\n\n    const vpcLink = VpcLink.fromVpcLinkAttributes(\n      this.scope,\n      `${this.parentService.id}VpcLink`,\n      {\n        vpc: this.parentService.vpc,\n        vpcLinkId: importValue(\"vpc-link-id\"),\n      },\n    );\n\n    const httpApi = HttpApi.fromHttpApiAttributes(\n      this.scope,\n      `${this.parentService.id}HttpApi`,\n      {\n        httpApiId: importValue(\"id\"),\n      },\n    );\n\n    const integration = new HttpServiceDiscoveryIntegration(\n      `${this.parentService.id}ServiceDiscoveryIntegration`,\n      service.cloudMapService,\n      {\n        method: HttpMethod.ANY,\n        vpcLink,\n        parameterMapping: new ParameterMapping().overwritePath(\n          MappingValue.custom(\"/$request.path.proxy\"),\n        ),\n      },\n    );\n\n    const userPoolClient = UserPoolClient.fromUserPoolClientId(\n      this.scope,\n      `${this.parentService.id}ApiUserPoolClient`,\n      importCognito(\"full-access-client-id\"),\n    );\n\n    const appUserPoolClient = UserPoolClient.fromUserPoolClientId(\n      this.scope,\n      `${this.parentService.id}AppUserPoolClient`,\n      importCognito(\"user-pool-client-id\"),\n    );\n\n    const userPool = UserPool.fromUserPoolId(\n      this.scope,\n      `${this.parentService.id}ApiGWUserPool`,\n      importCognito(\"user-pool-id\"),\n    );\n\n    const authorizer = new HttpUserPoolAuthorizer(\n      `${this.parentService.id}Authorizer`,\n      userPool,\n      {\n        userPoolClients: [userPoolClient, appUserPoolClient],\n      },\n    );\n\n    new HttpRoute(this.scope, `${this.parentService.id}HttpRoute`, {\n      httpApi,\n      integration,\n      routeKey: HttpRouteKey.with(\n        `${this.props.prefix}/{proxy+}`,\n        HttpMethod.ANY,\n      ),\n      authorizer,\n    });\n\n    const apiGwSecurityGroup = SecurityGroup.fromLookupById(\n      this.scope,\n      `${this.parentService.id}ApiGatewaySecurityGroup`,\n      this.props.securityGroupId,\n    );\n\n    apiGwSecurityGroup.connections.allowTo(\n      service,\n      Port.tcp(container.trafficPort),\n      `Allow traffic from API GW to ${this.parentService.id}`,\n    );\n\n    const fqdn = createImporter(this.props.platformStackName)(\"fqdn\");\n\n    this.parentService.addURL(\n      \"public\",\n      `https://api.${fqdn}${this.props.prefix}`,\n    );\n  }\n}\n"]}
@@ -99,5 +99,5 @@ class ApplicationLoadBalancerExtension extends ecs_service_extensions_1.ServiceE
99
99
  }
100
100
  exports.ApplicationLoadBalancerExtension = ApplicationLoadBalancerExtension;
101
101
  _a = JSII_RTTI_SYMBOL_1;
102
- ApplicationLoadBalancerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerExtension", version: "0.5.3" };
102
+ ApplicationLoadBalancerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerExtension", version: "0.5.5" };
103
103
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApplicationLoadBalancerExtension.js","sourceRoot":"","sources":["../../src/extensions/ApplicationLoadBalancerExtension.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Container,\n  ContainerMutatingHook,\n  Service,\n  ServiceBuild,\n  ServiceExtension,\n} from \"@aws-cdk-containers/ecs-service-extensions\";\nimport { Aws, Duration } from \"aws-cdk-lib\";\nimport {\n  IUserPool,\n  IUserPoolClient,\n  IUserPoolDomain,\n  UserPool,\n  UserPoolClient,\n  UserPoolDomain,\n} from \"aws-cdk-lib/aws-cognito\";\nimport { SecurityGroup } from \"aws-cdk-lib/aws-ec2\";\nimport {\n  ContainerDefinitionOptions,\n  Ec2Service,\n  FargateService,\n} from \"aws-cdk-lib/aws-ecs\";\nimport {\n  ApplicationListener,\n  ApplicationProtocol,\n  ApplicationTargetGroup,\n  IApplicationListener,\n  ListenerAction,\n  ListenerCondition,\n  UnauthenticatedAction,\n} from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\nimport { AuthenticateCognitoAction } from \"aws-cdk-lib/aws-elasticloadbalancingv2-actions\";\nimport { Construct } from \"constructs\";\nimport { createImporter, importValue } from \"../utils/ImportValue\";\n\nexport interface ApplicationLoadBalancerExtensionProps {\n  readonly platformStackName: string;\n  readonly userPoolClientSecret: string;\n  readonly securityGroupId: string;\n  readonly clientScope: string;\n  readonly healtCheckPath?: string;\n  readonly path?: string; // path to redirect the client after successful authentication\n}\n\ninterface OidcVarsHookProps {\n  readonly issuerUrl: string;\n  readonly clientId: string;\n  readonly clientSecret: string;\n  readonly clientScope: string;\n  readonly redirectUri: string;\n}\n\nclass AddOidcVarsHook extends ContainerMutatingHook {\n  readonly props: OidcVarsHookProps;\n  constructor(props: OidcVarsHookProps) {\n    super();\n    this.props = props;\n  }\n\n  mutateContainerDefinition(\n    props: ContainerDefinitionOptions,\n  ): ContainerDefinitionOptions {\n    return {\n      ...props,\n      environment: {\n        ...props.environment,\n        OIDC_ISSUER_URL: this.props.issuerUrl,\n        OIDC_CLIENT_ID: this.props.clientId,\n        OIDC_CLIENT_SECRET: this.props.clientSecret,\n        OIDC_POST_LOGOUT_REDIRECT_URI: this.props.redirectUri,\n        OIDC_SCOPE: this.props.clientScope,\n      },\n    };\n  }\n}\n\nexport class ApplicationLoadBalancerExtension extends ServiceExtension {\n  private listener!: IApplicationListener;\n  private readonly props: ApplicationLoadBalancerExtensionProps;\n\n  userPool!: IUserPool;\n  userPoolClient!: IUserPoolClient;\n  userPoolDomain!: IUserPoolDomain;\n\n  readonly fqdn: string;\n\n  constructor(props: ApplicationLoadBalancerExtensionProps) {\n    super(\"application-load-balancer\");\n    this.props = props;\n    this.fqdn = importValue(this.props.platformStackName, \"fqdn\");\n  }\n\n  addHooks(): void {\n    const container = this.parentService.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n\n    if (!container || !container.trafficPort) {\n      throw new Error(\n        \"Cannot apply ALB Extension, no main app container found\",\n      );\n    }\n\n    container.addContainerMutatingHook(\n      new AddOidcVarsHook({\n        clientId: this.userPoolClient.userPoolClientId,\n        clientSecret: this.props.userPoolClientSecret,\n        clientScope: this.props.clientScope,\n        issuerUrl: `https://cognito-idp.${Aws.REGION}.amazonaws.com/${this.userPool.userPoolId}`,\n        redirectUri: `https://${this.fqdn}${this.props.path ?? \"\"}`,\n      }),\n    );\n  }\n\n  prehook(service: Service, scope: Construct): void {\n    this.parentService = service;\n    this.scope = scope;\n\n    const importCognitoValue = createImporter(\n      this.props.platformStackName,\n      \"cognito\",\n    );\n\n    const albListenerArn = importValue(\n      this.props.platformStackName,\n      \"alb\",\n      \"listener-arn\",\n    );\n\n    this.listener = ApplicationListener.fromApplicationListenerAttributes(\n      scope,\n      `${this.parentService.id}Listener`,\n      {\n        listenerArn: albListenerArn,\n        securityGroup: SecurityGroup.fromLookupById(\n          scope,\n          `${this.parentService.id}ALBSecurityGroup`,\n          this.props.securityGroupId,\n        ),\n      },\n    );\n\n    this.userPool = UserPool.fromUserPoolId(\n      this.scope,\n      `${this.parentService.id}ALBUserPool`,\n      importCognitoValue(\"user-pool-id\"),\n    );\n\n    this.userPoolClient = UserPoolClient.fromUserPoolClientId(\n      this.scope,\n      `${this.parentService.id}UserPoolClient`,\n      importCognitoValue(\"user-pool-client-id\"),\n    );\n\n    this.userPoolDomain = UserPoolDomain.fromDomainName(\n      this.scope,\n      `${this.parentService.id}UserPoolDomain`,\n      importCognitoValue(\"domain-prefix\"),\n    );\n  }\n\n  modifyServiceProps(props: ServiceBuild): ServiceBuild {\n    return {\n      ...props,\n      healthCheckGracePeriod: Duration.minutes(1),\n    } satisfies ServiceBuild;\n  }\n\n  public useService(service: Ec2Service | FargateService): void {\n    const container = this.parentService.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n    if (!container || !container.trafficPort) {\n      throw new Error(\n        \"Cannot apply ALB Extension, no main app container found\",\n      );\n    }\n\n    const targetGroup = new ApplicationTargetGroup(\n      this.parentService,\n      `${this.parentService.id}TargetGroup`,\n      {\n        vpc: this.parentService.vpc,\n        port: container.trafficPort,\n        protocol: ApplicationProtocol.HTTP,\n        deregistrationDelay: Duration.seconds(10),\n        targets: [service],\n        healthCheck: {\n          path: this.props.healtCheckPath,\n        },\n      },\n    );\n\n    this.listener.addAction(`${this.parentService.id}Action`, {\n      priority: 55,\n      conditions: [ListenerCondition.hostHeaders([this.fqdn])],\n      action: new AuthenticateCognitoAction({\n        userPool: this.userPool,\n        userPoolClient: this.userPoolClient,\n        userPoolDomain: this.userPoolDomain,\n        next: ListenerAction.forward([targetGroup]),\n        onUnauthenticatedRequest: UnauthenticatedAction.AUTHENTICATE,\n      }),\n    });\n\n    this.parentService.targetGroup = targetGroup;\n    this.parentService.addURL(\"public\", `https://${this.fqdn}`);\n  }\n}\n"]}
@@ -77,5 +77,5 @@ class CloudMapExtension extends ecs_service_extensions_1.ServiceExtension {
77
77
  }
78
78
  exports.CloudMapExtension = CloudMapExtension;
79
79
  _a = JSII_RTTI_SYMBOL_1;
80
- CloudMapExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.CloudMapExtension", version: "0.5.3" };
80
+ CloudMapExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.CloudMapExtension", version: "0.5.5" };
81
81
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CloudMapExtension.js","sourceRoot":"","sources":["../../src/extensions/CloudMapExtension.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ConnectToProps,\n  Container,\n  Service,\n  ServiceBuild,\n  ServiceExtension,\n} from \"@aws-cdk-containers/ecs-service-extensions\";\nimport { Duration } from \"aws-cdk-lib\";\nimport { Port } from \"aws-cdk-lib/aws-ec2\";\nimport { Ec2Service, FargateService } from \"aws-cdk-lib/aws-ecs\";\nimport {\n  CfnService,\n  DnsRecordType,\n  PrivateDnsNamespace,\n} from \"aws-cdk-lib/aws-servicediscovery\";\nimport { kebabCase } from \"lodash\";\nimport { createImporter } from \"../utils/ImportValue\";\n\nexport interface CloudMapExtensionProps {\n  /**\n   * The name of the platform stack to import the namespace parameter details from.\n   */\n  readonly platformStackName: string;\n\n  /**\n   * The key of the Output parameter to import the namespace details from the platform stack.\n   *\n   * @default - \"namespace\"\n   */\n  readonly parameterKey?: string;\n}\n\nexport class CloudMapExtension extends ServiceExtension {\n  props: CloudMapExtensionProps;\n\n  serviceName!: string;\n\n  constructor(props: CloudMapExtensionProps) {\n    super(\"cloudmap-extension\");\n\n    this.props = props;\n  }\n\n  modifyServiceProps(props: ServiceBuild): ServiceBuild {\n    const importNamespace = createImporter(\n      this.props.platformStackName,\n      this.props.parameterKey ?? \"namespace\",\n    );\n\n    const mainContainer = props.taskDefinition.findContainer(\"app\");\n\n    if (!mainContainer) {\n      throw new Error(\n        \"You must add a container before configuring the CloudMap extension\",\n      );\n    }\n\n    const namespaceArn = importNamespace(\"arn\");\n    const namespaceId = importNamespace(\"id\");\n    const namespaceName = importNamespace(\"name\");\n\n    this.serviceName = kebabCase(this.parentService.id);\n\n    const cloudMapNamespace =\n      PrivateDnsNamespace.fromPrivateDnsNamespaceAttributes(\n        this.scope,\n        `${this.parentService.id}Namespace`,\n        {\n          namespaceArn,\n          namespaceId,\n          namespaceName,\n        },\n      );\n\n    return {\n      ...props,\n      cloudMapOptions: {\n        name: this.serviceName,\n        dnsRecordType: DnsRecordType.SRV,\n        dnsTtl: Duration.seconds(60),\n        containerPort: mainContainer.containerPort,\n        cloudMapNamespace,\n      },\n    };\n  }\n\n  useService(service: Ec2Service | FargateService): void {\n    const container = this.parentService.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n\n    if (!service.cloudMapService) {\n      throw new Error(\"Expected the cloud map settings to be available\");\n    }\n\n    const {\n      cloudMapService: {\n        namespace: { namespaceName },\n      },\n    } = service;\n\n    this.parentService.addURL(\n      \"internal\",\n      `http://${this.serviceName}.${namespaceName}:${container.trafficPort}`,\n    );\n\n    // add hack to support SRV + A records\n\n    const cfnService = service.cloudMapService?.node.defaultChild as CfnService;\n    cfnService.dnsConfig = {\n      ...cfnService.dnsConfig,\n      dnsRecords: [\n        {\n          ttl: 60,\n          type: \"A\",\n        },\n        {\n          ttl: 60,\n          type: \"SRV\",\n        },\n      ],\n    };\n  }\n\n  /**\n   * Adjust the security group of the given service to allow traffic from this service.\n   *\n   */\n  connectToService(service: Service, _connectToProps?: ConnectToProps): void {\n    const container = service.serviceDescription.get(\n      \"service-container\",\n    ) as Container;\n    if (!container || !container.trafficPort) {\n      throw new Error(\n        \"Cannot apply extension, no main app container found in target service\",\n      );\n    }\n\n    service.ecsService.connections.allowFrom(\n      this.parentService.ecsService,\n      Port.tcp(container.trafficPort),\n    );\n  }\n}\n"]}