@btc-embedded/cdk-extensions 0.8.3 → 0.9.0

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 (55) hide show
  1. package/.jsii +1830 -244
  2. package/API.md +3409 -1331
  3. package/CHANGELOG.md +14 -0
  4. package/lib/constructs/SecureRestApi.d.ts +3 -0
  5. package/lib/constructs/SecureRestApi.js +5 -2
  6. package/lib/constructs/SecureRestApiV2.d.ts +32 -0
  7. package/lib/constructs/SecureRestApiV2.js +64 -0
  8. package/lib/constructs/index.d.ts +1 -0
  9. package/lib/constructs/index.js +2 -1
  10. package/lib/extensions/ApiGatewayExtension.d.ts +1 -0
  11. package/lib/extensions/ApiGatewayExtension.js +3 -2
  12. package/lib/extensions/ApplicationLoadBalancerExtension.d.ts +3 -0
  13. package/lib/extensions/ApplicationLoadBalancerExtension.js +5 -2
  14. package/lib/extensions/ApplicationLoadBalancerExtensionV2.d.ts +24 -0
  15. package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +79 -0
  16. package/lib/extensions/CloudMapExtension.js +1 -1
  17. package/lib/extensions/DocumentDbAccessExtension.js +1 -1
  18. package/lib/extensions/DomainEventMessagingExtension.js +1 -1
  19. package/lib/extensions/ExtraContainerExtension.js +1 -1
  20. package/lib/extensions/HTTPApiExtension.d.ts +44 -0
  21. package/lib/extensions/HTTPApiExtension.js +116 -0
  22. package/lib/extensions/LogExtension.js +1 -1
  23. package/lib/extensions/ModifyContainerDefinitionExtension.js +1 -1
  24. package/lib/extensions/ModifyTaskDefinitionExtension.js +1 -1
  25. package/lib/extensions/OpenTelemetryExtension.js +1 -1
  26. package/lib/extensions/PostgresDbAccessExtension.js +1 -1
  27. package/lib/extensions/SharedVolumeExtension.js +1 -1
  28. package/lib/extensions/TcpKeepAliveExtension.js +1 -1
  29. package/lib/extensions/index.d.ts +2 -0
  30. package/lib/extensions/index.js +3 -1
  31. package/lib/platform/ApiGateway.d.ts +1 -1
  32. package/lib/platform/ApiGateway.js +3 -4
  33. package/lib/platform/ApiGatewayV2.d.ts +28 -0
  34. package/lib/platform/ApiGatewayV2.js +55 -0
  35. package/lib/platform/ApiUserPoolClient.d.ts +32 -0
  36. package/lib/platform/ApiUserPoolClient.js +47 -0
  37. package/lib/platform/ApplicationLoadBalancer.d.ts +3 -0
  38. package/lib/platform/ApplicationLoadBalancer.js +5 -2
  39. package/lib/platform/ApplicationLoadBalancerV2.d.ts +58 -0
  40. package/lib/platform/ApplicationLoadBalancerV2.js +97 -0
  41. package/lib/platform/ApplicationUserPoolClient.d.ts +51 -0
  42. package/lib/platform/ApplicationUserPoolClient.js +66 -0
  43. package/lib/platform/CognitoUserPool.d.ts +14 -0
  44. package/lib/platform/CognitoUserPool.js +28 -0
  45. package/lib/platform/DefaultUserPoolClients.d.ts +1 -0
  46. package/lib/platform/DefaultUserPoolClients.js +3 -2
  47. package/lib/platform/DocumentDB.js +1 -1
  48. package/lib/platform/PrivateDnsNamespace.js +1 -1
  49. package/lib/platform/ResourceServer.d.ts +34 -0
  50. package/lib/platform/ResourceServer.js +43 -0
  51. package/lib/platform/Vpc.js +1 -1
  52. package/lib/platform/index.d.ts +6 -0
  53. package/lib/platform/index.js +7 -1
  54. package/lib/utils/ImportValue.js +2 -1
  55. package/package.json +1 -1
package/CHANGELOG.md CHANGED
@@ -1,4 +1,18 @@
1
1
 
