@btc-embedded/cdk-extensions 0.9.4 → 0.9.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 (65) hide show
  1. package/.backstage/catalog-info.yaml +23 -0
  2. package/.jsii +2332 -1370
  3. package/API.md +1070 -323
  4. package/CHANGELOG.md +7 -0
  5. package/docs/RFC003-referencing-platform-components.md +125 -0
  6. package/docs/adrs/0001-use-adrs.md +36 -0
  7. package/docs/index.md +20 -0
  8. package/lib/constructs/EventPipe.js +1 -1
  9. package/lib/constructs/S3Bucket.js +1 -1
  10. package/lib/constructs/SecureRestApi.js +7 -6
  11. package/lib/constructs/SecureRestApiV2.d.ts +6 -7
  12. package/lib/constructs/SecureRestApiV2.js +17 -25
  13. package/lib/extensions/ApiGatewayExtension.js +1 -1
  14. package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
  15. package/lib/extensions/ApplicationLoadBalancerExtensionV2.d.ts +4 -4
  16. package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +9 -15
  17. package/lib/extensions/CloudMapExtension.d.ts +0 -6
  18. package/lib/extensions/CloudMapExtension.js +5 -13
  19. package/lib/extensions/DeactivatableServiceExtension.js +1 -1
  20. package/lib/extensions/DocumentDbAccessExtension.d.ts +2 -1
  21. package/lib/extensions/DocumentDbAccessExtension.js +9 -13
  22. package/lib/extensions/DomainEventMessagingExtension.js +1 -1
  23. package/lib/extensions/ExtraContainerExtension.js +1 -1
  24. package/lib/extensions/HTTPApiExtension.js +15 -24
  25. package/lib/extensions/LogExtension.js +1 -1
  26. package/lib/extensions/ModifyContainerDefinitionExtension.js +1 -1
  27. package/lib/extensions/ModifyTaskDefinitionExtension.js +1 -1
  28. package/lib/extensions/OpenTelemetryExtension.js +1 -1
  29. package/lib/extensions/PostgresDbAccessExtension.js +1 -1
  30. package/lib/extensions/SharedVolumeExtension.js +1 -1
  31. package/lib/extensions/TcpKeepAliveExtension.js +1 -1
  32. package/lib/platform/ApiGateway.js +1 -1
  33. package/lib/platform/ApiGatewayV2.d.ts +16 -6
  34. package/lib/platform/ApiGatewayV2.js +34 -18
  35. package/lib/platform/ApplicationLoadBalancer.js +1 -1
  36. package/lib/platform/ApplicationLoadBalancerV2.d.ts +21 -8
  37. package/lib/platform/ApplicationLoadBalancerV2.js +47 -33
  38. package/lib/platform/CognitoUserPool.d.ts +52 -5
  39. package/lib/platform/CognitoUserPool.js +98 -15
  40. package/lib/platform/DefaultUserPoolClients.d.ts +1 -1
  41. package/lib/platform/DefaultUserPoolClients.js +3 -3
  42. package/lib/platform/DocumentDB.d.ts +15 -1
  43. package/lib/platform/DocumentDB.js +36 -17
  44. package/lib/platform/PrivateDnsNamespace.d.ts +10 -3
  45. package/lib/platform/PrivateDnsNamespace.js +33 -18
  46. package/lib/platform/ResourceServer.js +1 -1
  47. package/lib/platform/Vpc.d.ts +17 -3
  48. package/lib/platform/Vpc.js +32 -13
  49. package/lib/platform/index.d.ts +0 -2
  50. package/lib/platform/index.js +1 -3
  51. package/lib/utils/ImportValue.d.ts +10 -3
  52. package/lib/utils/ImportValue.js +12 -15
  53. package/lib/utils/StackParameter.d.ts +35 -0
  54. package/lib/utils/StackParameter.js +65 -0
  55. package/lib/utils/functions.js +3 -3
  56. package/lib/utils/index.d.ts +1 -0
  57. package/lib/utils/index.js +2 -1
  58. package/mkdocs.yml +8 -0
  59. package/package.json +1 -1
  60. package/lib/platform/ApiUserPoolClient.d.ts +0 -32
  61. package/lib/platform/ApiUserPoolClient.js +0 -47
  62. package/lib/platform/ApplicationUserPoolClient.d.ts +0 -51
  63. package/lib/platform/ApplicationUserPoolClient.js +0 -66
  64. /package/{rfcs/001-api-gateway.md → docs/RFC001-api-gateway.md} +0 -0
  65. /package/{rfcs/002-developer-stacks.md → docs/RFC002-developer-stacks.md} +0 -0
@@ -84,5 +84,5 @@ class PostgresDbAccessExtension extends ecs_service_extensions_1.ServiceExtensio
84
84
  }
85
85
  exports.PostgresDbAccessExtension = PostgresDbAccessExtension;
86
86
  _a = JSII_RTTI_SYMBOL_1;
87
- PostgresDbAccessExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.PostgresDbAccessExtension", version: "0.9.4" };
87
+ PostgresDbAccessExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.PostgresDbAccessExtension", version: "0.9.5" };
88
88
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PostgresDbAccessExtension.js","sourceRoot":"","sources":["../../src/extensions/PostgresDbAccessExtension.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ContainerMutatingHook,\n  Service,\n  ServiceExtension,\n} from \"@aws-cdk-containers/ecs-service-extensions\";\nimport { SecretValue } from \"aws-cdk-lib\";\nimport { Port, SecurityGroup } from \"aws-cdk-lib/aws-ec2\";\nimport * as ecs from \"aws-cdk-lib/aws-ecs\";\nimport { ISecret, Secret } from \"aws-cdk-lib/aws-secretsmanager\";\nimport { Construct } from \"constructs\";\nimport { filterContainers, importValue } from \"../utils\";\nimport { ExtraContainerExtension } from \"./ExtraContainerExtension\";\n\nexport interface EnvironmentVariableNames {\n  /**\n   * Environment variable for the connction string.\n   *\n   * @default DATABASE_URL\n   */\n  readonly databaseUrl?: string;\n\n  /**\n   * Environment variable for the Postgres endpoint.\n   *\n   * @default POSTGRES_ENDPOINT\n   */\n  readonly postgresEndpoint?: string;\n\n  /**\n   * Environment variable for the Postgres database name.\n   *\n   * @default POSTGRES_DATABASE\n   */\n  readonly postgresDatabase?: string;\n\n  /**\n   * Environment variable for the Postgres username.\n   *\n   * @default POSTGRES_USERNAME\n   */\n  readonly postgresUsername?: string;\n\n  /**\n   * Environment variable for the Postgres password.\n   *\n   * @default POSTGRES_PASSWORD\n   */\n  readonly postgresPassword?: string;\n}\n\nexport interface PostgresDbAccessExtensionProps {\n  /**\n   * The name of the base platform stack. This name is used to look up output\n   * parameters.\n   */\n  readonly basePlatformStackName: string;\n\n  /**\n   * Security group ID of the Postgres DB cluster.\n   */\n  readonly securityGroupId: string;\n\n  /**\n   * The name of the database.\n   */\n  readonly dbName: string;\n\n  /**\n   * Additional connection properties to be added to the database connection\n   * string as query parameters.\n   *\n   * @default - adds \"schema=public\" to the connection string\n   */\n  readonly dbConnectionProperties?: Record<string, string>;\n\n  /**\n   * Adjust the environment variables.\n   *\n   * @default - uses the default environment variable names\n   */\n  readonly environmentVariableNames?: EnvironmentVariableNames;\n}\n\nclass AddPostgresDbHook extends ContainerMutatingHook {\n  readonly envVarNames: Required<EnvironmentVariableNames>;\n\n  constructor(\n    private connectionStringSecret: ISecret,\n    private credentialsSecret: ISecret,\n    private endpoint: string,\n    private dbName: string,\n    environmentVariableNames: EnvironmentVariableNames = {},\n  ) {\n    super();\n\n    this.envVarNames = {\n      databaseUrl: \"DATABASE_URL\",\n      postgresEndpoint: \"POSTGRES_ENDPOINT\",\n      postgresDatabase: \"POSTGRES_DATABASE\",\n      postgresUsername: \"POSTGRES_USERNAME\",\n      postgresPassword: \"POSTGRES_PASSWORD\",\n      ...environmentVariableNames,\n    };\n  }\n\n  mutateContainerDefinition(\n    props: ecs.ContainerDefinitionOptions,\n  ): ecs.ContainerDefinitionOptions {\n    const credentials = this.extractCredentials(this.credentialsSecret);\n\n    return {\n      ...props,\n      secrets: {\n        ...props.secrets,\n        [this.envVarNames.databaseUrl]: ecs.Secret.fromSecretsManager(\n          this.connectionStringSecret,\n        ),\n        ...credentials,\n      },\n      environment: {\n        ...props.environment,\n        [this.envVarNames.postgresEndpoint]: this.endpoint,\n        [this.envVarNames.postgresDatabase]: this.dbName,\n      },\n    };\n  }\n\n  private extractCredentials(secret: ISecret) {\n    return {\n      [this.envVarNames.postgresUsername]: ecs.Secret.fromSecretsManager(\n        secret,\n        \"username\",\n      ),\n      [this.envVarNames.postgresPassword]: ecs.Secret.fromSecretsManager(\n        secret,\n        \"password\",\n      ),\n    };\n  }\n}\n\nexport class PostgresDbAccessExtension extends ServiceExtension {\n  readonly props: PostgresDbAccessExtensionProps;\n\n  connectionString!: ISecret;\n  credentialsSecret!: ISecret;\n  endpoint!: string;\n\n  constructor(props: PostgresDbAccessExtensionProps) {\n    super(\"postgresdb-access-extension\");\n    this.props = props;\n  }\n\n  prehook(parent: Service, scope: Construct): void {\n    this.parentService = parent;\n    this.scope = scope;\n\n    const credentialsSecretArn = importValue(\n      this.props.basePlatformStackName,\n      \"aurora-postgres-db\",\n      \"credentials-secret-arn\",\n    );\n\n    this.endpoint = importValue(\n      this.props.basePlatformStackName,\n      \"aurora-postgres-db\",\n      \"cluster-endpoint\",\n    );\n\n    this.credentialsSecret = Secret.fromSecretCompleteArn(\n      this.scope,\n      `${parent.id}CredentialsSecret`,\n      credentialsSecretArn,\n    );\n\n    const secretArn = importValue(\n      this.props.basePlatformStackName,\n      \"aurora-postgres-db\",\n      \"secret-arn\",\n    );\n\n    const properties = this.props.dbConnectionProperties ?? {\n      schema: \"public\",\n    };\n\n    const queryParameters = Object.entries(properties)\n      .map(([key, value]) => `${key}=${value}`)\n      .join(\"&\");\n\n    const urlSecret = Secret.fromSecretCompleteArn(\n      this.scope,\n      `${parent.id}DbSecret`,\n      secretArn,\n    );\n\n    this.connectionString = new Secret(\n      scope,\n      `${parent.id}DBConnectionStringSecret`,\n      {\n        description: `PostgresDb Connection String for service ${parent.id} to access database ${this.props.dbName}`,\n        secretStringValue: new SecretValue(\n          `${urlSecret.secretValue}${this.props.dbName}?${queryParameters ?? \"\"}`,\n        ),\n      },\n    );\n  }\n\n  public addHooks() {\n    filterContainers(this.parentService)\n      .filter(\n        (ext) => !(ext instanceof ExtraContainerExtension) || ext.dbAccess,\n      )\n      .forEach((extension) =>\n        extension.addContainerMutatingHook(\n          new AddPostgresDbHook(\n            this.connectionString,\n            this.credentialsSecret,\n            this.endpoint,\n            this.props.dbName,\n            this.props.environmentVariableNames,\n          ),\n        ),\n      );\n  }\n\n  public useService(service: ecs.Ec2Service | ecs.FargateService): void {\n    SecurityGroup.fromLookupById(\n      this.scope,\n      `${this.parentService.id}PostgresDbSecurityGroup`,\n      this.props.securityGroupId,\n    ).connections.allowFrom(service, Port.tcp(5432));\n  }\n}\n"]}
@@ -32,5 +32,5 @@ class SharedVolumeExtension extends ecs_service_extensions_1.ServiceExtension {
32
32
  }
