@btc-embedded/cdk-extensions 0.20.2 → 0.20.4
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 +207 -2
- package/API.md +344 -0
- package/CHANGELOG.md +10 -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/extensions/ApiGatewayExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
- package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +1 -1
- package/lib/extensions/CloudMapExtension.js +1 -1
- package/lib/extensions/DeactivatableServiceExtension.js +1 -1
- package/lib/extensions/DeploymentConfigExtension.d.ts +65 -0
- package/lib/extensions/DeploymentConfigExtension.js +69 -0
- package/lib/extensions/DocumentDbAccessExtension.js +1 -1
- package/lib/extensions/DomainEventMessagingExtension.js +1 -1
- package/lib/extensions/EfsMountExtension.js +1 -1
- package/lib/extensions/ExtraContainerExtension.js +1 -1
- package/lib/extensions/HTTPApiExtension.js +1 -1
- package/lib/extensions/LogExtension.js +1 -1
- package/lib/extensions/ModifyContainerDefinitionExtension.js +1 -1
- package/lib/extensions/ModifyTaskDefinitionExtension.js +1 -1
- package/lib/extensions/OpenIdExtension.js +1 -1
- package/lib/extensions/OpenTelemetryExtension.js +1 -1
- package/lib/extensions/PostgresDbAccessExtension.js +1 -1
- package/lib/extensions/SharedVolumeExtension.js +1 -1
- package/lib/extensions/TcpKeepAliveExtension.js +1 -1
- package/lib/extensions/index.d.ts +2 -1
- package/lib/extensions/index.js +3 -2
- package/lib/platform/ApiGateway.js +1 -1
- 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.js +2 -2
- package/lib/platform/EcsCluster.js +1 -1
- package/lib/platform/EfsFileSystem.js +1 -1
- package/lib/platform/PrivateDnsNamespace.js +1 -1
- package/lib/platform/ResourceServer.js +1 -1
- package/lib/platform/Vpc.js +1 -1
- package/lib/platform/VpcV2.js +1 -1
- package/lib/utils/StackParameter.js +1 -1
- package/package.json +1 -1
package/.jsii
CHANGED
|
@@ -7199,6 +7199,211 @@
|
|
|
7199
7199
|
],
|
|
7200
7200
|
"symbolId": "src/platform/DefaultUserPoolClients:DefaultUserPoolClientsProps"
|
|
7201
7201
|
},
|
|
7202
|
+
"@btc-embedded/cdk-extensions.DeploymentConfigExtension": {
|
|
7203
|
+
"assembly": "@btc-embedded/cdk-extensions",
|
|
7204
|
+
"base": "@aws-cdk-containers/ecs-service-extensions.ServiceExtension",
|
|
7205
|
+
"docs": {
|
|
7206
|
+
"remarks": "This extension allows you to:\n1. Configure deployment parameters for faster or safer deployments\n2. Enable the use of cluster's FARGATE_SPOT capacity provider strategy",
|
|
7207
|
+
"stability": "experimental",
|
|
7208
|
+
"summary": "Extension that configures ECS service deployment options and capacity provider strategy."
|
|
7209
|
+
},
|
|
7210
|
+
"fqn": "@btc-embedded/cdk-extensions.DeploymentConfigExtension",
|
|
7211
|
+
"initializer": {
|
|
7212
|
+
"docs": {
|
|
7213
|
+
"stability": "experimental"
|
|
7214
|
+
},
|
|
7215
|
+
"locationInModule": {
|
|
7216
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7217
|
+
"line": 73
|
|
7218
|
+
},
|
|
7219
|
+
"parameters": [
|
|
7220
|
+
{
|
|
7221
|
+
"name": "props",
|
|
7222
|
+
"optional": true,
|
|
7223
|
+
"type": {
|
|
7224
|
+
"fqn": "@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps"
|
|
7225
|
+
}
|
|
7226
|
+
}
|
|
7227
|
+
]
|
|
7228
|
+
},
|
|
7229
|
+
"kind": "class",
|
|
7230
|
+
"locationInModule": {
|
|
7231
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7232
|
+
"line": 70
|
|
7233
|
+
},
|
|
7234
|
+
"methods": [
|
|
7235
|
+
{
|
|
7236
|
+
"docs": {
|
|
7237
|
+
"stability": "experimental",
|
|
7238
|
+
"summary": "Prior to launching the task definition as a service, this hook is called on each extension to give it a chance to mutate the properties of the service to be created."
|
|
7239
|
+
},
|
|
7240
|
+
"locationInModule": {
|
|
7241
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7242
|
+
"line": 78
|
|
7243
|
+
},
|
|
7244
|
+
"name": "modifyServiceProps",
|
|
7245
|
+
"overrides": "@aws-cdk-containers/ecs-service-extensions.ServiceExtension",
|
|
7246
|
+
"parameters": [
|
|
7247
|
+
{
|
|
7248
|
+
"name": "props",
|
|
7249
|
+
"type": {
|
|
7250
|
+
"fqn": "@aws-cdk-containers/ecs-service-extensions.ServiceBuild"
|
|
7251
|
+
}
|
|
7252
|
+
}
|
|
7253
|
+
],
|
|
7254
|
+
"returns": {
|
|
7255
|
+
"type": {
|
|
7256
|
+
"fqn": "@aws-cdk-containers/ecs-service-extensions.ServiceBuild"
|
|
7257
|
+
}
|
|
7258
|
+
}
|
|
7259
|
+
},
|
|
7260
|
+
{
|
|
7261
|
+
"docs": {
|
|
7262
|
+
"remarks": "It is generally used to\ncreate any final resources which might depend on the service itself.",
|
|
7263
|
+
"stability": "experimental",
|
|
7264
|
+
"summary": "When this hook is implemented by extension, it allows the extension to use the service which has been created."
|
|
7265
|
+
},
|
|
7266
|
+
"locationInModule": {
|
|
7267
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7268
|
+
"line": 91
|
|
7269
|
+
},
|
|
7270
|
+
"name": "useService",
|
|
7271
|
+
"overrides": "@aws-cdk-containers/ecs-service-extensions.ServiceExtension",
|
|
7272
|
+
"parameters": [
|
|
7273
|
+
{
|
|
7274
|
+
"name": "service",
|
|
7275
|
+
"type": {
|
|
7276
|
+
"union": {
|
|
7277
|
+
"types": [
|
|
7278
|
+
{
|
|
7279
|
+
"fqn": "aws-cdk-lib.aws_ecs.Ec2Service"
|
|
7280
|
+
},
|
|
7281
|
+
{
|
|
7282
|
+
"fqn": "aws-cdk-lib.aws_ecs.FargateService"
|
|
7283
|
+
}
|
|
7284
|
+
]
|
|
7285
|
+
}
|
|
7286
|
+
}
|
|
7287
|
+
}
|
|
7288
|
+
]
|
|
7289
|
+
}
|
|
7290
|
+
],
|
|
7291
|
+
"name": "DeploymentConfigExtension",
|
|
7292
|
+
"symbolId": "src/extensions/DeploymentConfigExtension:DeploymentConfigExtension"
|
|
7293
|
+
},
|
|
7294
|
+
"@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps": {
|
|
7295
|
+
"assembly": "@btc-embedded/cdk-extensions",
|
|
7296
|
+
"datatype": true,
|
|
7297
|
+
"docs": {
|
|
7298
|
+
"stability": "experimental",
|
|
7299
|
+
"summary": "Properties for configuring service deployment and capacity provider strategy."
|
|
7300
|
+
},
|
|
7301
|
+
"fqn": "@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps",
|
|
7302
|
+
"kind": "interface",
|
|
7303
|
+
"locationInModule": {
|
|
7304
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7305
|
+
"line": 11
|
|
7306
|
+
},
|
|
7307
|
+
"name": "DeploymentConfigExtensionProps",
|
|
7308
|
+
"properties": [
|
|
7309
|
+
{
|
|
7310
|
+
"abstract": true,
|
|
7311
|
+
"docs": {
|
|
7312
|
+
"default": "0",
|
|
7313
|
+
"remarks": "This is the minimum number of tasks that should use Fargate Spot.\nOnly used when useCapacityProvider is true.",
|
|
7314
|
+
"stability": "experimental",
|
|
7315
|
+
"summary": "The base value for the FARGATE_SPOT capacity provider."
|
|
7316
|
+
},
|
|
7317
|
+
"immutable": true,
|
|
7318
|
+
"locationInModule": {
|
|
7319
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7320
|
+
"line": 33
|
|
7321
|
+
},
|
|
7322
|
+
"name": "capacityProviderBase",
|
|
7323
|
+
"optional": true,
|
|
7324
|
+
"type": {
|
|
7325
|
+
"primitive": "number"
|
|
7326
|
+
}
|
|
7327
|
+
},
|
|
7328
|
+
{
|
|
7329
|
+
"abstract": true,
|
|
7330
|
+
"docs": {
|
|
7331
|
+
"default": "1",
|
|
7332
|
+
"remarks": "Higher values mean more tasks will use Fargate Spot.\nOnly used when useCapacityProvider is true.",
|
|
7333
|
+
"stability": "experimental",
|
|
7334
|
+
"summary": "The weight value for the FARGATE_SPOT capacity provider."
|
|
7335
|
+
},
|
|
7336
|
+
"immutable": true,
|
|
7337
|
+
"locationInModule": {
|
|
7338
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7339
|
+
"line": 42
|
|
7340
|
+
},
|
|
7341
|
+
"name": "capacityProviderWeight",
|
|
7342
|
+
"optional": true,
|
|
7343
|
+
"type": {
|
|
7344
|
+
"primitive": "number"
|
|
7345
|
+
}
|
|
7346
|
+
},
|
|
7347
|
+
{
|
|
7348
|
+
"abstract": true,
|
|
7349
|
+
"docs": {
|
|
7350
|
+
"default": "200",
|
|
7351
|
+
"remarks": "Controls how many additional tasks can be started during deployment.",
|
|
7352
|
+
"stability": "experimental",
|
|
7353
|
+
"summary": "The maximum healthy percent for the service deployment."
|
|
7354
|
+
},
|
|
7355
|
+
"immutable": true,
|
|
7356
|
+
"locationInModule": {
|
|
7357
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7358
|
+
"line": 59
|
|
7359
|
+
},
|
|
7360
|
+
"name": "maxHealthyPercent",
|
|
7361
|
+
"optional": true,
|
|
7362
|
+
"type": {
|
|
7363
|
+
"primitive": "number"
|
|
7364
|
+
}
|
|
7365
|
+
},
|
|
7366
|
+
{
|
|
7367
|
+
"abstract": true,
|
|
7368
|
+
"docs": {
|
|
7369
|
+
"default": "100",
|
|
7370
|
+
"remarks": "Set to 0 to allow all tasks to be replaced at once for faster deployments\nwhere service interruption is acceptable.",
|
|
7371
|
+
"stability": "experimental",
|
|
7372
|
+
"summary": "The minimum healthy percent for the service deployment."
|
|
7373
|
+
},
|
|
7374
|
+
"immutable": true,
|
|
7375
|
+
"locationInModule": {
|
|
7376
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7377
|
+
"line": 51
|
|
7378
|
+
},
|
|
7379
|
+
"name": "minHealthyPercent",
|
|
7380
|
+
"optional": true,
|
|
7381
|
+
"type": {
|
|
7382
|
+
"primitive": "number"
|
|
7383
|
+
}
|
|
7384
|
+
},
|
|
7385
|
+
{
|
|
7386
|
+
"abstract": true,
|
|
7387
|
+
"docs": {
|
|
7388
|
+
"default": "false",
|
|
7389
|
+
"remarks": "When enabled, the service will use the capacity provider strategy\nconfigured at the cluster level (e.g., FARGATE_SPOT).\n\n**Requirements:**\n- The ECS cluster must have capacity providers enabled\n (set `enableFargateSpotCapacityProvider: true` in EcsCluster)",
|
|
7390
|
+
"stability": "experimental",
|
|
7391
|
+
"summary": "Whether to use the cluster's FARGATE_SPOT capacity provider strategy."
|
|
7392
|
+
},
|
|
7393
|
+
"immutable": true,
|
|
7394
|
+
"locationInModule": {
|
|
7395
|
+
"filename": "src/extensions/DeploymentConfigExtension.ts",
|
|
7396
|
+
"line": 24
|
|
7397
|
+
},
|
|
7398
|
+
"name": "useFargateSpotInstances",
|
|
7399
|
+
"optional": true,
|
|
7400
|
+
"type": {
|
|
7401
|
+
"primitive": "boolean"
|
|
7402
|
+
}
|
|
7403
|
+
}
|
|
7404
|
+
],
|
|
7405
|
+
"symbolId": "src/extensions/DeploymentConfigExtension:DeploymentConfigExtensionProps"
|
|
7406
|
+
},
|
|
7202
7407
|
"@btc-embedded/cdk-extensions.DocumentDB": {
|
|
7203
7408
|
"assembly": "@btc-embedded/cdk-extensions",
|
|
7204
7409
|
"base": "constructs.Construct",
|
|
@@ -13460,6 +13665,6 @@
|
|
|
13460
13665
|
"symbolId": "src/platform/VpcV2:VpcV2Props"
|
|
13461
13666
|
}
|
|
13462
13667
|
},
|
|
13463
|
-
"version": "0.20.
|
|
13464
|
-
"fingerprint": "
|
|
13668
|
+
"version": "0.20.4",
|
|
13669
|
+
"fingerprint": "35E6DRZ1Gjkx6CgoqfnHHbSqxzixD00+mbBYcmo+2Yk="
|
|
13465
13670
|
}
|
package/API.md
CHANGED
|
@@ -7686,6 +7686,113 @@ Specify valid logout URLs which should be added to the frontend user pool client
|
|
|
7686
7686
|
|
|
7687
7687
|
---
|
|
7688
7688
|
|
|
7689
|
+
### DeploymentConfigExtensionProps <a name="DeploymentConfigExtensionProps" id="@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps"></a>
|
|
7690
|
+
|
|
7691
|
+
Properties for configuring service deployment and capacity provider strategy.
|
|
7692
|
+
|
|
7693
|
+
#### Initializer <a name="Initializer" id="@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.Initializer"></a>
|
|
7694
|
+
|
|
7695
|
+
```typescript
|
|
7696
|
+
import { DeploymentConfigExtensionProps } from '@btc-embedded/cdk-extensions'
|
|
7697
|
+
|
|
7698
|
+
const deploymentConfigExtensionProps: DeploymentConfigExtensionProps = { ... }
|
|
7699
|
+
```
|
|
7700
|
+
|
|
7701
|
+
#### Properties <a name="Properties" id="Properties"></a>
|
|
7702
|
+
|
|
7703
|
+
| **Name** | **Type** | **Description** |
|
|
7704
|
+
| --- | --- | --- |
|
|
7705
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.capacityProviderBase">capacityProviderBase</a></code> | <code>number</code> | The base value for the FARGATE_SPOT capacity provider. |
|
|
7706
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.capacityProviderWeight">capacityProviderWeight</a></code> | <code>number</code> | The weight value for the FARGATE_SPOT capacity provider. |
|
|
7707
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.maxHealthyPercent">maxHealthyPercent</a></code> | <code>number</code> | The maximum healthy percent for the service deployment. |
|
|
7708
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.minHealthyPercent">minHealthyPercent</a></code> | <code>number</code> | The minimum healthy percent for the service deployment. |
|
|
7709
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.useFargateSpotInstances">useFargateSpotInstances</a></code> | <code>boolean</code> | Whether to use the cluster's FARGATE_SPOT capacity provider strategy. |
|
|
7710
|
+
|
|
7711
|
+
---
|
|
7712
|
+
|
|
7713
|
+
##### `capacityProviderBase`<sup>Optional</sup> <a name="capacityProviderBase" id="@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.capacityProviderBase"></a>
|
|
7714
|
+
|
|
7715
|
+
```typescript
|
|
7716
|
+
public readonly capacityProviderBase: number;
|
|
7717
|
+
```
|
|
7718
|
+
|
|
7719
|
+
- *Type:* number
|
|
7720
|
+
- *Default:* 0
|
|
7721
|
+
|
|
7722
|
+
The base value for the FARGATE_SPOT capacity provider.
|
|
7723
|
+
|
|
7724
|
+
This is the minimum number of tasks that should use Fargate Spot.
|
|
7725
|
+
Only used when useCapacityProvider is true.
|
|
7726
|
+
|
|
7727
|
+
---
|
|
7728
|
+
|
|
7729
|
+
##### `capacityProviderWeight`<sup>Optional</sup> <a name="capacityProviderWeight" id="@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.capacityProviderWeight"></a>
|
|
7730
|
+
|
|
7731
|
+
```typescript
|
|
7732
|
+
public readonly capacityProviderWeight: number;
|
|
7733
|
+
```
|
|
7734
|
+
|
|
7735
|
+
- *Type:* number
|
|
7736
|
+
- *Default:* 1
|
|
7737
|
+
|
|
7738
|
+
The weight value for the FARGATE_SPOT capacity provider.
|
|
7739
|
+
|
|
7740
|
+
Higher values mean more tasks will use Fargate Spot.
|
|
7741
|
+
Only used when useCapacityProvider is true.
|
|
7742
|
+
|
|
7743
|
+
---
|
|
7744
|
+
|
|
7745
|
+
##### `maxHealthyPercent`<sup>Optional</sup> <a name="maxHealthyPercent" id="@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.maxHealthyPercent"></a>
|
|
7746
|
+
|
|
7747
|
+
```typescript
|
|
7748
|
+
public readonly maxHealthyPercent: number;
|
|
7749
|
+
```
|
|
7750
|
+
|
|
7751
|
+
- *Type:* number
|
|
7752
|
+
- *Default:* 200
|
|
7753
|
+
|
|
7754
|
+
The maximum healthy percent for the service deployment.
|
|
7755
|
+
|
|
7756
|
+
Controls how many additional tasks can be started during deployment.
|
|
7757
|
+
|
|
7758
|
+
---
|
|
7759
|
+
|
|
7760
|
+
##### `minHealthyPercent`<sup>Optional</sup> <a name="minHealthyPercent" id="@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.minHealthyPercent"></a>
|
|
7761
|
+
|
|
7762
|
+
```typescript
|
|
7763
|
+
public readonly minHealthyPercent: number;
|
|
7764
|
+
```
|
|
7765
|
+
|
|
7766
|
+
- *Type:* number
|
|
7767
|
+
- *Default:* 100
|
|
7768
|
+
|
|
7769
|
+
The minimum healthy percent for the service deployment.
|
|
7770
|
+
|
|
7771
|
+
Set to 0 to allow all tasks to be replaced at once for faster deployments
|
|
7772
|
+
where service interruption is acceptable.
|
|
7773
|
+
|
|
7774
|
+
---
|
|
7775
|
+
|
|
7776
|
+
##### `useFargateSpotInstances`<sup>Optional</sup> <a name="useFargateSpotInstances" id="@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps.property.useFargateSpotInstances"></a>
|
|
7777
|
+
|
|
7778
|
+
```typescript
|
|
7779
|
+
public readonly useFargateSpotInstances: boolean;
|
|
7780
|
+
```
|
|
7781
|
+
|
|
7782
|
+
- *Type:* boolean
|
|
7783
|
+
- *Default:* false
|
|
7784
|
+
|
|
7785
|
+
Whether to use the cluster's FARGATE_SPOT capacity provider strategy.
|
|
7786
|
+
|
|
7787
|
+
When enabled, the service will use the capacity provider strategy
|
|
7788
|
+
configured at the cluster level (e.g., FARGATE_SPOT).
|
|
7789
|
+
|
|
7790
|
+
**Requirements:**
|
|
7791
|
+
- The ECS cluster must have capacity providers enabled
|
|
7792
|
+
(set `enableFargateSpotCapacityProvider: true` in EcsCluster)
|
|
7793
|
+
|
|
7794
|
+
---
|
|
7795
|
+
|
|
7689
7796
|
### DocumentDbAccessExtensionProps <a name="DocumentDbAccessExtensionProps" id="@btc-embedded/cdk-extensions.DocumentDbAccessExtensionProps"></a>
|
|
7690
7797
|
|
|
7691
7798
|
#### Initializer <a name="Initializer" id="@btc-embedded/cdk-extensions.DocumentDbAccessExtensionProps.Initializer"></a>
|
|
@@ -10927,6 +11034,243 @@ connected to the service.
|
|
|
10927
11034
|
---
|
|
10928
11035
|
|
|
10929
11036
|
|
|
11037
|
+
### DeploymentConfigExtension <a name="DeploymentConfigExtension" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension"></a>
|
|
11038
|
+
|
|
11039
|
+
Extension that configures ECS service deployment options and capacity provider strategy.
|
|
11040
|
+
|
|
11041
|
+
This extension allows you to:
|
|
11042
|
+
1. Configure deployment parameters for faster or safer deployments
|
|
11043
|
+
2. Enable the use of cluster's FARGATE_SPOT capacity provider strategy
|
|
11044
|
+
|
|
11045
|
+
#### Initializers <a name="Initializers" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.Initializer"></a>
|
|
11046
|
+
|
|
11047
|
+
```typescript
|
|
11048
|
+
import { DeploymentConfigExtension } from '@btc-embedded/cdk-extensions'
|
|
11049
|
+
|
|
11050
|
+
new DeploymentConfigExtension(props?: DeploymentConfigExtensionProps)
|
|
11051
|
+
```
|
|
11052
|
+
|
|
11053
|
+
| **Name** | **Type** | **Description** |
|
|
11054
|
+
| --- | --- | --- |
|
|
11055
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.Initializer.parameter.props">props</a></code> | <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps">DeploymentConfigExtensionProps</a></code> | *No description.* |
|
|
11056
|
+
|
|
11057
|
+
---
|
|
11058
|
+
|
|
11059
|
+
##### `props`<sup>Optional</sup> <a name="props" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.Initializer.parameter.props"></a>
|
|
11060
|
+
|
|
11061
|
+
- *Type:* <a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtensionProps">DeploymentConfigExtensionProps</a>
|
|
11062
|
+
|
|
11063
|
+
---
|
|
11064
|
+
|
|
11065
|
+
#### Methods <a name="Methods" id="Methods"></a>
|
|
11066
|
+
|
|
11067
|
+
| **Name** | **Description** |
|
|
11068
|
+
| --- | --- |
|
|
11069
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.addContainerMutatingHook">addContainerMutatingHook</a></code> | This hook allows another service extension to register a mutating hook for changing the primary container of this extension. |
|
|
11070
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.addHooks">addHooks</a></code> | A hook that allows the extension to add hooks to other extensions that are registered. |
|
|
11071
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.connectToService">connectToService</a></code> | This hook allows the extension to establish a connection to extensions from another service. |
|
|
11072
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.modifyServiceProps">modifyServiceProps</a></code> | Prior to launching the task definition as a service, this hook is called on each extension to give it a chance to mutate the properties of the service to be created. |
|
|
11073
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.modifyTaskDefinitionProps">modifyTaskDefinitionProps</a></code> | This is a hook which allows extensions to modify the settings of the task definition prior to it being created. |
|
|
11074
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.prehook">prehook</a></code> | A hook that is called for each extension ahead of time to allow for any initial setup, such as creating resources in advance. |
|
|
11075
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.resolveContainerDependencies">resolveContainerDependencies</a></code> | Once all containers are added to the task definition, this hook is called for each extension to give it a chance to resolve its dependency graph so that its container starts in the right order based on the other extensions that were enabled. |
|
|
11076
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.useService">useService</a></code> | When this hook is implemented by extension, it allows the extension to use the service which has been created. |
|
|
11077
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.useTaskDefinition">useTaskDefinition</a></code> | Once the task definition is created, this hook is called for each extension to give it a chance to add containers to the task definition, change the task definition's role to add permissions, etc. |
|
|
11078
|
+
|
|
11079
|
+
---
|
|
11080
|
+
|
|
11081
|
+
##### `addContainerMutatingHook` <a name="addContainerMutatingHook" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.addContainerMutatingHook"></a>
|
|
11082
|
+
|
|
11083
|
+
```typescript
|
|
11084
|
+
public addContainerMutatingHook(hook: ContainerMutatingHook): void
|
|
11085
|
+
```
|
|
11086
|
+
|
|
11087
|
+
This hook allows another service extension to register a mutating hook for changing the primary container of this extension.
|
|
11088
|
+
|
|
11089
|
+
This is primarily used
|
|
11090
|
+
for the application extension. For example, the Firelens extension wants to
|
|
11091
|
+
be able to modify the settings of the application container to
|
|
11092
|
+
route logs through Firelens.
|
|
11093
|
+
|
|
11094
|
+
###### `hook`<sup>Required</sup> <a name="hook" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.addContainerMutatingHook.parameter.hook"></a>
|
|
11095
|
+
|
|
11096
|
+
- *Type:* @aws-cdk-containers/ecs-service-extensions.ContainerMutatingHook
|
|
11097
|
+
|
|
11098
|
+
---
|
|
11099
|
+
|
|
11100
|
+
##### `addHooks` <a name="addHooks" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.addHooks"></a>
|
|
11101
|
+
|
|
11102
|
+
```typescript
|
|
11103
|
+
public addHooks(): void
|
|
11104
|
+
```
|
|
11105
|
+
|
|
11106
|
+
A hook that allows the extension to add hooks to other extensions that are registered.
|
|
11107
|
+
|
|
11108
|
+
##### `connectToService` <a name="connectToService" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.connectToService"></a>
|
|
11109
|
+
|
|
11110
|
+
```typescript
|
|
11111
|
+
public connectToService(service: Service, connectToProps?: ConnectToProps): void
|
|
11112
|
+
```
|
|
11113
|
+
|
|
11114
|
+
This hook allows the extension to establish a connection to extensions from another service.
|
|
11115
|
+
|
|
11116
|
+
Usually used for things like
|
|
11117
|
+
allowing one service to talk to the load balancer or service mesh
|
|
11118
|
+
proxy for another service.
|
|
11119
|
+
|
|
11120
|
+
###### `service`<sup>Required</sup> <a name="service" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.connectToService.parameter.service"></a>
|
|
11121
|
+
|
|
11122
|
+
- *Type:* @aws-cdk-containers/ecs-service-extensions.Service
|
|
11123
|
+
|
|
11124
|
+
The other service to connect to.
|
|
11125
|
+
|
|
11126
|
+
---
|
|
11127
|
+
|
|
11128
|
+
###### `connectToProps`<sup>Optional</sup> <a name="connectToProps" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.connectToService.parameter.connectToProps"></a>
|
|
11129
|
+
|
|
11130
|
+
- *Type:* @aws-cdk-containers/ecs-service-extensions.ConnectToProps
|
|
11131
|
+
|
|
11132
|
+
---
|
|
11133
|
+
|
|
11134
|
+
##### `modifyServiceProps` <a name="modifyServiceProps" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.modifyServiceProps"></a>
|
|
11135
|
+
|
|
11136
|
+
```typescript
|
|
11137
|
+
public modifyServiceProps(props: ServiceBuild): ServiceBuild
|
|
11138
|
+
```
|
|
11139
|
+
|
|
11140
|
+
Prior to launching the task definition as a service, this hook is called on each extension to give it a chance to mutate the properties of the service to be created.
|
|
11141
|
+
|
|
11142
|
+
###### `props`<sup>Required</sup> <a name="props" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.modifyServiceProps.parameter.props"></a>
|
|
11143
|
+
|
|
11144
|
+
- *Type:* @aws-cdk-containers/ecs-service-extensions.ServiceBuild
|
|
11145
|
+
|
|
11146
|
+
---
|
|
11147
|
+
|
|
11148
|
+
##### `modifyTaskDefinitionProps` <a name="modifyTaskDefinitionProps" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.modifyTaskDefinitionProps"></a>
|
|
11149
|
+
|
|
11150
|
+
```typescript
|
|
11151
|
+
public modifyTaskDefinitionProps(props: TaskDefinitionProps): TaskDefinitionProps
|
|
11152
|
+
```
|
|
11153
|
+
|
|
11154
|
+
This is a hook which allows extensions to modify the settings of the task definition prior to it being created.
|
|
11155
|
+
|
|
11156
|
+
For example, the App Mesh
|
|
11157
|
+
extension needs to configure an Envoy proxy in the task definition,
|
|
11158
|
+
or the Application extension wants to set the overall resource for
|
|
11159
|
+
the task.
|
|
11160
|
+
|
|
11161
|
+
###### `props`<sup>Required</sup> <a name="props" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.modifyTaskDefinitionProps.parameter.props"></a>
|
|
11162
|
+
|
|
11163
|
+
- *Type:* aws-cdk-lib.aws_ecs.TaskDefinitionProps
|
|
11164
|
+
|
|
11165
|
+
Properties of the task definition to be created.
|
|
11166
|
+
|
|
11167
|
+
---
|
|
11168
|
+
|
|
11169
|
+
##### `prehook` <a name="prehook" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.prehook"></a>
|
|
11170
|
+
|
|
11171
|
+
```typescript
|
|
11172
|
+
public prehook(parent: Service, scope: Construct): void
|
|
11173
|
+
```
|
|
11174
|
+
|
|
11175
|
+
A hook that is called for each extension ahead of time to allow for any initial setup, such as creating resources in advance.
|
|
11176
|
+
|
|
11177
|
+
###### `parent`<sup>Required</sup> <a name="parent" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.prehook.parameter.parent"></a>
|
|
11178
|
+
|
|
11179
|
+
- *Type:* @aws-cdk-containers/ecs-service-extensions.Service
|
|
11180
|
+
|
|
11181
|
+
The parent service which this extension has been added to.
|
|
11182
|
+
|
|
11183
|
+
---
|
|
11184
|
+
|
|
11185
|
+
###### `scope`<sup>Required</sup> <a name="scope" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.prehook.parameter.scope"></a>
|
|
11186
|
+
|
|
11187
|
+
- *Type:* constructs.Construct
|
|
11188
|
+
|
|
11189
|
+
The scope that this extension should create resources in.
|
|
11190
|
+
|
|
11191
|
+
---
|
|
11192
|
+
|
|
11193
|
+
##### `resolveContainerDependencies` <a name="resolveContainerDependencies" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.resolveContainerDependencies"></a>
|
|
11194
|
+
|
|
11195
|
+
```typescript
|
|
11196
|
+
public resolveContainerDependencies(): void
|
|
11197
|
+
```
|
|
11198
|
+
|
|
11199
|
+
Once all containers are added to the task definition, this hook is called for each extension to give it a chance to resolve its dependency graph so that its container starts in the right order based on the other extensions that were enabled.
|
|
11200
|
+
|
|
11201
|
+
##### `useService` <a name="useService" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.useService"></a>
|
|
11202
|
+
|
|
11203
|
+
```typescript
|
|
11204
|
+
public useService(service: Ec2Service | FargateService): void
|
|
11205
|
+
```
|
|
11206
|
+
|
|
11207
|
+
When this hook is implemented by extension, it allows the extension to use the service which has been created.
|
|
11208
|
+
|
|
11209
|
+
It is generally used to
|
|
11210
|
+
create any final resources which might depend on the service itself.
|
|
11211
|
+
|
|
11212
|
+
###### `service`<sup>Required</sup> <a name="service" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.useService.parameter.service"></a>
|
|
11213
|
+
|
|
11214
|
+
- *Type:* aws-cdk-lib.aws_ecs.Ec2Service | aws-cdk-lib.aws_ecs.FargateService
|
|
11215
|
+
|
|
11216
|
+
---
|
|
11217
|
+
|
|
11218
|
+
##### `useTaskDefinition` <a name="useTaskDefinition" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.useTaskDefinition"></a>
|
|
11219
|
+
|
|
11220
|
+
```typescript
|
|
11221
|
+
public useTaskDefinition(taskDefinition: TaskDefinition): void
|
|
11222
|
+
```
|
|
11223
|
+
|
|
11224
|
+
Once the task definition is created, this hook is called for each extension to give it a chance to add containers to the task definition, change the task definition's role to add permissions, etc.
|
|
11225
|
+
|
|
11226
|
+
###### `taskDefinition`<sup>Required</sup> <a name="taskDefinition" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.useTaskDefinition.parameter.taskDefinition"></a>
|
|
11227
|
+
|
|
11228
|
+
- *Type:* aws-cdk-lib.aws_ecs.TaskDefinition
|
|
11229
|
+
|
|
11230
|
+
The created task definition to add containers to.
|
|
11231
|
+
|
|
11232
|
+
---
|
|
11233
|
+
|
|
11234
|
+
|
|
11235
|
+
#### Properties <a name="Properties" id="Properties"></a>
|
|
11236
|
+
|
|
11237
|
+
| **Name** | **Type** | **Description** |
|
|
11238
|
+
| --- | --- | --- |
|
|
11239
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.property.name">name</a></code> | <code>string</code> | The name of the extension. |
|
|
11240
|
+
| <code><a href="#@btc-embedded/cdk-extensions.DeploymentConfigExtension.property.container">container</a></code> | <code>aws-cdk-lib.aws_ecs.ContainerDefinition</code> | The container for this extension. |
|
|
11241
|
+
|
|
11242
|
+
---
|
|
11243
|
+
|
|
11244
|
+
##### `name`<sup>Required</sup> <a name="name" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.property.name"></a>
|
|
11245
|
+
|
|
11246
|
+
```typescript
|
|
11247
|
+
public readonly name: string;
|
|
11248
|
+
```
|
|
11249
|
+
|
|
11250
|
+
- *Type:* string
|
|
11251
|
+
|
|
11252
|
+
The name of the extension.
|
|
11253
|
+
|
|
11254
|
+
---
|
|
11255
|
+
|
|
11256
|
+
##### `container`<sup>Optional</sup> <a name="container" id="@btc-embedded/cdk-extensions.DeploymentConfigExtension.property.container"></a>
|
|
11257
|
+
|
|
11258
|
+
```typescript
|
|
11259
|
+
public readonly container: ContainerDefinition;
|
|
11260
|
+
```
|
|
11261
|
+
|
|
11262
|
+
- *Type:* aws-cdk-lib.aws_ecs.ContainerDefinition
|
|
11263
|
+
|
|
11264
|
+
The container for this extension.
|
|
11265
|
+
|
|
11266
|
+
Most extensions have a container, but not
|
|
11267
|
+
every extension is required to have a container. Some extensions may just
|
|
11268
|
+
modify the properties of the service, or create external resources
|
|
11269
|
+
connected to the service.
|
|
11270
|
+
|
|
11271
|
+
---
|
|
11272
|
+
|
|
11273
|
+
|
|
10930
11274
|
### DocumentDbAccessExtension <a name="DocumentDbAccessExtension" id="@btc-embedded/cdk-extensions.DocumentDbAccessExtension"></a>
|
|
10931
11275
|
|
|
10932
11276
|
#### Initializers <a name="Initializers" id="@btc-embedded/cdk-extensions.DocumentDbAccessExtension.Initializer"></a>
|
package/CHANGELOG.md
CHANGED
|
@@ -1,4 +1,14 @@
|
|
|
1
1
|
|
|
2
|
+
## [0.20.3](https://github.com/btc-embedded/cdk-extensions/compare/v0.20.2...v0.20.3) (2026-01-16)
|
|
3
|
+
|
|
4
|
+
## [0.20.2](https://github.com/btc-embedded/cdk-extensions/compare/v0.20.1...v0.20.2) (2026-01-16)
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
### Features
|
|
8
|
+
|
|
9
|
+
* add ExportedService construct for cross-stack ECS service connectivity ([c1bcdd9](https://github.com/btc-embedded/cdk-extensions/commit/c1bcdd9efde3541d644dc68a231ae115003a4898))
|
|
10
|
+
* make domain prefix optional in ALBv2 ([af85121](https://github.com/btc-embedded/cdk-extensions/commit/af851211c0b245d8cd60dbf5e197443b3485d536))
|
|
11
|
+
|
|
2
12
|
## [0.20.1](https://github.com/btc-embedded/cdk-extensions/compare/v0.20.0...v0.20.1) (2026-01-15)
|
|
3
13
|
|
|
4
14
|
|
|
@@ -145,5 +145,5 @@ class EventPipe extends construct_1.Construct {
|
|
|
145
145
|
}
|
|
146
146
|
exports.EventPipe = EventPipe;
|
|
147
147
|
_a = JSII_RTTI_SYMBOL_1;
|
|
148
|
-
EventPipe[_a] = { fqn: "@btc-embedded/cdk-extensions.EventPipe", version: "0.20.
|
|
148
|
+
EventPipe[_a] = { fqn: "@btc-embedded/cdk-extensions.EventPipe", version: "0.20.4" };
|
|
149
149
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventPipe.js","sourceRoot":"","sources":["../../src/constructs/EventPipe.ts"],"names":[],"mappings":";;;;;AAAA,6CAA0C;AAC1C,iDAA6D;AAE7D,qDAAgD;AAGhD,wDAAqD;AACrD,0CAA0C;AAC1C,wEAAuE;AAsCvE,IAAY,QAiBX;AAjBD,WAAY,QAAQ;IAClB;;OAEG;IACH,uBAAW,CAAA;IACX;;OAEG;IACH,2BAAe,CAAA;IACf;;OAEG;IACH,yBAAa,CAAA;IACb;;OAEG;IACH,2BAAe,CAAA;AACjB,CAAC,EAjBW,QAAQ,wBAAR,QAAQ,QAiBnB;AAED;;GAEG;AACH,IAAY,cAcX;AAdD,WAAY,cAAc;IACxB;;;;;OAKG;IACH,2EAAgB,CAAA;IAChB;;;;OAIG;IACH,yEAAe,CAAA;AACjB,CAAC,EAdW,cAAc,8BAAd,cAAc,QAczB;AA2FD;;GAEG;AACH,MAAa,SAAU,SAAQ,qBAAS;IAGtC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAqB;QAC7D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,kBAAkB,GACpB,cAAc,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC;QACzE,IAAI,4BAA4B,GAC9B,YAAY,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;QAErE,IAAI,WAAW,GAAG,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;QAE3E,IAAI,SAAS,GAAG,WAAW,KAAK,SAAS,CAAC;QAE1C,IAAI,SAAS,GAAG,SAAS;YACvB,CAAC,CAAC,WAAY,CAAC,QAAQ;YACvB,CAAC,CAAC,kBAAmB,CAAC,eAAe,CAAC;QAExC,IAAI,YAAY,GAAG,SAAS,CAAC;QAC7B,IAAI,IAAA,6CAAsB,EAAC,EAAE,CAAC,EAAE,CAAC;YAC/B,yBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,4BAA4B,CAAC,CAAC;YAChE,YAAY,GAAG,SAAS,CAAC;QAC3B,CAAC;QAED,IAAI,CAAC,IAAI;YACP,KAAK,CAAC,IAAI;gBACV,IAAI,cAAI,CAAC,IAAI,EAAE,eAAe,EAAE;oBAC9B,SAAS,EAAE,IAAI,0BAAgB,CAAC,qBAAqB,CAAC;iBACvD,CAAC,CAAC;QAEL,IAAI,cAAc,GAAG,KAAK,CAAC,MAAM;YAC/B,CAAC,CAAC;gBACE,OAAO,EAAE;oBACP;wBACE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;4BACtB,IAAI,EAAE;gCACJ,GAAG,KAAK,CAAC,MAAM;6BAChB;yBACF,CAAC;qBACH;iBACF;aACF;YACH,CAAC,CAAC,SAAS,CAAC;QAEd,IAAI,gBAAgB,GAAyC,EAAE,CAAC;QAChE,IAAI,WAAW,EAAE,CAAC;YAChB,gBAAgB,GAAG;gBACjB,kBAAkB,EAAE;oBAClB,cAAc,EAAE,SAAS;iBAC1B;aACF,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,gBAAgB,GAAG;gBACjB,kCAAkC,EAAE;oBAClC,cAAc,EAAE,4BAA4B,EAAE,cAAc;wBAC1D,CAAC,CAAC,cAAc,CAAC,4BAA4B,CAAC,cAAc,CAAC;wBAC7D,CAAC,CAAC,cAAc,CAAC,cAAc,CAAC,gBAAgB,CAAC;iBACpD;gBACD,GAAG,CAAC,4BAA4B,EAAE,aAAa,IAAI;oBACjD,aAAa,EAAE,IAAI,CAAC,SAAS,CAC3B,4BAA4B,CAAC,aAAa,CAC3C,CAAC,OAAO,CAAC,iBAAiB,EAAE,IAAI,CAAC;iBACnC,CAAC;aACH,CAAC;QACJ,CAAC;QAED,IAAI,gBAAgB,GAAG;YACrB,kBAAkB,EAAE;gBAClB,SAAS,EAAE,CAAC;aACb;YACD,GAAG,CAAC,cAAc,IAAI,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC;SAC1D,CAAC;QAEF,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;YACzC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ;gBACf,IAAI,sBAAW,CAAC,IAAI,EAAE,mBAAmB,EAAE;oBACzC,OAAO,EAAE,YAAY;iBACtB,CAAC,CAAC;YACL,CAAC,CAAC,SAAS,CAAC;QAEd,MAAM,iBAAiB,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;YAClD,CAAC,CAAC;gBACE,gBAAgB,EAAE;oBAChB,4BAA4B,EAAE;wBAC5B,WAAW,EAAE,QAAS,CAAC,WAAW;qBACnC;oBACD,KAAK,EAAE,KAAK,CAAC,QAAQ;iBACtB;aACF;YACH,CAAC,CAAC,EAAE,CAAC;QAEP,IAAI,mBAAO,CAAC,IAAI,EAAE,WAAW,EAAE;YAC7B,GAAG,iBAAiB;YACpB,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO;YAC1B,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,QAAQ;YAC7B,MAAM,EAAE,SAAS;YACjB,gBAAgB,EAAE,gBAAgB;YAClC,gBAAgB,EAAE,gBAAgB;YAClC,YAAY,EAAE,YAAY;SAC3B,CAAC,CAAC;QAEH,KAAK,CAAC,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7C,WAAW,EAAE,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1C,kBAAkB,EAAE,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,QAAQ,EAAE,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAEO,cAAc,CAAC,KAAqB;QAC1C,OAAO,KAAK,CAAC,QAAQ,KAAK,SAAS,IAAI,KAAK,CAAC,QAAQ,KAAK,QAAQ,CAAC,GAAG,CAAC;IACzE,CAAC;;AA9GH,8BA+GC","sourcesContent":["import { Annotations } from \"aws-cdk-lib\";\nimport { Role, ServicePrincipal } from \"aws-cdk-lib/aws-iam\";\nimport { ILogGroup } from \"aws-cdk-lib/aws-logs\";\nimport { CfnPipe } from \"aws-cdk-lib/aws-pipes\";\nimport { IQueue } from \"aws-cdk-lib/aws-sqs\";\nimport { IStateMachine } from \"aws-cdk-lib/aws-stepfunctions\";\nimport { Construct } from \"constructs/lib/construct\";\nimport { BTCLogGroup } from \"../platform\";\nimport { isDeactivatedConstruct } from \"../utils/deactivatedConstruct\";\n\n/**\n * Properties for pipe construction.\n */\nexport interface EventPipeProps {\n  /**\n   * The source SQS queue. No other source types are supported at the moment.\n   */\n  readonly source: IQueue;\n\n  /**\n   * The target SQS queue or target step function.\n   */\n  readonly target: TargetQueue | TargetStepFunction;\n\n  /**\n   * The role used by the event pipe. If omitted, a new role is created.\n   */\n  readonly role?: Role;\n\n  /**\n   * An optional filter for the pipe.\n   */\n  readonly filter?: PipeFilter;\n\n  /**\n   * Set the log level for the pipe. Creates a new log group, if enabled.\n   * Default: Disabled.\n   */\n  readonly logLevel?: LogLevel;\n\n  /**\n   * Use an existing log group. If none is given and logging is enabled, a new log group will be created.\n   */\n  readonly logGroup?: ILogGroup;\n}\n\nexport enum LogLevel {\n  /**\n   * Deactivate logging. No log group will be created.\n   */\n  OFF = \"OFF\",\n  /**\n   * Only log errors.\n   */\n  ERROR = \"ERROR\",\n  /**\n   * Log errors and informational messages.\n   */\n  INFO = \"INFO\",\n  /**\n   * Log very verbose.\n   */\n  TRACE = \"TRACE\",\n}\n\n/**\n * The invocation type of the step function.\n */\nexport enum InvocationType {\n  /**\n   * (default) - Invoke synchronously. For more information, see\n   * [StartSyncExecution](https://docs.aws.amazon.com/step-functions/latest/apireference/API_StartSyncExecution.html)\n   * in the *AWS Step Functions API Reference*.\n   * > `REQUEST_RESPONSE` is not supported for `STANDARD` state machine workflows.\n   */\n  REQUEST_RESPONSE,\n  /**\n   * Invoke asynchronously. For more information, see\n   * [StartExecution](https://docs.aws.amazon.com/step-functions/latest/apireference/API_StartExecution.html)\n   * in the *AWS Step Functions API Reference*.\n   */\n  FIRE_AND_FORGET,\n}\n\n/**\n * The input template.\n * Note that some values in the resulting code should not have quotes around the value, e.g. if an object\n * shall be added. To reflect this, add curly brackets around the value, e.g. `{{<$.body>}}`.\n */\nexport interface InputTemplate {\n  /**\n   * @jsii ignore\n   */\n  readonly [key: string]: string;\n}\n\n/**\n * SQS queue as pipe target.\n */\nexport interface TargetQueue {\n  readonly queue: IQueue;\n}\n\n/**\n * StepFunction as pipe target.\n */\nexport interface TargetStepFunction {\n  readonly stepFunction: IStateMachine;\n  readonly parameters?: TargetStepFunctionParameters;\n}\n\n/**\n * Parameters for a step function target.\n */\nexport interface TargetStepFunctionParameters {\n  readonly inputTemplate?: InputTemplate;\n  readonly invocationType?: InvocationType;\n}\n\n/**\n * Base type for filter rules. Not all available rules are currently implemented.\n */\nexport type FilterRule =\n  | PrefixFilterRule\n  | SuffixFilterRule\n  | AnythingButFilterRule\n  | FilterEqualsIgnoreCase;\n\n/**\n * Rule that a property has to start with a prefix.\n */\nexport interface PrefixFilterRule {\n  readonly prefix: string | FilterEqualsIgnoreCase;\n}\n\n/**\n * Rule that a property has to end with a suffix.\n */\nexport interface SuffixFilterRule {\n  readonly suffix: string | FilterEqualsIgnoreCase;\n}\n\n/**\n * Rule that allows all values except the given ones.\n */\nexport interface AnythingButFilterRule {\n  /**\n   * @jsii ignore\n   */\n  readonly \"anything-but\": string[] | FilterRule;\n}\n\n/**\n * Rule that matches a string, ignoring the case.\n */\nexport interface FilterEqualsIgnoreCase {\n  /**\n   * @jsii ignore\n   */\n  readonly \"equals-ignore-case\": string | string[];\n}\n\n/**\n * A filter for messages in the pipe.\n */\nexport interface PipeFilter {\n  /**\n   * The rules for each attribute of the body.\n   * @jsii ignore\n   */\n  readonly [key: string]: FilterRule[];\n}\n\n/**\n * A wrapper for the L1 event pipe with the ability to deactivate it within the stack.\n */\nexport class EventPipe extends Construct {\n  public readonly role: Role;\n\n  constructor(scope: Construct, id: string, props: EventPipeProps) {\n    super(scope, id);\n\n    let targetStepFunction =\n      \"stepFunction\" in props.target ? props.target.stepFunction : undefined;\n    let targetStepFunctionParameters =\n      \"parameters\" in props.target ? props.target.parameters : undefined;\n\n    let targetQueue = \"queue\" in props.target ? props.target.queue : undefined;\n\n    let sqsTarget = targetQueue !== undefined;\n\n    let targetArn = sqsTarget\n      ? targetQueue!.queueArn\n      : targetStepFunction!.stateMachineArn;\n\n    let desiredState = \"RUNNING\";\n    if (isDeactivatedConstruct(id)) {\n      Annotations.of(this).addInfo(`${id} is set do be deactivated.`);\n      desiredState = \"STOPPED\";\n    }\n\n    this.role =\n      props.role ||\n      new Role(this, \"EventPipeRole\", {\n        assumedBy: new ServicePrincipal(\"pipes.amazonaws.com\"),\n      });\n\n    let filterCriteria = props.filter\n      ? {\n          filters: [\n            {\n              pattern: JSON.stringify({\n                body: {\n                  ...props.filter,\n                },\n              }),\n            },\n          ],\n        }\n      : undefined;\n\n    let targetParameters: CfnPipe.PipeTargetParametersProperty = {};\n    if (targetQueue) {\n      targetParameters = {\n        sqsQueueParameters: {\n          messageGroupId: \"default\",\n        },\n      };\n    } else {\n      targetParameters = {\n        stepFunctionStateMachineParameters: {\n          invocationType: targetStepFunctionParameters?.invocationType\n            ? InvocationType[targetStepFunctionParameters.invocationType]\n            : InvocationType[InvocationType.REQUEST_RESPONSE],\n        },\n        ...(targetStepFunctionParameters?.inputTemplate && {\n          inputTemplate: JSON.stringify(\n            targetStepFunctionParameters.inputTemplate,\n          ).replace(/\"\\{\\{(.+?)\\}\\}\"/, \"$1\"),\n        }),\n      };\n    }\n\n    let sourceParameters = {\n      sqsQueueParameters: {\n        batchSize: 1,\n      },\n      ...(filterCriteria && { filterCriteria: filterCriteria }),\n    };\n\n    const logGroup = this.loggingEnabled(props)\n      ? (props.logGroup ??\n        new BTCLogGroup(this, \"EventPipeLogGroup\", {\n          logType: \"event-pipe\",\n        }))\n      : undefined;\n\n    const pipeConfiguration = this.loggingEnabled(props)\n      ? {\n          logConfiguration: {\n            cloudwatchLogsLogDestination: {\n              logGroupArn: logGroup!.logGroupArn,\n            },\n            level: props.logLevel,\n          },\n        }\n      : {};\n\n    new CfnPipe(this, \"EventPipe\", {\n      ...pipeConfiguration,\n      roleArn: this.role.roleArn,\n      source: props.source.queueArn,\n      target: targetArn,\n      sourceParameters: sourceParameters,\n      targetParameters: targetParameters,\n      desiredState: desiredState,\n    });\n\n    props.source.grantConsumeMessages(this.role);\n    targetQueue?.grantSendMessages(this.role);\n    targetStepFunction?.grantStartExecution(this.role);\n    logGroup?.grantWrite(this.role);\n  }\n\n  private loggingEnabled(props: EventPipeProps): boolean {\n    return props.logLevel !== undefined && props.logLevel !== LogLevel.OFF;\n  }\n}\n"]}
|