2
+ ## [0.8.4](https://github.com/btc-embedded/cdk-extensions/compare/v0.8.3...v0.8.4) (2025-03-25)
3
+
4
+
5
+ ### Bug Fixes
6
+
7
+ * use default path for custom API GW domain ([51e2da8](https://github.com/btc-embedded/cdk-extensions/commit/51e2da86db4a068a6b0688438c07f0f19048672f))
8
+
9
+ ## [0.8.3](https://github.com/btc-embedded/cdk-extensions/compare/v0.8.2...v0.8.3) (2025-03-19)
10
+
11
+
12
+ ### Features
13
+
14
+ * allow to set env var names for Postgres ([e386f92](https://github.com/btc-embedded/cdk-extensions/commit/e386f9297396624361b47ae74f480e84dff5eda7))
15
+
2
16
  ## [0.8.2](https://github.com/btc-embedded/cdk-extensions/compare/v0.8.1...v0.8.2) (2025-03-17)
3
17
 
4
18
 
@@ -21,6 +21,9 @@ export interface SecureRestApiProps {
21
21
  */
22
22
  readonly restApiProps: RestApiProps;
23
23
  }
24
+ /**
25
+ * @deprecated Use {@link SecureRestApiV2} instead
26
+ */
24
27
  export declare class SecureRestApi extends Construct {
25
28
  domainName: string;
26
29
  defaultAuthorizer: CognitoUserPoolsAuthorizer;
@@ -9,6 +9,9 @@ const aws_cognito_1 = require("aws-cdk-lib/aws-cognito");
9
9
  const aws_route53_1 = require("aws-cdk-lib/aws-route53");
10
10
  const construct_1 = require("constructs/lib/construct");
11
11
  const ImportValue_1 = require("../utils/ImportValue");
12
+ /**
13
+ * @deprecated Use {@link SecureRestApiV2} instead
14
+ */
12
15
  class SecureRestApi extends construct_1.Construct {
13
16
  constructor(scope, id, props) {
14
17
  super(scope, id);
@@ -47,5 +50,5 @@ class SecureRestApi extends construct_1.Construct {
47
50
  }
48
51
  exports.SecureRestApi = SecureRestApi;
49
52
  _a = JSII_RTTI_SYMBOL_1;
50
- SecureRestApi[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApi", version: "0.8.3" };
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdHJ1Y3RzL1NlY3VyZVJlc3RBcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrREFJb0M7QUFDcEMsK0VBRzRDO0FBQzVDLHlEQUFtRDtBQUNuRCx5REFBa0U7QUFDbEUsd0RBQXFEO0FBQ3JELHNEQUFtRDtBQXdCbkQsTUFBYSxhQUFjLFNBQVEscUJBQVM7SUFRMUMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUF5QjtRQUNqRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pCLG9CQUFvQjtRQUNwQixJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3hELE1BQU0sSUFBSSxLQUFLLENBQUMsZ0RBQWdELENBQUMsQ0FBQztRQUNwRSxDQUFDO1FBRUQsTUFBTSxpQkFBaUIsR0FBRyxJQUFBLHlCQUFXLEVBQ25DLEtBQUssQ0FBQyxxQkFBcUIsRUFDM0IsU0FBUyxFQUNULGNBQWMsQ0FDZixDQUFDO1FBQ0YsTUFBTSxXQUFXLEdBQUcsc0JBQVEsQ0FBQyxjQUFjLENBQ3pDLElBQUksRUFDSixhQUFhLEVBQ2IsaUJBQWlCLENBQ2xCLENBQUM7UUFDRixNQUFNLGdCQUFnQixHQUFHLElBQUEseUJBQVcsRUFBQyxLQUFLLENBQUMscUJBQXFCLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDMUUsTUFBTSxVQUFVLEdBQ2QsS0FBSyxDQUFDLFVBQVU7WUFDaEIsd0JBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRTtnQkFDeEMsVUFBVSxFQUFFLGdCQUFnQjthQUM3QixDQUFDLENBQUM7UUFDTCxJQUFJLENBQUMsVUFBVSxHQUFHLEdBQUcsS0FBSyxDQUFDLFlBQVksSUFBSSxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakUsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLG9DQUFXLENBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRTtZQUN0RCxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDM0IsVUFBVSxFQUFFLDhDQUFxQixDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUM7U0FDdEQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGlCQUFpQixHQUFHLElBQUksMkNBQTBCLENBQ3JELElBQUksRUFDSixtQkFBbUIsRUFDbkI7WUFDRSxnQkFBZ0IsRUFBRSxDQUFDLFdBQVcsQ0FBQztTQUNoQyxDQUNGLENBQUM7UUFFRixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksd0JBQU8sQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQzFDLEdBQUcsS0FBSyxDQUFDLFlBQVk7WUFDckIsb0JBQW9CLEVBQUU7Z0JBQ3BCLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxvQkFBb0I7Z0JBQzFDLFVBQVUsRUFBRSxJQUFJLENBQUMsaUJBQWlCO2FBQ25DO1lBQ0QsVUFBVSxFQUFFO2dCQUNWLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQyxVQUFVO2dCQUNoQyxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7Z0JBQzNCLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVzthQUM5QjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBMURILHNDQTJEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyLFxuICBSZXN0QXBpLFxuICBSZXN0QXBpUHJvcHMsXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7IFVzZXJQb29sIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jb2duaXRvXCI7XG5pbXBvcnQgeyBIb3N0ZWRab25lLCBJSG9zdGVkWm9uZSB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHMvbGliL2NvbnN0cnVjdFwiO1xuaW1wb3J0IHsgaW1wb3J0VmFsdWUgfSBmcm9tIFwiLi4vdXRpbHMvSW1wb3J0VmFsdWVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTZWN1cmVSZXN0QXBpUHJvcHMge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIEJhc2UgcGxhdGZvcm0gU3RhY2tcbiAgICovXG4gIHJlYWRvbmx5IGJhc2VQbGF0Zm9ybVN0YWNrTmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogU3ViZG9tYWluIHRoYXQgaXMgdXNlZCBmb3IgUkVTVCBBUEkgcHJvcHNcbiAgICovXG4gIHJlYWRvbmx5IGFwaVN1YkRvbWFpbjogc3RyaW5nO1xuICAvKipcbiAgICogaG9zdGVkIHpvbmUgZm9yIHRoZSBzdWJkb21haW5cbiAgICogQW4gb3B0aW9uYWwgcGFyYW1ldGVyXG4gICAqIEBkZWZhdWx0IC0gZnFkbiBvdXRwdXQgb2YgYmFzZSBwbGF0Zm9ybSBzdGFjayBpcyB1c2VkIHRvIGltcG9ydCB0aGUgaG9zdGVkIHpvbmVcbiAgICovXG4gIHJlYWRvbmx5IGhvc3RlZFpvbmU/OiBJSG9zdGVkWm9uZTtcblxuICAvKipcbiAgICogUHJvcHMgZm9yd2FyZGVkIHRvIHRoZSBSZXN0QXBpIGNvbnN0cnVjdC5cbiAgICovXG4gIHJlYWRvbmx5IHJlc3RBcGlQcm9wczogUmVzdEFwaVByb3BzO1xufVxuXG5leHBvcnQgY2xhc3MgU2VjdXJlUmVzdEFwaSBleHRlbmRzIENvbnN0cnVjdCB7XG4gIC8vcHVibGljIHJlc3RBcGlEb21haW5OYW1lOiBEb21haW5OYW1lO1xuICBwdWJsaWMgZG9tYWluTmFtZTogc3RyaW5nO1xuICBwdWJsaWMgZGVmYXVsdEF1dGhvcml6ZXI6IENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyO1xuICBwcml2YXRlIGNlcnRpZmljYXRlOiBDZXJ0aWZpY2F0ZTtcblxuICBwdWJsaWMgcmVzdEFwaTogUmVzdEFwaTtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU2VjdXJlUmVzdEFwaVByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcbiAgICAvL3ZhbGlkYXRlIHRoZSBwcm9wc1xuICAgIGlmICghcHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lICYmICFwcm9wcy5hcGlTdWJEb21haW4pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcInBsYXRmb3JtU3RhY2tOYW1lIGFuZCBBcGlTdWJEb21haW4gaXMgcmVxdWlyZWRcIik7XG4gICAgfVxuXG4gICAgY29uc3QgY29nbml0b1VzZXJQb29sSWQgPSBpbXBvcnRWYWx1ZShcbiAgICAgIHByb3BzLmJhc2VQbGF0Zm9ybVN0YWNrTmFtZSxcbiAgICAgIFwiY29nbml0b1wiLFxuICAgICAgXCJ1c2VyLXBvb2wtaWRcIixcbiAgICApO1xuICAgIGNvbnN0IHVzZXJQb29sUmVmID0gVXNlclBvb2wuZnJvbVVzZXJQb29sSWQoXG4gICAgICB0aGlzLFxuICAgICAgXCJVc2VyUG9vbFJlZlwiLFxuICAgICAgY29nbml0b1VzZXJQb29sSWQsXG4gICAgKTtcbiAgICBjb25zdCBiYXNlUGxhdGZvcm1GcWRuID0gaW1wb3J0VmFsdWUocHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lLCBcImZxZG5cIik7XG4gICAgY29uc3QgaG9zdGVkWm9uZSA9XG4gICAgICBwcm9wcy5ob3N0ZWRab25lID8/XG4gICAgICBIb3N0ZWRab25lLmZyb21Mb29rdXAodGhpcywgXCJIb3N0ZWRab25lXCIsIHtcbiAgICAgICAgZG9tYWluTmFtZTogYmFzZVBsYXRmb3JtRnFkbixcbiAgICAgIH0pO1xuICAgIHRoaXMuZG9tYWluTmFtZSA9IGAke3Byb3BzLmFwaVN1YkRvbWFpbn0uJHtob3N0ZWRab25lLnpvbmVOYW1lfWA7XG5cbiAgICB0aGlzLmNlcnRpZmljYXRlID0gbmV3IENlcnRpZmljYXRlKHRoaXMsIFwiQ2VydGlmaWNhdGVcIiwge1xuICAgICAgZG9tYWluTmFtZTogdGhpcy5kb21haW5OYW1lLFxuICAgICAgdmFsaWRhdGlvbjogQ2VydGlmaWNhdGVWYWxpZGF0aW9uLmZyb21EbnMoaG9zdGVkWm9uZSksXG4gICAgfSk7XG5cbiAgICB0aGlzLmRlZmF1bHRBdXRob3JpemVyID0gbmV3IENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyKFxuICAgICAgdGhpcyxcbiAgICAgIFwiZGVmYXVsdEF1dGhvcml6ZXJcIixcbiAgICAgIHtcbiAgICAgICAgY29nbml0b1VzZXJQb29sczogW3VzZXJQb29sUmVmXSxcbiAgICAgIH0sXG4gICAgKTtcblxuICAgIHRoaXMucmVzdEFwaSA9IG5ldyBSZXN0QXBpKHRoaXMsIFwiUmVzdEFwaVwiLCB7XG4gICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMsXG4gICAgICBkZWZhdWx0TWV0aG9kT3B0aW9uczoge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZGVmYXVsdE1ldGhvZE9wdGlvbnMsXG4gICAgICAgIGF1dGhvcml6ZXI6IHRoaXMuZGVmYXVsdEF1dGhvcml6ZXIsXG4gICAgICB9LFxuICAgICAgZG9tYWluTmFtZToge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZG9tYWluTmFtZSxcbiAgICAgICAgZG9tYWluTmFtZTogdGhpcy5kb21haW5OYW1lLFxuICAgICAgICBjZXJ0aWZpY2F0ZTogdGhpcy5jZXJ0aWZpY2F0ZSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
53
+ SecureRestApi[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApi", version: "0.9.0" };
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdHJ1Y3RzL1NlY3VyZVJlc3RBcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrREFJb0M7QUFDcEMsK0VBRzRDO0FBQzVDLHlEQUFtRDtBQUNuRCx5REFBa0U7QUFDbEUsd0RBQXFEO0FBQ3JELHNEQUFtRDtBQXVCbkQ7O0dBRUc7QUFDSCxNQUFhLGFBQWMsU0FBUSxxQkFBUztJQVExQyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXlCO1FBQ2pFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDakIsb0JBQW9CO1FBQ3BCLElBQUksQ0FBQyxLQUFLLENBQUMscUJBQXFCLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDeEQsTUFBTSxJQUFJLEtBQUssQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO1FBQ3BFLENBQUM7UUFFRCxNQUFNLGlCQUFpQixHQUFHLElBQUEseUJBQVcsRUFDbkMsS0FBSyxDQUFDLHFCQUFxQixFQUMzQixTQUFTLEVBQ1QsY0FBYyxDQUNmLENBQUM7UUFDRixNQUFNLFdBQVcsR0FBRyxzQkFBUSxDQUFDLGNBQWMsQ0FDekMsSUFBSSxFQUNKLGFBQWEsRUFDYixpQkFBaUIsQ0FDbEIsQ0FBQztRQUNGLE1BQU0sZ0JBQWdCLEdBQUcsSUFBQSx5QkFBVyxFQUFDLEtBQUssQ0FBQyxxQkFBcUIsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUMxRSxNQUFNLFVBQVUsR0FDZCxLQUFLLENBQUMsVUFBVTtZQUNoQix3QkFBVSxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUsWUFBWSxFQUFFO2dCQUN4QyxVQUFVLEVBQUUsZ0JBQWdCO2FBQzdCLENBQUMsQ0FBQztRQUNMLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxLQUFLLENBQUMsWUFBWSxJQUFJLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUVqRSxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksb0NBQVcsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQ3RELFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixVQUFVLEVBQUUsOENBQXFCLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQztTQUN0RCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSwyQ0FBMEIsQ0FDckQsSUFBSSxFQUNKLG1CQUFtQixFQUNuQjtZQUNFLGdCQUFnQixFQUFFLENBQUMsV0FBVyxDQUFDO1NBQ2hDLENBQ0YsQ0FBQztRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSx3QkFBTyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDMUMsR0FBRyxLQUFLLENBQUMsWUFBWTtZQUNyQixvQkFBb0IsRUFBRTtnQkFDcEIsR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDLG9CQUFvQjtnQkFDMUMsVUFBVSxFQUFFLElBQUksQ0FBQyxpQkFBaUI7YUFDbkM7WUFDRCxVQUFVLEVBQUU7Z0JBQ1YsR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDLFVBQVU7Z0JBQ2hDLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtnQkFDM0IsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO2FBQzlCO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUExREgsc0NBMkRDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIsXG4gIFJlc3RBcGksXG4gIFJlc3RBcGlQcm9wcyxcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1hcGlnYXRld2F5XCI7XG5pbXBvcnQge1xuICBDZXJ0aWZpY2F0ZSxcbiAgQ2VydGlmaWNhdGVWYWxpZGF0aW9uLFxufSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWNlcnRpZmljYXRlbWFuYWdlclwiO1xuaW1wb3J0IHsgVXNlclBvb2wgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWNvZ25pdG9cIjtcbmltcG9ydCB7IEhvc3RlZFpvbmUsIElIb3N0ZWRab25lIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1yb3V0ZTUzXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0cy9saWIvY29uc3RydWN0XCI7XG5pbXBvcnQgeyBpbXBvcnRWYWx1ZSB9IGZyb20gXCIuLi91dGlscy9JbXBvcnRWYWx1ZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNlY3VyZVJlc3RBcGlQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgQmFzZSBwbGF0Zm9ybSBTdGFja1xuICAgKi9cbiAgcmVhZG9ubHkgYmFzZVBsYXRmb3JtU3RhY2tOYW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBTdWJkb21haW4gdGhhdCBpcyB1c2VkIGZvciBSRVNUIEFQSSBwcm9wc1xuICAgKi9cbiAgcmVhZG9ubHkgYXBpU3ViRG9tYWluOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBob3N0ZWQgem9uZSBmb3IgdGhlIHN1YmRvbWFpblxuICAgKiBBbiBvcHRpb25hbCBwYXJhbWV0ZXJcbiAgICogQGRlZmF1bHQgLSBmcWRuIG91dHB1dCBvZiBiYXNlIHBsYXRmb3JtIHN0YWNrIGlzIHVzZWQgdG8gaW1wb3J0IHRoZSBob3N0ZWQgem9uZVxuICAgKi9cbiAgcmVhZG9ubHkgaG9zdGVkWm9uZT86IElIb3N0ZWRab25lO1xuXG4gIC8qKlxuICAgKiBQcm9wcyBmb3J3YXJkZWQgdG8gdGhlIFJlc3RBcGkgY29uc3RydWN0LlxuICAgKi9cbiAgcmVhZG9ubHkgcmVzdEFwaVByb3BzOiBSZXN0QXBpUHJvcHM7XG59XG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSB7QGxpbmsgU2VjdXJlUmVzdEFwaVYyfSBpbnN0ZWFkXG4gKi9cbmV4cG9ydCBjbGFzcyBTZWN1cmVSZXN0QXBpIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgLy9wdWJsaWMgcmVzdEFwaURvbWFpbk5hbWU6IERvbWFpbk5hbWU7XG4gIHB1YmxpYyBkb21haW5OYW1lOiBzdHJpbmc7XG4gIHB1YmxpYyBkZWZhdWx0QXV0aG9yaXplcjogQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXI7XG4gIHByaXZhdGUgY2VydGlmaWNhdGU6IENlcnRpZmljYXRlO1xuXG4gIHB1YmxpYyByZXN0QXBpOiBSZXN0QXBpO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTZWN1cmVSZXN0QXBpUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIC8vdmFsaWRhdGUgdGhlIHByb3BzXG4gICAgaWYgKCFwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUgJiYgIXByb3BzLmFwaVN1YkRvbWFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwicGxhdGZvcm1TdGFja05hbWUgYW5kIEFwaVN1YkRvbWFpbiBpcyByZXF1aXJlZFwiKTtcbiAgICB9XG5cbiAgICBjb25zdCBjb2duaXRvVXNlclBvb2xJZCA9IGltcG9ydFZhbHVlKFxuICAgICAgcHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lLFxuICAgICAgXCJjb2duaXRvXCIsXG4gICAgICBcInVzZXItcG9vbC1pZFwiLFxuICAgICk7XG4gICAgY29uc3QgdXNlclBvb2xSZWYgPSBVc2VyUG9vbC5mcm9tVXNlclBvb2xJZChcbiAgICAgIHRoaXMsXG4gICAgICBcIlVzZXJQb29sUmVmXCIsXG4gICAgICBjb2duaXRvVXNlclBvb2xJZCxcbiAgICApO1xuICAgIGNvbnN0IGJhc2VQbGF0Zm9ybUZxZG4gPSBpbXBvcnRWYWx1ZShwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsIFwiZnFkblwiKTtcbiAgICBjb25zdCBob3N0ZWRab25lID1cbiAgICAgIHByb3BzLmhvc3RlZFpvbmUgPz9cbiAgICAgIEhvc3RlZFpvbmUuZnJvbUxvb2t1cCh0aGlzLCBcIkhvc3RlZFpvbmVcIiwge1xuICAgICAgICBkb21haW5OYW1lOiBiYXNlUGxhdGZvcm1GcWRuLFxuICAgICAgfSk7XG4gICAgdGhpcy5kb21haW5OYW1lID0gYCR7cHJvcHMuYXBpU3ViRG9tYWlufS4ke2hvc3RlZFpvbmUuem9uZU5hbWV9YDtcblxuICAgIHRoaXMuY2VydGlmaWNhdGUgPSBuZXcgQ2VydGlmaWNhdGUodGhpcywgXCJDZXJ0aWZpY2F0ZVwiLCB7XG4gICAgICBkb21haW5OYW1lOiB0aGlzLmRvbWFpbk5hbWUsXG4gICAgICB2YWxpZGF0aW9uOiBDZXJ0aWZpY2F0ZVZhbGlkYXRpb24uZnJvbURucyhob3N0ZWRab25lKSxcbiAgICB9KTtcblxuICAgIHRoaXMuZGVmYXVsdEF1dGhvcml6ZXIgPSBuZXcgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIoXG4gICAgICB0aGlzLFxuICAgICAgXCJkZWZhdWx0QXV0aG9yaXplclwiLFxuICAgICAge1xuICAgICAgICBjb2duaXRvVXNlclBvb2xzOiBbdXNlclBvb2xSZWZdLFxuICAgICAgfSxcbiAgICApO1xuXG4gICAgdGhpcy5yZXN0QXBpID0gbmV3IFJlc3RBcGkodGhpcywgXCJSZXN0QXBpXCIsIHtcbiAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcyxcbiAgICAgIGRlZmF1bHRNZXRob2RPcHRpb25zOiB7XG4gICAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcy5kZWZhdWx0TWV0aG9kT3B0aW9ucyxcbiAgICAgICAgYXV0aG9yaXplcjogdGhpcy5kZWZhdWx0QXV0aG9yaXplcixcbiAgICAgIH0sXG4gICAgICBkb21haW5OYW1lOiB7XG4gICAgICAgIC4uLnByb3BzLnJlc3RBcGlQcm9wcy5kb21haW5OYW1lLFxuICAgICAgICBkb21haW5OYW1lOiB0aGlzLmRvbWFpbk5hbWUsXG4gICAgICAgIGNlcnRpZmljYXRlOiB0aGlzLmNlcnRpZmljYXRlLFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -0,0 +1,32 @@
1
+ import { CognitoUserPoolsAuthorizer, Integration, MethodOptions, RestApiProps } from "aws-cdk-lib/aws-apigateway";
2
+ import { IHostedZone } from "aws-cdk-lib/aws-route53";
3
+ import { Construct } from "constructs/lib/construct";
4
+ export interface SecureRestApiPropsV2 {
5
+ /**
6
+ * The name of the Base platform Stack
7
+ */
8
+ readonly basePlatformStackName: string;
9
+ /**
10
+ * Subdomain that is used for REST API props
11
+ */
12
+ readonly apiSubDomain: string;
13
+ /**
14
+ * hosted zone for the subdomain
15
+ * An optional parameter
16
+ * @default - fqdn output of base platform stack is used to import the hosted zone
17
+ */
18
+ readonly hostedZone?: IHostedZone;
19
+ /**
20
+ * Props forwarded to the RestApi construct.
21
+ */
22
+ readonly restApiProps: RestApiProps;
23
+ }
24
+ export declare class SecureRestApiV2 extends Construct {
25
+ domainName: string;
26
+ defaultAuthorizer: CognitoUserPoolsAuthorizer;
27
+ private certificate;
28
+ private basePlatformFqdn;
29
+ private restApi;
30
+ constructor(scope: Construct, id: string, props: SecureRestApiPropsV2);
31
+ addMethod(httpMethod: string, target?: Integration, options?: MethodOptions): import("aws-cdk-lib/aws-apigateway").Method;
32
+ }
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SecureRestApiV2 = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const aws_apigateway_1 = require("aws-cdk-lib/aws-apigateway");
7
+ const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
8
+ const aws_cognito_1 = require("aws-cdk-lib/aws-cognito");
9
+ const aws_route53_1 = require("aws-cdk-lib/aws-route53");
10
+ const construct_1 = require("constructs/lib/construct");
11
+ const ImportValue_1 = require("../utils/ImportValue");
12
+ class SecureRestApiV2 extends construct_1.Construct {
13
+ constructor(scope, id, props) {
14
+ super(scope, id);
15
+ //validate the props
16
+ if (!props.basePlatformStackName && !props.apiSubDomain) {
17
+ throw new Error("platformStackName and ApiSubDomain is required");
18
+ }
19
+ const cognitoUserPoolId = (0, ImportValue_1.importValue)(props.basePlatformStackName, "cognito-v2", "user-pool-id");
20
+ const userPoolRef = aws_cognito_1.UserPool.fromUserPoolId(this, "UserPoolRef", cognitoUserPoolId);
21
+ this.basePlatformFqdn = (0, ImportValue_1.importValue)(props.basePlatformStackName, "fqdn");
22
+ const hostedZone = props.hostedZone ??
23
+ aws_route53_1.HostedZone.fromLookup(this, "HostedZone", {
24
+ domainName: this.basePlatformFqdn,
25
+ });
26
+ this.domainName = `${props.apiSubDomain}.${hostedZone.zoneName}`;
27
+ this.certificate = new aws_certificatemanager_1.Certificate(this, "Certificate", {
28
+ domainName: this.domainName,
29
+ validation: aws_certificatemanager_1.CertificateValidation.fromDns(hostedZone),
30
+ });
31
+ this.defaultAuthorizer = new aws_apigateway_1.CognitoUserPoolsAuthorizer(this, "defaultAuthorizer", {
32
+ cognitoUserPools: [userPoolRef],
33
+ });
34
+ this.restApi = new aws_apigateway_1.RestApi(this, "RestApi", {
35
+ ...props.restApiProps,
36
+ defaultMethodOptions: {
37
+ ...props.restApiProps.defaultMethodOptions,
38
+ authorizer: this.defaultAuthorizer,
39
+ },
40
+ domainName: {
41
+ ...props.restApiProps.domainName,
42
+ domainName: this.domainName,
43
+ certificate: this.certificate,
44
+ },
45
+ });
46
+ }
47
+ addMethod(httpMethod, target, options) {
48
+ const authorizationScopes = [`GET`, `HEAD`, `OPTIONS`].includes(httpMethod)
49
+ ? [
50
+ `https://api.${this.basePlatformFqdn}/read_api`,
51
+ `https://api.${this.basePlatformFqdn}/write_api`,
52
+ ]
53
+ : [`https://api.${this.basePlatformFqdn}/write_api`];
54
+ return this.restApi.root.addMethod(httpMethod, target, {
55
+ authorizer: this.defaultAuthorizer,
56
+ authorizationScopes,
57
+ ...options,
58
+ });
59
+ }
60
+ }
61
+ exports.SecureRestApiV2 = SecureRestApiV2;
62
+ _a = JSII_RTTI_SYMBOL_1;
63
+ SecureRestApiV2[_a] = { fqn: "@btc-embedded/cdk-extensions.SecureRestApiV2", version: "0.9.0" };
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VjdXJlUmVzdEFwaVYyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnN0cnVjdHMvU2VjdXJlUmVzdEFwaVYyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsK0RBTW9DO0FBQ3BDLCtFQUc0QztBQUM1Qyx5REFBbUQ7QUFDbkQseURBQWtFO0FBQ2xFLHdEQUFxRDtBQUNyRCxzREFBbUQ7QUF3Qm5ELE1BQWEsZUFBZ0IsU0FBUSxxQkFBUztJQVM1QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQTJCO1FBQ25FLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDakIsb0JBQW9CO1FBQ3BCLElBQUksQ0FBQyxLQUFLLENBQUMscUJBQXFCLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDeEQsTUFBTSxJQUFJLEtBQUssQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO1FBQ3BFLENBQUM7UUFFRCxNQUFNLGlCQUFpQixHQUFHLElBQUEseUJBQVcsRUFDbkMsS0FBSyxDQUFDLHFCQUFxQixFQUMzQixZQUFZLEVBQ1osY0FBYyxDQUNmLENBQUM7UUFDRixNQUFNLFdBQVcsR0FBRyxzQkFBUSxDQUFDLGNBQWMsQ0FDekMsSUFBSSxFQUNKLGFBQWEsRUFDYixpQkFBaUIsQ0FDbEIsQ0FBQztRQUNGLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFBLHlCQUFXLEVBQUMsS0FBSyxDQUFDLHFCQUFxQixFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3pFLE1BQU0sVUFBVSxHQUNkLEtBQUssQ0FBQyxVQUFVO1lBQ2hCLHdCQUFVLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUU7Z0JBQ3hDLFVBQVUsRUFBRSxJQUFJLENBQUMsZ0JBQWdCO2FBQ2xDLENBQUMsQ0FBQztRQUNMLElBQUksQ0FBQyxVQUFVLEdBQUcsR0FBRyxLQUFLLENBQUMsWUFBWSxJQUFJLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUVqRSxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksb0NBQVcsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQ3RELFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixVQUFVLEVBQUUsOENBQXFCLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQztTQUN0RCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSwyQ0FBMEIsQ0FDckQsSUFBSSxFQUNKLG1CQUFtQixFQUNuQjtZQUNFLGdCQUFnQixFQUFFLENBQUMsV0FBVyxDQUFDO1NBQ2hDLENBQ0YsQ0FBQztRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSx3QkFBTyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDMUMsR0FBRyxLQUFLLENBQUMsWUFBWTtZQUNyQixvQkFBb0IsRUFBRTtnQkFDcEIsR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDLG9CQUFvQjtnQkFDMUMsVUFBVSxFQUFFLElBQUksQ0FBQyxpQkFBaUI7YUFDbkM7WUFDRCxVQUFVLEVBQUU7Z0JBQ1YsR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDLFVBQVU7Z0JBQ2hDLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtnQkFDM0IsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO2FBQzlCO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLFNBQVMsQ0FDZCxVQUFrQixFQUNsQixNQUFvQixFQUNwQixPQUF1QjtRQUV2QixNQUFNLG1CQUFtQixHQUFHLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDO1lBQ3pFLENBQUMsQ0FBQztnQkFDRSxlQUFlLElBQUksQ0FBQyxnQkFBZ0IsV0FBVztnQkFDL0MsZUFBZSxJQUFJLENBQUMsZ0JBQWdCLFlBQVk7YUFDakQ7WUFDSCxDQUFDLENBQUMsQ0FBQyxlQUFlLElBQUksQ0FBQyxnQkFBZ0IsWUFBWSxDQUFDLENBQUM7UUFFdkQsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLE1BQU0sRUFBRTtZQUNyRCxVQUFVLEVBQUUsSUFBSSxDQUFDLGlCQUFpQjtZQUNsQyxtQkFBbUI7WUFDbkIsR0FBRyxPQUFPO1NBQ1gsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUE5RUgsMENBK0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29nbml0b1VzZXJQb29sc0F1dGhvcml6ZXIsXG4gIEludGVncmF0aW9uLFxuICBNZXRob2RPcHRpb25zLFxuICBSZXN0QXBpLFxuICBSZXN0QXBpUHJvcHMsXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheVwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7IFVzZXJQb29sIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jb2duaXRvXCI7XG5pbXBvcnQgeyBIb3N0ZWRab25lLCBJSG9zdGVkWm9uZSB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHMvbGliL2NvbnN0cnVjdFwiO1xuaW1wb3J0IHsgaW1wb3J0VmFsdWUgfSBmcm9tIFwiLi4vdXRpbHMvSW1wb3J0VmFsdWVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTZWN1cmVSZXN0QXBpUHJvcHNWMiB7XG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgQmFzZSBwbGF0Zm9ybSBTdGFja1xuICAgKi9cbiAgcmVhZG9ubHkgYmFzZVBsYXRmb3JtU3RhY2tOYW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBTdWJkb21haW4gdGhhdCBpcyB1c2VkIGZvciBSRVNUIEFQSSBwcm9wc1xuICAgKi9cbiAgcmVhZG9ubHkgYXBpU3ViRG9tYWluOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBob3N0ZWQgem9uZSBmb3IgdGhlIHN1YmRvbWFpblxuICAgKiBBbiBvcHRpb25hbCBwYXJhbWV0ZXJcbiAgICogQGRlZmF1bHQgLSBmcWRuIG91dHB1dCBvZiBiYXNlIHBsYXRmb3JtIHN0YWNrIGlzIHVzZWQgdG8gaW1wb3J0IHRoZSBob3N0ZWQgem9uZVxuICAgKi9cbiAgcmVhZG9ubHkgaG9zdGVkWm9uZT86IElIb3N0ZWRab25lO1xuXG4gIC8qKlxuICAgKiBQcm9wcyBmb3J3YXJkZWQgdG8gdGhlIFJlc3RBcGkgY29uc3RydWN0LlxuICAgKi9cbiAgcmVhZG9ubHkgcmVzdEFwaVByb3BzOiBSZXN0QXBpUHJvcHM7XG59XG5cbmV4cG9ydCBjbGFzcyBTZWN1cmVSZXN0QXBpVjIgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAvL3B1YmxpYyByZXN0QXBpRG9tYWluTmFtZTogRG9tYWluTmFtZTtcbiAgcHVibGljIGRvbWFpbk5hbWU6IHN0cmluZztcbiAgcHVibGljIGRlZmF1bHRBdXRob3JpemVyOiBDb2duaXRvVXNlclBvb2xzQXV0aG9yaXplcjtcbiAgcHJpdmF0ZSBjZXJ0aWZpY2F0ZTogQ2VydGlmaWNhdGU7XG4gIHByaXZhdGUgYmFzZVBsYXRmb3JtRnFkbjogc3RyaW5nO1xuXG4gIHByaXZhdGUgcmVzdEFwaTogUmVzdEFwaTtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogU2VjdXJlUmVzdEFwaVByb3BzVjIpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIC8vdmFsaWRhdGUgdGhlIHByb3BzXG4gICAgaWYgKCFwcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUgJiYgIXByb3BzLmFwaVN1YkRvbWFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwicGxhdGZvcm1TdGFja05hbWUgYW5kIEFwaVN1YkRvbWFpbiBpcyByZXF1aXJlZFwiKTtcbiAgICB9XG5cbiAgICBjb25zdCBjb2duaXRvVXNlclBvb2xJZCA9IGltcG9ydFZhbHVlKFxuICAgICAgcHJvcHMuYmFzZVBsYXRmb3JtU3RhY2tOYW1lLFxuICAgICAgXCJjb2duaXRvLXYyXCIsXG4gICAgICBcInVzZXItcG9vbC1pZFwiLFxuICAgICk7XG4gICAgY29uc3QgdXNlclBvb2xSZWYgPSBVc2VyUG9vbC5mcm9tVXNlclBvb2xJZChcbiAgICAgIHRoaXMsXG4gICAgICBcIlVzZXJQb29sUmVmXCIsXG4gICAgICBjb2duaXRvVXNlclBvb2xJZCxcbiAgICApO1xuICAgIHRoaXMuYmFzZVBsYXRmb3JtRnFkbiA9IGltcG9ydFZhbHVlKHByb3BzLmJhc2VQbGF0Zm9ybVN0YWNrTmFtZSwgXCJmcWRuXCIpO1xuICAgIGNvbnN0IGhvc3RlZFpvbmUgPVxuICAgICAgcHJvcHMuaG9zdGVkWm9uZSA/P1xuICAgICAgSG9zdGVkWm9uZS5mcm9tTG9va3VwKHRoaXMsIFwiSG9zdGVkWm9uZVwiLCB7XG4gICAgICAgIGRvbWFpbk5hbWU6IHRoaXMuYmFzZVBsYXRmb3JtRnFkbixcbiAgICAgIH0pO1xuICAgIHRoaXMuZG9tYWluTmFtZSA9IGAke3Byb3BzLmFwaVN1YkRvbWFpbn0uJHtob3N0ZWRab25lLnpvbmVOYW1lfWA7XG5cbiAgICB0aGlzLmNlcnRpZmljYXRlID0gbmV3IENlcnRpZmljYXRlKHRoaXMsIFwiQ2VydGlmaWNhdGVcIiwge1xuICAgICAgZG9tYWluTmFtZTogdGhpcy5kb21haW5OYW1lLFxuICAgICAgdmFsaWRhdGlvbjogQ2VydGlmaWNhdGVWYWxpZGF0aW9uLmZyb21EbnMoaG9zdGVkWm9uZSksXG4gICAgfSk7XG5cbiAgICB0aGlzLmRlZmF1bHRBdXRob3JpemVyID0gbmV3IENvZ25pdG9Vc2VyUG9vbHNBdXRob3JpemVyKFxuICAgICAgdGhpcyxcbiAgICAgIFwiZGVmYXVsdEF1dGhvcml6ZXJcIixcbiAgICAgIHtcbiAgICAgICAgY29nbml0b1VzZXJQb29sczogW3VzZXJQb29sUmVmXSxcbiAgICAgIH0sXG4gICAgKTtcblxuICAgIHRoaXMucmVzdEFwaSA9IG5ldyBSZXN0QXBpKHRoaXMsIFwiUmVzdEFwaVwiLCB7XG4gICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMsXG4gICAgICBkZWZhdWx0TWV0aG9kT3B0aW9uczoge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZGVmYXVsdE1ldGhvZE9wdGlvbnMsXG4gICAgICAgIGF1dGhvcml6ZXI6IHRoaXMuZGVmYXVsdEF1dGhvcml6ZXIsXG4gICAgICB9LFxuICAgICAgZG9tYWluTmFtZToge1xuICAgICAgICAuLi5wcm9wcy5yZXN0QXBpUHJvcHMuZG9tYWluTmFtZSxcbiAgICAgICAgZG9tYWluTmFtZTogdGhpcy5kb21haW5OYW1lLFxuICAgICAgICBjZXJ0aWZpY2F0ZTogdGhpcy5jZXJ0aWZpY2F0ZSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgYWRkTWV0aG9kKFxuICAgIGh0dHBNZXRob2Q6IHN0cmluZyxcbiAgICB0YXJnZXQ/OiBJbnRlZ3JhdGlvbixcbiAgICBvcHRpb25zPzogTWV0aG9kT3B0aW9ucyxcbiAgKSB7XG4gICAgY29uc3QgYXV0aG9yaXphdGlvblNjb3BlcyA9IFtgR0VUYCwgYEhFQURgLCBgT1BUSU9OU2BdLmluY2x1ZGVzKGh0dHBNZXRob2QpXG4gICAgICA/IFtcbiAgICAgICAgICBgaHR0cHM6Ly9hcGkuJHt0aGlzLmJhc2VQbGF0Zm9ybUZxZG59L3JlYWRfYXBpYCxcbiAgICAgICAgICBgaHR0cHM6Ly9hcGkuJHt0aGlzLmJhc2VQbGF0Zm9ybUZxZG59L3dyaXRlX2FwaWAsXG4gICAgICAgIF1cbiAgICAgIDogW2BodHRwczovL2FwaS4ke3RoaXMuYmFzZVBsYXRmb3JtRnFkbn0vd3JpdGVfYXBpYF07XG5cbiAgICByZXR1cm4gdGhpcy5yZXN0QXBpLnJvb3QuYWRkTWV0aG9kKGh0dHBNZXRob2QsIHRhcmdldCwge1xuICAgICAgYXV0aG9yaXplcjogdGhpcy5kZWZhdWx0QXV0aG9yaXplcixcbiAgICAgIGF1dGhvcml6YXRpb25TY29wZXMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -1 +1,2 @@
1
1
  export * from "./SecureRestApi";
2
+ export * from "./SecureRestApiV2";
@@ -15,4 +15,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./SecureRestApi"), exports);
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29uc3RydWN0cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsa0RBQWdDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vU2VjdXJlUmVzdEFwaVwiO1xuIl19
18
+ __exportStar(require("./SecureRestApiV2"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29uc3RydWN0cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsa0RBQWdDO0FBQ2hDLG9EQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL1NlY3VyZVJlc3RBcGlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL1NlY3VyZVJlc3RBcGlWMlwiO1xuIl19
@@ -16,6 +16,7 @@ export interface ApiGatewayExtensionProps {
16
16
  }
17
17
  /**
18
18
  * Configures the service to be reachable via an API Gateway.
19
+ * @deprecated Use {@link HTTPApiExtension} instead
19
20
  */
20
21
  export declare class ApiGatewayExtension extends ServiceExtension {
21
22
  readonly props: ApiGatewayExtensionProps;
@@ -12,6 +12,7 @@ const aws_ec2_1 = require("aws-cdk-lib/aws-ec2");
12
12
  const ImportValue_1 = require("../utils/ImportValue");
13
13
  /**
14
14
  * Configures the service to be reachable via an API Gateway.
15
+ * @deprecated Use {@link HTTPApiExtension} instead
15
16
  */
16
17
  class ApiGatewayExtension extends ecs_service_extensions_1.ServiceExtension {
17
18
  /**
@@ -64,5 +65,5 @@ class ApiGatewayExtension extends ecs_service_extensions_1.ServiceExtension {
64
65
  }
65
66
  exports.ApiGatewayExtension = ApiGatewayExtension;
66
67
  _a = JSII_RTTI_SYMBOL_1;
67
- ApiGatewayExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayExtension", version: "0.8.3" };
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"]}
68
+ ApiGatewayExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayExtension", version: "0.9.0" };
69
+ //# 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 * @deprecated Use {@link HTTPApiExtension} instead\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"]}
@@ -10,6 +10,9 @@ export interface ApplicationLoadBalancerExtensionProps {
10
10
  readonly healtCheckPath?: string;
11
11
  readonly path?: string;
12
12
  }
13
+ /**
14
+ * @deprecated Use {@link ApplicationLoadBalancerExtensionV2} instead
15
+ */
13
16
  export declare class ApplicationLoadBalancerExtension extends ServiceExtension {
14
17
  private listener;
15
18
  private readonly props;
@@ -29,6 +29,9 @@ class AddOidcVarsHook extends ecs_service_extensions_1.ContainerMutatingHook {
29
29
  };
30
30
  }
31
31
  }
32
+ /**
33
+ * @deprecated Use {@link ApplicationLoadBalancerExtensionV2} instead
34
+ */
32
35
  class ApplicationLoadBalancerExtension extends ecs_service_extensions_1.ServiceExtension {
33
36
  constructor(props) {
34
37
  super("application-load-balancer");
@@ -99,5 +102,5 @@ class ApplicationLoadBalancerExtension extends ecs_service_extensions_1.ServiceE
99
102
  }
100
103
  exports.ApplicationLoadBalancerExtension = ApplicationLoadBalancerExtension;
101
104
  _a = JSII_RTTI_SYMBOL_1;
102
- ApplicationLoadBalancerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerExtension", version: "0.8.3" };
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"]}
105
+ ApplicationLoadBalancerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerExtension", version: "0.9.0" };
106
+ //# 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/**\n * @deprecated Use {@link ApplicationLoadBalancerExtensionV2} instead\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"]}
@@ -0,0 +1,24 @@
1
+ import { Service, ServiceBuild, ServiceExtension } from "@aws-cdk-containers/ecs-service-extensions";
2
+ import { IUserPool, IUserPoolClient, IUserPoolDomain } from "aws-cdk-lib/aws-cognito";
3
+ import { Ec2Service, FargateService } from "aws-cdk-lib/aws-ecs";
4
+ import { Construct } from "constructs";
5
+ export interface ApplicationLoadBalancerExtensionPropsV2 {
6
+ readonly platformStackName: string;
7
+ readonly userPoolClientSecret: string;
8
+ readonly securityGroupId: string;
9
+ readonly clientScope: string;
10
+ readonly healtCheckPath?: string;
11
+ readonly path?: string;
12
+ }
13
+ export declare class ApplicationLoadBalancerExtensionV2 extends ServiceExtension {
14
+ private readonly props;
15
+ userPool: IUserPool;
16
+ userPoolClient: IUserPoolClient;
17
+ userPoolDomain: IUserPoolDomain;
18
+ readonly fqdn: string;
19
+ constructor(props: ApplicationLoadBalancerExtensionPropsV2);
20
+ addHooks(): void;
21
+ prehook(service: Service, scope: Construct): void;
22
+ modifyServiceProps(props: ServiceBuild): ServiceBuild;
23
+ useService(service: Ec2Service | FargateService): void;
24
+ }
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ApplicationLoadBalancerExtensionV2 = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const ecs_service_extensions_1 = require("@aws-cdk-containers/ecs-service-extensions");
7
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
8
+ const aws_cognito_1 = require("aws-cdk-lib/aws-cognito");
9
+ const aws_elasticloadbalancingv2_1 = require("aws-cdk-lib/aws-elasticloadbalancingv2");
10
+ const ImportValue_1 = require("../utils/ImportValue");
11
+ class AddOidcVarsHook extends ecs_service_extensions_1.ContainerMutatingHook {
12
+ constructor(props) {
13
+ super();
14
+ this.props = props;
15
+ }
16
+ mutateContainerDefinition(props) {
17
+ return {
18
+ ...props,
19
+ environment: {
20
+ ...props.environment,
21
+ OIDC_ISSUER_URL: this.props.issuerUrl,
22
+ OIDC_CLIENT_ID: this.props.clientId,
23
+ OIDC_CLIENT_SECRET: this.props.clientSecret,
24
+ OIDC_POST_LOGOUT_REDIRECT_URI: this.props.redirectUri,
25
+ OIDC_SCOPE: this.props.clientScope,
26
+ },
27
+ };
28
+ }
29
+ }
30
+ class ApplicationLoadBalancerExtensionV2 extends ecs_service_extensions_1.ServiceExtension {
31
+ constructor(props) {
32
+ super("application-load-balancer");
33
+ this.props = props;
34
+ this.fqdn = (0, ImportValue_1.importValue)(this.props.platformStackName, "fqdn");
35
+ }
36
+ addHooks() {
37
+ const container = this.parentService.serviceDescription.get("service-container");
38
+ if (!container || !container.trafficPort) {
39
+ throw new Error("Cannot apply ALB Extension, no main app container found");
40
+ }
41
+ container.addContainerMutatingHook(new AddOidcVarsHook({
42
+ clientId: this.userPoolClient.userPoolClientId,
43
+ clientSecret: this.props.userPoolClientSecret,
44
+ clientScope: this.props.clientScope,
45
+ issuerUrl: `https://cognito-idp.${aws_cdk_lib_1.Aws.REGION}.amazonaws.com/${this.userPool.userPoolId}`,
46
+ redirectUri: `https://${this.fqdn}${this.props.path ?? ""}`,
47
+ }));
48
+ }
49
+ prehook(service, scope) {
50
+ this.parentService = service;
51
+ this.scope = scope;
52
+ // Import from the base platform stack output values
53
+ const importCognitoValue = (0, ImportValue_1.createImporter)(this.props.platformStackName, "cognito-v2");
54
+ this.userPool = aws_cognito_1.UserPool.fromUserPoolId(this.scope, `${this.parentService.id}ALBUserPool`, importCognitoValue("user-pool-id"));
55
+ this.userPoolClient = aws_cognito_1.UserPoolClient.fromUserPoolClientId(this.scope, `${this.parentService.id}UserPoolClient`, importCognitoValue("application-client-id"));
56
+ this.userPoolDomain = aws_cognito_1.UserPoolDomain.fromDomainName(this.scope, `${this.parentService.id}UserPoolDomain`, importCognitoValue("domain-prefix"));
57
+ }
58
+ modifyServiceProps(props) {
59
+ return {
60
+ ...props,
61
+ healthCheckGracePeriod: aws_cdk_lib_1.Duration.minutes(1),
62
+ };
63
+ }
64
+ useService(service) {
65
+ const container = this.parentService.serviceDescription.get("service-container");
66
+ if (!container || !container.trafficPort) {
67
+ throw new Error("Cannot apply ALB Extension, no main app container found");
68
+ }
69
+ const targetGroup = aws_elasticloadbalancingv2_1.ApplicationTargetGroup.fromTargetGroupAttributes(this.scope, `${this.parentService.id}TargetGroup`, {
70
+ targetGroupArn: (0, ImportValue_1.importValue)(this.props.platformStackName, "alb-target-group-arn"),
71
+ });
72
+ targetGroup.addTarget(service);
73
+ this.parentService.addURL("public", `https://${this.fqdn}`);
74
+ }
75
+ }
76
+ exports.ApplicationLoadBalancerExtensionV2 = ApplicationLoadBalancerExtensionV2;
77
+ _a = JSII_RTTI_SYMBOL_1;
78
+ ApplicationLoadBalancerExtensionV2[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerExtensionV2", version: "0.9.0" };
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApplicationLoadBalancerExtensionV2.js","sourceRoot":"","sources":["../../src/extensions/ApplicationLoadBalancerExtensionV2.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 {\n  ContainerDefinitionOptions,\n  Ec2Service,\n  FargateService,\n} from \"aws-cdk-lib/aws-ecs\";\nimport { ApplicationTargetGroup } from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\nimport { Construct } from \"constructs\";\nimport { createImporter, importValue } from \"../utils/ImportValue\";\n\nexport interface ApplicationLoadBalancerExtensionPropsV2 {\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 ApplicationLoadBalancerExtensionV2 extends ServiceExtension {\n  private readonly props: ApplicationLoadBalancerExtensionPropsV2;\n\n  userPool!: IUserPool;\n  userPoolClient!: IUserPoolClient;\n  userPoolDomain!: IUserPoolDomain;\n\n  readonly fqdn: string;\n\n  constructor(props: ApplicationLoadBalancerExtensionPropsV2) {\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    // Import from the base platform stack output values\n    const importCognitoValue = createImporter(\n      this.props.platformStackName,\n      \"cognito-v2\",\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(\"application-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 = ApplicationTargetGroup.fromTargetGroupAttributes(\n      this.scope,\n      `${this.parentService.id}TargetGroup`,\n      {\n        targetGroupArn: importValue(\n          this.props.platformStackName,\n          \"alb-target-group-arn\",\n        ),\n      },\n    );\n    targetGroup.addTarget(service);\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.8.3" };
80
+ CloudMapExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.CloudMapExtension", version: "0.9.0" };
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"]}
@@ -52,5 +52,5 @@ class DocumentDbAccessExtension extends ecs_service_extensions_1.ServiceExtensio
52
52
  }
53
53
  exports.DocumentDbAccessExtension = DocumentDbAccessExtension;
54
54
  _a = JSII_RTTI_SYMBOL_1;
55
- DocumentDbAccessExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.DocumentDbAccessExtension", version: "0.8.3" };
55
+ DocumentDbAccessExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.DocumentDbAccessExtension", version: "0.9.0" };
56
56
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRG9jdW1lbnREYkFjY2Vzc0V4dGVuc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9leHRlbnNpb25zL0RvY3VtZW50RGJBY2Nlc3NFeHRlbnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSx1RkFJb0Q7QUFDcEQsaURBQTBEO0FBQzFELDJDQUEyQztBQUMzQyx1RUFBd0Q7QUFFeEQsb0NBQXlEO0FBQ3pELHVFQUFvRTtBQU9wRSxNQUFNLGlCQUFrQixTQUFRLDhDQUFxQjtJQUNuRCxZQUNVLEtBQWdCLEVBQ2hCLFNBQWlCLEVBQ2pCLElBQVk7UUFFcEIsS0FBSyxFQUFFLENBQUM7UUFKQSxVQUFLLEdBQUwsS0FBSyxDQUFXO1FBQ2hCLGNBQVMsR0FBVCxTQUFTLENBQVE7UUFDakIsU0FBSSxHQUFKLElBQUksQ0FBUTtJQUd0QixDQUFDO0lBRUQseUJBQXlCLENBQ3ZCLEtBQXFDO1FBRXJDLE1BQU0sU0FBUyxHQUFHLDJCQUFNLENBQUMscUJBQXFCLENBQzVDLElBQUksQ0FBQyxLQUFLLEVBQ1YsR0FBRyxJQUFJLENBQUMsSUFBSSxxQkFBcUIsRUFDakMsSUFBSSxDQUFDLFNBQVMsQ0FDZixDQUFDO1FBRUYsT0FBTztZQUNMLEdBQUcsS0FBSztZQUNSLE9BQU8sRUFBRTtnQkFDUCxHQUFHLEtBQUssQ0FBQyxPQUFPO2dCQUNoQixXQUFXLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxTQUFTLENBQUM7YUFDdEQ7WUFDRCxXQUFXLEVBQUU7Z0JBQ1gsR0FBRyxLQUFLLENBQUMsV0FBVztnQkFDcEIsNkJBQTZCLEVBQUUsTUFBTTthQUN0QztTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFFRCxNQUFhLHlCQUEwQixTQUFRLHlDQUFnQjtJQUs3RCxZQUFZLEtBQXFDO1FBQy9DLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO0lBQ3JCLENBQUM7SUFFRCxPQUFPLENBQUMsTUFBZSxFQUFFLEtBQWdCO1FBQ3ZDLElBQUksQ0FBQyxhQUFhLEdBQUcsTUFBTSxDQUFDO1FBQzVCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBRW5CLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBQSxtQkFBVyxFQUMxQixJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixFQUNoQyxhQUFhLEVBQ2IsWUFBWSxDQUNiLENBQUM7SUFDSixDQUFDO0lBRU0sUUFBUTtRQUNiLElBQUEsd0JBQWdCLEVBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQzthQUNqQyxNQUFNLENBQ0wsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLFlBQVksaURBQXVCLENBQUMsSUFBSSxHQUFHLENBQUMsUUFBUSxDQUNuRTthQUNBLE9BQU8sQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQ3JCLFNBQVMsQ0FBQyx3QkFBd0IsQ0FDaEMsSUFBSSxpQkFBaUIsQ0FDbkIsSUFBSSxDQUFDLEtBQUssRUFDVixJQUFJLENBQUMsU0FBUyxFQUNkLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxFQUFFLElBQUksU0FBUyxDQUFDLElBQUksRUFBRSxDQUM3QyxDQUNGLENBQ0YsQ0FBQztJQUNOLENBQUM7SUFFTSxVQUFVLENBQUMsT0FBNEM7UUFDNUQsdUJBQWEsQ0FBQyxjQUFjLENBQzFCLElBQUksQ0FBQyxLQUFLLEVBQ1YsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLEVBQUUseUJBQXlCLEVBQ2pELElBQUksQ0FBQyxLQUFLLENBQUMsZUFBZSxDQUMzQixDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLGNBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNwRCxDQUFDOztBQTNDSCw4REE0Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb250YWluZXJNdXRhdGluZ0hvb2ssXG4gIFNlcnZpY2UsXG4gIFNlcnZpY2VFeHRlbnNpb24sXG59IGZyb20gXCJAYXdzLWNkay1jb250YWluZXJzL2Vjcy1zZXJ2aWNlLWV4dGVuc2lvbnNcIjtcbmltcG9ydCB7IFBvcnQsIFNlY3VyaXR5R3JvdXAgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWVjMlwiO1xuaW1wb3J0ICogYXMgZWNzIGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtZWNzXCI7XG5pbXBvcnQgeyBTZWNyZXQgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXNlY3JldHNtYW5hZ2VyXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IHsgZmlsdGVyQ29udGFpbmVycywgaW1wb3J0VmFsdWUgfSBmcm9tIFwiLi4vdXRpbHNcIjtcbmltcG9ydCB7IEV4dHJhQ29udGFpbmVyRXh0ZW5zaW9uIH0gZnJvbSBcIi4vRXh0cmFDb250YWluZXJFeHRlbnNpb25cIjtcblxuZXhwb3J0IGludGVyZmFjZSBEb2N1bWVudERiQWNjZXNzRXh0ZW5zaW9uUHJvcHMge1xuICByZWFkb25seSBiYXNlUGxhdGZvcm1TdGFja05hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgc2VjdXJpdHlHcm91cElkOiBzdHJpbmc7XG59XG5cbmNsYXNzIEFkZERvY3VtZW50RGJIb29rIGV4dGVuZHMgQ29udGFpbmVyTXV0YXRpbmdIb29rIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBzY29wZTogQ29uc3RydWN0LFxuICAgIHByaXZhdGUgc2VjcmV0QXJuOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSBuYW1lOiBzdHJpbmcsXG4gICkge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICBtdXRhdGVDb250YWluZXJEZWZpbml0aW9uKFxuICAgIHByb3BzOiBlY3MuQ29udGFpbmVyRGVmaW5pdGlvbk9wdGlvbnMsXG4gICk6IGVjcy5Db250YWluZXJEZWZpbml0aW9uT3B0aW9ucyB7XG4gICAgY29uc3QgdXJsU2VjcmV0ID0gU2VjcmV0LmZyb21TZWNyZXRDb21wbGV0ZUFybihcbiAgICAgIHRoaXMuc2NvcGUsXG4gICAgICBgJHt0aGlzLm5hbWV9RG9jdW1lbnREYlVybFNlY3JldGAsXG4gICAgICB0aGlzLnNlY3JldEFybixcbiAgICApO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnByb3BzLFxuICAgICAgc2VjcmV0czoge1xuICAgICAgICAuLi5wcm9wcy5zZWNyZXRzLFxuICAgICAgICBNT05HT0RCX1VSTDogZWNzLlNlY3JldC5mcm9tU2VjcmV0c01hbmFnZXIodXJsU2VjcmV0KSxcbiAgICAgIH0sXG4gICAgICBlbnZpcm9ubWVudDoge1xuICAgICAgICAuLi5wcm9wcy5lbnZpcm9ubWVudCxcbiAgICAgICAgTU9OR09EQl9JR05PUkVfU1NMX1ZBTElEQVRJT046IFwidHJ1ZVwiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBEb2N1bWVudERiQWNjZXNzRXh0ZW5zaW9uIGV4dGVuZHMgU2VydmljZUV4dGVuc2lvbiB7XG4gIHJlYWRvbmx5IHByb3BzOiBEb2N1bWVudERiQWNjZXNzRXh0ZW5zaW9uUHJvcHM7XG5cbiAgc2VjcmV0QXJuITogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByb3BzOiBEb2N1bWVudERiQWNjZXNzRXh0ZW5zaW9uUHJvcHMpIHtcbiAgICBzdXBlcihcImRvY3VtZW50ZGItYWNjZXNzLWV4dGVuc2lvblwiKTtcbiAgICB0aGlzLnByb3BzID0gcHJvcHM7XG4gIH1cblxuICBwcmVob29rKHBhcmVudDogU2VydmljZSwgc2NvcGU6IENvbnN0cnVjdCk6IHZvaWQge1xuICAgIHRoaXMucGFyZW50U2VydmljZSA9IHBhcmVudDtcbiAgICB0aGlzLnNjb3BlID0gc2NvcGU7XG5cbiAgICB0aGlzLnNlY3JldEFybiA9IGltcG9ydFZhbHVlKFxuICAgICAgdGhpcy5wcm9wcy5iYXNlUGxhdGZvcm1TdGFja05hbWUsXG4gICAgICBcImRvY3VtZW50LWRiXCIsXG4gICAgICBcInNlY3JldC1hcm5cIixcbiAgICApO1xuICB9XG5cbiAgcHVibGljIGFkZEhvb2tzKCkge1xuICAgIGZpbHRlckNvbnRhaW5lcnModGhpcy5wYXJlbnRTZXJ2aWNlKVxuICAgICAgLmZpbHRlcihcbiAgICAgICAgKGV4dCkgPT4gIShleHQgaW5zdGFuY2VvZiBFeHRyYUNvbnRhaW5lckV4dGVuc2lvbikgfHwgZXh0LmRiQWNjZXNzLFxuICAgICAgKVxuICAgICAgLmZvckVhY2goKGV4dGVuc2lvbikgPT5cbiAgICAgICAgZXh0ZW5zaW9uLmFkZENvbnRhaW5lck11dGF0aW5nSG9vayhcbiAgICAgICAgICBuZXcgQWRkRG9jdW1lbnREYkhvb2soXG4gICAgICAgICAgICB0aGlzLnNjb3BlLFxuICAgICAgICAgICAgdGhpcy5zZWNyZXRBcm4sXG4gICAgICAgICAgICBgJHt0aGlzLnBhcmVudFNlcnZpY2UuaWR9LSR7ZXh0ZW5zaW9uLm5hbWV9YCxcbiAgICAgICAgICApLFxuICAgICAgICApLFxuICAgICAgKTtcbiAgfVxuXG4gIHB1YmxpYyB1c2VTZXJ2aWNlKHNlcnZpY2U6IGVjcy5FYzJTZXJ2aWNlIHwgZWNzLkZhcmdhdGVTZXJ2aWNlKTogdm9pZCB7XG4gICAgU2VjdXJpdHlHcm91cC5mcm9tTG9va3VwQnlJZChcbiAgICAgIHRoaXMuc2NvcGUsXG4gICAgICBgJHt0aGlzLnBhcmVudFNlcnZpY2UuaWR9RG9jdW1lbnREYlNlY3VyaXR5R3JvdXBgLFxuICAgICAgdGhpcy5wcm9wcy5zZWN1cml0eUdyb3VwSWQsXG4gICAgKS5jb25uZWN0aW9ucy5hbGxvd0Zyb20oc2VydmljZSwgUG9ydC50Y3AoMjcwMTcpKTtcbiAgfVxufVxuIl19
@@ -84,5 +84,5 @@ class DomainEventMessagingExtension extends ecs_service_extensions_1.ServiceExte
84
84
  }
85
85
  exports.DomainEventMessagingExtension = DomainEventMessagingExtension;
86
86
  _a = JSII_RTTI_SYMBOL_1;
87
- DomainEventMessagingExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.DomainEventMessagingExtension", version: "0.8.3" };
87
+ DomainEventMessagingExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.DomainEventMessagingExtension", version: "0.9.0" };
88
88
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DomainEventMessagingExtension.js","sourceRoot":"","sources":["../../src/extensions/DomainEventMessagingExtension.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  InjectableTopic,\n  InjecterExtension,\n  QueueExtension,\n  Service,\n  ServiceExtension,\n  TopicSubscription,\n} from \"@aws-cdk-containers/ecs-service-extensions\";\nimport { Duration } from \"aws-cdk-lib\";\nimport {\n  Ec2Service,\n  FargateService,\n  TaskDefinition,\n} from \"aws-cdk-lib/aws-ecs\";\nimport {\n  PolicyDocument,\n  PolicyStatement,\n  ServicePrincipal,\n} from \"aws-cdk-lib/aws-iam\";\nimport { ITopic } from \"aws-cdk-lib/aws-sns\";\nimport { CfnQueuePolicy, IQueue, Queue } from \"aws-cdk-lib/aws-sqs\";\nimport { Construct } from \"constructs\";\n\nexport interface EventListenerExtensionProps {\n  readonly queue?: Queue;\n}\n\nexport class DomainEventMessagingExtension extends ServiceExtension {\n  props: EventListenerExtensionProps;\n  queue: IQueue | undefined;\n  queueExtension?: QueueExtension;\n  injecterExtension?: InjecterExtension;\n  subscribeEvents: Array<ITopic> = [];\n  publishEvents: Array<ITopic> = [];\n\n  constructor(props?: EventListenerExtensionProps) {\n    super(\"event-listener-extension\");\n    this.props = props ?? {};\n  }\n\n  prehook(service: Service, scope: Construct): void {\n    if (!this.props.queue) {\n      this.queue = new Queue(scope, `${service.id}Queue`, {\n        deadLetterQueue: {\n          queue: new Queue(scope, `${service.id}DeadLetterQueue`, {\n            retentionPeriod: Duration.days(14),\n          }),\n          maxReceiveCount: 3,\n        },\n      });\n    } else {\n      this.queue = this.props.queue;\n    }\n\n    if (this.subscribeEvents.length > 0) {\n      this.queueExtension = new QueueExtension({\n        eventsQueue: this.queue,\n        subscriptions: this.subscribeEvents.map(\n          (topic) => new TopicSubscription({ topic }),\n        ),\n      });\n      this.queueExtension.prehook(service, scope);\n    }\n\n    if (this.publishEvents.length > 0) {\n      this.injecterExtension = new InjecterExtension({\n        injectables: this.publishEvents.map(\n          (topic) => new InjectableTopic({ topic }),\n        ),\n      });\n      this.injecterExtension.prehook(service, scope);\n    }\n  }\n\n  addHooks(): void {\n    this.queueExtension?.addHooks();\n    this.injecterExtension?.addHooks();\n  }\n\n  useTaskDefinition(taskDefinition: TaskDefinition): void {\n    this.queueExtension?.useTaskDefinition(taskDefinition);\n    this.injecterExtension?.useTaskDefinition(taskDefinition);\n  }\n\n  public subscribe(topic: ITopic): void {\n    this.subscribeEvents.push(topic);\n    // add the topic\n  }\n\n  public publish(topic: ITopic) {\n    this.publishEvents.push(topic);\n  }\n\n  public useService(_service: Ec2Service | FargateService): void {\n    if (!this.queue) {\n      throw new Error(\"Queue must be defined\");\n    }\n\n    // prevent issue with too many specific policy restrictions, see https://github.com/aws/aws-cdk/issues/7732\n    // undefined policy happens when there is no event topic to subscribe\n    const policyNode = this.queue.node.tryFindChild(\"Policy\");\n    if (policyNode) {\n      const queuePolicy = policyNode.node.tryFindChild(\n        \"Resource\",\n      ) as CfnQueuePolicy;\n      if (queuePolicy) {\n        queuePolicy.policyDocument = new PolicyDocument({\n          statements: [\n            new PolicyStatement({\n              actions: [\"sqs:SendMessage\"],\n              principals: [new ServicePrincipal(\"sns.amazonaws.com\")],\n              resources: [this.queue.queueArn],\n              sid: \"AllowSNSToSendToSQS\",\n            }),\n          ],\n        });\n        queuePolicy.queues = [this.queue.queueUrl];\n      }\n    }\n  }\n}\n"]}
@@ -61,5 +61,5 @@ class ExtraContainerExtension extends ecs_service_extensions_1.ServiceExtension
61
61
  }
62
62
  exports.ExtraContainerExtension = ExtraContainerExtension;
63
63
  _a = JSII_RTTI_SYMBOL_1;
64
- ExtraContainerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ExtraContainerExtension", version: "0.8.3" };
64
+ ExtraContainerExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.ExtraContainerExtension", version: "0.9.0" };
65
65
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ExtraContainerExtension.js","sourceRoot":"","sources":["../../src/extensions/ExtraContainerExtension.ts"],"names":[],"mappings":";;;;;AAAA,uFAA8E;AAC9E,iDAA2C;AAC3C,2CAA2C;AAkD3C,MAAa,uBAAwB,SAAQ,yCAAgB;IAI3D,YAAY,IAAY,EAAE,cAA4C;QACpE,KAAK,CAAC,GAAG,IAAI,4BAA4B,CAAC,CAAC;QAC3C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,KAAK,GAAG,cAAc,CAAC;IAC9B,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC;IACtC,CAAC;IAED,UAAU,CAAC,OAA4C;QACrD,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,EAAE;YACzD,OAAO,CAAC,WAAW,CAAC,SAAS,CAC3B,OAAO,EACP,cAAI,CAAC,GAAG,CAAC,WAAW,CAAC,aAAa,CAAC,CACpC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,cAAkC;QAClD,IAAI,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QAE1C,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC3C,cAAc,GAAG,IAAI,CAAC,yBAAyB,CAAC,cAAc,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;YAC5B,cAAc,GAAG;gBACf,GAAG,cAAc;gBACjB,OAAO,EAAE,IAAI,GAAG,CAAC,YAAY,CAAC;oBAC5B,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,EAAE;oBACnC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,QAAQ;iBACxC,CAAC;aACH,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,SAAS,GAAG,cAAc,CAAC,YAAY,CAC1C,IAAI,CAAC,aAAa,EAClB,cAAc,CACf,CAAC;QAEF,IAAI,CAAC,SAAS,CAAC,wBAAwB,CACrC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YAClE,SAAS,EAAE,GAAG,CAAC,GAAG,CAAC,SAAU;YAC7B,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC,CAAC,CACJ,CAAC;QAEF,MAAM,SAAS,GAAG,cAAc,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAEtD,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACvD,CAAC;QAED,8FAA8F;QAC9F,SAAS,CAAC,wBAAwB,CAAC;YACjC,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,SAAS,EAAE,IAAI,CAAC,eAAe;SAChC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,eAAe;QACjB,IAAI,IAAI,CAAC,KAAK,CAAC,oBAAoB,EAAE,CAAC;YACpC,OAAO,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC;QACzC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;YACtC,OAAO,GAAG,CAAC,4BAA4B,CAAC,KAAK,CAAC;QAChD,CAAC;QAED,OAAO,GAAG,CAAC,4BAA4B,CAAC,OAAO,CAAC;IAClD,CAAC;;AA3EH,0DA4EC","sourcesContent":["import { ServiceExtension } from \"@aws-cdk-containers/ecs-service-extensions\";\nimport { Port } from \"aws-cdk-lib/aws-ec2\";\nimport * as ecs from \"aws-cdk-lib/aws-ecs\";\nimport * as awslogs from \"aws-cdk-lib/aws-logs\";\n\n/**\n * The details of a dependency on another container in the task definition.\n *\n * @see https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_ContainerDependency.html\n */\nexport interface ContainerDependency {\n  /**\n   * The container extension to depend on.\n   */\n  readonly ext: ServiceExtension;\n\n  /**\n   * The state the container needs to be in to satisfy the dependency and proceed with startup.\n   * Valid values are ContainerDependencyCondition.START, ContainerDependencyCondition.COMPLETE,\n   * ContainerDependencyCondition.SUCCESS and ContainerDependencyCondition.HEALTHY.\n   *\n   * @default ContainerDependencyCondition.HEALTHY\n   */\n  readonly condition?: ecs.ContainerDependencyCondition;\n}\n\nexport interface ContainerProps extends ecs.ContainerDefinitionOptions {\n  /**\n   * The log group into which application container logs should be routed.\n   *\n   * @default - A log group is automatically created for you if the `ECS_SERVICE_EXTENSIONS_ENABLE_DEFAULT_LOG_DRIVER` feature flag is set.\n   */\n  readonly logGroup?: awslogs.ILogGroup;\n\n  /**\n   * Specify additional container dependencies which should be added after the\n   * container has been created in the task definition.\n   */\n  readonly containerDependencies?: ContainerDependency[];\n}\n\nexport interface ExtraContainerExtensionProps {\n  readonly container: ContainerProps;\n\n  /**\n   * Specify the condition when this container should be considered\n   * healthy such that the main container can start. Defaults to ContainerDependencyCondition.HEALTHY.\n   */\n  readonly healthCheckCondition?: ecs.ContainerDependencyCondition;\n  readonly dbAccess?: boolean;\n}\n\nexport class ExtraContainerExtension extends ServiceExtension {\n  readonly containerName: string;\n  readonly props: ExtraContainerExtensionProps;\n\n  constructor(name: string, extraContainer: ExtraContainerExtensionProps) {\n    super(`${name}-extra-container-extension`);\n    this.containerName = name;\n    this.props = extraContainer;\n  }\n\n  get dbAccess(): boolean {\n    return this.props.dbAccess ?? false;\n  }\n\n  useService(service: ecs.Ec2Service | ecs.FargateService): void {\n    this.props.container.portMappings?.forEach((portMapping) => {\n      service.connections.allowFrom(\n        service,\n        Port.tcp(portMapping.containerPort),\n      );\n    });\n  }\n\n  useTaskDefinition(taskDefinition: ecs.TaskDefinition): void {\n    let containerProps = this.props.container;\n\n    this.containerMutatingHooks.forEach((hook) => {\n      containerProps = hook.mutateContainerDefinition(containerProps);\n    });\n\n    if (!containerProps.logging) {\n      containerProps = {\n        ...containerProps,\n        logging: new ecs.AwsLogDriver({\n          streamPrefix: this.parentService.id,\n          logGroup: this.props.container.logGroup,\n        }),\n      };\n    }\n\n    this.container = taskDefinition.addContainer(\n      this.containerName,\n      containerProps,\n    );\n\n    this.container.addContainerDependencies(\n      ...(this.props.container.containerDependencies ?? []).map((dep) => ({\n        container: dep.ext.container!,\n        condition: dep.condition,\n      })),\n    );\n\n    const container = taskDefinition.findContainer(\"app\");\n\n    if (!container) {\n      throw new Error(\"You must specify a main container\");\n    }\n\n    // we want to make sure that the extra container is healthy before starting the main container\n    container.addContainerDependencies({\n      container: this.container,\n      condition: this.healthCondition,\n    });\n  }\n\n  get healthCondition() {\n    if (this.props.healthCheckCondition) {\n      return this.props.healthCheckCondition;\n    }\n\n    if (!this.props.container.healthCheck) {\n      return ecs.ContainerDependencyCondition.START;\n    }\n\n    return ecs.ContainerDependencyCondition.HEALTHY;\n  }\n}\n"]}