33
33
  exports.SharedVolumeExtension = SharedVolumeExtension;
34
34
  _a = JSII_RTTI_SYMBOL_1;
35
- SharedVolumeExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.SharedVolumeExtension", version: "0.9.4" };
35
+ SharedVolumeExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.SharedVolumeExtension", version: "0.9.5" };
36
36
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2hhcmVkVm9sdW1lRXh0ZW5zaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4dGVuc2lvbnMvU2hhcmVkVm9sdW1lRXh0ZW5zaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdUZBQThFO0FBRTlFLG9DQUE0QztBQXNCNUM7OztHQUdHO0FBQ0gsTUFBYSxxQkFBc0IsU0FBUSx5Q0FBZ0I7SUFLekQsWUFBWSxVQUFrQixFQUFFLEtBQWlDO1FBQy9ELEtBQUssQ0FBQyxHQUFHLFVBQVUsZ0JBQWdCLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztJQUMvQixDQUFDO0lBRUQsaUJBQWlCLENBQUMsY0FBa0M7UUFDbEQsY0FBYyxDQUFDLFNBQVMsQ0FBQztZQUN2QixJQUFJLEVBQUUsSUFBSSxDQUFDLFVBQVU7U0FDdEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFVBQVUsQ0FBQyxRQUE2QztRQUN0RCxJQUFBLHdCQUFnQixFQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUNuRCxHQUFHLENBQUMsU0FBUyxDQUFDLGNBQWMsQ0FBQztnQkFDM0IsWUFBWSxFQUFFLElBQUksQ0FBQyxVQUFVO2dCQUM3QixhQUFhLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJO2dCQUM5QixRQUFRLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLElBQUksS0FBSzthQUN2QyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBekJILHNEQTBCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlcnZpY2VFeHRlbnNpb24gfSBmcm9tIFwiQGF3cy1jZGstY29udGFpbmVycy9lY3Mtc2VydmljZS1leHRlbnNpb25zXCI7XG5pbXBvcnQgKiBhcyBlY3MgZnJvbSBcImF3cy1jZGstbGliL2F3cy1lY3NcIjtcbmltcG9ydCB7IGZpbHRlckNvbnRhaW5lcnMgfSBmcm9tIFwiLi4vdXRpbHNcIjtcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhbiBlcGhlcm1hbCBzaGFyZWQgdm9sdW1lLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNoYXJlZFZvbHVtZUV4dGVuc2lvblByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBwYXRoIGluc2lkZSB0aGUgY29udGFpbmVyIHRvIG1vdW50IHRoZSB2b2x1bWUuXG4gICAqL1xuICByZWFkb25seSBwYXRoOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdGhlIHZvbHVtZSBzaG91bGQgYmUgcmVhZC1vbmx5LiBEZWZhdWx0OiBmYWxzZS5cbiAgICovXG4gIHJlYWRvbmx5IHJlYWRvbmx5PzogYm9vbGVhbjtcblxuICAvKipcbiAgICogU2NvcGUgb2YgdGhlIHZvbHVtZS4gRGVmYXVsdDogU0hBUkVELlxuICAgKi9cbiAgcmVhZG9ubHkgc2NvcGU/OiBlY3MuU2NvcGU7XG59XG5cbi8qKlxuICogQ3JlYXRlIGEgc2hhcmVkIHZvbHVtZSBhbmQgYXR0YWNoIGl0IHRvIGFsbCBjb250YWluZXJzIGluIHRoaXMgdGFza1xuICogZGVmaW5pdGlvbi5cbiAqL1xuZXhwb3J0IGNsYXNzIFNoYXJlZFZvbHVtZUV4dGVuc2lvbiBleHRlbmRzIFNlcnZpY2VFeHRlbnNpb24ge1xuICByZWFkb25seSBwcm9wczogU2hhcmVkVm9sdW1lRXh0ZW5zaW9uUHJvcHM7XG5cbiAgcmVhZG9ubHkgdm9sdW1lTmFtZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHZvbHVtZU5hbWU6IHN0cmluZywgcHJvcHM6IFNoYXJlZFZvbHVtZUV4dGVuc2lvblByb3BzKSB7XG4gICAgc3VwZXIoYCR7dm9sdW1lTmFtZX0tc2hhcmVkLXZvbHVtZWApO1xuICAgIHRoaXMucHJvcHMgPSBwcm9wcztcbiAgICB0aGlzLnZvbHVtZU5hbWUgPSB2b2x1bWVOYW1lO1xuICB9XG5cbiAgdXNlVGFza0RlZmluaXRpb24odGFza0RlZmluaXRpb246IGVjcy5UYXNrRGVmaW5pdGlvbik6IHZvaWQge1xuICAgIHRhc2tEZWZpbml0aW9uLmFkZFZvbHVtZSh7XG4gICAgICBuYW1lOiB0aGlzLnZvbHVtZU5hbWUsXG4gICAgfSk7XG4gIH1cblxuICB1c2VTZXJ2aWNlKF9zZXJ2aWNlOiBlY3MuRWMyU2VydmljZSB8IGVjcy5GYXJnYXRlU2VydmljZSk6IHZvaWQge1xuICAgIGZpbHRlckNvbnRhaW5lcnModGhpcy5wYXJlbnRTZXJ2aWNlKS5mb3JFYWNoKChleHQpID0+IHtcbiAgICAgIGV4dC5jb250YWluZXIuYWRkTW91bnRQb2ludHMoe1xuICAgICAgICBzb3VyY2VWb2x1bWU6IHRoaXMudm9sdW1lTmFtZSxcbiAgICAgICAgY29udGFpbmVyUGF0aDogdGhpcy5wcm9wcy5wYXRoLFxuICAgICAgICByZWFkT25seTogdGhpcy5wcm9wcy5yZWFkb25seSB8fCBmYWxzZSxcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -53,5 +53,5 @@ class TcpKeepAliveExtension extends ecs_service_extensions_1.ServiceExtension {
53
53
  }
54
54
  exports.TcpKeepAliveExtension = TcpKeepAliveExtension;
55
55
  _a = JSII_RTTI_SYMBOL_1;
56
- TcpKeepAliveExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.TcpKeepAliveExtension", version: "0.9.4" };
56
+ TcpKeepAliveExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.TcpKeepAliveExtension", version: "0.9.5" };
57
57
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGNwS2VlcEFsaXZlRXh0ZW5zaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4dGVuc2lvbnMvVGNwS2VlcEFsaXZlRXh0ZW5zaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdUZBR29EO0FBRXBELG9DQUE0QztBQVE1QyxNQUFNLHFCQUFzQixTQUFRLDhDQUFxQjtJQUN2RCxZQUFvQixLQUFpQztRQUNuRCxLQUFLLEVBQUUsQ0FBQztRQURVLFVBQUssR0FBTCxLQUFLLENBQTRCO0lBRXJELENBQUM7SUFFRCx5QkFBeUIsQ0FDdkIsS0FBcUM7UUFFckMsT0FBTztZQUNMLEdBQUcsS0FBSztZQUNSLGNBQWMsRUFBRTtnQkFDZDtvQkFDRSxTQUFTLEVBQUUsNkJBQTZCO29CQUN4QyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO2lCQUNsQztnQkFDRDtvQkFDRSxTQUFTLEVBQUUsOEJBQThCO29CQUN6QyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFO2lCQUN0QztnQkFDRDtvQkFDRSxTQUFTLEVBQUUsK0JBQStCO29CQUMxQyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFO2lCQUNwQzthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQUVELE1BQWEscUJBQXNCLFNBQVEseUNBQWdCO0lBR3pELFlBQVksS0FBa0M7UUFDNUMsS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFFakMsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ3JCLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLEtBQUssR0FBRztnQkFDWCxJQUFJLEVBQUUsR0FBRztnQkFDVCxRQUFRLEVBQUUsR0FBRztnQkFDYixNQUFNLEVBQUUsQ0FBQzthQUNWLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQztJQUVNLFFBQVE7UUFDYix3R0FBd0c7UUFDeEcsSUFBQSx3QkFBZ0IsRUFBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDbkQsR0FBRyxDQUFDLHdCQUF3QixDQUFDLElBQUkscUJBQXFCLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDdEUsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOztBQXRCSCxzREF1QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb250YWluZXJNdXRhdGluZ0hvb2ssXG4gIFNlcnZpY2VFeHRlbnNpb24sXG59IGZyb20gXCJAYXdzLWNkay1jb250YWluZXJzL2Vjcy1zZXJ2aWNlLWV4dGVuc2lvbnNcIjtcbmltcG9ydCAqIGFzIGVjcyBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWVjc1wiO1xuaW1wb3J0IHsgZmlsdGVyQ29udGFpbmVycyB9IGZyb20gXCIuLi91dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRjcEtlZXBBbGl2ZUV4dGVuc2lvblByb3BzIHtcbiAgcmVhZG9ubHkgdGltZTogbnVtYmVyO1xuICByZWFkb25seSBpbnRlcnZhbDogbnVtYmVyO1xuICByZWFkb25seSBwcm9iZXM6IG51bWJlcjtcbn1cblxuY2xhc3MgQWRkU3lzdGVtQ29udHJvbHNIb29rIGV4dGVuZHMgQ29udGFpbmVyTXV0YXRpbmdIb29rIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBwcm9wczogVGNwS2VlcEFsaXZlRXh0ZW5zaW9uUHJvcHMpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgbXV0YXRlQ29udGFpbmVyRGVmaW5pdGlvbihcbiAgICBwcm9wczogZWNzLkNvbnRhaW5lckRlZmluaXRpb25PcHRpb25zLFxuICApOiBlY3MuQ29udGFpbmVyRGVmaW5pdGlvbk9wdGlvbnMge1xuICAgIHJldHVybiB7XG4gICAgICAuLi5wcm9wcyxcbiAgICAgIHN5c3RlbUNvbnRyb2xzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lc3BhY2U6IFwibmV0LmlwdjQudGNwX2tlZXBhbGl2ZV90aW1lXCIsXG4gICAgICAgICAgdmFsdWU6IHRoaXMucHJvcHMudGltZS50b1N0cmluZygpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgbmFtZXNwYWNlOiBcIm5ldC5pcHY0LnRjcF9rZWVwYWxpdmVfaW50dmxcIixcbiAgICAgICAgICB2YWx1ZTogdGhpcy5wcm9wcy5pbnRlcnZhbC50b1N0cmluZygpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgbmFtZXNwYWNlOiBcIm5ldC5pcHY0LnRjcF9rZWVwYWxpdmVfcHJvYmVzXCIsXG4gICAgICAgICAgdmFsdWU6IHRoaXMucHJvcHMucHJvYmVzLnRvU3RyaW5nKCksXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH07XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFRjcEtlZXBBbGl2ZUV4dGVuc2lvbiBleHRlbmRzIFNlcnZpY2VFeHRlbnNpb24ge1xuICByZWFkb25seSBwcm9wczogVGNwS2VlcEFsaXZlRXh0ZW5zaW9uUHJvcHM7XG5cbiAgY29uc3RydWN0b3IocHJvcHM/OiBUY3BLZWVwQWxpdmVFeHRlbnNpb25Qcm9wcykge1xuICAgIHN1cGVyKFwidGNwLWtlZXBhbGl2ZS1leHRlbnNpb25cIik7XG5cbiAgICBpZiAocHJvcHMpIHtcbiAgICAgIHRoaXMucHJvcHMgPSBwcm9wcztcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5wcm9wcyA9IHtcbiAgICAgICAgdGltZTogMjAwLFxuICAgICAgICBpbnRlcnZhbDogMjAwLFxuICAgICAgICBwcm9iZXM6IDUsXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBhZGRIb29rcygpIHtcbiAgICAvLyBhZGQgdGhpcyBob29rIHRvIHRoZSBtYWluIHNlcnZpY2UgY29udGFpbmVyIGFuZCBhbGwgY29udGFpbmVycyBhZGRlZCBieSBvdXIgZXh0cmEgY29udGFpbmVyIGV4dGVuc2lvblxuICAgIGZpbHRlckNvbnRhaW5lcnModGhpcy5wYXJlbnRTZXJ2aWNlKS5mb3JFYWNoKChleHQpID0+IHtcbiAgICAgIGV4dC5hZGRDb250YWluZXJNdXRhdGluZ0hvb2sobmV3IEFkZFN5c3RlbUNvbnRyb2xzSG9vayh0aGlzLnByb3BzKSk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -110,5 +110,5 @@ class ApiGateway extends constructs_1.Construct {
110
110
  }
