@btc-embedded/cdk-extensions 0.20.3 → 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.
Files changed (46) hide show
  1. package/.jsii +207 -2
  2. package/API.md +344 -0
  3. package/CHANGELOG.md +2 -0
  4. package/lib/constructs/EventPipe.js +1 -1
  5. package/lib/constructs/ExportedService.js +1 -1
  6. package/lib/constructs/S3Bucket.js +1 -1
  7. package/lib/constructs/SecureRestApi.js +1 -1
  8. package/lib/constructs/SecureRestApiV2.js +1 -1
  9. package/lib/extensions/ApiGatewayExtension.js +1 -1
  10. package/lib/extensions/ApplicationLoadBalancerExtension.js +1 -1
  11. package/lib/extensions/ApplicationLoadBalancerExtensionV2.js +1 -1
  12. package/lib/extensions/CloudMapExtension.js +1 -1
  13. package/lib/extensions/DeactivatableServiceExtension.js +1 -1
  14. package/lib/extensions/DeploymentConfigExtension.d.ts +65 -0
  15. package/lib/extensions/DeploymentConfigExtension.js +69 -0
  16. package/lib/extensions/DocumentDbAccessExtension.js +1 -1
  17. package/lib/extensions/DomainEventMessagingExtension.js +1 -1
  18. package/lib/extensions/EfsMountExtension.js +1 -1
  19. package/lib/extensions/ExtraContainerExtension.js +1 -1
  20. package/lib/extensions/HTTPApiExtension.js +1 -1
  21. package/lib/extensions/LogExtension.js +1 -1
  22. package/lib/extensions/ModifyContainerDefinitionExtension.js +1 -1
  23. package/lib/extensions/ModifyTaskDefinitionExtension.js +1 -1
  24. package/lib/extensions/OpenIdExtension.js +1 -1
  25. package/lib/extensions/OpenTelemetryExtension.js +1 -1
  26. package/lib/extensions/PostgresDbAccessExtension.js +1 -1
  27. package/lib/extensions/SharedVolumeExtension.js +1 -1
  28. package/lib/extensions/TcpKeepAliveExtension.js +1 -1
  29. package/lib/extensions/index.d.ts +2 -1
  30. package/lib/extensions/index.js +3 -2
  31. package/lib/platform/ApiGateway.js +1 -1
  32. package/lib/platform/ApiGatewayVpcLink.js +2 -2
  33. package/lib/platform/ApplicationLoadBalancer.js +1 -1
  34. package/lib/platform/ApplicationLoadBalancerV2.js +2 -2
  35. package/lib/platform/BTCLogGroup.js +1 -1
  36. package/lib/platform/CognitoUserPool.js +2 -2
  37. package/lib/platform/DefaultUserPoolClients.js +1 -1
  38. package/lib/platform/DocumentDB.js +2 -2
  39. package/lib/platform/EcsCluster.js +1 -1
  40. package/lib/platform/EfsFileSystem.js +1 -1
  41. package/lib/platform/PrivateDnsNamespace.js +1 -1
  42. package/lib/platform/ResourceServer.js +1 -1
  43. package/lib/platform/Vpc.js +1 -1
  44. package/lib/platform/VpcV2.js +1 -1
  45. package/lib/utils/StackParameter.js +1 -1
  46. 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.3",
13464
- "fingerprint": "F4F0u0OX/Q1q/3BJqdarjmFjjr85dX/SwRywHaoKlSg="
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,6 @@
1
1
 
2
+ ## [0.20.3](https://github.com/btc-embedded/cdk-extensions/compare/v0.20.2...v0.20.3) (2026-01-16)
3
+
2
4
  ## [0.20.2](https://github.com/btc-embedded/cdk-extensions/compare/v0.20.1...v0.20.2) (2026-01-16)
3
5
 
4
6
 
@@ -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.3" };
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":"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","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"]}
@@ -135,5 +135,5 @@ class ExportedService extends ExportedServiceBase {
135
135
  }
