@btc-embedded/cdk-extensions 0.22.2 → 0.22.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +283 -202
- package/API.md +238 -62
- package/CHANGELOG.md +7 -0
- package/README.md +2 -0
- package/lib/constructs/EventPipe.js +1 -1
- package/lib/constructs/ExportedService.js +1 -1
- package/lib/constructs/S3Bucket.js +1 -1
- package/lib/constructs/SecureRestApi.js +1 -1
- package/lib/constructs/SecureRestApiV2.js +1 -1
- package/lib/constructs/api-keys/ApiKeyClientAuthorization.js +1 -1
- package/lib/constructs/api-keys/ApiKeyManagement.d.ts +0 -5
- package/lib/constructs/api-keys/ApiKeyManagement.js +2 -2
- package/lib/constructs/api-keys/ApiKeyPreTokenHandler.js +1 -1
- package/lib/constructs/api-keys/ApiKeyStore.js +1 -1
- package/lib/extensions/ApiGatewayExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtensionV2.d.ts +19 -0
- package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +10 -2
- package/lib/extensions/CloudMapExtension.js +1 -1
- package/lib/extensions/DeactivatableServiceExtension.js +1 -1
- package/lib/extensions/DeploymentConfigExtension.js +1 -1
- package/lib/extensions/DocumentDbAccessExtension.d.ts +24 -0
- package/lib/extensions/DocumentDbAccessExtension.js +12 -2
- package/lib/extensions/DomainEventMessagingExtension.d.ts +17 -0
- package/lib/extensions/DomainEventMessagingExtension.js +11 -2
- package/lib/extensions/EfsMountExtension.js +1 -1
- package/lib/extensions/ExecExtension.d.ts +26 -0
- package/lib/extensions/ExecExtension.js +26 -1
- package/lib/extensions/ExtraContainerExtension.js +1 -1
- package/lib/extensions/HTTPApiExtension.js +1 -1
- package/lib/extensions/LogExtension.d.ts +18 -0
- package/lib/extensions/LogExtension.js +19 -2
- package/lib/extensions/ModifyContainerDefinitionExtension.js +1 -1
- package/lib/extensions/ModifyTaskDefinitionExtension.js +1 -1
- package/lib/extensions/OpenIdExtension.d.ts +27 -0
- package/lib/extensions/OpenIdExtension.js +28 -2
- package/lib/extensions/OpenTelemetryExtension.js +1 -1
- package/lib/extensions/PostgresDbAccessExtension.d.ts +44 -1
- package/lib/extensions/PostgresDbAccessExtension.js +47 -2
- package/lib/extensions/SharedVolumeExtension.js +1 -1
- package/lib/extensions/TcpKeepAliveExtension.d.ts +30 -0
- package/lib/extensions/TcpKeepAliveExtension.js +23 -2
- package/lib/platform/ApiGateway.d.ts +1 -1
- package/lib/platform/ApiGateway.js +3 -3
- package/lib/platform/ApiGatewayVpcLink.js +2 -2
- package/lib/platform/ApplicationLoadBalancer.js +1 -1
- package/lib/platform/ApplicationLoadBalancerV2.js +2 -2
- package/lib/platform/BTCLogGroup.js +1 -1
- package/lib/platform/CognitoUserPool.js +2 -2
- package/lib/platform/DefaultUserPoolClients.js +1 -1
- package/lib/platform/DocumentDB.d.ts +37 -0
- package/lib/platform/DocumentDB.js +22 -3
- package/lib/platform/EcsCluster.js +1 -1
- package/lib/platform/EfsFileSystem.js +1 -1
- package/lib/platform/HostedZone.js +1 -1
- package/lib/platform/PrivateDnsNamespace.d.ts +43 -0
- package/lib/platform/PrivateDnsNamespace.js +22 -2
- package/lib/platform/ResourceServer.js +1 -1
- package/lib/platform/Vpc.js +1 -1
- package/lib/platform/VpcV2.js +1 -1
- package/lib/stacks/ApplicationStack.js +1 -1
- package/lib/utils/BasePlatformStackResolver.js +1 -1
- package/lib/utils/StackParameter.js +1 -1
- package/lib/utils/configFileParsing.d.ts +8 -6
- package/lib/utils/configFileParsing.js +9 -7
- package/package.json +4 -1
- package/typedoc.json +44 -0
|
@@ -3,9 +3,13 @@ import * as ecs from "aws-cdk-lib/aws-ecs";
|
|
|
3
3
|
import { ILogGroup } from "aws-cdk-lib/aws-logs";
|
|
4
4
|
import { ISecret } from "aws-cdk-lib/aws-secretsmanager";
|
|
5
5
|
import { Construct } from "constructs";
|
|
6
|
+
/**
|
|
7
|
+
* Optional overrides for the environment variable names injected into
|
|
8
|
+
* application containers.
|
|
9
|
+
*/
|
|
6
10
|
export interface EnvironmentVariableNames {
|
|
7
11
|
/**
|
|
8
|
-
* Environment variable for the
|
|
12
|
+
* Environment variable for the connection string.
|
|
9
13
|
*
|
|
10
14
|
* @default DATABASE_URL
|
|
11
15
|
*/
|
|
@@ -81,15 +85,54 @@ export interface PostgresDbAccessExtensionProps {
|
|
|
81
85
|
*/
|
|
82
86
|
readonly migrationParameter?: string;
|
|
83
87
|
}
|
|
88
|
+
/**
|
|
89
|
+
* ECS service extension that grants an ECS service access to an Aurora Postgres
|
|
90
|
+
* database created by the base platform.
|
|
91
|
+
*
|
|
92
|
+
* What it does:
|
|
93
|
+
* - Imports DB endpoint, secrets and security group IDs from the base platform stack outputs.
|
|
94
|
+
* - Allows the service SG to connect to the DB SG on port 5432.
|
|
95
|
+
* - Injects connection details into selected containers via container hooks.
|
|
96
|
+
* - Optionally adds a one-shot migration container and wires dependencies so the
|
|
97
|
+
* main container starts only after migrations succeed.
|
|
98
|
+
*/
|
|
84
99
|
export declare class PostgresDbAccessExtension extends ServiceExtension {
|
|
85
100
|
readonly props: PostgresDbAccessExtensionProps;
|
|
101
|
+
/** Connection-string secret created for this service (populated in {@link prehook}). */
|
|
86
102
|
connectionString: ISecret;
|
|
103
|
+
/** Credentials secret imported from base platform (populated in {@link prehook}). */
|
|
87
104
|
credentialsSecret: ISecret;
|
|
105
|
+
/** Database endpoint imported from base platform (populated in {@link prehook}). */
|
|
88
106
|
endpoint: string;
|
|
89
107
|
constructor(props: PostgresDbAccessExtensionProps);
|
|
108
|
+
/**
|
|
109
|
+
* Resolves base-platform outputs (endpoint, secret ARNs) and prepares a
|
|
110
|
+
* service-specific connection-string secret.
|
|
111
|
+
*/
|
|
90
112
|
prehook(parent: Service, _scope: Construct): void;
|
|
113
|
+
/**
|
|
114
|
+
* Applies the Postgres env/secrets hook to database-access containers.
|
|
115
|
+
*
|
|
116
|
+
* If `enableMigration` is true, also applies the hook to the migration
|
|
117
|
+
* container (created later in {@link useTaskDefinition}).
|
|
118
|
+
*/
|
|
91
119
|
addHooks(): void;
|
|
120
|
+
/**
|
|
121
|
+
* Grants the ECS service security group ingress to the database security group
|
|
122
|
+
* on TCP 5432.
|
|
123
|
+
*/
|
|
92
124
|
useService(service: ecs.Ec2Service | ecs.FargateService): void;
|
|
125
|
+
/**
|
|
126
|
+
* Optionally adds a non-essential migration container that runs before the
|
|
127
|
+
* default container.
|
|
128
|
+
*
|
|
129
|
+
* The migration container uses the same image repo/tag as the default
|
|
130
|
+
* container, but runs with `command: [migrationParameter]`.
|
|
131
|
+
*/
|
|
93
132
|
useTaskDefinition(taskDefinition: ecs.TaskDefinition): void;
|
|
133
|
+
/**
|
|
134
|
+
* When migrations are enabled, ensures the default container depends on the
|
|
135
|
+
* migration container completing successfully.
|
|
136
|
+
*/
|
|
94
137
|
modifyServiceProps(props: ServiceBuild): ServiceBuild;
|
|
95
138
|
}
|
|
@@ -10,6 +10,15 @@ const aws_ecr_1 = require("aws-cdk-lib/aws-ecr");
|
|
|
10
10
|
const ecs = require("aws-cdk-lib/aws-ecs");
|
|
11
11
|
const aws_secretsmanager_1 = require("aws-cdk-lib/aws-secretsmanager");
|
|
12
12
|
const utils_1 = require("../utils");
|
|
13
|
+
/**
|
|
14
|
+
* Container mutating hook that injects Postgres connection details into an ECS
|
|
15
|
+
* container.
|
|
16
|
+
*
|
|
17
|
+
* Injects:
|
|
18
|
+
* - Connection string as a secret (default env var: `DATABASE_URL`)
|
|
19
|
+
* - Username/password as secrets (`POSTGRES_USERNAME`, `POSTGRES_PASSWORD`)
|
|
20
|
+
* - Endpoint/database name as plain env vars (`POSTGRES_ENDPOINT`, `POSTGRES_DATABASE`)
|
|
21
|
+
*/
|
|
13
22
|
class AddPostgresDbHook extends ecs_service_extensions_1.ContainerMutatingHook {
|
|
14
23
|
constructor(connectionStringSecret, credentialsSecret, endpoint, dbName, environmentVariableNames = {}) {
|
|
15
24
|
super();
|
|
@@ -49,11 +58,26 @@ class AddPostgresDbHook extends ecs_service_extensions_1.ContainerMutatingHook {
|
|
|
49
58
|
};
|
|
50
59
|
}
|
|
51
60
|
}
|
|
61
|
+
/**
|
|
62
|
+
* ECS service extension that grants an ECS service access to an Aurora Postgres
|
|
63
|
+
* database created by the base platform.
|
|
64
|
+
*
|
|
65
|
+
* What it does:
|
|
66
|
+
* - Imports DB endpoint, secrets and security group IDs from the base platform stack outputs.
|
|
67
|
+
* - Allows the service SG to connect to the DB SG on port 5432.
|
|
68
|
+
* - Injects connection details into selected containers via container hooks.
|
|
69
|
+
* - Optionally adds a one-shot migration container and wires dependencies so the
|
|
70
|
+
* main container starts only after migrations succeed.
|
|
71
|
+
*/
|
|
52
72
|
class PostgresDbAccessExtension extends ecs_service_extensions_1.ServiceExtension {
|
|
53
73
|
constructor(props) {
|
|
54
74
|
super("postgresdb-access-extension");
|
|
55
75
|
this.props = props;
|
|
56
76
|
}
|
|
77
|
+
/**
|
|
78
|
+
* Resolves base-platform outputs (endpoint, secret ARNs) and prepares a
|
|
79
|
+
* service-specific connection-string secret.
|
|
80
|
+
*/
|
|
57
81
|
prehook(parent, _scope) {
|
|
58
82
|
this.parentService = parent;
|
|
59
83
|
const credentialsSecretArnParameter = new utils_1.StackParameter({
|
|
@@ -84,6 +108,12 @@ class PostgresDbAccessExtension extends ecs_service_extensions_1.ServiceExtensio
|
|
|
84
108
|
secretStringValue: new aws_cdk_lib_1.SecretValue(`${urlSecret.secretValue}${this.props.dbName}?${queryParameters ?? ""}`),
|
|
85
109
|
});
|
|
86
110
|
}
|
|
111
|
+
/**
|
|
112
|
+
* Applies the Postgres env/secrets hook to database-access containers.
|
|
113
|
+
*
|
|
114
|
+
* If `enableMigration` is true, also applies the hook to the migration
|
|
115
|
+
* container (created later in {@link useTaskDefinition}).
|
|
116
|
+
*/
|
|
87
117
|
addHooks() {
|
|
88
118
|
const hook = new AddPostgresDbHook(this.connectionString, this.credentialsSecret, this.endpoint, this.props.dbName, this.props.environmentVariableNames);
|
|
89
119
|
(0, utils_1.filterDbAccessContainers)(this.parentService).forEach((extension) => extension.addContainerMutatingHook(hook));
|
|
@@ -91,6 +121,10 @@ class PostgresDbAccessExtension extends ecs_service_extensions_1.ServiceExtensio
|
|
|
91
121
|
this.addContainerMutatingHook(hook);
|
|
92
122
|
}
|
|
93
123
|
}
|
|
124
|
+
/**
|
|
125
|
+
* Grants the ECS service security group ingress to the database security group
|
|
126
|
+
* on TCP 5432.
|
|
127
|
+
*/
|
|
94
128
|
useService(service) {
|
|
95
129
|
const securityGroupIdParameter = new utils_1.StackParameter({
|
|
96
130
|
prefix: ["aurora-postgres-db"],
|
|
@@ -99,6 +133,13 @@ class PostgresDbAccessExtension extends ecs_service_extensions_1.ServiceExtensio
|
|
|
99
133
|
const sgId = securityGroupIdParameter.import(service, this.props.basePlatformStackName);
|
|
100
134
|
aws_ec2_1.SecurityGroup.fromSecurityGroupId(service, "PostgresDbSecurityGroup", sgId).connections.allowFrom(service, aws_ec2_1.Port.tcp(5432));
|
|
101
135
|
}
|
|
136
|
+
/**
|
|
137
|
+
* Optionally adds a non-essential migration container that runs before the
|
|
138
|
+
* default container.
|
|
139
|
+
*
|
|
140
|
+
* The migration container uses the same image repo/tag as the default
|
|
141
|
+
* container, but runs with `command: [migrationParameter]`.
|
|
142
|
+
*/
|
|
102
143
|
useTaskDefinition(taskDefinition) {
|
|
103
144
|
if (!this.props.enableMigration) {
|
|
104
145
|
return;
|
|
@@ -127,6 +168,10 @@ class PostgresDbAccessExtension extends ecs_service_extensions_1.ServiceExtensio
|
|
|
127
168
|
}
|
|
128
169
|
this.container = taskDefinition.addContainer("DatabaseMigrationContainer", containerProps);
|
|
129
170
|
}
|
|
171
|
+
/**
|
|
172
|
+
* When migrations are enabled, ensures the default container depends on the
|
|
173
|
+
* migration container completing successfully.
|
|
174
|
+
*/
|
|
130
175
|
modifyServiceProps(props) {
|
|
131
176
|
if (!this.props.enableMigration) {
|
|
132
177
|
return props;
|
|
@@ -140,5 +185,5 @@ class PostgresDbAccessExtension extends ecs_service_extensions_1.ServiceExtensio
|
|
|
140
185
|
}
|
|
141
186
|
exports.PostgresDbAccessExtension = PostgresDbAccessExtension;
|
|
142
187
|
_a = JSII_RTTI_SYMBOL_1;
|
|
143
|
-
PostgresDbAccessExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.PostgresDbAccessExtension", version: "0.22.
|
|
144
|
-
//# 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  ServiceBuild,\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 { Repository } from \"aws-cdk-lib/aws-ecr\";\nimport * as ecs from \"aws-cdk-lib/aws-ecs\";\nimport { ILogGroup } from \"aws-cdk-lib/aws-logs\";\nimport { ISecret, Secret } from \"aws-cdk-lib/aws-secretsmanager\";\nimport { Construct } from \"constructs\";\nimport { filterDbAccessContainers, StackParameter } from \"../utils\";\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   * The name of the database.\n   */\n  readonly dbName: string;\n\n  /**\n   * Specify a log group to use for the database migration container.\n   *\n   * This log group is used when the log extension is not added to the service.\n   *\n   * @default - creates a new log group\n   */\n  readonly logGroup?: ILogGroup;\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  /**\n   * Enable database migration by calling the default image with the migration\n   * parameter. The image has to support migration.\n   * The database variables will be passed to the container as configured for\n   * the extension.\n   * @default false\n   */\n  readonly enableMigration?: boolean;\n\n  /**\n   * The parameter passed to the default container to perform the database migration.\n   *\n   * @default \"migrate\"\n   */\n  readonly migrationParameter?: string;\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  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\n    const credentialsSecretArnParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"credentials-secret-arn\",\n    });\n    const clusterEndpointParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"cluster-endpoint\",\n    });\n    const secretArnParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"secret-arn\",\n    });\n\n    const credentialsSecretArn = credentialsSecretArnParameter.import(\n      parent,\n      this.props.basePlatformStackName,\n    );\n\n    this.endpoint = clusterEndpointParameter.import(\n      parent,\n      this.props.basePlatformStackName,\n    );\n\n    this.credentialsSecret = Secret.fromSecretCompleteArn(\n      parent,\n      \"CredentialsSecret\",\n      credentialsSecretArn,\n    );\n\n    const secretArn = secretArnParameter.import(\n      parent,\n      this.props.basePlatformStackName,\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      parent,\n      \"DbSecret\",\n      secretArn,\n    );\n\n    this.connectionString = new Secret(parent, \"DBConnectionStringSecret\", {\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  public addHooks() {\n    const hook = new AddPostgresDbHook(\n      this.connectionString,\n      this.credentialsSecret,\n      this.endpoint,\n      this.props.dbName,\n      this.props.environmentVariableNames,\n    );\n    filterDbAccessContainers(this.parentService).forEach((extension) =>\n      extension.addContainerMutatingHook(hook),\n    );\n    if (this.props.enableMigration) {\n      this.addContainerMutatingHook(hook);\n    }\n  }\n\n  public useService(service: ecs.Ec2Service | ecs.FargateService): void {\n    const securityGroupIdParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"security-group-id\",\n    });\n\n    const sgId = securityGroupIdParameter.import(\n      service,\n      this.props.basePlatformStackName,\n    );\n\n    SecurityGroup.fromSecurityGroupId(\n      service,\n      \"PostgresDbSecurityGroup\",\n      sgId,\n    ).connections.allowFrom(service, Port.tcp(5432));\n  }\n\n  public useTaskDefinition(taskDefinition: ecs.TaskDefinition): void {\n    if (!this.props.enableMigration) {\n      return;\n    }\n\n    const imageNameString = taskDefinition.defaultContainer!.imageName;\n\n    const imageParts = imageNameString.split(\"/\");\n    const imageName = imageParts.slice(1).join(\"/\");\n\n    const [repoName, imageTag] = imageName.split(\":\");\n\n    const image = ecs.EcrImage.fromEcrRepository(\n      Repository.fromRepositoryName(\n        taskDefinition,\n        \"DatabaseMigrationRepository\",\n        repoName,\n      ),\n      imageTag,\n    );\n\n    let containerProps: ecs.ContainerDefinitionOptions = {\n      image: image,\n      essential: false,\n      command: [this.props.migrationParameter ?? \"migrate\"],\n    };\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.logGroup,\n        }),\n      };\n    }\n\n    this.container = taskDefinition.addContainer(\n      \"DatabaseMigrationContainer\",\n      containerProps,\n    );\n  }\n\n  public modifyServiceProps(props: ServiceBuild): ServiceBuild {\n    if (!this.props.enableMigration) {\n      return props;\n    }\n    props.taskDefinition.defaultContainer?.addContainerDependencies({\n      container: this.container!,\n      condition: ecs.ContainerDependencyCondition.SUCCESS,\n    });\n    return props;\n  }\n}\n"]}
|
|
188
|
+
PostgresDbAccessExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.PostgresDbAccessExtension", version: "0.22.3" };
|
|
189
|
+
//# 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  ServiceBuild,\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 { Repository } from \"aws-cdk-lib/aws-ecr\";\nimport * as ecs from \"aws-cdk-lib/aws-ecs\";\nimport { ILogGroup } from \"aws-cdk-lib/aws-logs\";\nimport { ISecret, Secret } from \"aws-cdk-lib/aws-secretsmanager\";\nimport { Construct } from \"constructs\";\nimport { filterDbAccessContainers, StackParameter } from \"../utils\";\n\n/**\n * Optional overrides for the environment variable names injected into\n * application containers.\n */\nexport interface EnvironmentVariableNames {\n  /**\n   * Environment variable for the connection 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   * The name of the database.\n   */\n  readonly dbName: string;\n\n  /**\n   * Specify a log group to use for the database migration container.\n   *\n   * This log group is used when the log extension is not added to the service.\n   *\n   * @default - creates a new log group\n   */\n  readonly logGroup?: ILogGroup;\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  /**\n   * Enable database migration by calling the default image with the migration\n   * parameter. The image has to support migration.\n   * The database variables will be passed to the container as configured for\n   * the extension.\n   * @default false\n   */\n  readonly enableMigration?: boolean;\n\n  /**\n   * The parameter passed to the default container to perform the database migration.\n   *\n   * @default \"migrate\"\n   */\n  readonly migrationParameter?: string;\n}\n\n/**\n * Container mutating hook that injects Postgres connection details into an ECS\n * container.\n *\n * Injects:\n * - Connection string as a secret (default env var: `DATABASE_URL`)\n * - Username/password as secrets (`POSTGRES_USERNAME`, `POSTGRES_PASSWORD`)\n * - Endpoint/database name as plain env vars (`POSTGRES_ENDPOINT`, `POSTGRES_DATABASE`)\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\n/**\n * ECS service extension that grants an ECS service access to an Aurora Postgres\n * database created by the base platform.\n *\n * What it does:\n * - Imports DB endpoint, secrets and security group IDs from the base platform stack outputs.\n * - Allows the service SG to connect to the DB SG on port 5432.\n * - Injects connection details into selected containers via container hooks.\n * - Optionally adds a one-shot migration container and wires dependencies so the\n *   main container starts only after migrations succeed.\n */\nexport class PostgresDbAccessExtension extends ServiceExtension {\n  readonly props: PostgresDbAccessExtensionProps;\n\n  /** Connection-string secret created for this service (populated in {@link prehook}). */\n  connectionString!: ISecret;\n\n  /** Credentials secret imported from base platform (populated in {@link prehook}). */\n  credentialsSecret!: ISecret;\n\n  /** Database endpoint imported from base platform (populated in {@link prehook}). */\n  endpoint!: string;\n\n  constructor(props: PostgresDbAccessExtensionProps) {\n    super(\"postgresdb-access-extension\");\n    this.props = props;\n  }\n\n  /**\n   * Resolves base-platform outputs (endpoint, secret ARNs) and prepares a\n   * service-specific connection-string secret.\n   */\n  prehook(parent: Service, _scope: Construct): void {\n    this.parentService = parent;\n\n    const credentialsSecretArnParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"credentials-secret-arn\",\n    });\n    const clusterEndpointParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"cluster-endpoint\",\n    });\n    const secretArnParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"secret-arn\",\n    });\n\n    const credentialsSecretArn = credentialsSecretArnParameter.import(\n      parent,\n      this.props.basePlatformStackName,\n    );\n\n    this.endpoint = clusterEndpointParameter.import(\n      parent,\n      this.props.basePlatformStackName,\n    );\n\n    this.credentialsSecret = Secret.fromSecretCompleteArn(\n      parent,\n      \"CredentialsSecret\",\n      credentialsSecretArn,\n    );\n\n    const secretArn = secretArnParameter.import(\n      parent,\n      this.props.basePlatformStackName,\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      parent,\n      \"DbSecret\",\n      secretArn,\n    );\n\n    this.connectionString = new Secret(parent, \"DBConnectionStringSecret\", {\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   * Applies the Postgres env/secrets hook to database-access containers.\n   *\n   * If `enableMigration` is true, also applies the hook to the migration\n   * container (created later in {@link useTaskDefinition}).\n   */\n  public addHooks() {\n    const hook = new AddPostgresDbHook(\n      this.connectionString,\n      this.credentialsSecret,\n      this.endpoint,\n      this.props.dbName,\n      this.props.environmentVariableNames,\n    );\n    filterDbAccessContainers(this.parentService).forEach((extension) =>\n      extension.addContainerMutatingHook(hook),\n    );\n    if (this.props.enableMigration) {\n      this.addContainerMutatingHook(hook);\n    }\n  }\n\n  /**\n   * Grants the ECS service security group ingress to the database security group\n   * on TCP 5432.\n   */\n  public useService(service: ecs.Ec2Service | ecs.FargateService): void {\n    const securityGroupIdParameter = new StackParameter({\n      prefix: [\"aurora-postgres-db\"],\n      key: \"security-group-id\",\n    });\n\n    const sgId = securityGroupIdParameter.import(\n      service,\n      this.props.basePlatformStackName,\n    );\n\n    SecurityGroup.fromSecurityGroupId(\n      service,\n      \"PostgresDbSecurityGroup\",\n      sgId,\n    ).connections.allowFrom(service, Port.tcp(5432));\n  }\n\n  /**\n   * Optionally adds a non-essential migration container that runs before the\n   * default container.\n   *\n   * The migration container uses the same image repo/tag as the default\n   * container, but runs with `command: [migrationParameter]`.\n   */\n  public useTaskDefinition(taskDefinition: ecs.TaskDefinition): void {\n    if (!this.props.enableMigration) {\n      return;\n    }\n\n    const imageNameString = taskDefinition.defaultContainer!.imageName;\n\n    const imageParts = imageNameString.split(\"/\");\n    const imageName = imageParts.slice(1).join(\"/\");\n\n    const [repoName, imageTag] = imageName.split(\":\");\n\n    const image = ecs.EcrImage.fromEcrRepository(\n      Repository.fromRepositoryName(\n        taskDefinition,\n        \"DatabaseMigrationRepository\",\n        repoName,\n      ),\n      imageTag,\n    );\n\n    let containerProps: ecs.ContainerDefinitionOptions = {\n      image: image,\n      essential: false,\n      command: [this.props.migrationParameter ?? \"migrate\"],\n    };\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.logGroup,\n        }),\n      };\n    }\n\n    this.container = taskDefinition.addContainer(\n      \"DatabaseMigrationContainer\",\n      containerProps,\n    );\n  }\n\n  /**\n   * When migrations are enabled, ensures the default container depends on the\n   * migration container completing successfully.\n   */\n  public modifyServiceProps(props: ServiceBuild): ServiceBuild {\n    if (!this.props.enableMigration) {\n      return props;\n    }\n    props.taskDefinition.defaultContainer?.addContainerDependencies({\n      container: this.container!,\n      condition: ecs.ContainerDependencyCondition.SUCCESS,\n    });\n    return props;\n  }\n}\n"]}
|
|
@@ -33,5 +33,5 @@ class SharedVolumeExtension extends ecs_service_extensions_1.ServiceExtension {
|
|
|
33
33
|
}
|
|
34
34
|
exports.SharedVolumeExtension = SharedVolumeExtension;
|
|
35
35
|
_a = JSII_RTTI_SYMBOL_1;
|
|
36
|
-
SharedVolumeExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.SharedVolumeExtension", version: "0.22.
|
|
36
|
+
SharedVolumeExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.SharedVolumeExtension", version: "0.22.3" };
|
|
37
37
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2hhcmVkVm9sdW1lRXh0ZW5zaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4dGVuc2lvbnMvU2hhcmVkVm9sdW1lRXh0ZW5zaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdUZBQThFO0FBRTlFLG9DQUFnRDtBQXNCaEQ7OztHQUdHO0FBQ0gsTUFBYSxxQkFBc0IsU0FBUSx5Q0FBZ0I7SUFLekQsWUFBWSxVQUFrQixFQUFFLEtBQWlDO1FBQy9ELEtBQUssQ0FBQyxHQUFHLFVBQVUsZ0JBQWdCLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsVUFBVSxHQUFHLFVBQVUsQ0FBQztJQUMvQixDQUFDO0lBRUQsaUJBQWlCLENBQUMsY0FBa0M7UUFDbEQsY0FBYyxDQUFDLFNBQVMsQ0FBQztZQUN2QixJQUFJLEVBQUUsSUFBSSxDQUFDLFVBQVU7U0FDdEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFVBQVUsQ0FBQyxRQUE2QztRQUN0RCxxREFBcUQ7UUFDckQsSUFBQSw0QkFBb0IsRUFBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7WUFDN0QsU0FBUyxDQUFDLGNBQWMsQ0FBQztnQkFDdkIsWUFBWSxFQUFFLElBQUksQ0FBQyxVQUFVO2dCQUM3QixhQUFhLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJO2dCQUM5QixRQUFRLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLElBQUksS0FBSzthQUN2QyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBMUJILHNEQTJCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlcnZpY2VFeHRlbnNpb24gfSBmcm9tIFwiQGF3cy1jZGstY29udGFpbmVycy9lY3Mtc2VydmljZS1leHRlbnNpb25zXCI7XG5pbXBvcnQgKiBhcyBlY3MgZnJvbSBcImF3cy1jZGstbGliL2F3cy1lY3NcIjtcbmltcG9ydCB7IGdldFNlcnZpY2VDb250YWluZXJzIH0gZnJvbSBcIi4uL3V0aWxzXCI7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgZGVmaW5pbmcgYW4gZXBoZXJtYWwgc2hhcmVkIHZvbHVtZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTaGFyZWRWb2x1bWVFeHRlbnNpb25Qcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgcGF0aCBpbnNpZGUgdGhlIGNvbnRhaW5lciB0byBtb3VudCB0aGUgdm9sdW1lLlxuICAgKi9cbiAgcmVhZG9ubHkgcGF0aDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSB2b2x1bWUgc2hvdWxkIGJlIHJlYWQtb25seS4gRGVmYXVsdDogZmFsc2UuXG4gICAqL1xuICByZWFkb25seSByZWFkb25seT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFNjb3BlIG9mIHRoZSB2b2x1bWUuIERlZmF1bHQ6IFNIQVJFRC5cbiAgICovXG4gIHJlYWRvbmx5IHNjb3BlPzogZWNzLlNjb3BlO1xufVxuXG4vKipcbiAqIENyZWF0ZSBhIHNoYXJlZCB2b2x1bWUgYW5kIGF0dGFjaCBpdCB0byBhbGwgY29udGFpbmVycyBpbiB0aGlzIHRhc2tcbiAqIGRlZmluaXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBTaGFyZWRWb2x1bWVFeHRlbnNpb24gZXh0ZW5kcyBTZXJ2aWNlRXh0ZW5zaW9uIHtcbiAgcmVhZG9ubHkgcHJvcHM6IFNoYXJlZFZvbHVtZUV4dGVuc2lvblByb3BzO1xuXG4gIHJlYWRvbmx5IHZvbHVtZU5hbWU6IHN0cmluZztcblxuICBjb25zdHJ1Y3Rvcih2b2x1bWVOYW1lOiBzdHJpbmcsIHByb3BzOiBTaGFyZWRWb2x1bWVFeHRlbnNpb25Qcm9wcykge1xuICAgIHN1cGVyKGAke3ZvbHVtZU5hbWV9LXNoYXJlZC12b2x1bWVgKTtcbiAgICB0aGlzLnByb3BzID0gcHJvcHM7XG4gICAgdGhpcy52b2x1bWVOYW1lID0gdm9sdW1lTmFtZTtcbiAgfVxuXG4gIHVzZVRhc2tEZWZpbml0aW9uKHRhc2tEZWZpbml0aW9uOiBlY3MuVGFza0RlZmluaXRpb24pOiB2b2lkIHtcbiAgICB0YXNrRGVmaW5pdGlvbi5hZGRWb2x1bWUoe1xuICAgICAgbmFtZTogdGhpcy52b2x1bWVOYW1lLFxuICAgIH0pO1xuICB9XG5cbiAgdXNlU2VydmljZShfc2VydmljZTogZWNzLkVjMlNlcnZpY2UgfCBlY3MuRmFyZ2F0ZVNlcnZpY2UpOiB2b2lkIHtcbiAgICAvLyBuZWRkIHRvIHVzZSB0aGUgYWN0dWFsIGNvbnRhaW5lciBkZWZpbml0aW9ucyBoZXJlLlxuICAgIGdldFNlcnZpY2VDb250YWluZXJzKHRoaXMucGFyZW50U2VydmljZSkuZm9yRWFjaCgoY29udGFpbmVyKSA9PiB7XG4gICAgICBjb250YWluZXIuYWRkTW91bnRQb2ludHMoe1xuICAgICAgICBzb3VyY2VWb2x1bWU6IHRoaXMudm9sdW1lTmFtZSxcbiAgICAgICAgY29udGFpbmVyUGF0aDogdGhpcy5wcm9wcy5wYXRoLFxuICAgICAgICByZWFkT25seTogdGhpcy5wcm9wcy5yZWFkb25seSB8fCBmYWxzZSxcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -1,11 +1,41 @@
|
|
|
1
1
|
import { ServiceExtension } from "@aws-cdk-containers/ecs-service-extensions";
|
|
2
|
+
/**
|
|
3
|
+
* Configuration for Linux TCP keepalive settings applied to the ECS task
|
|
4
|
+
* container via `systemControls`.
|
|
5
|
+
*
|
|
6
|
+
* Values map to the following kernel parameters:
|
|
7
|
+
* - `net.ipv4.tcp_keepalive_time`
|
|
8
|
+
* - `net.ipv4.tcp_keepalive_intvl`
|
|
9
|
+
* - `net.ipv4.tcp_keepalive_probes`
|
|
10
|
+
*/
|
|
2
11
|
export interface TcpKeepAliveExtensionProps {
|
|
12
|
+
/**
|
|
13
|
+
* Seconds of idle time before keepalive probes are sent.
|
|
14
|
+
*/
|
|
3
15
|
readonly time: number;
|
|
16
|
+
/**
|
|
17
|
+
* Seconds between keepalive probes.
|
|
18
|
+
*/
|
|
4
19
|
readonly interval: number;
|
|
20
|
+
/**
|
|
21
|
+
* Number of unacknowledged probes before declaring the connection dead.
|
|
22
|
+
*/
|
|
5
23
|
readonly probes: number;
|
|
6
24
|
}
|
|
25
|
+
/**
|
|
26
|
+
* ECS service extension that configures Linux TCP keepalive settings for the
|
|
27
|
+
* service's containers.
|
|
28
|
+
*
|
|
29
|
+
* If no props are provided, defaults are applied:
|
|
30
|
+
* - `time`: 200
|
|
31
|
+
* - `interval`: 200
|
|
32
|
+
* - `probes`: 5
|
|
33
|
+
*/
|
|
7
34
|
export declare class TcpKeepAliveExtension extends ServiceExtension {
|
|
8
35
|
readonly props: TcpKeepAliveExtensionProps;
|
|
9
36
|
constructor(props?: TcpKeepAliveExtensionProps);
|
|
37
|
+
/**
|
|
38
|
+
* Registers a container mutating hook that sets TCP keepalive sysctls.
|
|
39
|
+
*/
|
|
10
40
|
addHooks(): void;
|
|
11
41
|
}
|
|
@@ -5,11 +5,20 @@ exports.TcpKeepAliveExtension = void 0;
|
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const ecs_service_extensions_1 = require("@aws-cdk-containers/ecs-service-extensions");
|
|
7
7
|
const utils_1 = require("../utils");
|
|
8
|
+
/**
|
|
9
|
+
* Container mutating hook that applies TCP keepalive sysctl values.
|
|
10
|
+
*/
|
|
8
11
|
class AddSystemControlsHook extends ecs_service_extensions_1.ContainerMutatingHook {
|
|
12
|
+
/**
|
|
13
|
+
* @param props Keepalive values to apply to the container.
|
|
14
|
+
*/
|
|
9
15
|
constructor(props) {
|
|
10
16
|
super();
|
|
11
17
|
this.props = props;
|
|
12
18
|
}
|
|
19
|
+
/**
|
|
20
|
+
* Adds Linux TCP keepalive `systemControls` to the container definition.
|
|
21
|
+
*/
|
|
13
22
|
mutateContainerDefinition(props) {
|
|
14
23
|
return {
|
|
15
24
|
...props,
|
|
@@ -30,6 +39,15 @@ class AddSystemControlsHook extends ecs_service_extensions_1.ContainerMutatingHo
|
|
|
30
39
|
};
|
|
31
40
|
}
|
|
32
41
|
}
|
|
42
|
+
/**
|
|
43
|
+
* ECS service extension that configures Linux TCP keepalive settings for the
|
|
44
|
+
* service's containers.
|
|
45
|
+
*
|
|
46
|
+
* If no props are provided, defaults are applied:
|
|
47
|
+
* - `time`: 200
|
|
48
|
+
* - `interval`: 200
|
|
49
|
+
* - `probes`: 5
|
|
50
|
+
*/
|
|
33
51
|
class TcpKeepAliveExtension extends ecs_service_extensions_1.ServiceExtension {
|
|
34
52
|
constructor(props) {
|
|
35
53
|
super("tcp-keepalive-extension");
|
|
@@ -44,11 +62,14 @@ class TcpKeepAliveExtension extends ecs_service_extensions_1.ServiceExtension {
|
|
|
44
62
|
};
|
|
45
63
|
}
|
|
46
64
|
}
|
|
65
|
+
/**
|
|
66
|
+
* Registers a container mutating hook that sets TCP keepalive sysctls.
|
|
67
|
+
*/
|
|
47
68
|
addHooks() {
|
|
48
69
|
(0, utils_1.addHookToExtensions)(this.parentService, new AddSystemControlsHook(this.props));
|
|
49
70
|
}
|
|
50
71
|
}
|
|
51
72
|
exports.TcpKeepAliveExtension = TcpKeepAliveExtension;
|
|
52
73
|
_a = JSII_RTTI_SYMBOL_1;
|
|
53
|
-
TcpKeepAliveExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.TcpKeepAliveExtension", version: "0.22.
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
TcpKeepAliveExtension[_a] = { fqn: "@btc-embedded/cdk-extensions.TcpKeepAliveExtension", version: "0.22.3" };
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGNwS2VlcEFsaXZlRXh0ZW5zaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4dGVuc2lvbnMvVGNwS2VlcEFsaXZlRXh0ZW5zaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdUZBR29EO0FBRXBELG9DQUErQztBQTRCL0M7O0dBRUc7QUFDSCxNQUFNLHFCQUFzQixTQUFRLDhDQUFxQjtJQUN2RDs7T0FFRztJQUNILFlBQW9CLEtBQWlDO1FBQ25ELEtBQUssRUFBRSxDQUFDO1FBRFUsVUFBSyxHQUFMLEtBQUssQ0FBNEI7SUFFckQsQ0FBQztJQUVEOztPQUVHO0lBQ0gseUJBQXlCLENBQ3ZCLEtBQXFDO1FBRXJDLE9BQU87WUFDTCxHQUFHLEtBQUs7WUFDUixjQUFjLEVBQUU7Z0JBQ2Q7b0JBQ0UsU0FBUyxFQUFFLDZCQUE2QjtvQkFDeEMsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtpQkFDbEM7Z0JBQ0Q7b0JBQ0UsU0FBUyxFQUFFLDhCQUE4QjtvQkFDekMsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRTtpQkFDdEM7Z0JBQ0Q7b0JBQ0UsU0FBUyxFQUFFLCtCQUErQjtvQkFDMUMsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRTtpQkFDcEM7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFFRDs7Ozs7Ozs7R0FRRztBQUNILE1BQWEscUJBQXNCLFNBQVEseUNBQWdCO0lBR3pELFlBQVksS0FBa0M7UUFDNUMsS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFFakMsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ3JCLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLEtBQUssR0FBRztnQkFDWCxJQUFJLEVBQUUsR0FBRztnQkFDVCxRQUFRLEVBQUUsR0FBRztnQkFDYixNQUFNLEVBQUUsQ0FBQzthQUNWLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUTtRQUNiLElBQUEsMkJBQW1CLEVBQ2pCLElBQUksQ0FBQyxhQUFhLEVBQ2xCLElBQUkscUJBQXFCLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUN0QyxDQUFDO0lBQ0osQ0FBQzs7QUF6Qkgsc0RBMEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29udGFpbmVyTXV0YXRpbmdIb29rLFxuICBTZXJ2aWNlRXh0ZW5zaW9uLFxufSBmcm9tIFwiQGF3cy1jZGstY29udGFpbmVycy9lY3Mtc2VydmljZS1leHRlbnNpb25zXCI7XG5pbXBvcnQgKiBhcyBlY3MgZnJvbSBcImF3cy1jZGstbGliL2F3cy1lY3NcIjtcbmltcG9ydCB7IGFkZEhvb2tUb0V4dGVuc2lvbnMgfSBmcm9tIFwiLi4vdXRpbHNcIjtcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGZvciBMaW51eCBUQ1Aga2VlcGFsaXZlIHNldHRpbmdzIGFwcGxpZWQgdG8gdGhlIEVDUyB0YXNrXG4gKiBjb250YWluZXIgdmlhIGBzeXN0ZW1Db250cm9sc2AuXG4gKlxuICogVmFsdWVzIG1hcCB0byB0aGUgZm9sbG93aW5nIGtlcm5lbCBwYXJhbWV0ZXJzOlxuICogLSBgbmV0LmlwdjQudGNwX2tlZXBhbGl2ZV90aW1lYFxuICogLSBgbmV0LmlwdjQudGNwX2tlZXBhbGl2ZV9pbnR2bGBcbiAqIC0gYG5ldC5pcHY0LnRjcF9rZWVwYWxpdmVfcHJvYmVzYFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRjcEtlZXBBbGl2ZUV4dGVuc2lvblByb3BzIHtcbiAgLyoqXG4gICAqIFNlY29uZHMgb2YgaWRsZSB0aW1lIGJlZm9yZSBrZWVwYWxpdmUgcHJvYmVzIGFyZSBzZW50LlxuICAgKi9cbiAgcmVhZG9ubHkgdGltZTogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBTZWNvbmRzIGJldHdlZW4ga2VlcGFsaXZlIHByb2Jlcy5cbiAgICovXG4gIHJlYWRvbmx5IGludGVydmFsOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIE51bWJlciBvZiB1bmFja25vd2xlZGdlZCBwcm9iZXMgYmVmb3JlIGRlY2xhcmluZyB0aGUgY29ubmVjdGlvbiBkZWFkLlxuICAgKi9cbiAgcmVhZG9ubHkgcHJvYmVzOiBudW1iZXI7XG59XG5cbi8qKlxuICogQ29udGFpbmVyIG11dGF0aW5nIGhvb2sgdGhhdCBhcHBsaWVzIFRDUCBrZWVwYWxpdmUgc3lzY3RsIHZhbHVlcy5cbiAqL1xuY2xhc3MgQWRkU3lzdGVtQ29udHJvbHNIb29rIGV4dGVuZHMgQ29udGFpbmVyTXV0YXRpbmdIb29rIHtcbiAgLyoqXG4gICAqIEBwYXJhbSBwcm9wcyBLZWVwYWxpdmUgdmFsdWVzIHRvIGFwcGx5IHRvIHRoZSBjb250YWluZXIuXG4gICAqL1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHByb3BzOiBUY3BLZWVwQWxpdmVFeHRlbnNpb25Qcm9wcykge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBMaW51eCBUQ1Aga2VlcGFsaXZlIGBzeXN0ZW1Db250cm9sc2AgdG8gdGhlIGNvbnRhaW5lciBkZWZpbml0aW9uLlxuICAgKi9cbiAgbXV0YXRlQ29udGFpbmVyRGVmaW5pdGlvbihcbiAgICBwcm9wczogZWNzLkNvbnRhaW5lckRlZmluaXRpb25PcHRpb25zLFxuICApOiBlY3MuQ29udGFpbmVyRGVmaW5pdGlvbk9wdGlvbnMge1xuICAgIHJldHVybiB7XG4gICAgICAuLi5wcm9wcyxcbiAgICAgIHN5c3RlbUNvbnRyb2xzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lc3BhY2U6IFwibmV0LmlwdjQudGNwX2tlZXBhbGl2ZV90aW1lXCIsXG4gICAgICAgICAgdmFsdWU6IHRoaXMucHJvcHMudGltZS50b1N0cmluZygpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgbmFtZXNwYWNlOiBcIm5ldC5pcHY0LnRjcF9rZWVwYWxpdmVfaW50dmxcIixcbiAgICAgICAgICB2YWx1ZTogdGhpcy5wcm9wcy5pbnRlcnZhbC50b1N0cmluZygpLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgbmFtZXNwYWNlOiBcIm5ldC5pcHY0LnRjcF9rZWVwYWxpdmVfcHJvYmVzXCIsXG4gICAgICAgICAgdmFsdWU6IHRoaXMucHJvcHMucHJvYmVzLnRvU3RyaW5nKCksXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH07XG4gIH1cbn1cblxuLyoqXG4gKiBFQ1Mgc2VydmljZSBleHRlbnNpb24gdGhhdCBjb25maWd1cmVzIExpbnV4IFRDUCBrZWVwYWxpdmUgc2V0dGluZ3MgZm9yIHRoZVxuICogc2VydmljZSdzIGNvbnRhaW5lcnMuXG4gKlxuICogSWYgbm8gcHJvcHMgYXJlIHByb3ZpZGVkLCBkZWZhdWx0cyBhcmUgYXBwbGllZDpcbiAqIC0gYHRpbWVgOiAyMDBcbiAqIC0gYGludGVydmFsYDogMjAwXG4gKiAtIGBwcm9iZXNgOiA1XG4gKi9cbmV4cG9ydCBjbGFzcyBUY3BLZWVwQWxpdmVFeHRlbnNpb24gZXh0ZW5kcyBTZXJ2aWNlRXh0ZW5zaW9uIHtcbiAgcmVhZG9ubHkgcHJvcHM6IFRjcEtlZXBBbGl2ZUV4dGVuc2lvblByb3BzO1xuXG4gIGNvbnN0cnVjdG9yKHByb3BzPzogVGNwS2VlcEFsaXZlRXh0ZW5zaW9uUHJvcHMpIHtcbiAgICBzdXBlcihcInRjcC1rZWVwYWxpdmUtZXh0ZW5zaW9uXCIpO1xuXG4gICAgaWYgKHByb3BzKSB7XG4gICAgICB0aGlzLnByb3BzID0gcHJvcHM7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMucHJvcHMgPSB7XG4gICAgICAgIHRpbWU6IDIwMCxcbiAgICAgICAgaW50ZXJ2YWw6IDIwMCxcbiAgICAgICAgcHJvYmVzOiA1LFxuICAgICAgfTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXJzIGEgY29udGFpbmVyIG11dGF0aW5nIGhvb2sgdGhhdCBzZXRzIFRDUCBrZWVwYWxpdmUgc3lzY3Rscy5cbiAgICovXG4gIHB1YmxpYyBhZGRIb29rcygpIHtcbiAgICBhZGRIb29rVG9FeHRlbnNpb25zKFxuICAgICAgdGhpcy5wYXJlbnRTZXJ2aWNlLFxuICAgICAgbmV3IEFkZFN5c3RlbUNvbnRyb2xzSG9vayh0aGlzLnByb3BzKSxcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -45,7 +45,7 @@ export interface ApiGatewayProps {
|
|
|
45
45
|
*
|
|
46
46
|
* The relevant parameters are exposed as CloudFormation outputs so that they
|
|
47
47
|
* can be used by the CDK extensions provided in this library.
|
|
48
|
-
* @deprecated Use the
|
|
48
|
+
* @deprecated Use the ApiGatewayVpcLink construct instead.
|
|
49
49
|
*/
|
|
50
50
|
export declare class ApiGateway extends Construct {
|
|
51
51
|
private securityGroup;
|
|
@@ -23,7 +23,7 @@ const utils_1 = require("../utils");
|
|
|
23
23
|
*
|
|
24
24
|
* The relevant parameters are exposed as CloudFormation outputs so that they
|
|
25
25
|
* can be used by the CDK extensions provided in this library.
|
|
26
|
-
* @deprecated Use the
|
|
26
|
+
* @deprecated Use the ApiGatewayVpcLink construct instead.
|
|
27
27
|
*/
|
|
28
28
|
class ApiGateway extends constructs_1.Construct {
|
|
29
29
|
constructor(scope, id, props) {
|
|
@@ -106,5 +106,5 @@ class ApiGateway extends constructs_1.Construct {
|
|
|
106
106
|
}
|
|
107
107
|
exports.ApiGateway = ApiGateway;
|
|
108
108
|
_a = JSII_RTTI_SYMBOL_1;
|
|
109
|
-
ApiGateway[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGateway", version: "0.22.
|
|
110
|
-
//# 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 { ILogGroup } 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   * If provided then enable the access logs for the API Gateway.\n   *\n   */\n  readonly logGroup?: ILogGroup;\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.logGroup) {\n      this.enableAccessLogs(this.httpApi, props.logGroup);\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, logGroup: ILogGroup) {\n    const stage = apiEndpoint.defaultStage!.node.defaultChild as CfnStage;\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"]}
|
|
109
|
+
ApiGateway[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGateway", version: "0.22.3" };
|
|
110
|
+
//# 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 { ILogGroup } 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   * If provided then enable the access logs for the API Gateway.\n   *\n   */\n  readonly logGroup?: ILogGroup;\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 ApiGatewayVpcLink 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.logGroup) {\n      this.enableAccessLogs(this.httpApi, props.logGroup);\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, logGroup: ILogGroup) {\n    const stage = apiEndpoint.defaultStage!.node.defaultChild as CfnStage;\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"]}
|
|
@@ -14,7 +14,7 @@ class ApiGatewayVpcLinkBase extends constructs_1.Construct {
|
|
|
14
14
|
}
|
|
15
15
|
exports.ApiGatewayVpcLinkBase = ApiGatewayVpcLinkBase;
|
|
16
16
|
_a = JSII_RTTI_SYMBOL_1;
|
|
17
|
-
ApiGatewayVpcLinkBase[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayVpcLinkBase", version: "0.22.
|
|
17
|
+
ApiGatewayVpcLinkBase[_a] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayVpcLinkBase", version: "0.22.3" };
|
|
18
18
|
/**
|
|
19
19
|
* Constructs an API Gateway VPC link and an associated security group.
|
|
20
20
|
*
|
|
@@ -62,7 +62,7 @@ class ApiGatewayVpcLink extends ApiGatewayVpcLinkBase {
|
|
|
62
62
|
}
|
|
63
63
|
exports.ApiGatewayVpcLink = ApiGatewayVpcLink;
|
|
64
64
|
_b = JSII_RTTI_SYMBOL_1;
|
|
65
|
-
ApiGatewayVpcLink[_b] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayVpcLink", version: "0.22.
|
|
65
|
+
ApiGatewayVpcLink[_b] = { fqn: "@btc-embedded/cdk-extensions.ApiGatewayVpcLink", version: "0.22.3" };
|
|
66
66
|
ApiGatewayVpcLink.vpcLinkParameter = new utils_1.StackParameter({
|
|
67
67
|
name: "APIGateway VPCLink Id",
|
|
68
68
|
key: "vpc-link-id",
|
|
@@ -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.22.
|
|
64
|
+
ApplicationLoadBalancer[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancer", version: "0.22.3" };
|
|
65
65
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBwbGljYXRpb25Mb2FkQmFsYW5jZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGxhdGZvcm0vQXBwbGljYXRpb25Mb2FkQmFsYW5jZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw2Q0FBaUM7QUFDakMsK0VBRzRDO0FBTzVDLHVGQU1nRDtBQUNoRCx1R0FBMkY7QUFDM0YseURBQTZFO0FBQzdFLHlFQUFxRTtBQUNyRSwyQ0FBdUM7QUFDdkMsb0NBQTBDO0FBVTFDOztHQUVHO0FBQ0gsTUFBYSx1QkFBd0IsU0FBUSxzQkFBUztJQUlwRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzNCLENBQUM7SUFFRCxZQUNFLEtBQWdCLEVBQ2hCLEVBQVUsRUFDVixLQUFtQztRQUVuQyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sV0FBVyxHQUFHLElBQUksb0NBQVcsQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFO1lBQ3ZELFVBQVUsRUFBRSxLQUFLLENBQUMsSUFBSTtZQUN0QixVQUFVLEVBQUUsOENBQXFCLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUM7U0FDNUQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLG9EQUEwQixDQUFDLElBQUksRUFBRSxLQUFLLEVBQUU7WUFDOUQsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO1lBQ2QsY0FBYyxFQUFFLElBQUk7U0FDckIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxVQUFVLEVBQUU7WUFDeEQsSUFBSSxFQUFFLEdBQUc7WUFDVCxZQUFZLEVBQUUsQ0FBQyxXQUFXLENBQUM7WUFDM0IsYUFBYSxFQUFFLElBQUksOERBQXlCLENBQUM7Z0JBQzNDLFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUTtnQkFDeEIsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO2dCQUNwQyxjQUFjLEVBQUUsS0FBSyxDQUFDLGNBQWM7Z0JBQ3BDLElBQUksRUFBRSwyQ0FBYyxDQUFDLGFBQWEsQ0FBQyxHQUFHLEVBQUU7b0JBQ3RDLFdBQVcsRUFBRSxnQ0FBZ0M7aUJBQzlDLENBQUM7Z0JBQ0Ysd0JBQXdCLEVBQUUsa0RBQXFCLENBQUMsWUFBWTthQUM3RCxDQUFDO1NBQ0gsQ0FBQyxDQUFDO1FBRUgsSUFBSSxxQkFBTyxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUU7WUFDOUIsSUFBSSxFQUFFLEtBQUssQ0FBQyxVQUFVO1lBQ3RCLFVBQVUsRUFBRSxLQUFLLENBQUMsSUFBSTtZQUN0QixNQUFNLEVBQUUsMEJBQVksQ0FBQyxTQUFTLENBQUMsSUFBSSx3Q0FBa0IsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7U0FDMUUsQ0FBQyxDQUFDO1FBRUgsTUFBTSxXQUFXLEdBQUcsSUFBQSxzQkFBYyxFQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztRQUVoRCxXQUFXLENBQUM7WUFDVixJQUFJLEVBQUUsa0JBQWtCO1lBQ3hCLEdBQUcsRUFBRSxjQUFjO1lBQ25CLEtBQUssRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVc7U0FDakMsQ0FBQyxDQUFDO1FBRUgsV0FBVyxDQUFDO1lBQ1YsSUFBSSxFQUFFLHVCQUF1QjtZQUM3QixHQUFHLEVBQUUsbUJBQW1CO1lBQ3hCLEtBQUssRUFBRSxnQkFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQywwQkFBMEIsQ0FBQztTQUNsRSxDQUFDLENBQUM7SUFDTCxDQUFDOztBQTFESCwwREEyREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGbiB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHtcbiAgQ2VydGlmaWNhdGUsXG4gIENlcnRpZmljYXRlVmFsaWRhdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1jZXJ0aWZpY2F0ZW1hbmFnZXJcIjtcbmltcG9ydCB7XG4gIElVc2VyUG9vbCxcbiAgSVVzZXJQb29sQ2xpZW50LFxuICBJVXNlclBvb2xEb21haW4sXG59IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtY29nbml0b1wiO1xuaW1wb3J0IHsgSVZwYyB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtZWMyXCI7XG5pbXBvcnQge1xuICBBcHBsaWNhdGlvbkxvYWRCYWxhbmNlciBhcyBBV1NBcHBsaWNhdGlvbkxvYWRCYWxhbmNlcixcbiAgSUFwcGxpY2F0aW9uTGlzdGVuZXIsXG4gIElBcHBsaWNhdGlvbkxvYWRCYWxhbmNlcixcbiAgTGlzdGVuZXJBY3Rpb24sXG4gIFVuYXV0aGVudGljYXRlZEFjdGlvbixcbn0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1lbGFzdGljbG9hZGJhbGFuY2luZ3YyXCI7XG5pbXBvcnQgeyBBdXRoZW50aWNhdGVDb2duaXRvQWN0aW9uIH0gZnJvbSBcImF3cy1jZGstbGliL2F3cy1lbGFzdGljbG9hZGJhbGFuY2luZ3YyLWFjdGlvbnNcIjtcbmltcG9ydCB7IEFSZWNvcmQsIElIb3N0ZWRab25lLCBSZWNvcmRUYXJnZXQgfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXJvdXRlNTNcIjtcbmltcG9ydCB7IExvYWRCYWxhbmNlclRhcmdldCB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3Mtcm91dGU1My10YXJnZXRzXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IHsgY3JlYXRlRXhwb3J0ZXIgfSBmcm9tIFwiLi4vdXRpbHNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBBcHBsaWNhdGlvbkxvYWRCYWxhbmNlclByb3BzIHtcbiAgcmVhZG9ubHkgZnFkbjogc3RyaW5nO1xuICByZWFkb25seSB2cGM6IElWcGM7XG4gIHJlYWRvbmx5IHVzZXJQb29sOiBJVXNlclBvb2w7XG4gIHJlYWRvbmx5IHVzZXJQb29sQ2xpZW50OiBJVXNlclBvb2xDbGllbnQ7XG4gIHJlYWRvbmx5IHVzZXJQb29sRG9tYWluOiBJVXNlclBvb2xEb21haW47XG4gIHJlYWRvbmx5IGhvc3RlZFpvbmU6IElIb3N0ZWRab25lO1xufVxuLyoqXG4gKiBAZGVwcmVjYXRlZCBVc2Uge0BsaW5rIEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyVjJ9IGluc3RlYWRcbiAqL1xuZXhwb3J0IGNsYXNzIEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgcHVibGljIHJlYWRvbmx5IGxvYWRiYWxhbmNlcjogQVdTQXBwbGljYXRpb25Mb2FkQmFsYW5jZXI7XG4gIHB1YmxpYyByZWFkb25seSBsaXN0ZW5lcjogSUFwcGxpY2F0aW9uTGlzdGVuZXI7XG5cbiAgcHVibGljIGdldCBsb2FkQmFsYW5jZXIoKTogSUFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyIHtcbiAgICByZXR1cm4gdGhpcy5sb2FkYmFsYW5jZXI7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBzY29wZTogQ29uc3RydWN0LFxuICAgIGlkOiBzdHJpbmcsXG4gICAgcHJvcHM6IEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHMsXG4gICkge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBjb25zdCBjZXJ0aWZpY2F0ZSA9IG5ldyBDZXJ0aWZpY2F0ZSh0aGlzLCBcIkNlcnRpZmljYXRlXCIsIHtcbiAgICAgIGRvbWFpbk5hbWU6IHByb3BzLmZxZG4sXG4gICAgICB2YWxpZGF0aW9uOiBDZXJ0aWZpY2F0ZVZhbGlkYXRpb24uZnJvbURucyhwcm9wcy5ob3N0ZWRab25lKSxcbiAgICB9KTtcblxuICAgIHRoaXMubG9hZGJhbGFuY2VyID0gbmV3IEFXU0FwcGxpY2F0aW9uTG9hZEJhbGFuY2VyKHRoaXMsIFwiQUxCXCIsIHtcbiAgICAgIHZwYzogcHJvcHMudnBjLFxuICAgICAgaW50ZXJuZXRGYWNpbmc6IHRydWUsXG4gICAgfSk7XG5cbiAgICB0aGlzLmxpc3RlbmVyID0gdGhpcy5sb2FkYmFsYW5jZXIuYWRkTGlzdGVuZXIoXCJMaXN0ZW5lclwiLCB7XG4gICAgICBwb3J0OiA0NDMsXG4gICAgICBjZXJ0aWZpY2F0ZXM6IFtjZXJ0aWZpY2F0ZV0sXG4gICAgICBkZWZhdWx0QWN0aW9uOiBuZXcgQXV0aGVudGljYXRlQ29nbml0b0FjdGlvbih7XG4gICAgICAgIHVzZXJQb29sOiBwcm9wcy51c2VyUG9vbCxcbiAgICAgICAgdXNlclBvb2xDbGllbnQ6IHByb3BzLnVzZXJQb29sQ2xpZW50LFxuICAgICAgICB1c2VyUG9vbERvbWFpbjogcHJvcHMudXNlclBvb2xEb21haW4sXG4gICAgICAgIG5leHQ6IExpc3RlbmVyQWN0aW9uLmZpeGVkUmVzcG9uc2UoMjAwLCB7XG4gICAgICAgICAgbWVzc2FnZUJvZHk6IFwiVGhpcyBpcyB0aGUgQUxCIGRlZmF1bHQgYWN0aW9uXCIsXG4gICAgICAgIH0pLFxuICAgICAgICBvblVuYXV0aGVudGljYXRlZFJlcXVlc3Q6IFVuYXV0aGVudGljYXRlZEFjdGlvbi5BVVRIRU5USUNBVEUsXG4gICAgICB9KSxcbiAgICB9KTtcblxuICAgIG5ldyBBUmVjb3JkKHRoaXMsIFwiQUxCQVJlY29yZFwiLCB7XG4gICAgICB6b25lOiBwcm9wcy5ob3N0ZWRab25lLFxuICAgICAgcmVjb3JkTmFtZTogcHJvcHMuZnFkbixcbiAgICAgIHRhcmdldDogUmVjb3JkVGFyZ2V0LmZyb21BbGlhcyhuZXcgTG9hZEJhbGFuY2VyVGFyZ2V0KHRoaXMubG9hZEJhbGFuY2VyKSksXG4gICAgfSk7XG5cbiAgICBjb25zdCBleHBvcnRWYWx1ZSA9IGNyZWF0ZUV4cG9ydGVyKHRoaXMsIFwiYWxiXCIpO1xuXG4gICAgZXhwb3J0VmFsdWUoe1xuICAgICAgbmFtZTogXCJBTEIgTGlzdGVuZXIgQVJOXCIsXG4gICAgICBrZXk6IFwibGlzdGVuZXItYXJuXCIsXG4gICAgICB2YWx1ZTogdGhpcy5saXN0ZW5lci5saXN0ZW5lckFybixcbiAgICB9KTtcblxuICAgIGV4cG9ydFZhbHVlKHtcbiAgICAgIG5hbWU6IFwiQUxCIFNlY3VyaXR5IEdyb3VwIElkXCIsXG4gICAgICBrZXk6IFwic2VjdXJpdHktZ3JvdXAtaWRcIixcbiAgICAgIHZhbHVlOiBGbi5zZWxlY3QoMCwgdGhpcy5sb2FkYmFsYW5jZXIubG9hZEJhbGFuY2VyU2VjdXJpdHlHcm91cHMpLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -18,7 +18,7 @@ class ApplicationLoadBalancerV2Base extends constructs_1.Construct {
|
|
|
18
18
|
}
|
|
19
19
|
exports.ApplicationLoadBalancerV2Base = ApplicationLoadBalancerV2Base;
|
|
20
20
|
_a = JSII_RTTI_SYMBOL_1;
|
|
21
|
-
ApplicationLoadBalancerV2Base[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerV2Base", version: "0.22.
|
|
21
|
+
ApplicationLoadBalancerV2Base[_a] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerV2Base", version: "0.22.3" };
|
|
22
22
|
/**
|
|
23
23
|
* A construct that creates an Application Load Balancer (ALB) with Cognito authentication.
|
|
24
24
|
*
|
|
@@ -100,7 +100,7 @@ class ApplicationLoadBalancerV2 extends ApplicationLoadBalancerV2Base {
|
|
|
100
100
|
}
|
|
101
101
|
exports.ApplicationLoadBalancerV2 = ApplicationLoadBalancerV2;
|
|
102
102
|
_b = JSII_RTTI_SYMBOL_1;
|
|
103
|
-
ApplicationLoadBalancerV2[_b] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerV2", version: "0.22.
|
|
103
|
+
ApplicationLoadBalancerV2[_b] = { fqn: "@btc-embedded/cdk-extensions.ApplicationLoadBalancerV2", version: "0.22.3" };
|
|
104
104
|
ApplicationLoadBalancerV2.securityGroupIdParameter = new utils_1.StackParameter({
|
|
105
105
|
name: "ALB Security Group Id",
|
|
106
106
|
key: "security-group-id",
|
|
@@ -35,7 +35,7 @@ class BTCLogGroup extends aws_logs_1.LogGroup {
|
|
|
35
35
|
}
|
|
36
36
|
exports.BTCLogGroup = BTCLogGroup;
|
|
37
37
|
_a = JSII_RTTI_SYMBOL_1;
|
|
38
|
-
BTCLogGroup[_a] = { fqn: "@btc-embedded/cdk-extensions.BTCLogGroup", version: "0.22.
|
|
38
|
+
BTCLogGroup[_a] = { fqn: "@btc-embedded/cdk-extensions.BTCLogGroup", version: "0.22.3" };
|
|
39
39
|
BTCLogGroup.logGroupParameter = new utils_1.StackParameter({
|
|
40
40
|
name: "Log Group Name",
|
|
41
41
|
key: "log-group-name",
|
|
@@ -24,7 +24,7 @@ class CognitoUserPoolBase extends constructs_1.Construct {
|
|
|
24
24
|
}
|
|
25
25
|
exports.CognitoUserPoolBase = CognitoUserPoolBase;
|
|
26
26
|
_a = JSII_RTTI_SYMBOL_1;
|
|
27
|
-
CognitoUserPoolBase[_a] = { fqn: "@btc-embedded/cdk-extensions.CognitoUserPoolBase", version: "0.22.
|
|
27
|
+
CognitoUserPoolBase[_a] = { fqn: "@btc-embedded/cdk-extensions.CognitoUserPoolBase", version: "0.22.3" };
|
|
28
28
|
class CognitoUserPool extends CognitoUserPoolBase {
|
|
29
29
|
static fromBasePlatform(scope, id, basePlatformStackName) {
|
|
30
30
|
class Import extends CognitoUserPoolBase {
|
|
@@ -117,7 +117,7 @@ class CognitoUserPool extends CognitoUserPoolBase {
|
|
|
117
117
|
}
|
|
118
118
|
exports.CognitoUserPool = CognitoUserPool;
|
|
119
119
|
_b = JSII_RTTI_SYMBOL_1;
|
|
120
|
-
CognitoUserPool[_b] = { fqn: "@btc-embedded/cdk-extensions.CognitoUserPool", version: "0.22.
|
|
120
|
+
CognitoUserPool[_b] = { fqn: "@btc-embedded/cdk-extensions.CognitoUserPool", version: "0.22.3" };
|
|
121
121
|
CognitoUserPool.userPoolIdParameter = new utils_1.StackParameter({
|
|
122
122
|
name: "Cognito User Pool Id",
|
|
123
123
|
key: "user-pool-id",
|
|
@@ -97,5 +97,5 @@ class DefaultUserPoolClients extends constructs_1.Construct {
|
|
|
97
97
|
}
|
|
98
98
|
exports.DefaultUserPoolClients = DefaultUserPoolClients;
|
|
99
99
|
_a = JSII_RTTI_SYMBOL_1;
|
|
100
|
-
DefaultUserPoolClients[_a] = { fqn: "@btc-embedded/cdk-extensions.DefaultUserPoolClients", version: "0.22.
|
|
100
|
+
DefaultUserPoolClients[_a] = { fqn: "@btc-embedded/cdk-extensions.DefaultUserPoolClients", version: "0.22.3" };
|
|
101
101
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DefaultUserPoolClients.js","sourceRoot":"","sources":["../../src/platform/DefaultUserPoolClients.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  IUserPool,\n  IUserPoolClient,\n  OAuthScope,\n  ResourceServerScope,\n  UserPoolClient,\n  UserPoolClientIdentityProvider,\n  UserPoolClientOptions,\n} from \"aws-cdk-lib/aws-cognito\";\nimport { Secret } from \"aws-cdk-lib/aws-secretsmanager\";\nimport { Construct } from \"constructs\";\nimport { createExporter } from \"../utils\";\n\nexport interface DefaultUserPoolClientsProps {\n  /**\n   * The user pool which should be attached to the clients.\n   */\n  readonly userPool: IUserPool;\n\n  /**\n   * The fully qualified domain name which the ALB will listen to.\n   *\n   * This setting is used to configure the correct callback URL for user pool\n   * client such that the ALB can perform authentication.\n   *\n   */\n  readonly fqdn: string;\n\n  /**\n   * Specify valid logout URLs which should be added to the frontend user pool client.\n   */\n  readonly logoutUrls?: string[];\n\n  /**\n   * Specify additional callback URLs which the frontend uses for OIDC authentication.\n   *\n   */\n  readonly callbackUrls?: string[];\n\n  /**\n   * Specify additional user pool identity providers to enable federated login.\n   */\n  readonly additonalUserPoolIdentityProviders?: string[];\n\n  /**\n   * Client options for the API client, extending and overwriting the defaults.\n   */\n  readonly apiClientOptions?: UserPoolClientOptions;\n\n  /**\n   * Client options for the frontend client, extending and overwriting the defaults.\n   */\n  readonly frontendClientOptions?: UserPoolClientOptions;\n\n  /**\n   * Additional OAuth scopes for the frontend.\n   */\n  readonly frontendOAuthScopes?: OAuthScope[];\n}\n\n/**\n * Create default user pool clients for the frontend and API access.\n * @deprecated Use {@link CognitoUserPool}  instead\n */\nexport class DefaultUserPoolClients extends Construct {\n  public frontendClient: IUserPoolClient;\n  public apiClient: IUserPoolClient;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: DefaultUserPoolClientsProps,\n  ) {\n    super(scope, id);\n\n    const apiAccessScope = new ResourceServerScope({\n      scopeName: \"api_access\",\n      scopeDescription: \"REST API full access scope\",\n    });\n\n    const server = props.userPool.addResourceServer(\"RESTAPIResourceServer\", {\n      identifier: `${id}RESTAPI`,\n      scopes: [apiAccessScope],\n    });\n\n    const providerNames =\n      props.additonalUserPoolIdentityProviders?.map((name) =>\n        UserPoolClientIdentityProvider.custom(name),\n      ) ?? [];\n\n    const callbackUrls = props.callbackUrls ?? [];\n\n    const apiClientScope = OAuthScope.resourceServer(server, apiAccessScope);\n\n    this.apiClient = new UserPoolClient(this, \"RESTAPIUserPoolClient\", {\n      userPool: props.userPool,\n      generateSecret: true,\n      oAuth: {\n        flows: {\n          clientCredentials: true,\n        },\n        scopes: [apiClientScope],\n      },\n      supportedIdentityProviders: [\n        UserPoolClientIdentityProvider.COGNITO,\n        ...providerNames,\n      ],\n      ...props.apiClientOptions,\n    });\n\n    this.frontendClient = new UserPoolClient(this, \"FrontendUserPoolClient\", {\n      userPool: props.userPool,\n\n      // Required minimal configuration for use with an ELB\n      generateSecret: true,\n      authFlows: {\n        userPassword: true,\n      },\n\n      oAuth: {\n        flows: {\n          authorizationCodeGrant: true,\n        },\n        scopes: [\n          OAuthScope.OPENID,\n          OAuthScope.PROFILE,\n          ...(props.frontendOAuthScopes ?? []),\n        ],\n        callbackUrls: [\n          // add callback URL for ALB\n          `https://${props.fqdn}/oauth2/idpresponse`,\n          ...callbackUrls,\n        ],\n        logoutUrls: props.logoutUrls,\n      },\n      supportedIdentityProviders: [\n        UserPoolClientIdentityProvider.COGNITO,\n        ...providerNames,\n      ],\n      ...props.frontendClientOptions,\n    });\n\n    const apiSecret = new Secret(this, \"ApiClientSecret\", {\n      secretStringValue: this.apiClient.userPoolClientSecret,\n    });\n\n    const exportValue = createExporter(this, \"cognito\");\n\n    exportValue({\n      name: \"Cognito Full Access Client Id\",\n      key: \"full-access-client-id\",\n      value: this.apiClient.userPoolClientId,\n    });\n\n    exportValue({\n      name: \"Cognito Api Client Scope\",\n      key: \"full-access-client-scope\",\n      value: apiClientScope.scopeName,\n    });\n\n    exportValue({\n      name: \"Cognito Api Client Secret\",\n      key: \"full-access-client-secret\",\n      value: apiSecret.secretArn,\n    });\n\n    exportValue({\n      name: \"Cognito User Pool Client Id\",\n      key: \"user-pool-client-id\",\n      value: this.frontendClient.userPoolClientId,\n    });\n  }\n}\n"]}
|