111
111
  exports.ApiGateway = ApiGateway;
112
112
  _a = JSII_RTTI_SYMBOL_1;
113
- ApiGateway[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGateway", version: "0.9.4" };
113
+ ApiGateway[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGateway", version: "0.9.5" };
114
114
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApiGateway.js","sourceRoot":"","sources":["../../src/platform/ApiGateway.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CfnStage,\n  DomainName,\n  HttpApi,\n  IVpcLink,\n  VpcLink,\n} from \"aws-cdk-lib/aws-apigatewayv2\";\nimport { HttpUserPoolAuthorizer } from \"aws-cdk-lib/aws-apigatewayv2-authorizers\";\nimport {\n  Certificate,\n  CertificateValidation,\n} from \"aws-cdk-lib/aws-certificatemanager\";\nimport { IUserPool, IUserPoolClient } from \"aws-cdk-lib/aws-cognito\";\nimport { ISecurityGroup, IVpc, SecurityGroup } from \"aws-cdk-lib/aws-ec2\";\nimport { ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { LogGroup } from \"aws-cdk-lib/aws-logs\";\nimport { ARecord, IHostedZone, RecordTarget } from \"aws-cdk-lib/aws-route53\";\nimport { ApiGatewayv2DomainProperties } from \"aws-cdk-lib/aws-route53-targets\";\nimport { Construct } from \"constructs\";\nimport { createExporter } from \"../utils\";\n\nexport interface ApiGatewayProps {\n  /**\n   * The name of the stack, used for prefixing the output parameter names.\n   */\n  readonly stackName: string;\n\n  /**\n   * VPC where the API GW Security group and VPC Link will be created.\n   */\n  readonly vpc: IVpc;\n\n  /**\n   * Specify the Cognito User Pool to be used for authorizing requests on the API Gateway.\n   */\n  readonly userPool: IUserPool;\n\n  /**\n   * List of User Pool Clients that are allowed to access the API Gateway.\n   */\n  readonly userPoolClients: Array<IUserPoolClient>;\n\n  /**\n   * Domain prefix for the API Gateway endpoint.\n   */\n  readonly domainPrefix: string;\n\n  /**\n   * Hosted Zone to create the gateway domain A record.\n   */\n  readonly hostedZone: IHostedZone;\n\n  /**\n   * Enable access logs for the API Gateway.\n   *\n   * default: true\n   */\n  readonly enableAccessLogs?: boolean;\n}\n\n/**\n * API Gateway construct to be used in base platforms.\n *\n * This API Gateway construct sets up an API Gateway V2 and a default HTTP API\n * protected by the provided Cognito user pool and client(s). The construct\n * registers an A record for the subdomain in the provided hosted zone. It also\n * creates a VPC Link (and security group) for the API Gateway to connect to\n * services in the VPC.\n *\n * The relevant parameters are exposed as CloudFormation outputs so that they\n * can be used by the CDK extensions provided in this library.\n * @deprecated Use the {@link ApiGatewayV2} construct instead.\n */\nexport class ApiGateway extends Construct {\n  private securityGroup: ISecurityGroup;\n  private vpcLink: IVpcLink;\n  private httpApi: HttpApi;\n\n  private readonly OUTPUT_PARAMETER_PREFIX = \"api-gateway\";\n\n  constructor(scope: Construct, id: string, props: ApiGatewayProps) {\n    super(scope, id);\n\n    this.securityGroup = new SecurityGroup(this, \"VpcLinkSecurityGroup\", {\n      vpc: props.vpc,\n      allowAllOutbound: false,\n    });\n\n    this.vpcLink = new VpcLink(this, \"HttpVpcLink\", {\n      vpc: props.vpc,\n      vpcLinkName: \"APIGW V2 VPC Link\",\n      securityGroups: [this.securityGroup],\n    });\n\n    const domainName = `${props.domainPrefix}.${props.hostedZone.zoneName}`;\n\n    const certificate = new Certificate(this, \"Certificate\", {\n      domainName: domainName,\n      validation: CertificateValidation.fromDns(props.hostedZone),\n    });\n\n    const domain = new DomainName(this, \"DomainName\", {\n      domainName: domainName,\n      certificate: certificate,\n    });\n\n    new ARecord(this, \"APIGWARecord\", {\n      zone: props.hostedZone,\n      recordName: props.domainPrefix,\n      target: RecordTarget.fromAlias(\n        new ApiGatewayv2DomainProperties(\n          domain.regionalDomainName,\n          domain.regionalHostedZoneId,\n        ),\n      ),\n    });\n\n    const defaultAuthorizer = new HttpUserPoolAuthorizer(\n      \"CognitoAuthorizer\",\n      props.userPool,\n      {\n        userPoolClients: props.userPoolClients,\n      },\n    );\n\n    this.httpApi = new HttpApi(this, \"HttpApi\", {\n      apiName: `${props.stackName}HttpApi`,\n      description: \"Default HTTP API\",\n      defaultAuthorizer: defaultAuthorizer,\n      defaultDomainMapping: {\n        domainName: domain,\n      },\n    });\n\n    if (props.enableAccessLogs ?? true) {\n      this.enableAccessLogs(this.httpApi);\n    }\n\n    this.exposeParameters();\n  }\n\n  private exposeParameters() {\n    const exportValue = createExporter(this, this.OUTPUT_PARAMETER_PREFIX);\n\n    exportValue({\n      name: \"APIGateway Id\",\n      key: \"id\",\n      value: this.httpApi.apiId,\n    });\n\n    exportValue({\n      name: \"APIGateway VPCLink Id\",\n      key: \"vpc-link-id\",\n      value: this.vpcLink.vpcLinkId,\n    });\n\n    exportValue({\n      name: \"APIGateway Security Group Id\",\n      key: \"security-group-id\",\n      value: this.securityGroup.securityGroupId,\n    });\n  }\n\n  private enableAccessLogs(apiEndpoint: HttpApi) {\n    const stage = apiEndpoint.defaultStage!.node.defaultChild as CfnStage;\n    const logGroup = new LogGroup(apiEndpoint, \"APIGWAccessLogs\", {\n      retention: 90,\n    });\n\n    stage.accessLogSettings = {\n      destinationArn: logGroup.logGroupArn,\n      format: JSON.stringify({\n        requestId: \"$context.requestId\",\n        userAgent: \"$context.identity.userAgent\",\n        sourceIp: \"$context.identity.sourceIp\",\n        requestTime: \"$context.requestTime\",\n        httpMethod: \"$context.httpMethod\",\n        path: \"$context.path\",\n        status: \"$context.status\",\n        responseLength: \"$context.responseLength\",\n      }),\n    };\n\n    logGroup.grantWrite(new ServicePrincipal(\"apigateway.amazonaws.com\"));\n  }\n}\n"]}
@@ -1,4 +1,5 @@
1
- import { IVpc } from "aws-cdk-lib/aws-ec2";
1
+ import { IVpcLink } from "aws-cdk-lib/aws-apigatewayv2";
2
+ import { ISecurityGroup, IVpc } from "aws-cdk-lib/aws-ec2";
2
3
  import { Construct } from "constructs";
3
4
  export interface ApiGatewayPropsV2 {
4
5
  /**
@@ -6,6 +7,14 @@ export interface ApiGatewayPropsV2 {
6
7
  */
7
8
  readonly vpc: IVpc;
8
9
  }
10
+ export interface IApiGatewayV2 {
11
+ readonly vpcLink: IVpcLink;
12
+ readonly securityGroup: ISecurityGroup;
13
+ }
14
+ export interface ApiGatewayV2LookupOptions {
15
+ readonly basePlatform: string;
16
+ readonly vpc: IVpc;
17
+ }
9
18
  /**
10
19
  * Constructs an API Gateway V2 resource for use in base platforms.
11
20
  *
@@ -19,10 +28,11 @@ export interface ApiGatewayPropsV2 {
19
28
  *
20
29
  * These outputs can be utilized by other CDK extensions provided in this library.
21
30
  */