136
136
  exports.ExportedService = ExportedService;
137
137
  _a = JSII_RTTI_SYMBOL_1;
138
- ExportedService[_a] = { fqn: "@btc-embedded/cdk-extensions.ExportedService", version: "0.20.3" };
138
+ ExportedService[_a] = { fqn: "@btc-embedded/cdk-extensions.ExportedService", version: "0.20.4" };
139
139
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ExportedService.js","sourceRoot":"","sources":["../../src/constructs/ExportedService.ts"],"names":[],"mappings":"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","sourcesContent":["import { Service } from \"@aws-cdk-containers/ecs-service-extensions\";\nimport {\n  IConnectable,\n  ISecurityGroup,\n  Port,\n  SecurityGroup,\n} from \"aws-cdk-lib/aws-ec2\";\nimport { Construct } from \"constructs\";\nimport { StackParameter } from \"../utils\";\nimport { kebabCase } from \"../utils/common\";\n\n/**\n * Options for importing an ExportedService from another stack.\n */\nexport interface ExportedServiceLookupOptions {\n  /**\n   * The name of the stack where the service was exported.\n   */\n  readonly stackName: string;\n\n  /**\n   * The name of the exported ECS service.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The port on which the service is listening.\n   */\n  readonly port: number;\n}\n\n/**\n * Public interface for an ExportedService.\n */\nexport interface IExportedService extends IConnectable {\n  /**\n   * The security group of the exported ECS service.\n   */\n  readonly securityGroup: ISecurityGroup;\n\n  /**\n   * Get the internal API URL of the service.\n   */\n  apiUrl(): string;\n\n  /**\n   * Allow an ECS service to connect to this exported service.\n   */\n  allowFrom(service: Service, description?: string): void;\n}\n\n/**\n * Properties for creating a new ExportedService.\n */\nexport interface ExportedServiceProps {\n  /**\n   * The name of the ECS service being exported.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The security group of the ECS service.\n   */\n  readonly securityGroup: ISecurityGroup;\n\n  /**\n   * The namespace name where the service is registered (CloudMap namespace).\n   */\n  readonly namespaceName: string;\n}\n\n/**\n * Base class for an ECS service that can be used across stack boundaries.\n *\n * This abstract class provides common functionality for working with exported\n * ECS services, including API URL generation and connection management.\n */\nabstract class ExportedServiceBase\n  extends Construct\n  implements IExportedService\n{\n  protected readonly serviceName: string;\n  protected readonly namespaceName: string;\n  protected readonly port: number;\n  public readonly securityGroup: ISecurityGroup;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    serviceName: string,\n    namespaceName: string,\n    port: number,\n    securityGroup: ISecurityGroup,\n  ) {\n    super(scope, id);\n    this.serviceName = serviceName;\n    this.namespaceName = namespaceName;\n    this.port = port;\n    this.securityGroup = securityGroup;\n  }\n\n  /**\n   * Get the internal API URL of the service.\n   *\n   * The URL format is: http://<service-name>.<namespace>:<port>/\n   *\n   * @returns The internal API URL\n   */\n  public apiUrl(): string {\n    return `http://${this.serviceName}.${this.namespaceName}:${this.port}/`;\n  }\n\n  /**\n   * Get the connections object for this service.\n   *\n   * This allows the ExportedService to be used with the standard CDK IConnectable\n   * pattern for security group management.\n   */\n  get connections() {\n    return this.securityGroup.connections;\n  }\n\n  /**\n   * Allow an ECS service to connect to this exported service.\n   *\n   * This method adds a security group ingress rule allowing traffic from the\n   * given service to this exported service on its configured port.\n   *\n   * @param service - The ECS service to allow connections from\n   * @param description - Optional description for the security group rule\n   */\n  public allowFrom(\n    service: Service,\n    description: string = \"Allow connection from ECS service\",\n  ): void {\n    this.securityGroup.connections.allowFrom(\n      service.ecsService,\n      Port.tcp(this.port),\n      description,\n    );\n  }\n}\n\n/**\n * Represents an ECS service exported from another CDK stack.\n *\n * This construct enables cross-stack service connectivity by transporting service\n * metadata (security group ID and namespace) across stack boundaries using StackParameter.\n * The port must be specified when importing the service.\n *\n * On the provider side (where the service is defined), use ExportedService\n * within the CloudMapExtension to expose the service. On the consumer side,\n * use ExportedService.fromAttributes() to import the service with the port.\n *\n * @example\n * // Provider side\n * const exportedService = new ExportedService(this, \"ExportedService\", {\n *   serviceName: 'my-service',\n *   securityGroup: service.connections.securityGroups[0],\n *   namespaceName: 'my-namespace',\n * });\n *\n * @example\n * // Consumer side\n * const exportedService = ExportedService.fromAttributes(scope, id, {\n *   stackName: 'my-service-stack',\n *   serviceName: 'my-service',\n *   port: 8080,\n * });\n *\n * exportedService.allowFrom(myService);\n * const url = exportedService.apiUrl();\n */\nexport class ExportedService extends ExportedServiceBase {\n  /**\n   * Import an ExportedService from another stack.\n   *\n   * This method imports the service metadata (security group and namespace)\n   * that was exported by the provider stack and constructs an IExportedService\n   * instance that can be used for establishing connections.\n   *\n   * @param scope - The scope in which to define the construct\n   * @param id - The construct ID\n   * @param attrs - The exported service lookup options (stackName, serviceName, and port)\n   * @returns An IExportedService instance\n   */\n  public static fromAttributes(\n    scope: Construct,\n    id: string,\n    attrs: ExportedServiceLookupOptions,\n  ): IExportedService {\n    const normalizedServiceName = kebabCase(attrs.serviceName);\n    const stackParameters = ExportedService.createStackParameters(\n      normalizedServiceName,\n    );\n\n    const securityGroupId = stackParameters.securityGroupParameter.import(\n      attrs.stackName,\n    );\n    const namespaceName = stackParameters.namespaceParameter.import(\n      attrs.stackName,\n    );\n\n    const securityGroup = SecurityGroup.fromSecurityGroupId(\n      scope,\n      \"ImportedSecurityGroup\",\n      securityGroupId,\n      { allowAllOutbound: true },\n    );\n\n    class Import extends ExportedServiceBase {\n      constructor() {\n        super(\n          scope,\n          id,\n          normalizedServiceName,\n          namespaceName,\n          attrs.port,\n          securityGroup,\n        );\n      }\n    }\n\n    return new Import();\n  }\n  private static createStackParameters(serviceName: string) {\n    return {\n      securityGroupParameter: new StackParameter({\n        prefix: [\"exported-service\", serviceName],\n        key: \"security-group-id\",\n        description: \"Security Group ID of the exported ECS service\",\n      }),\n      namespaceParameter: new StackParameter({\n        prefix: [\"exported-service\", serviceName],\n        key: \"namespace\",\n        description: \"CloudMap namespace of the exported ECS service\",\n      }),\n    };\n  }\n\n  private readonly stackParameters: ReturnType<\n    typeof ExportedService.createStackParameters\n  >;\n\n  constructor(scope: Construct, id: string, props: ExportedServiceProps) {\n    const normalizedServiceName = kebabCase(props.serviceName);\n    super(\n      scope,\n      id,\n      normalizedServiceName,\n      props.namespaceName,\n      0, // Default port - actual port is specified on consumer side\n      props.securityGroup,\n    );\n\n    this.stackParameters = ExportedService.createStackParameters(\n      normalizedServiceName,\n    );\n\n    // Export service metadata for cross-stack consumption\n    this.stackParameters.securityGroupParameter.export(\n      this,\n      props.securityGroup.securityGroupId,\n    );\n    this.stackParameters.namespaceParameter.export(this, props.namespaceName);\n  }\n}\n"]}