22
- export declare class ApiGatewayV2 extends Construct {
23
- private securityGroup;
24
- private vpcLink;
25
- private readonly OUTPUT_PARAMETER_PREFIX;
31
+ export declare class ApiGatewayV2 extends Construct implements IApiGatewayV2 {
32
+ static fromBasePlatform(scope: Construct, id: string, options: ApiGatewayV2LookupOptions): IApiGatewayV2;
33
+ private static readonly vpcLinkParameter;
34
+ private static readonly securityGroupIdParameter;
35
+ readonly securityGroup: ISecurityGroup;
36
+ readonly vpcLink: IVpcLink;
26
37
  constructor(scope: Construct, id: string, props: ApiGatewayPropsV2);
27
- private exposeParameters;
28
38
  }
@@ -21,35 +21,51 @@ const utils_1 = require("../utils");
21
21
  * These outputs can be utilized by other CDK extensions provided in this library.
22
22
  */
23
23
  class ApiGatewayV2 extends constructs_1.Construct {
24
+ static fromBasePlatform(scope, id, options) {
25
+ const { vpc, basePlatform } = options;
26
+ const vpcLink = aws_apigatewayv2_1.VpcLink.fromVpcLinkAttributes(scope, "VPCLink", {
27
+ vpc,
28
+ vpcLinkId: ApiGatewayV2.vpcLinkParameter.import(basePlatform),
29
+ });
30
+ const securityGroup = aws_ec2_1.SecurityGroup.fromSecurityGroupId(scope, "SecurityGroup", ApiGatewayV2.securityGroupIdParameter.import(basePlatform), { allowAllOutbound: false });
31
+ class Import extends constructs_1.Construct {
32
+ constructor() {
33
+ super(...arguments);
34
+ this.securityGroup = securityGroup;
35
+ this.vpcLink = vpcLink;
36
+ }
37
+ }
38
+ return new Import(scope, id);
39
+ }
24
40
  constructor(scope, id, props) {
25
41
  super(scope, id);
26
- this.OUTPUT_PARAMETER_PREFIX = "api-gateway-v2";
27
42
  this.securityGroup = new aws_ec2_1.SecurityGroup(this, "VpcLinkSecurityGroup", {
28
43
  vpc: props.vpc,
29
44
  allowAllOutbound: false,
30
45
  });
31
- this.vpcLink = new aws_apigatewayv2_1.VpcLink(this, "HttpVpcLink", {
46
+ this.vpcLink = new aws_apigatewayv2_1.VpcLink(this, "VpcLink", {
32
47
  vpc: props.vpc,
33
48
  vpcLinkName: "APIGW V2 VPC Link",
34
49
  securityGroups: [this.securityGroup],
35
50
  });
36
- this.exposeParameters();
37
- }
38
- exposeParameters() {
39
- const exportValue = (0, utils_1.createExporter)(this, this.OUTPUT_PARAMETER_PREFIX);
40
- exportValue({
41
- name: "APIGateway VPCLink Id",
42
- key: "vpc-link-id",
43
- value: this.vpcLink.vpcLinkId,
44
- });
45
- exportValue({
46
- name: "APIGateway Security Group Id",
47
- key: "security-group-id",
48
- value: this.securityGroup.securityGroupId,
49
- });
51
+ ApiGatewayV2.vpcLinkParameter.export(this, this.vpcLink.vpcLinkId);
52
+ // NOTE: Security group ID cannot be imported. We export it here to make it easier to access it manually
53
+ ApiGatewayV2.securityGroupIdParameter.export(this, this.securityGroup.securityGroupId);
50
54
  }
51
55
  }
52
56
  exports.ApiGatewayV2 = ApiGatewayV2;
53
57
  _a = JSII_RTTI_SYMBOL_1;
54
- ApiGatewayV2[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayV2", version: "0.9.4" };
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBpR2F0ZXdheVYyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BsYXRmb3JtL0FwaUdhdGV3YXlWMi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1FQUFpRTtBQUNqRSxpREFBMEU7QUFDMUUsMkNBQXVDO0FBQ3ZDLG9DQUEwQztBQVMxQzs7Ozs7Ozs7Ozs7O0dBWUc7QUFDSCxNQUFhLFlBQWEsU0FBUSxzQkFBUztJQU16QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXdCO1FBQ2hFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFIRiw0QkFBdUIsR0FBRyxnQkFBZ0IsQ0FBQztRQUsxRCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksdUJBQWEsQ0FBQyxJQUFJLEVBQUUsc0JBQXNCLEVBQUU7WUFDbkUsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO1lBQ2QsZ0JBQWdCLEVBQUUsS0FBSztTQUN4QixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksMEJBQU8sQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQzlDLEdBQUcsRUFBRSxLQUFLLENBQUMsR0FBRztZQUNkLFdBQVcsRUFBRSxtQkFBbUI7WUFDaEMsY0FBYyxFQUFFLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQztTQUNyQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRU8sZ0JBQWdCO1FBQ3RCLE1BQU0sV0FBVyxHQUFHLElBQUEsc0JBQWMsRUFBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFFdkUsV0FBVyxDQUFDO1lBQ1YsSUFBSSxFQUFFLHVCQUF1QjtZQUM3QixHQUFHLEVBQUUsYUFBYTtZQUNsQixLQUFLLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTO1NBQzlCLENBQUMsQ0FBQztRQUVILFdBQVcsQ0FBQztZQUNWLElBQUksRUFBRSw4QkFBOEI7WUFDcEMsR0FBRyxFQUFFLG1CQUFtQjtZQUN4QixLQUFLLEVBQUUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxlQUFlO1NBQzFDLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBckNILG9DQXNDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElWcGNMaW5rLCBWcGNMaW5rIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1hcGlnYXRld2F5djJcIjtcbmltcG9ydCB7IElTZWN1cml0eUdyb3VwLCBJVnBjLCBTZWN1cml0eUdyb3VwIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1lYzJcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgeyBjcmVhdGVFeHBvcnRlciB9IGZyb20gXCIuLi91dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFwaUdhdGV3YXlQcm9wc1YyIHtcbiAgLyoqXG4gICAqIFZQQyB3aGVyZSB0aGUgQVBJIEdXIFNlY3VyaXR5IGdyb3VwIGFuZCBWUEMgTGluayB3aWxsIGJlIGNyZWF0ZWQuXG4gICAqL1xuICByZWFkb25seSB2cGM6IElWcGM7XG59XG5cbi8qKlxuICogQ29uc3RydWN0cyBhbiBBUEkgR2F0ZXdheSBWMiByZXNvdXJjZSBmb3IgdXNlIGluIGJhc2UgcGxhdGZvcm1zLlxuICpcbiAqIFRoaXMgY29uc3RydWN0IGNyZWF0ZXM6XG4gKiAtIEEgVlBDIExpbmsgZm9yIHRoZSBBUEkgR2F0ZXdheSB0byBjb25uZWN0IHRvIHNlcnZpY2VzIHdpdGhpbiB0aGUgc3BlY2lmaWVkIFZQQy5cbiAqIC0gQSBTZWN1cml0eSBHcm91cCBhc3NvY2lhdGVkIHdpdGggdGhlIFZQQyBMaW5rIHRvIGNvbnRyb2wgbmV0d29yayB0cmFmZmljLlxuICpcbiAqIEFkZGl0aW9uYWxseSwgdGhlIGZvbGxvd2luZyBwYXJhbWV0ZXJzIGFyZSBleHBvc2VkIGFzIENsb3VkRm9ybWF0aW9uIG91dHB1dHM6XG4gKiAtIFRoZSBWUEMgTGluayBJRC5cbiAqIC0gVGhlIFNlY3VyaXR5IEdyb3VwIElELlxuICpcbiAqIFRoZXNlIG91dHB1dHMgY2FuIGJlIHV0aWxpemVkIGJ5IG90aGVyIENESyBleHRlbnNpb25zIHByb3ZpZGVkIGluIHRoaXMgbGlicmFyeS5cbiAqL1xuZXhwb3J0IGNsYXNzIEFwaUdhdGV3YXlWMiBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHByaXZhdGUgc2VjdXJpdHlHcm91cDogSVNlY3VyaXR5R3JvdXA7XG4gIHByaXZhdGUgdnBjTGluazogSVZwY0xpbms7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBPVVRQVVRfUEFSQU1FVEVSX1BSRUZJWCA9IFwiYXBpLWdhdGV3YXktdjJcIjtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogQXBpR2F0ZXdheVByb3BzVjIpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5zZWN1cml0eUdyb3VwID0gbmV3IFNlY3VyaXR5R3JvdXAodGhpcywgXCJWcGNMaW5rU2VjdXJpdHlHcm91cFwiLCB7XG4gICAgICB2cGM6IHByb3BzLnZwYyxcbiAgICAgIGFsbG93QWxsT3V0Ym91bmQ6IGZhbHNlLFxuICAgIH0pO1xuXG4gICAgdGhpcy52cGNMaW5rID0gbmV3IFZwY0xpbmsodGhpcywgXCJIdHRwVnBjTGlua1wiLCB7XG4gICAgICB2cGM6IHByb3BzLnZwYyxcbiAgICAgIHZwY0xpbmtOYW1lOiBcIkFQSUdXIFYyIFZQQyBMaW5rXCIsXG4gICAgICBzZWN1cml0eUdyb3VwczogW3RoaXMuc2VjdXJpdHlHcm91cF0sXG4gICAgfSk7XG5cbiAgICB0aGlzLmV4cG9zZVBhcmFtZXRlcnMoKTtcbiAgfVxuXG4gIHByaXZhdGUgZXhwb3NlUGFyYW1ldGVycygpIHtcbiAgICBjb25zdCBleHBvcnRWYWx1ZSA9IGNyZWF0ZUV4cG9ydGVyKHRoaXMsIHRoaXMuT1VUUFVUX1BBUkFNRVRFUl9QUkVGSVgpO1xuXG4gICAgZXhwb3J0VmFsdWUoe1xuICAgICAgbmFtZTogXCJBUElHYXRld2F5IFZQQ0xpbmsgSWRcIixcbiAgICAgIGtleTogXCJ2cGMtbGluay1pZFwiLFxuICAgICAgdmFsdWU6IHRoaXMudnBjTGluay52cGNMaW5rSWQsXG4gICAgfSk7XG5cbiAgICBleHBvcnRWYWx1ZSh7XG4gICAgICBuYW1lOiBcIkFQSUdhdGV3YXkgU2VjdXJpdHkgR3JvdXAgSWRcIixcbiAgICAgIGtleTogXCJzZWN1cml0eS1ncm91cC1pZFwiLFxuICAgICAgdmFsdWU6IHRoaXMuc2VjdXJpdHlHcm91cC5zZWN1cml0eUdyb3VwSWQsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
58
+ ApiGatewayV2[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayV2", version: "0.9.5" };
59
+ ApiGatewayV2.vpcLinkParameter = new utils_1.StackParameter({
60
+ name: "APIGateway VPCLink Id",
61
+ key: "vpc-link-id",
62
+ prefix: "api-gateway",
63
+ version: 2,
64
+ });
65
+ ApiGatewayV2.securityGroupIdParameter = new utils_1.StackParameter({
66
+ name: "APIGateway Security Group Id",
67
+ key: "security-group-id",
68
+ prefix: "api-gateway",
69
+ version: 2,
70
+ });
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBpR2F0ZXdheVYyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BsYXRmb3JtL0FwaUdhdGV3YXlWMi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLG1FQUFpRTtBQUNqRSxpREFBMEU7QUFDMUUsMkNBQXVDO0FBQ3ZDLG9DQUEwQztBQW1CMUM7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsTUFBYSxZQUFhLFNBQVEsc0JBQVM7SUFDbEMsTUFBTSxDQUFDLGdCQUFnQixDQUM1QixLQUFnQixFQUNoQixFQUFVLEVBQ1YsT0FBa0M7UUFFbEMsTUFBTSxFQUFFLEdBQUcsRUFBRSxZQUFZLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFFdEMsTUFBTSxPQUFPLEdBQUcsMEJBQU8sQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFO1lBQzlELEdBQUc7WUFDSCxTQUFTLEVBQUUsWUFBWSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUM7U0FDOUQsQ0FBQyxDQUFDO1FBRUgsTUFBTSxhQUFhLEdBQUcsdUJBQWEsQ0FBQyxtQkFBbUIsQ0FDckQsS0FBSyxFQUNMLGVBQWUsRUFDZixZQUFZLENBQUMsd0JBQXdCLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxFQUMxRCxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxDQUM1QixDQUFDO1FBRUYsTUFBTSxNQUFPLFNBQVEsc0JBQVM7WUFBOUI7O2dCQUNrQixrQkFBYSxHQUFtQixhQUFhLENBQUM7Z0JBQzlDLFlBQU8sR0FBYSxPQUFPLENBQUM7WUFDOUMsQ0FBQztTQUFBO1FBRUQsT0FBTyxJQUFJLE1BQU0sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQW1CRCxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXdCO1FBQ2hFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLHVCQUFhLENBQUMsSUFBSSxFQUFFLHNCQUFzQixFQUFFO1lBQ25FLEdBQUcsRUFBRSxLQUFLLENBQUMsR0FBRztZQUNkLGdCQUFnQixFQUFFLEtBQUs7U0FDeEIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLDBCQUFPLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRTtZQUMxQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEdBQUc7WUFDZCxXQUFXLEVBQUUsbUJBQW1CO1lBQ2hDLGNBQWMsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUM7U0FDckMsQ0FBQyxDQUFDO1FBRUgsWUFBWSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUVuRSx3R0FBd0c7UUFDeEcsWUFBWSxDQUFDLHdCQUF3QixDQUFDLE1BQU0sQ0FDMUMsSUFBSSxFQUNKLElBQUksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUNuQyxDQUFDO0lBQ0osQ0FBQzs7QUFsRUgsb0NBbUVDOzs7QUF2Q3lCLDZCQUFnQixHQUFHLElBQUksc0JBQWMsQ0FBQztJQUM1RCxJQUFJLEVBQUUsdUJBQXVCO0lBQzdCLEdBQUcsRUFBRSxhQUFhO0lBQ2xCLE1BQU0sRUFBRSxhQUFhO0lBQ3JCLE9BQU8sRUFBRSxDQUFDO0NBQ1gsQ0FBQyxDQUFDO0FBRXFCLHFDQUF3QixHQUFHLElBQUksc0JBQWMsQ0FBQztJQUNwRSxJQUFJLEVBQUUsOEJBQThCO0lBQ3BDLEdBQUcsRUFBRSxtQkFBbUI7SUFDeEIsTUFBTSxFQUFFLGFBQWE7SUFDckIsT0FBTyxFQUFFLENBQUM7Q0FDWCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJVnBjTGluaywgVnBjTGluayB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtYXBpZ2F0ZXdheXYyXCI7XG5pbXBvcnQgeyBJU2VjdXJpdHlHcm91cCwgSVZwYywgU2VjdXJpdHlHcm91cCB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtZWMyXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IHsgU3RhY2tQYXJhbWV0ZXIgfSBmcm9tIFwiLi4vdXRpbHNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBBcGlHYXRld2F5UHJvcHNWMiB7XG4gIC8qKlxuICAgKiBWUEMgd2hlcmUgdGhlIEFQSSBHVyBTZWN1cml0eSBncm91cCBhbmQgVlBDIExpbmsgd2lsbCBiZSBjcmVhdGVkLlxuICAgKi9cbiAgcmVhZG9ubHkgdnBjOiBJVnBjO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElBcGlHYXRld2F5VjIge1xuICByZWFkb25seSB2cGNMaW5rOiBJVnBjTGluaztcbiAgcmVhZG9ubHkgc2VjdXJpdHlHcm91cDogSVNlY3VyaXR5R3JvdXA7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXBpR2F0ZXdheVYyTG9va3VwT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGJhc2VQbGF0Zm9ybTogc3RyaW5nO1xuICByZWFkb25seSB2cGM6IElWcGM7XG59XG5cbi8qKlxuICogQ29uc3RydWN0cyBhbiBBUEkgR2F0ZXdheSBWMiByZXNvdXJjZSBmb3IgdXNlIGluIGJhc2UgcGxhdGZvcm1zLlxuICpcbiAqIFRoaXMgY29uc3RydWN0IGNyZWF0ZXM6XG4gKiAtIEEgVlBDIExpbmsgZm9yIHRoZSBBUEkgR2F0ZXdheSB0byBjb25uZWN0IHRvIHNlcnZpY2VzIHdpdGhpbiB0aGUgc3BlY2lmaWVkIFZQQy5cbiAqIC0gQSBTZWN1cml0eSBHcm91cCBhc3NvY2lhdGVkIHdpdGggdGhlIFZQQyBMaW5rIHRvIGNvbnRyb2wgbmV0d29yayB0cmFmZmljLlxuICpcbiAqIEFkZGl0aW9uYWxseSwgdGhlIGZvbGxvd2luZyBwYXJhbWV0ZXJzIGFyZSBleHBvc2VkIGFzIENsb3VkRm9ybWF0aW9uIG91dHB1dHM6XG4gKiAtIFRoZSBWUEMgTGluayBJRC5cbiAqIC0gVGhlIFNlY3VyaXR5IEdyb3VwIElELlxuICpcbiAqIFRoZXNlIG91dHB1dHMgY2FuIGJlIHV0aWxpemVkIGJ5IG90aGVyIENESyBleHRlbnNpb25zIHByb3ZpZGVkIGluIHRoaXMgbGlicmFyeS5cbiAqL1xuZXhwb3J0IGNsYXNzIEFwaUdhdGV3YXlWMiBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElBcGlHYXRld2F5VjIge1xuICBwdWJsaWMgc3RhdGljIGZyb21CYXNlUGxhdGZvcm0oXG4gICAgc2NvcGU6IENvbnN0cnVjdCxcbiAgICBpZDogc3RyaW5nLFxuICAgIG9wdGlvbnM6IEFwaUdhdGV3YXlWMkxvb2t1cE9wdGlvbnMsXG4gICk6IElBcGlHYXRld2F5VjIge1xuICAgIGNvbnN0IHsgdnBjLCBiYXNlUGxhdGZvcm0gfSA9IG9wdGlvbnM7XG5cbiAgICBjb25zdCB2cGNMaW5rID0gVnBjTGluay5mcm9tVnBjTGlua0F0dHJpYnV0ZXMoc2NvcGUsIFwiVlBDTGlua1wiLCB7XG4gICAgICB2cGMsXG4gICAgICB2cGNMaW5rSWQ6IEFwaUdhdGV3YXlWMi52cGNMaW5rUGFyYW1ldGVyLmltcG9ydChiYXNlUGxhdGZvcm0pLFxuICAgIH0pO1xuXG4gICAgY29uc3Qgc2VjdXJpdHlHcm91cCA9IFNlY3VyaXR5R3JvdXAuZnJvbVNlY3VyaXR5R3JvdXBJZChcbiAgICAgIHNjb3BlLFxuICAgICAgXCJTZWN1cml0eUdyb3VwXCIsXG4gICAgICBBcGlHYXRld2F5VjIuc2VjdXJpdHlHcm91cElkUGFyYW1ldGVyLmltcG9ydChiYXNlUGxhdGZvcm0pLFxuICAgICAgeyBhbGxvd0FsbE91dGJvdW5kOiBmYWxzZSB9LCAvLyBzZWUgYmVsb3dcbiAgICApO1xuXG4gICAgY2xhc3MgSW1wb3J0IGV4dGVuZHMgQ29uc3RydWN0IGltcGxlbWVudHMgSUFwaUdhdGV3YXlWMiB7XG4gICAgICBwdWJsaWMgcmVhZG9ubHkgc2VjdXJpdHlHcm91cDogSVNlY3VyaXR5R3JvdXAgPSBzZWN1cml0eUdyb3VwO1xuICAgICAgcHVibGljIHJlYWRvbmx5IHZwY0xpbms6IElWcGNMaW5rID0gdnBjTGluaztcbiAgICB9XG5cbiAgICByZXR1cm4gbmV3IEltcG9ydChzY29wZSwgaWQpO1xuICB9XG5cbiAgcHJpdmF0ZSBzdGF0aWMgcmVhZG9ubHkgdnBjTGlua1BhcmFtZXRlciA9IG5ldyBTdGFja1BhcmFtZXRlcih7XG4gICAgbmFtZTogXCJBUElHYXRld2F5IFZQQ0xpbmsgSWRcIixcbiAgICBrZXk6IFwidnBjLWxpbmstaWRcIixcbiAgICBwcmVmaXg6IFwiYXBpLWdhdGV3YXlcIixcbiAgICB2ZXJzaW9uOiAyLFxuICB9KTtcblxuICBwcml2YXRlIHN0YXRpYyByZWFkb25seSBzZWN1cml0eUdyb3VwSWRQYXJhbWV0ZXIgPSBuZXcgU3RhY2tQYXJhbWV0ZXIoe1xuICAgIG5hbWU6IFwiQVBJR2F0ZXdheSBTZWN1cml0eSBHcm91cCBJZFwiLFxuICAgIGtleTogXCJzZWN1cml0eS1ncm91cC1pZFwiLFxuICAgIHByZWZpeDogXCJhcGktZ2F0ZXdheVwiLFxuICAgIHZlcnNpb246IDIsXG4gIH0pO1xuXG4gIHB1YmxpYyByZWFkb25seSBzZWN1cml0eUdyb3VwOiBJU2VjdXJpdHlHcm91cDtcbiAgcHVibGljIHJlYWRvbmx5IHZwY0xpbms6IElWcGNMaW5rO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBBcGlHYXRld2F5UHJvcHNWMikge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICB0aGlzLnNlY3VyaXR5R3JvdXAgPSBuZXcgU2VjdXJpdHlHcm91cCh0aGlzLCBcIlZwY0xpbmtTZWN1cml0eUdyb3VwXCIsIHtcbiAgICAgIHZwYzogcHJvcHMudnBjLFxuICAgICAgYWxsb3dBbGxPdXRib3VuZDogZmFsc2UsXG4gICAgfSk7XG5cbiAgICB0aGlzLnZwY0xpbmsgPSBuZXcgVnBjTGluayh0aGlzLCBcIlZwY0xpbmtcIiwge1xuICAgICAgdnBjOiBwcm9wcy52cGMsXG4gICAgICB2cGNMaW5rTmFtZTogXCJBUElHVyBWMiBWUEMgTGlua1wiLFxuICAgICAgc2VjdXJpdHlHcm91cHM6IFt0aGlzLnNlY3VyaXR5R3JvdXBdLFxuICAgIH0pO1xuXG4gICAgQXBpR2F0ZXdheVYyLnZwY0xpbmtQYXJhbWV0ZXIuZXhwb3J0KHRoaXMsIHRoaXMudnBjTGluay52cGNMaW5rSWQpO1xuXG4gICAgLy8gTk9URTogU2VjdXJpdHkgZ3JvdXAgSUQgY2Fubm90IGJlIGltcG9ydGVkLiBXZSBleHBvcnQgaXQgaGVyZSB0byBtYWtlIGl0IGVhc2llciB0byBhY2Nlc3MgaXQgbWFudWFsbHlcbiAgICBBcGlHYXRld2F5VjIuc2VjdXJpdHlHcm91cElkUGFyYW1ldGVyLmV4cG9ydChcbiAgICAgIHRoaXMsXG4gICAgICB0aGlzLnNlY3VyaXR5R3JvdXAuc2VjdXJpdHlHcm91cElkLFxuICAgICk7XG4gIH1cbn1cbiJdfQ==
@@ -61,5 +61,5 @@ class ApplicationLoadBalancer extends constructs_1.Construct {
61
61
  }
62
62
  exports.ApplicationLoadBalancer = ApplicationLoadBalancer;
63
63
  _a = JSII_RTTI_SYMBOL_1;
64
- ApplicationLoadBalancer[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancer", version: "0.9.4" };
64
+ ApplicationLoadBalancer[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancer", version: "0.9.5" };
65
65
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBwbGljYXRpb25Mb2FkQmFsYW5jZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGxhdGZvcm0vQXBwbGljYXRpb25Mb2FkQmFsYW5jZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2Q0FBaUM7QUFDakMsK0VBRzRDO0FBTzVDLHVGQUtnRDtBQUNoRCx1R0FBMkY7QUFDM0YseURBQTZFO0FBQzdFLHlFQUFxRTtBQUNyRSwyQ0FBdUM7QUFDdkMsb0NBQTBDO0FBVTFDOztHQUVHO0FBQ0gsTUFBYSx1QkFBd0IsU0FBUSxzQkFBUztJQUdwRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzNCLENBQUM7SUFFRCxZQUNFLEtBQWdCLEVBQ2hCLEVBQVUsRUFDVixLQUFtQztRQUVuQyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sV0FBVyxHQUFHLElBQUksb0NBQVcsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQ3ZELFVBQVUsRUFBRSxLQUFLLENBQUMsSUFBSTtZQUN0QixVQUFVLEVBQUUsOENBQXFCLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUM7U0FDNUQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLG9EQUEwQixDQUFDLElBQUksRUFBRSxLQUFLLEVBQUU7WUFDOUQsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO1lBQ2QsY0FBYyxFQUFFLElBQUk7U0FDckIsQ0FBQyxDQUFDO1FBRUgsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsVUFBVSxFQUFFO1lBQ3pELElBQUksRUFBRSxHQUFHO1lBQ1QsWUFBWSxFQUFFLENBQUMsV0FBVyxDQUFDO1lBQzNCLGFBQWEsRUFBRSxJQUFJLDhEQUF5QixDQUFDO2dCQUMzQyxRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVE7Z0JBQ3hCLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYztnQkFDcEMsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO2dCQUNwQyxJQUFJLEVBQUUsMkNBQWMsQ0FBQyxhQUFhLENBQUMsR0FBRyxFQUFFO29CQUN0QyxXQUFXLEVBQUUsZ0NBQWdDO2lCQUM5QyxDQUFDO2dCQUNGLHdCQUF3QixFQUFFLGtEQUFxQixDQUFDLFlBQVk7YUFDN0QsQ0FBQztTQUNILENBQUMsQ0FBQztRQUVILElBQUkscUJBQU8sQ0FBQyxJQUFJLEVBQUUsWUFBWSxFQUFFO1lBQzlCLElBQUksRUFBRSxLQUFLLENBQUMsVUFBVTtZQUN0QixVQUFVLEVBQUUsS0FBSyxDQUFDLElBQUk7WUFDdEIsTUFBTSxFQUFFLDBCQUFZLENBQUMsU0FBUyxDQUFDLElBQUksd0NBQWtCLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1NBQzFFLENBQUMsQ0FBQztRQUVILE1BQU0sV0FBVyxHQUFHLElBQUEsc0JBQWMsRUFBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFaEQsV0FBVyxDQUFDO1lBQ1YsSUFBSSxFQUFFLGtCQUFrQjtZQUN4QixHQUFHLEVBQUUsY0FBYztZQUNuQixLQUFLLEVBQUUsUUFBUSxDQUFDLFdBQVc7U0FDNUIsQ0FBQyxDQUFDO1FBRUgsV0FBVyxDQUFDO1lBQ1YsSUFBSSxFQUFFLHVCQUF1QjtZQUM3QixHQUFHLEVBQUUsbUJBQW1CO1lBQ3hCLEtBQUssRUFBRSxnQkFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQywwQkFBMEIsQ0FBQztTQUNsRSxDQUFDLENBQUM7SUFDTCxDQUFDOztBQXpESCwwREEwREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGbiB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7XG4gIElVc2VyUG9vbCxcbiAgSVVzZXJQb29sQ2xpZW50LFxuICBJVXNlclBvb2xEb21haW4sXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtY29nbml0b1wiO1xuaW1wb3J0IHsgSVZwYyB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtZWMyXCI7XG5pbXBvcnQge1xuICBBcHBsaWNhdGlvbkxvYWRCYWxhbmNlciBhcyBBV1NBcHBsaWNhdGlvbkxvYWRCYWxhbmNlcixcbiAgSUFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyLFxuICBMaXN0ZW5lckFjdGlvbixcbiAgVW5hdXRoZW50aWNhdGVkQWN0aW9uLFxufSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWVsYXN0aWNsb2FkYmFsYW5jaW5ndjJcIjtcbmltcG9ydCB7IEF1dGhlbnRpY2F0ZUNvZ25pdG9BY3Rpb24gfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWVsYXN0aWNsb2FkYmFsYW5jaW5ndjItYWN0aW9uc1wiO1xuaW1wb3J0IHsgQVJlY29yZCwgSUhvc3RlZFpvbmUsIFJlY29yZFRhcmdldCB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1M1wiO1xuaW1wb3J0IHsgTG9hZEJhbGFuY2VyVGFyZ2V0IH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1yb3V0ZTUzLXRhcmdldHNcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgeyBjcmVhdGVFeHBvcnRlciB9IGZyb20gXCIuLi91dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHMge1xuICByZWFkb25seSBmcWRuOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHZwYzogSVZwYztcbiAgcmVhZG9ubHkgdXNlclBvb2w6IElVc2VyUG9vbDtcbiAgcmVhZG9ubHkgdXNlclBvb2xDbGllbnQ6IElVc2VyUG9vbENsaWVudDtcbiAgcmVhZG9ubHkgdXNlclBvb2xEb21haW46IElVc2VyUG9vbERvbWFpbjtcbiAgcmVhZG9ubHkgaG9zdGVkWm9uZTogSUhvc3RlZFpvbmU7XG59XG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSB7QGxpbmsgQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJWMn0gaW5zdGVhZFxuICovXG5leHBvcnQgY2xhc3MgQXBwbGljYXRpb25Mb2FkQmFsYW5jZXIgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwdWJsaWMgcmVhZG9ubHkgbG9hZGJhbGFuY2VyOiBBV1NBcHBsaWNhdGlvbkxvYWRCYWxhbmNlcjtcblxuICBwdWJsaWMgZ2V0IGxvYWRCYWxhbmNlcigpOiBJQXBwbGljYXRpb25Mb2FkQmFsYW5jZXIge1xuICAgIHJldHVybiB0aGlzLmxvYWRiYWxhbmNlcjtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHNjb3BlOiBDb25zdHJ1Y3QsXG4gICAgaWQ6IHN0cmluZyxcbiAgICBwcm9wczogQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJQcm9wcyxcbiAgKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGNvbnN0IGNlcnRpZmljYXRlID0gbmV3IENlcnRpZmljYXRlKHRoaXMsIFwiQ2VydGlmaWNhdGVcIiwge1xuICAgICAgZG9tYWluTmFtZTogcHJvcHMuZnFkbixcbiAgICAgIHZhbGlkYXRpb246IENlcnRpZmljYXRlVmFsaWRhdGlvbi5mcm9tRG5zKHByb3BzLmhvc3RlZFpvbmUpLFxuICAgIH0pO1xuXG4gICAgdGhpcy5sb2FkYmFsYW5jZXIgPSBuZXcgQVdTQXBwbGljYXRpb25Mb2FkQmFsYW5jZXIodGhpcywgXCJBTEJcIiwge1xuICAgICAgdnBjOiBwcm9wcy52cGMsXG4gICAgICBpbnRlcm5ldEZhY2luZzogdHJ1ZSxcbiAgICB9KTtcblxuICAgIGNvbnN0IGxpc3RlbmVyID0gdGhpcy5sb2FkYmFsYW5jZXIuYWRkTGlzdGVuZXIoXCJMaXN0ZW5lclwiLCB7XG4gICAgICBwb3J0OiA0NDMsXG4gICAgICBjZXJ0aWZpY2F0ZXM6IFtjZXJ0aWZpY2F0ZV0sXG4gICAgICBkZWZhdWx0QWN0aW9uOiBuZXcgQXV0aGVudGljYXRlQ29nbml0b0FjdGlvbih7XG4gICAgICAgIHVzZXJQb29sOiBwcm9wcy51c2VyUG9vbCxcbiAgICAgICAgdXNlclBvb2xDbGllbnQ6IHByb3BzLnVzZXJQb29sQ2xpZW50LFxuICAgICAgICB1c2VyUG9vbERvbWFpbjogcHJvcHMudXNlclBvb2xEb21haW4sXG4gICAgICAgIG5leHQ6IExpc3RlbmVyQWN0aW9uLmZpeGVkUmVzcG9uc2UoMjAwLCB7XG4gICAgICAgICAgbWVzc2FnZUJvZHk6IFwiVGhpcyBpcyB0aGUgQUxCIGRlZmF1bHQgYWN0aW9uXCIsXG4gICAgICAgIH0pLFxuICAgICAgICBvblVuYXV0aGVudGljYXRlZFJlcXVlc3Q6IFVuYXV0aGVudGljYXRlZEFjdGlvbi5BVVRIRU5USUNBVEUsXG4gICAgICB9KSxcbiAgICB9KTtcblxuICAgIG5ldyBBUmVjb3JkKHRoaXMsIFwiQUxCQVJlY29yZFwiLCB7XG4gICAgICB6b25lOiBwcm9wcy5ob3N0ZWRab25lLFxuICAgICAgcmVjb3JkTmFtZTogcHJvcHMuZnFkbixcbiAgICAgIHRhcmdldDogUmVjb3JkVGFyZ2V0LmZyb21BbGlhcyhuZXcgTG9hZEJhbGFuY2VyVGFyZ2V0KHRoaXMubG9hZEJhbGFuY2VyKSksXG4gICAgfSk7XG5cbiAgICBjb25zdCBleHBvcnRWYWx1ZSA9IGNyZWF0ZUV4cG9ydGVyKHRoaXMsIFwiYWxiXCIpO1xuXG4gICAgZXhwb3J0VmFsdWUoe1xuICAgICAgbmFtZTogXCJBTEIgTGlzdGVuZXIgQVJOXCIsXG4gICAgICBrZXk6IFwibGlzdGVuZXItYXJuXCIsXG4gICAgICB2YWx1ZTogbGlzdGVuZXIubGlzdGVuZXJBcm4sXG4gICAgfSk7XG5cbiAgICBleHBvcnRWYWx1ZSh7XG4gICAgICBuYW1lOiBcIkFMQiBTZWN1cml0eSBHcm91cCBJZFwiLFxuICAgICAga2V5OiBcInNlY3VyaXR5LWdyb3VwLWlkXCIsXG4gICAgICB2YWx1ZTogRm4uc2VsZWN0KDAsIHRoaXMubG9hZGJhbGFuY2VyLmxvYWRCYWxhbmNlclNlY3VyaXR5R3JvdXBzKSxcbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -1,9 +1,9 @@
1
1
  import { IUserPoolDomain } from "aws-cdk-lib/aws-cognito";
2
2
  import { IVpc } from "aws-cdk-lib/aws-ec2";
3
- import { ApplicationLoadBalancer as AWSApplicationLoadBalancer, IApplicationLoadBalancer } from "aws-cdk-lib/aws-elasticloadbalancingv2";
3
+ import { IApplicationLoadBalancerTarget, IApplicationTargetGroup } from "aws-cdk-lib/aws-elasticloadbalancingv2";
4
4
  import { IHostedZone } from "aws-cdk-lib/aws-route53";
5
5
  import { Construct } from "constructs";
6
- import { ApplicationUserPoolClient } from "./ApplicationUserPoolClient";
6
+ import { CognitoUserPool } from "./CognitoUserPool";
7
7
  export interface ApplicationLoadBalancerPropsV2 {
8
8
  /**
9
9
  * The fully qualified domain name (FQDN) for the Application Load Balancer (ALB).
@@ -15,10 +15,9 @@ export interface ApplicationLoadBalancerPropsV2 {
15
15
  */
16
16
  readonly vpc: IVpc;
17
17
  /**
18
- * The Cognito User Pool Client associated with the ALB.
19
- * This client is used for handling OAuth flows.
18
+ * The Cognito User Pool of this base platform.
20
19
  */
21
- readonly userPoolClient: ApplicationUserPoolClient;
20
+ readonly userPool: CognitoUserPool;
22
21
  /**
23
22
  * The Cognito User Pool Domain used for authentication.
24
23
  */
@@ -42,6 +41,17 @@ export interface ApplicationLoadBalancerPropsV2 {
42
41
  */
43
42
  readonly healtCheckPath: string;
44
43
  }
44
+ export interface ApplicationLoadBalancerV2LookupOptions {
45
+ readonly basePlatform: string;
46
+ }
47
+ export interface IApplicationLoadBalancerV2 {
48
+ readonly targetGroup: IApplicationTargetGroup;
49
+ addTarget(target: IApplicationLoadBalancerTarget): void;
50
+ }
51
+ export declare abstract class ApplicationLoadBalancerV2Base extends Construct implements IApplicationLoadBalancerV2 {
52
+ abstract readonly targetGroup: IApplicationTargetGroup;
53
+ addTarget(target: IApplicationLoadBalancerTarget): void;
54
+ }
45
55
  /**
46
56
  * A construct that creates an Application Load Balancer (ALB) with Cognito authentication.
47
57
  *
@@ -51,8 +61,11 @@ export interface ApplicationLoadBalancerPropsV2 {
51
61
  * - Adds a Route 53 DNS record for the ALB.
52
62
  * - Exports key ALB properties (listener ARN, target group ARN, security group ID) as CloudFormation outputs.
53
63
  */
54
- export declare class ApplicationLoadBalancerV2 extends Construct {
55
- readonly loadbalancer: AWSApplicationLoadBalancer;
56
- get loadBalancer(): IApplicationLoadBalancer;
64
+ export declare class ApplicationLoadBalancerV2 extends ApplicationLoadBalancerV2Base {
65
+ static fromBasePlatform(scope: Construct, id: string, { basePlatform }: ApplicationLoadBalancerV2LookupOptions): IApplicationLoadBalancerV2;
66
+ private static readonly securityGroupIdParameter;
67
+ private static readonly targetGroupIdParameter;
68
+ private readonly alb;
69
+ readonly targetGroup: IApplicationTargetGroup;
57
70
  constructor(scope: Construct, id: string, props: ApplicationLoadBalancerPropsV2);
58
71
  }
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
- var _a;
2
+ var _a, _b;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.ApplicationLoadBalancerV2 = void 0;
4
+ exports.ApplicationLoadBalancerV2 = exports.ApplicationLoadBalancerV2Base = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const aws_cdk_lib_1 = require("aws-cdk-lib");
7
7
  const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager");
@@ -11,6 +11,14 @@ const aws_route53_1 = require("aws-cdk-lib/aws-route53");
11
11
  const aws_route53_targets_1 = require("aws-cdk-lib/aws-route53-targets");
12
12
  const constructs_1 = require("constructs");
13
13
  const utils_1 = require("../utils");
14
+ class ApplicationLoadBalancerV2Base extends constructs_1.Construct {
15
+ addTarget(target) {
16
+ return this.targetGroup.addTarget(target);
17
+ }
18
+ }
19
+ exports.ApplicationLoadBalancerV2Base = ApplicationLoadBalancerV2Base;
20
+ _a = JSII_RTTI_SYMBOL_1;
21
+ ApplicationLoadBalancerV2Base[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerV2Base", version: "0.9.5" };
14
22
  /**
15
23
  * A construct that creates an Application Load Balancer (ALB) with Cognito authentication.
16
24
  *
@@ -20,9 +28,17 @@ const utils_1 = require("../utils");
20
28
  * - Adds a Route 53 DNS record for the ALB.
21
29
  * - Exports key ALB properties (listener ARN, target group ARN, security group ID) as CloudFormation outputs.
22
30
  */
23
- class ApplicationLoadBalancerV2 extends constructs_1.Construct {
24
- get loadBalancer() {
25
- return this.loadbalancer;
31
+ class ApplicationLoadBalancerV2 extends ApplicationLoadBalancerV2Base {
32
+ static fromBasePlatform(scope, id, { basePlatform }) {
33
+ class Import extends ApplicationLoadBalancerV2Base {
34
+ constructor() {
35
+ super(...arguments);
36
+ this.targetGroup = aws_elasticloadbalancingv2_1.ApplicationTargetGroup.fromTargetGroupAttributes(this, "TargetGroupLookup", {
37
+ targetGroupArn: ApplicationLoadBalancerV2.targetGroupIdParameter.import(basePlatform),
38
+ });
39
+ }
40
+ }
41
+ return new Import(scope, id);
26
42
  }
27
43
  constructor(scope, id, props) {
28
44
  super(scope, id);
@@ -30,16 +46,16 @@ class ApplicationLoadBalancerV2 extends constructs_1.Construct {
30
46
  domainName: props.fqdn,
31
47
  validation: aws_certificatemanager_1.CertificateValidation.fromDns(props.hostedZone),
32
48
  });
33
- this.loadbalancer = new aws_elasticloadbalancingv2_1.ApplicationLoadBalancer(this, "ALB", {
49
+ this.alb = new aws_elasticloadbalancingv2_1.ApplicationLoadBalancer(this, "ALB", {
34
50
  vpc: props.vpc,
35
51
  internetFacing: true,
36
52
  });
37
- const listener = this.loadbalancer.addListener("Listener", {
53
+ const listener = this.alb.addListener("Listener", {
38
54
  port: 443,
39
55
  certificates: [certificate],
40
56
  defaultAction: new aws_elasticloadbalancingv2_actions_1.AuthenticateCognitoAction({
41
- userPool: props.userPoolClient.userPool,
42
- userPoolClient: props.userPoolClient.client,
57
+ userPool: props.userPool.userPool,
58
+ userPoolClient: props.userPool.appUserPoolClient,
43
59
  userPoolDomain: props.userPoolDomain,
44
60
  next: aws_elasticloadbalancingv2_1.ListenerAction.fixedResponse(200, {
45
61
  messageBody: "This is the ALB default action",
@@ -47,7 +63,7 @@ class ApplicationLoadBalancerV2 extends constructs_1.Construct {
47
63
  onUnauthenticatedRequest: aws_elasticloadbalancingv2_1.UnauthenticatedAction.AUTHENTICATE,
48
64
  }),
49
65
  });
50
- const targetGroup = new aws_elasticloadbalancingv2_1.ApplicationTargetGroup(this, `${id}TargetGroup`, {
66
+ this.targetGroup = new aws_elasticloadbalancingv2_1.ApplicationTargetGroup(this, `${id}TargetGroup`, {
51
67
  vpc: props.vpc,
52
68
  port: props.trafficPort,
53
69
  protocol: aws_elasticloadbalancingv2_1.ApplicationProtocol.HTTP,
@@ -61,37 +77,35 @@ class ApplicationLoadBalancerV2 extends constructs_1.Construct {
61
77
  priority: 55,
62
78
  conditions: [aws_elasticloadbalancingv2_1.ListenerCondition.hostHeaders([props.fqdn])],
63
79
  action: new aws_elasticloadbalancingv2_actions_1.AuthenticateCognitoAction({
64
- userPool: props.userPoolClient.userPool,
65
- userPoolClient: props.userPoolClient.client,
80
+ userPool: props.userPool.userPool,
81
+ userPoolClient: props.userPool.appUserPoolClient,
66
82
  userPoolDomain: props.userPoolDomain,
67
- next: aws_elasticloadbalancingv2_1.ListenerAction.forward([targetGroup]),
83
+ next: aws_elasticloadbalancingv2_1.ListenerAction.forward([this.targetGroup]),
68
84
  onUnauthenticatedRequest: aws_elasticloadbalancingv2_1.UnauthenticatedAction.AUTHENTICATE,
69
85
  }),
70
86
  });
71
87
  new aws_route53_1.ARecord(this, "ALBARecord", {
72
88
  zone: props.hostedZone,
73
89
  recordName: props.fqdn,
74
- target: aws_route53_1.RecordTarget.fromAlias(new aws_route53_targets_1.LoadBalancerTarget(this.loadBalancer)),
75
- });
76
- const exportValue = (0, utils_1.createExporter)(this, "alb-v2");
77
- exportValue({
78
- name: "ALB Listener ARN",
79
- key: "listener-arn",
80
- value: listener.listenerArn,
81
- });
82
- exportValue({
83
- name: "default target group ARN",
84
- key: "alb-target-group-arn",
85
- value: targetGroup.targetGroupArn,
86
- });
87
- exportValue({
88
- name: "ALB Security Group Id",
89
- key: "security-group-id",
90
- value: aws_cdk_lib_1.Fn.select(0, this.loadbalancer.loadBalancerSecurityGroups),
90
+ target: aws_route53_1.RecordTarget.fromAlias(new aws_route53_targets_1.LoadBalancerTarget(this.alb)),
91
91
  });
92
+ ApplicationLoadBalancerV2.targetGroupIdParameter.export(this, this.targetGroup.targetGroupArn);
93
+ ApplicationLoadBalancerV2.securityGroupIdParameter.export(this, aws_cdk_lib_1.Fn.select(0, this.alb.loadBalancerSecurityGroups));
92
94
  }
93
95
  }
94
96
  exports.ApplicationLoadBalancerV2 = ApplicationLoadBalancerV2;
95
- _a = JSII_RTTI_SYMBOL_1;
96
- ApplicationLoadBalancerV2[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerV2", version: "0.9.4" };
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApplicationLoadBalancerV2.js","sourceRoot":"","sources":["../../src/platform/ApplicationLoadBalancerV2.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Fn } from \"aws-cdk-lib\";\nimport {\n  Certificate,\n  CertificateValidation,\n} from \"aws-cdk-lib/aws-certificatemanager\";\nimport { IUserPoolDomain } from \"aws-cdk-lib/aws-cognito\";\nimport { IVpc } from \"aws-cdk-lib/aws-ec2\";\nimport {\n  ApplicationProtocol,\n  ApplicationTargetGroup,\n  ApplicationLoadBalancer as AWSApplicationLoadBalancer,\n  IApplicationLoadBalancer,\n  ListenerAction,\n  ListenerCondition,\n  UnauthenticatedAction,\n} from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\nimport { AuthenticateCognitoAction } from \"aws-cdk-lib/aws-elasticloadbalancingv2-actions\";\nimport { ARecord, IHostedZone, RecordTarget } from \"aws-cdk-lib/aws-route53\";\nimport { LoadBalancerTarget } from \"aws-cdk-lib/aws-route53-targets\";\nimport { Construct } from \"constructs\";\nimport { createExporter } from \"../utils\";\nimport { ApplicationUserPoolClient } from \"./ApplicationUserPoolClient\";\n\nexport interface ApplicationLoadBalancerPropsV2 {\n  /**\n   * The fully qualified domain name (FQDN) for the Application Load Balancer (ALB).\n   * This is used for configuring DNS records.\n   */\n  readonly fqdn: string;\n\n  /**\n   * The VPC in which the Application Load Balancer will be deployed.\n   */\n  readonly vpc: IVpc;\n\n  /**\n   * The Cognito User Pool Client associated with the ALB.\n   * This client is used for handling OAuth flows.\n   */\n  readonly userPoolClient: ApplicationUserPoolClient;\n\n  /**\n   * The Cognito User Pool Domain used for authentication.\n   */\n  readonly userPoolDomain: IUserPoolDomain;\n\n  /**\n   * The Route 53 hosted zone where the ALB's DNS record will be created.\n   */\n  readonly hostedZone: IHostedZone;\n\n  /**\n   * Additional callback URLs to be added to the Cognito User Pool Client.\n   *\n   * @default - No additional callback URLs are configured.\n   */\n  readonly additionalCallbackUrls?: string[];\n\n  /**\n   * The port on which the target group will receive traffic.\n   */\n  readonly trafficPort: number;\n\n  /**\n   * The health check path for the target group.\n   */\n  readonly healtCheckPath: string;\n}\n\n/**\n * A construct that creates an Application Load Balancer (ALB) with Cognito authentication.\n *\n * This construct:\n * - Creates an ALB with an HTTPS listener and a Cognito authentication action.\n * - Configures a target group with health checks.\n * - Adds a Route 53 DNS record for the ALB.\n * - Exports key ALB properties (listener ARN, target group ARN, security group ID) as CloudFormation outputs.\n */\nexport class ApplicationLoadBalancerV2 extends Construct {\n  public readonly loadbalancer: AWSApplicationLoadBalancer;\n\n  public get loadBalancer(): IApplicationLoadBalancer {\n    return this.loadbalancer;\n  }\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: ApplicationLoadBalancerPropsV2,\n  ) {\n    super(scope, id);\n\n    const certificate = new Certificate(this, \"Certificate\", {\n      domainName: props.fqdn,\n      validation: CertificateValidation.fromDns(props.hostedZone),\n    });\n\n    this.loadbalancer = new AWSApplicationLoadBalancer(this, \"ALB\", {\n      vpc: props.vpc,\n      internetFacing: true,\n    });\n\n    const listener = this.loadbalancer.addListener(\"Listener\", {\n      port: 443,\n      certificates: [certificate],\n      defaultAction: new AuthenticateCognitoAction({\n        userPool: props.userPoolClient.userPool,\n        userPoolClient: props.userPoolClient.client,\n        userPoolDomain: props.userPoolDomain,\n        next: ListenerAction.fixedResponse(200, {\n          messageBody: \"This is the ALB default action\",\n        }),\n        onUnauthenticatedRequest: UnauthenticatedAction.AUTHENTICATE,\n      }),\n    });\n\n    const targetGroup = new ApplicationTargetGroup(this, `${id}TargetGroup`, {\n      vpc: props.vpc,\n      port: props.trafficPort,\n      protocol: ApplicationProtocol.HTTP,\n      deregistrationDelay: Duration.seconds(10),\n      targets: [],\n      healthCheck: {\n        path: props.healtCheckPath,\n      },\n    });\n\n    listener.addAction(`${id}Action`, {\n      priority: 55,\n      conditions: [ListenerCondition.hostHeaders([props.fqdn])],\n      action: new AuthenticateCognitoAction({\n        userPool: props.userPoolClient.userPool,\n        userPoolClient: props.userPoolClient.client,\n        userPoolDomain: props.userPoolDomain,\n        next: ListenerAction.forward([targetGroup]),\n        onUnauthenticatedRequest: UnauthenticatedAction.AUTHENTICATE,\n      }),\n    });\n\n    new ARecord(this, \"ALBARecord\", {\n      zone: props.hostedZone,\n      recordName: props.fqdn,\n      target: RecordTarget.fromAlias(new LoadBalancerTarget(this.loadBalancer)),\n    });\n\n    const exportValue = createExporter(this, \"alb-v2\");\n\n    exportValue({\n      name: \"ALB Listener ARN\",\n      key: \"listener-arn\",\n      value: listener.listenerArn,\n    });\n\n    exportValue({\n      name: \"default target group ARN\",\n      key: \"alb-target-group-arn\",\n      value: targetGroup.targetGroupArn,\n    });\n\n    exportValue({\n      name: \"ALB Security Group Id\",\n      key: \"security-group-id\",\n      value: Fn.select(0, this.loadbalancer.loadBalancerSecurityGroups),\n    });\n  }\n}\n"]}
97
+ _b = JSII_RTTI_SYMBOL_1;
98
+ ApplicationLoadBalancerV2[_b] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerV2", version: "0.9.5" };
99
+ ApplicationLoadBalancerV2.securityGroupIdParameter = new utils_1.StackParameter({
100
+ name: "ALB Security Group Id",
101
+ key: "security-group-id",
102
+ prefix: "alb",
103
+ version: 2,
104
+ });
105
+ ApplicationLoadBalancerV2.targetGroupIdParameter = new utils_1.StackParameter({
106
+ name: "ALB Target Group Id",
107
+ key: "target-group-id",
108
+ prefix: "alb",
109
+ version: 2,
110
+ });
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApplicationLoadBalancerV2.js","sourceRoot":"","sources":["../../src/platform/ApplicationLoadBalancerV2.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Fn } from \"aws-cdk-lib\";\nimport {\n  Certificate,\n  CertificateValidation,\n} from \"aws-cdk-lib/aws-certificatemanager\";\nimport { IUserPoolDomain } from \"aws-cdk-lib/aws-cognito\";\nimport { IVpc } from \"aws-cdk-lib/aws-ec2\";\nimport {\n  ApplicationProtocol,\n  ApplicationTargetGroup,\n  ApplicationLoadBalancer as AWSApplicationLoadBalancer,\n  IApplicationLoadBalancerTarget,\n  IApplicationTargetGroup,\n  ListenerAction,\n  ListenerCondition,\n  UnauthenticatedAction,\n} from \"aws-cdk-lib/aws-elasticloadbalancingv2\";\nimport { AuthenticateCognitoAction } from \"aws-cdk-lib/aws-elasticloadbalancingv2-actions\";\nimport { ARecord, IHostedZone, RecordTarget } from \"aws-cdk-lib/aws-route53\";\nimport { LoadBalancerTarget } from \"aws-cdk-lib/aws-route53-targets\";\nimport { Construct } from \"constructs\";\nimport { StackParameter } from \"../utils\";\nimport { CognitoUserPool } from \"./CognitoUserPool\";\n\nexport interface ApplicationLoadBalancerPropsV2 {\n  /**\n   * The fully qualified domain name (FQDN) for the Application Load Balancer (ALB).\n   * This is used for configuring DNS records.\n   */\n  readonly fqdn: string;\n\n  /**\n   * The VPC in which the Application Load Balancer will be deployed.\n   */\n  readonly vpc: IVpc;\n\n  /**\n   * The Cognito User Pool of this base platform.\n   */\n  readonly userPool: CognitoUserPool;\n\n  /**\n   * The Cognito User Pool Domain used for authentication.\n   */\n  readonly userPoolDomain: IUserPoolDomain;\n\n  /**\n   * The Route 53 hosted zone where the ALB's DNS record will be created.\n   */\n  readonly hostedZone: IHostedZone;\n\n  /**\n   * Additional callback URLs to be added to the Cognito User Pool Client.\n   *\n   * @default - No additional callback URLs are configured.\n   */\n  readonly additionalCallbackUrls?: string[];\n\n  /**\n   * The port on which the target group will receive traffic.\n   */\n  readonly trafficPort: number;\n\n  /**\n   * The health check path for the target group.\n   */\n  readonly healtCheckPath: string;\n}\n\nexport interface ApplicationLoadBalancerV2LookupOptions {\n  readonly basePlatform: string;\n}\n\nexport interface IApplicationLoadBalancerV2 {\n  readonly targetGroup: IApplicationTargetGroup;\n\n  addTarget(target: IApplicationLoadBalancerTarget): void;\n}\n\nexport abstract class ApplicationLoadBalancerV2Base\n  extends Construct\n  implements IApplicationLoadBalancerV2\n{\n  abstract readonly targetGroup: IApplicationTargetGroup;\n\n  addTarget(target: IApplicationLoadBalancerTarget) {\n    return this.targetGroup.addTarget(target);\n  }\n}\n\n/**\n * A construct that creates an Application Load Balancer (ALB) with Cognito authentication.\n *\n * This construct:\n * - Creates an ALB with an HTTPS listener and a Cognito authentication action.\n * - Configures a target group with health checks.\n * - Adds a Route 53 DNS record for the ALB.\n * - Exports key ALB properties (listener ARN, target group ARN, security group ID) as CloudFormation outputs.\n */\nexport class ApplicationLoadBalancerV2 extends ApplicationLoadBalancerV2Base {\n  static fromBasePlatform(\n    scope: Construct,\n    id: string,\n    { basePlatform }: ApplicationLoadBalancerV2LookupOptions,\n  ): IApplicationLoadBalancerV2 {\n    class Import extends ApplicationLoadBalancerV2Base {\n      readonly targetGroup: IApplicationTargetGroup =\n        ApplicationTargetGroup.fromTargetGroupAttributes(\n          this,\n          \"TargetGroupLookup\",\n          {\n            targetGroupArn:\n              ApplicationLoadBalancerV2.targetGroupIdParameter.import(\n                basePlatform,\n              ),\n          },\n        );\n    }\n\n    return new Import(scope, id);\n  }\n\n  private static readonly securityGroupIdParameter = new StackParameter({\n    name: \"ALB Security Group Id\",\n    key: \"security-group-id\",\n    prefix: \"alb\",\n    version: 2,\n  });\n\n  private static readonly targetGroupIdParameter = new StackParameter({\n    name: \"ALB Target Group Id\",\n    key: \"target-group-id\",\n    prefix: \"alb\",\n    version: 2,\n  });\n\n  private readonly alb: AWSApplicationLoadBalancer;\n  readonly targetGroup: IApplicationTargetGroup;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: ApplicationLoadBalancerPropsV2,\n  ) {\n    super(scope, id);\n\n    const certificate = new Certificate(this, \"Certificate\", {\n      domainName: props.fqdn,\n      validation: CertificateValidation.fromDns(props.hostedZone),\n    });\n\n    this.alb = new AWSApplicationLoadBalancer(this, \"ALB\", {\n      vpc: props.vpc,\n      internetFacing: true,\n    });\n\n    const listener = this.alb.addListener(\"Listener\", {\n      port: 443,\n      certificates: [certificate],\n      defaultAction: new AuthenticateCognitoAction({\n        userPool: props.userPool.userPool,\n        userPoolClient: props.userPool.appUserPoolClient,\n        userPoolDomain: props.userPoolDomain,\n        next: ListenerAction.fixedResponse(200, {\n          messageBody: \"This is the ALB default action\",\n        }),\n        onUnauthenticatedRequest: UnauthenticatedAction.AUTHENTICATE,\n      }),\n    });\n\n    this.targetGroup = new ApplicationTargetGroup(this, `${id}TargetGroup`, {\n      vpc: props.vpc,\n      port: props.trafficPort,\n      protocol: ApplicationProtocol.HTTP,\n      deregistrationDelay: Duration.seconds(10),\n      targets: [],\n      healthCheck: {\n        path: props.healtCheckPath,\n      },\n    });\n\n    listener.addAction(`${id}Action`, {\n      priority: 55,\n      conditions: [ListenerCondition.hostHeaders([props.fqdn])],\n      action: new AuthenticateCognitoAction({\n        userPool: props.userPool.userPool,\n        userPoolClient: props.userPool.appUserPoolClient,\n        userPoolDomain: props.userPoolDomain,\n        next: ListenerAction.forward([this.targetGroup]),\n        onUnauthenticatedRequest: UnauthenticatedAction.AUTHENTICATE,\n      }),\n    });\n\n    new ARecord(this, \"ALBARecord\", {\n      zone: props.hostedZone,\n      recordName: props.fqdn,\n      target: RecordTarget.fromAlias(new LoadBalancerTarget(this.alb)),\n    });\n\n    ApplicationLoadBalancerV2.targetGroupIdParameter.export(\n      this,\n      this.targetGroup.targetGroupArn,\n    );\n\n    ApplicationLoadBalancerV2.securityGroupIdParameter.export(\n      this,\n      Fn.select(0, this.alb.loadBalancerSecurityGroups),\n    );\n  }\n}\n"]}
@@ -1,14 +1,61 @@
1
- import { IUserPool } from "aws-cdk-lib/aws-cognito";
1
+ import { CognitoUserPoolsAuthorizer } from "aws-cdk-lib/aws-apigateway";
2
+ import { HttpUserPoolAuthorizer } from "aws-cdk-lib/aws-apigatewayv2-authorizers";
3
+ import { IUserPool, IUserPoolClient } from "aws-cdk-lib/aws-cognito";
2
4
  import { Construct } from "constructs";
5
+ import { ResourceServer } from "./ResourceServer";
3
6
  export interface CognitoUserPoolProps {
4
7
  /**
5
8
  * The ID of the Cognito User Pool to be imported.
6
9
  */
7
10
  readonly userPoolId: string;
11
+ /**
12
+ * The fully qualified domain name which the ALB will listen to.
13
+ *
14
+ * This setting is used to configure the correct callback URL for user pool
15
+ * client such that the ALB can perform authentication.
16
+ *
17
+ */
18
+ readonly fqdn: string;
19
+ /**
20
+ * Specify additional user pool identity providers to enable federated login.
21
+ */
22
+ readonly additonalUserPoolIdentityProviders?: string[];
23
+ /**
24
+ * The resource server associated with the user pool client.
25
+ * This is used to define OAuth scopes for the client.
26
+ */
27
+ readonly resourceServer: ResourceServer;
28
+ /**
29
+ * Specify valid logout URLs which should be added to the frontend user pool client.
30
+ */
31
+ readonly logoutUrls?: string[];
32
+ /**
33
+ * Specify additional callback URLs which the frontend uses for OIDC authentication.
34
+ *
35
+ */
36
+ readonly callbackUrls?: string[];
37
+ }
38
+ export interface ICognitoUserPool {
39
+ readonly userPool: IUserPool;
40
+ readonly appUserPoolClient: IUserPoolClient;
41
+ readonly apiUserPoolClient: IUserPoolClient;
42
+ createHttpUserPoolAuthorizer(): HttpUserPoolAuthorizer;
43
+ createCognitoUserPoolsAuthorizer(): CognitoUserPoolsAuthorizer;
44
+ }
45
+ export declare abstract class CognitoUserPoolBase extends Construct implements ICognitoUserPool {
46
+ abstract readonly userPool: IUserPool;
47
+ abstract readonly appUserPoolClient: IUserPoolClient;
48
+ abstract readonly apiUserPoolClient: IUserPoolClient;
49
+ createHttpUserPoolAuthorizer(): HttpUserPoolAuthorizer;
50
+ createCognitoUserPoolsAuthorizer(): CognitoUserPoolsAuthorizer;
8
51
  }
9
- export declare class CognitoUserPool extends Construct {
10
- userPool: IUserPool;
11
- private readonly OUTPUT_PARAMETER_PREFIX;
52
+ export declare class CognitoUserPool extends CognitoUserPoolBase {
53
+ static fromBasePlatform(scope: Construct, id: string, basePlatform: string): ICognitoUserPool;
54
+ private static readonly userPoolIdParameter;
55
+ private static readonly appUserPoolClientParameter;
56
+ private static readonly apiUserPoolClientParameter;
57
+ readonly userPool: IUserPool;
58
+ readonly appUserPoolClient: IUserPoolClient;
59
+ readonly apiUserPoolClient: IUserPoolClient;
12
60
  constructor(scope: Construct, id: string, props: CognitoUserPoolProps);
13
- private exposeParameters;
14
61
  }