@aws-solutions-constructs/aws-fargate-opensearch 2.85.2 → 2.85.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 CHANGED
@@ -8,7 +8,7 @@
8
8
  "url": "https://aws.amazon.com"
9
9
  },
10
10
  "dependencies": {
11
- "@aws-solutions-constructs/core": "2.85.2",
11
+ "@aws-solutions-constructs/core": "2.85.4",
12
12
  "aws-cdk-lib": "^2.193.0",
13
13
  "constructs": "^10.0.0"
14
14
  },
@@ -3993,7 +3993,7 @@
3993
3993
  },
3994
3994
  "name": "@aws-solutions-constructs/aws-fargate-opensearch",
3995
3995
  "readme": {
3996
- "markdown": "# aws-fargate-opensearch module\n<!--BEGIN STABILITY BANNER-->\n\n---\n\n![Stability: Experimental](https://img.shields.io/badge/stability-Experimental-important.svg?style=for-the-badge)\n\n> All classes are under active development and subject to non-backward compatible changes or removal in any\n> future version. These are not subject to the [Semantic Versioning](https://semver.org/) model.\n> This means that while you may use them, you may need to update your source code when upgrading to a newer version of this package.\n\n---\n<!--END STABILITY BANNER-->\n\n| **Reference Documentation**:| <span style=\"font-weight: normal\">https://docs.aws.amazon.com/solutions/latest/constructs/</span>|\n|:-------------|:-------------|\n<div style=\"height:8px\"></div>\n\n| **Language** | **Package** |\n|:-------------|-----------------|\n|![Python Logo](https://docs.aws.amazon.com/cdk/api/latest/img/python32.png) Python|`aws_solutions_constructs.aws_fargate_opensearch`|\n|![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-fargate-opensearch`|\n|![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.fargateopensearch`|\n\n## Overview\nThis AWS Solutions Construct implements an AWS Fargate service that can write/read to an Amazon OpenSearch Service domain.\n\nHere is a minimal deployable pattern definition:\n\nTypescript\n``` typescript\nimport { Construct } from 'constructs';\nimport { Stack, StackProps } from 'aws-cdk-lib';\nimport { FargateToOpenSearch, FargateToOpenSearchProps } from '@aws-solutions-constructs/aws-fargate-opensearch';\n\nconst constructProps: FargateToOpenSearchProps = {\n publicApi: true,\n ecrRepositoryArn: \"arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo\",\n openSearchDomainName: 'testdomain',\n // TODO: Ensure the Cognito domain name is globally unique\n cognitoDomainName: 'globallyuniquedomain' + Aws.ACCOUNT_ID\n};\n\nnew FargateToOpenSearch(this, 'test-construct', constructProps);\n```\n\nPython\n``` python\nfrom aws_solutions_constructs.aws_fargate_opensearch import FargateToOpenSearch, FargateToOpenSearchProps\nfrom aws_cdk import (\n Stack\n)\nfrom constructs import Construct\n\nFargateToOpenSearch(self, 'test_construct',\n public_api=True,\n ecr_repository_arn=\"arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo\",\n open_search_domain_name='testdomain',\n # TODO: Ensure the Cognito domain name is globally unique\n cognito_domain_name='globallyuniquedomain' + Aws.ACCOUNT_ID)\n```\n\nJava\n``` java\nimport software.constructs.Construct;\n\nimport software.amazon.awscdk.Stack;\nimport software.amazon.awscdk.StackProps;\nimport software.amazon.awsconstructs.services.fargateopensearch.*;\n\nnew FargateToOpenSearch(this, \"test_construct\", new FargateToOpenSearchProps.Builder()\n .publicApi(true)\n .ecrRepositoryArn(\"arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo\"\n .openSearchDomainName(\"testdomain\")\n // TODO: Ensure the Cognito domain name is globally unique\n .cognitoDomainName(\"globallyuniquedomain\" + Aws.ACCOUNT_ID)\n .build());\n```\n## Pattern Construct Props\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n| publicApi | `boolean` | Whether the construct is deploying a private or public API. This has implications for the VPC. |\n| vpcProps? | [`ec2.VpcProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.VpcProps.html) | Optional custom properties for a VPC the construct will create. This VPC will be used by any Private Hosted Zone the construct creates (that's why loadBalancerProps and privateHostedZoneProps can't include a VPC). Providing both this and existingVpc is an error. |\n| existingVpc? | [`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html) | An existing VPC in which to deploy the construct. Providing both this and vpcProps is an error. If the client provides an existing load balancer and/or existing Private Hosted Zone, those constructs must exist in this VPC. |\n| clusterProps? | [`ecs.ClusterProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ClusterProps.html) | Optional properties to create a new ECS cluster. To provide an existing cluster, use the cluster attribute of fargateServiceProps. |\n| ecrRepositoryArn? | `string` | The arn of an ECR Repository containing the image to use to generate the containers. Either this or the image property of containerDefinitionProps must be provided. format: arn:aws:ecr:*region*:*account number*:repository/*Repository Name* |\n| ecrImageVersion? | `string` | The version of the image to use from the repository. Defaults to 'Latest'. |\n| containerDefinitionProps? | [`ecs.ContainerDefinitionProps \\| any`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinitionProps.html) | Optional props to define the container created for the Fargate Service (defaults found in fargate-defaults.ts). |\n| fargateTaskDefinitionProps? | [`ecs.FargateTaskDefinitionProps \\| any`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateTaskDefinitionProps.html) | Optional props to define the Fargate Task Definition for this construct (defaults found in fargate-defaults.ts). |\n| fargateServiceProps? | [`ecs.FargateServiceProps \\| any`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateServiceProps.html) | Optional values to override default Fargate Task definition properties (fargate-defaults.ts). The construct will default to launching the service is the most isolated subnets available (precedence: Isolated, Private and Public). Override those and other defaults here. |\n| existingFargateServiceObject? | [`ecs.FargateService`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateService.html) | A Fargate Service already instantiated (probably by another Solutions Construct). If this is specified, then no props defining a new service can be provided, including: ecrImageVersion, containerDefinitionProps, fargateTaskDefinitionProps, ecrRepositoryArn, fargateServiceProps, clusterProps.|\n| existingContainerDefinitionObject? | [`ecs.ContainerDefinition`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinition.html) | A container definition already instantiated as part of a Fargate service. This must be the container in the existingFargateServiceObject.|\n|openSearchDomainProps?|[`opensearchservice.CfnDomainProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_opensearchservice.CfnDomainProps.html)|Optional user provided props to override the default props for the OpenSearch Service.|\n|openSearchDomainName|`string`|Domain name for the OpenSearch Service.|\n|cognitoDomainName?|`string`|Optional Amazon Cognito domain name. If omitted the Amazon Cognito domain will default to the OpenSearch Service domain name.|\n|createCloudWatchAlarms?|`boolean`|Whether to create the recommended CloudWatch alarms.|\n|domainEndpointEnvironmentVariableName?|`string`|Optional name for the OpenSearch Service domain endpoint environment variable set for the Lambda function. Default is `DOMAIN_ENDPOINT`.|\n\n## Pattern Properties\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n| vpc | [`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html) | The VPC used by the construct (whether created by the construct or provided by the client). |\n| service | [`ecs.FargateService`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateService.html) | The AWS Fargate service used by this construct (whether created by this construct or passed to this construct at initialization). |\n| container | [`ecs.ContainerDefinition`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinition.html) | The container associated with the AWS Fargate service in the service property. |\n|userPool|[`cognito.UserPool`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.UserPool.html)|Returns an instance of `cognito.UserPool` created by the construct.|\n|userPoolClient|[`cognito.UserPoolClient`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.UserPoolClient.html)|Returns an instance of `cognito.UserPoolClient` created by the construct.|\n|identityPool|[`cognito.CfnIdentityPool`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.CfnIdentityPool.html)|Returns an instance of `cognito.CfnIdentityPool` created by the construct.|\n|openSearchDomain|[`opensearchservice.CfnDomain`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_opensearchservice.CfnDomain.html)|Returns an instance of `opensearch.CfnDomain` created by the construct.|\n|openSearchRole|[`iam.Role`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_iam.Role.html)|Returns an instance of `iam.Role` created by the construct for `opensearch.CfnDomain`.|\n|cloudWatchAlarms?|[`cloudwatch.Alarm[]`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cloudwatch.Alarm.html)|Returns a list of `cloudwatch.Alarm` created by the construct.|\n\n## Default settings\n\nOut of the box implementation of the Construct without any override will set the following defaults:\n\n### AWS Fargate Service\n* Sets up an AWS Fargate service\n * Uses the existing service if provided\n * Creates a new service if none provided\n * Service will run in isolated subnets if available, then private subnets if available and finally public subnets\n * Adds environment variables to the container with the OpenSearch Service domain endpoint\n * Add permissions to the container IAM role allowing it to write/read to the OpenSearch Service domain endpoint\n\n### Amazon Cognito\n* Set password policy for User Pools\n* Enforce the advanced security mode for User Pools\n\n### Amazon OpenSearch Service\n* Deploy best practices CloudWatch Alarms for the OpenSearch Service domain\n* Secure the OpenSearch Service dashboard access with Cognito User Pools\n* Enable server-side encryption for OpenSearch Service domain using AWS managed KMS Key\n* Enable node-to-node encryption for the OpenSearch Service domain\n* Configure the cluster for the OpenSearch Service domain\n\n## Architecture\n![Architecture Diagram](architecture.png)\n\n***\n&copy; Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n"
3996
+ "markdown": "Documentation for this pattern can be found [here](https://github.com/awslabs/aws-solutions-constructs/blob/main/source/patterns/%40aws-solutions-constructs/aws-fargate-opensearch/README.adoc)\n"
3997
3997
  },
3998
3998
  "repository": {
3999
3999
  "directory": "source/patterns/@aws-solutions-constructs/aws-fargate-opensearch",
@@ -4445,6 +4445,6 @@
4445
4445
  "symbolId": "lib/index:FargateToOpenSearchProps"
4446
4446
  }
4447
4447
  },
4448
- "version": "2.85.2",
4449
- "fingerprint": "V0LmSW/yPE+D1iWVSB6BXwllCzy/Y0N1IOv/oSO8t+4="
4448
+ "version": "2.85.4",
4449
+ "fingerprint": "NOVArjlV3IOKrRnaSNifpiqH4+R+ohDux/w++92CCSc="
4450
4450
  }
package/README.adoc ADDED
@@ -0,0 +1,279 @@
1
+ //!!NODE_ROOT <section>
2
+ //== aws-fargate-opensearch module
3
+
4
+ [.topic]
5
+ = aws-fargate-opensearch
6
+ :info_doctype: section
7
+ :info_title: aws-fargate-opensearch
8
+
9
+
10
+ image:https://img.shields.io/badge/stability-Experimental-important.svg?style=for-the-badge[Stability:Experimental]
11
+
12
+ ____
13
+ All classes are under active development and subject to non-backward
14
+ compatible changes or removal in any future version. These are not
15
+ subject to the https://semver.org/[Semantic Versioning] model. This
16
+ means that while you may use them, you may need to update your source
17
+ code when upgrading to a newer version of this package.
18
+ ____
19
+
20
+ [width="100%",cols="<50%,<50%",options="header",]
21
+ |===
22
+ |*Reference Documentation*:
23
+ |https://docs.aws.amazon.com/solutions/latest/constructs/
24
+ |===
25
+
26
+ [width="100%",cols="<46%,54%",options="header",]
27
+ |===
28
+ |*Language* |*Package*
29
+ |image:https://docs.aws.amazon.com/cdk/api/latest/img/python32.png[Python
30
+ Logo] Python
31
+ |`aws_solutions_constructs.aws_fargate_opensearch`
32
+
33
+ |image:https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png[Typescript
34
+ Logo] Typescript |`@aws-solutions-constructs/aws-fargate-opensearch`
35
+
36
+ |image:https://docs.aws.amazon.com/cdk/api/latest/img/java32.png[Java
37
+ Logo] Java |`software.amazon.awsconstructs.services.fargateopensearch`
38
+ |===
39
+
40
+ == Overview
41
+
42
+ This AWS Solutions Construct implements an AWS Fargate service that can
43
+ write/read to an Amazon OpenSearch Service domain.
44
+
45
+ Here is a minimal deployable pattern definition:
46
+
47
+ ====
48
+ [role="tablist"]
49
+ Typescript::
50
+ +
51
+ [source,typescript]
52
+ ----
53
+ import { Construct } from 'constructs';
54
+ import { Stack, StackProps } from 'aws-cdk-lib';
55
+ import { FargateToOpenSearch, FargateToOpenSearchProps } from '@aws-solutions-constructs/aws-fargate-opensearch';
56
+
57
+ const constructProps: FargateToOpenSearchProps = {
58
+ publicApi: true,
59
+ ecrRepositoryArn: "arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo",
60
+ openSearchDomainName: 'testdomain',
61
+ // NOTE: Ensure the Cognito domain name is globally unique
62
+ cognitoDomainName: 'globallyuniquedomain' + Aws.ACCOUNT_ID
63
+ };
64
+
65
+ new FargateToOpenSearch(this, 'test-construct', constructProps);
66
+ ----
67
+
68
+ Python::
69
+ +
70
+ [source,python]
71
+ ----
72
+ from aws_solutions_constructs.aws_fargate_opensearch import FargateToOpenSearch, FargateToOpenSearchProps
73
+ from aws_cdk import (
74
+ Stack
75
+ )
76
+ from constructs import Construct
77
+
78
+ FargateToOpenSearch(self, 'test_construct',
79
+ public_api=True,
80
+ ecr_repository_arn="arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo",
81
+ open_search_domain_name='testdomain',
82
+ # NOTE: Ensure the Cognito domain name is globally unique
83
+ cognito_domain_name='globallyuniquedomain' + Aws.ACCOUNT_ID)
84
+ ----
85
+
86
+ Java::
87
+ +
88
+ [source,java]
89
+ ----
90
+ import software.constructs.Construct;
91
+
92
+ import software.amazon.awscdk.Stack;
93
+ import software.amazon.awscdk.StackProps;
94
+ import software.amazon.awsconstructs.services.fargateopensearch.*;
95
+
96
+ new FargateToOpenSearch(this, "test_construct", new FargateToOpenSearchProps.Builder()
97
+ .publicApi(true)
98
+ .ecrRepositoryArn("arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo"
99
+ .openSearchDomainName("testdomain")
100
+ // NOTE: Ensure the Cognito domain name is globally unique
101
+ .cognitoDomainName("globallyuniquedomain" + Aws.ACCOUNT_ID)
102
+ .build());
103
+ ----
104
+ ====
105
+
106
+ == Pattern Construct Props
107
+
108
+ [width="100%",cols="<30%,<35%,35%",options="header",]
109
+ |===
110
+ |*Name* |*Type* |*Description*
111
+ |publicApi |`boolean` |Whether the construct is deploying a private or
112
+ public API. This has implications for the VPC.
113
+
114
+ |vpcProps?
115
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.VpcProps.html[`ec2.VpcProps`]
116
+ |Optional custom properties for a VPC the construct will create. This
117
+ VPC will be used by any Private Hosted Zone the construct creates
118
+ (that’s why loadBalancerProps and privateHostedZoneProps can’t include a
119
+ VPC). Providing both this and existingVpc is an error.
120
+
121
+ |existingVpc?
122
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html[`ec2.IVpc`]
123
+ |An existing VPC in which to deploy the construct. Providing both this
124
+ and vpcProps is an error. If the client provides an existing load
125
+ balancer and/or existing Private Hosted Zone, those constructs must
126
+ exist in this VPC.
127
+
128
+ |clusterProps?
129
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ClusterProps.html[`ecs.ClusterProps`]
130
+ |Optional properties to create a new ECS cluster. To provide an existing
131
+ cluster, use the cluster attribute of fargateServiceProps.
132
+
133
+ |ecrRepositoryArn? |`string` |The arn of an ECR Repository containing
134
+ the image to use to generate the containers. Either this or the image
135
+ property of containerDefinitionProps must be provided. format:
136
+ arn:aws:ecr:_region_:_account number_:repository/_Repository Name_
137
+
138
+ |ecrImageVersion? |`string` |The version of the image to use from the
139
+ repository. Defaults to '`Latest`'.
140
+
141
+ |containerDefinitionProps?
142
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinitionProps.html[`ecs.ContainerDefinitionProps`] {vbar} any
143
+ |Optional props to define the container created for the Fargate Service
144
+ (defaults found in fargate-defaults.ts).
145
+
146
+ |fargateTaskDefinitionProps?
147
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateTaskDefinitionProps.html[`ecs.FargateTaskDefinitionProps`] {vbar} any
148
+ |Optional props to define the Fargate Task Definition for this construct
149
+ (defaults found in fargate-defaults.ts).
150
+
151
+ |fargateServiceProps?
152
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateServiceProps.html[`ecs.FargateServiceProps`] {vbar} any
153
+ |Optional values to override default Fargate Task definition properties
154
+ (fargate-defaults.ts). The construct will default to launching the
155
+ service is the most isolated subnets available (precedence: Isolated,
156
+ Private and Public). Override those and other defaults here.
157
+
158
+ |existingFargateServiceObject?
159
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateService.html[`ecs.FargateService`]
160
+ |A Fargate Service already instantiated (probably by another Solutions
161
+ Construct). If this is specified, then no props defining a new service
162
+ can be provided, including: ecrImageVersion, containerDefinitionProps,
163
+ fargateTaskDefinitionProps, ecrRepositoryArn, fargateServiceProps,
164
+ clusterProps.
165
+
166
+ |existingContainerDefinitionObject?
167
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinition.html[`ecs.ContainerDefinition`]
168
+ |A container definition already instantiated as part of a Fargate
169
+ service. This must be the container in the existingFargateServiceObject.
170
+
171
+ |openSearchDomainProps?
172
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_opensearchservice.CfnDomainProps.html[`opensearchservice.CfnDomainProps`]
173
+ |Optional user provided props to override the default props for the
174
+ OpenSearch Service.
175
+
176
+ |openSearchDomainName |`string` |Domain name for the OpenSearch Service.
177
+
178
+ |cognitoDomainName? |`string` |Optional Amazon Cognito domain name. If
179
+ omitted the Amazon Cognito domain will default to the OpenSearch Service
180
+ domain name.
181
+
182
+ |createCloudWatchAlarms? |`boolean` |Whether to create the recommended
183
+ CloudWatch alarms.
184
+
185
+ |domainEndpointEnvironmentVariableName? |`string` |Optional name for the
186
+ OpenSearch Service domain endpoint environment variable set for the
187
+ Lambda function. Default is `DOMAIN_ENDPOINT`.
188
+ |===
189
+
190
+ == Pattern Properties
191
+
192
+ [width="100%",cols="<30%,<35%,35%",options="header",]
193
+ |===
194
+ |*Name* |*Type* |*Description*
195
+ |vpc
196
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html[`ec2.IVpc`]
197
+ |The VPC used by the construct (whether created by the construct or
198
+ provided by the client).
199
+
200
+ |service
201
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateService.html[`ecs.FargateService`]
202
+ |The AWS Fargate service used by this construct (whether created by this
203
+ construct or passed to this construct at initialization).
204
+
205
+ |container
206
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinition.html[`ecs.ContainerDefinition`]
207
+ |The container associated with the AWS Fargate service in the service
208
+ property.
209
+
210
+ |userPool
211
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.UserPool.html[`cognito.UserPool`]
212
+ |Returns an instance of `cognito.UserPool` created by the construct.
213
+
214
+ |userPoolClient
215
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.UserPoolClient.html[`cognito.UserPoolClient`]
216
+ |Returns an instance of `cognito.UserPoolClient` created by the
217
+ construct.
218
+
219
+ |identityPool
220
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.CfnIdentityPool.html[`cognito.CfnIdentityPool`]
221
+ |Returns an instance of `cognito.CfnIdentityPool` created by the
222
+ construct.
223
+
224
+ |openSearchDomain
225
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_opensearchservice.CfnDomain.html[`opensearchservice.CfnDomain`]
226
+ |Returns an instance of `opensearch.CfnDomain` created by the construct.
227
+
228
+ |openSearchRole
229
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_iam.Role.html[`iam.Role`]
230
+ |Returns an instance of `iam.Role` created by the construct for
231
+ `opensearch.CfnDomain`.
232
+
233
+ |cloudWatchAlarms?
234
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cloudwatch.Alarm.html[`cloudwatch.Alarm[\]`]
235
+ |Returns a list of `cloudwatch.Alarm` created by the construct.
236
+ |===
237
+
238
+ == Default settings
239
+
240
+ Out of the box implementation of the Construct without any override will
241
+ set the following defaults:
242
+
243
+ === AWS Fargate Service
244
+
245
+ * Sets up an AWS Fargate service
246
+ ** Uses the existing service if provided
247
+ ** Creates a new service if none provided
248
+ *** Service will run in isolated subnets if available, then private
249
+ subnets if available and finally public subnets
250
+ ** Adds environment variables to the container with the OpenSearch
251
+ Service domain endpoint
252
+ ** Add permissions to the container IAM role allowing it to write/read
253
+ to the OpenSearch Service domain endpoint
254
+
255
+ === Amazon Cognito
256
+
257
+ * Set password policy for User Pools
258
+ * Enforce the advanced security mode for User Pools
259
+
260
+ === Amazon OpenSearch Service
261
+
262
+ * Deploy best practices CloudWatch Alarms for the OpenSearch Service
263
+ domain
264
+ * Secure the OpenSearch Service dashboard access with Cognito User Pools
265
+ * Enable server-side encryption for OpenSearch Service domain using AWS
266
+ managed KMS Key
267
+ * Enable node-to-node encryption for the OpenSearch Service domain
268
+ * Configure the cluster for the OpenSearch Service domain
269
+
270
+ == Architecture
271
+
272
+
273
+ image::aws-fargate-opensearch.png["Diagram showing the Fargate service, OpenSearch domain, Cognito domain and IAM role created by the construct",scaledwidth=100%]
274
+
275
+ // github block
276
+
277
+ '''''
278
+
279
+ © Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
package/README.md CHANGED
@@ -1,141 +1 @@
1
- # aws-fargate-opensearch module
2
- <!--BEGIN STABILITY BANNER-->
3
-
4
- ---
5
-
6
- ![Stability: Experimental](https://img.shields.io/badge/stability-Experimental-important.svg?style=for-the-badge)
7
-
8
- > All classes are under active development and subject to non-backward compatible changes or removal in any
9
- > future version. These are not subject to the [Semantic Versioning](https://semver.org/) model.
10
- > This means that while you may use them, you may need to update your source code when upgrading to a newer version of this package.
11
-
12
- ---
13
- <!--END STABILITY BANNER-->
14
-
15
- | **Reference Documentation**:| <span style="font-weight: normal">https://docs.aws.amazon.com/solutions/latest/constructs/</span>|
16
- |:-------------|:-------------|
17
- <div style="height:8px"></div>
18
-
19
- | **Language** | **Package** |
20
- |:-------------|-----------------|
21
- |![Python Logo](https://docs.aws.amazon.com/cdk/api/latest/img/python32.png) Python|`aws_solutions_constructs.aws_fargate_opensearch`|
22
- |![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-fargate-opensearch`|
23
- |![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.fargateopensearch`|
24
-
25
- ## Overview
26
- This AWS Solutions Construct implements an AWS Fargate service that can write/read to an Amazon OpenSearch Service domain.
27
-
28
- Here is a minimal deployable pattern definition:
29
-
30
- Typescript
31
- ``` typescript
32
- import { Construct } from 'constructs';
33
- import { Stack, StackProps } from 'aws-cdk-lib';
34
- import { FargateToOpenSearch, FargateToOpenSearchProps } from '@aws-solutions-constructs/aws-fargate-opensearch';
35
-
36
- const constructProps: FargateToOpenSearchProps = {
37
- publicApi: true,
38
- ecrRepositoryArn: "arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo",
39
- openSearchDomainName: 'testdomain',
40
- // TODO: Ensure the Cognito domain name is globally unique
41
- cognitoDomainName: 'globallyuniquedomain' + Aws.ACCOUNT_ID
42
- };
43
-
44
- new FargateToOpenSearch(this, 'test-construct', constructProps);
45
- ```
46
-
47
- Python
48
- ``` python
49
- from aws_solutions_constructs.aws_fargate_opensearch import FargateToOpenSearch, FargateToOpenSearchProps
50
- from aws_cdk import (
51
- Stack
52
- )
53
- from constructs import Construct
54
-
55
- FargateToOpenSearch(self, 'test_construct',
56
- public_api=True,
57
- ecr_repository_arn="arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo",
58
- open_search_domain_name='testdomain',
59
- # TODO: Ensure the Cognito domain name is globally unique
60
- cognito_domain_name='globallyuniquedomain' + Aws.ACCOUNT_ID)
61
- ```
62
-
63
- Java
64
- ``` java
65
- import software.constructs.Construct;
66
-
67
- import software.amazon.awscdk.Stack;
68
- import software.amazon.awscdk.StackProps;
69
- import software.amazon.awsconstructs.services.fargateopensearch.*;
70
-
71
- new FargateToOpenSearch(this, "test_construct", new FargateToOpenSearchProps.Builder()
72
- .publicApi(true)
73
- .ecrRepositoryArn("arn:aws:ecr:us-east-1:123456789012:repository/your-ecr-repo"
74
- .openSearchDomainName("testdomain")
75
- // TODO: Ensure the Cognito domain name is globally unique
76
- .cognitoDomainName("globallyuniquedomain" + Aws.ACCOUNT_ID)
77
- .build());
78
- ```
79
- ## Pattern Construct Props
80
-
81
- | **Name** | **Type** | **Description** |
82
- |:-------------|:----------------|-----------------|
83
- | publicApi | `boolean` | Whether the construct is deploying a private or public API. This has implications for the VPC. |
84
- | vpcProps? | [`ec2.VpcProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.VpcProps.html) | Optional custom properties for a VPC the construct will create. This VPC will be used by any Private Hosted Zone the construct creates (that's why loadBalancerProps and privateHostedZoneProps can't include a VPC). Providing both this and existingVpc is an error. |
85
- | existingVpc? | [`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html) | An existing VPC in which to deploy the construct. Providing both this and vpcProps is an error. If the client provides an existing load balancer and/or existing Private Hosted Zone, those constructs must exist in this VPC. |
86
- | clusterProps? | [`ecs.ClusterProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ClusterProps.html) | Optional properties to create a new ECS cluster. To provide an existing cluster, use the cluster attribute of fargateServiceProps. |
87
- | ecrRepositoryArn? | `string` | The arn of an ECR Repository containing the image to use to generate the containers. Either this or the image property of containerDefinitionProps must be provided. format: arn:aws:ecr:*region*:*account number*:repository/*Repository Name* |
88
- | ecrImageVersion? | `string` | The version of the image to use from the repository. Defaults to 'Latest'. |
89
- | containerDefinitionProps? | [`ecs.ContainerDefinitionProps \| any`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinitionProps.html) | Optional props to define the container created for the Fargate Service (defaults found in fargate-defaults.ts). |
90
- | fargateTaskDefinitionProps? | [`ecs.FargateTaskDefinitionProps \| any`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateTaskDefinitionProps.html) | Optional props to define the Fargate Task Definition for this construct (defaults found in fargate-defaults.ts). |
91
- | fargateServiceProps? | [`ecs.FargateServiceProps \| any`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateServiceProps.html) | Optional values to override default Fargate Task definition properties (fargate-defaults.ts). The construct will default to launching the service is the most isolated subnets available (precedence: Isolated, Private and Public). Override those and other defaults here. |
92
- | existingFargateServiceObject? | [`ecs.FargateService`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateService.html) | A Fargate Service already instantiated (probably by another Solutions Construct). If this is specified, then no props defining a new service can be provided, including: ecrImageVersion, containerDefinitionProps, fargateTaskDefinitionProps, ecrRepositoryArn, fargateServiceProps, clusterProps.|
93
- | existingContainerDefinitionObject? | [`ecs.ContainerDefinition`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinition.html) | A container definition already instantiated as part of a Fargate service. This must be the container in the existingFargateServiceObject.|
94
- |openSearchDomainProps?|[`opensearchservice.CfnDomainProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_opensearchservice.CfnDomainProps.html)|Optional user provided props to override the default props for the OpenSearch Service.|
95
- |openSearchDomainName|`string`|Domain name for the OpenSearch Service.|
96
- |cognitoDomainName?|`string`|Optional Amazon Cognito domain name. If omitted the Amazon Cognito domain will default to the OpenSearch Service domain name.|
97
- |createCloudWatchAlarms?|`boolean`|Whether to create the recommended CloudWatch alarms.|
98
- |domainEndpointEnvironmentVariableName?|`string`|Optional name for the OpenSearch Service domain endpoint environment variable set for the Lambda function. Default is `DOMAIN_ENDPOINT`.|
99
-
100
- ## Pattern Properties
101
-
102
- | **Name** | **Type** | **Description** |
103
- |:-------------|:----------------|-----------------|
104
- | vpc | [`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html) | The VPC used by the construct (whether created by the construct or provided by the client). |
105
- | service | [`ecs.FargateService`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.FargateService.html) | The AWS Fargate service used by this construct (whether created by this construct or passed to this construct at initialization). |
106
- | container | [`ecs.ContainerDefinition`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ecs.ContainerDefinition.html) | The container associated with the AWS Fargate service in the service property. |
107
- |userPool|[`cognito.UserPool`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.UserPool.html)|Returns an instance of `cognito.UserPool` created by the construct.|
108
- |userPoolClient|[`cognito.UserPoolClient`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.UserPoolClient.html)|Returns an instance of `cognito.UserPoolClient` created by the construct.|
109
- |identityPool|[`cognito.CfnIdentityPool`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cognito.CfnIdentityPool.html)|Returns an instance of `cognito.CfnIdentityPool` created by the construct.|
110
- |openSearchDomain|[`opensearchservice.CfnDomain`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_opensearchservice.CfnDomain.html)|Returns an instance of `opensearch.CfnDomain` created by the construct.|
111
- |openSearchRole|[`iam.Role`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_iam.Role.html)|Returns an instance of `iam.Role` created by the construct for `opensearch.CfnDomain`.|
112
- |cloudWatchAlarms?|[`cloudwatch.Alarm[]`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_cloudwatch.Alarm.html)|Returns a list of `cloudwatch.Alarm` created by the construct.|
113
-
114
- ## Default settings
115
-
116
- Out of the box implementation of the Construct without any override will set the following defaults:
117
-
118
- ### AWS Fargate Service
119
- * Sets up an AWS Fargate service
120
- * Uses the existing service if provided
121
- * Creates a new service if none provided
122
- * Service will run in isolated subnets if available, then private subnets if available and finally public subnets
123
- * Adds environment variables to the container with the OpenSearch Service domain endpoint
124
- * Add permissions to the container IAM role allowing it to write/read to the OpenSearch Service domain endpoint
125
-
126
- ### Amazon Cognito
127
- * Set password policy for User Pools
128
- * Enforce the advanced security mode for User Pools
129
-
130
- ### Amazon OpenSearch Service
131
- * Deploy best practices CloudWatch Alarms for the OpenSearch Service domain
132
- * Secure the OpenSearch Service dashboard access with Cognito User Pools
133
- * Enable server-side encryption for OpenSearch Service domain using AWS managed KMS Key
134
- * Enable node-to-node encryption for the OpenSearch Service domain
135
- * Configure the cluster for the OpenSearch Service domain
136
-
137
- ## Architecture
138
- ![Architecture Diagram](architecture.png)
139
-
140
- ***
141
- &copy; Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
1
+ Documentation for this pattern can be found [here](https://github.com/awslabs/aws-solutions-constructs/blob/main/source/patterns/%40aws-solutions-constructs/aws-fargate-opensearch/README.adoc)
package/lib/index.js CHANGED
@@ -77,5 +77,5 @@ class FargateToOpenSearch extends constructs_1.Construct {
77
77
  }
78
78
  exports.FargateToOpenSearch = FargateToOpenSearch;
79
79
  _a = JSII_RTTI_SYMBOL_1;
80
- FargateToOpenSearch[_a] = { fqn: "@aws-solutions-constructs/aws-fargate-opensearch.FargateToOpenSearch", version: "2.85.2" };
80
+ FargateToOpenSearch[_a] = { fqn: "@aws-solutions-constructs/aws-fargate-opensearch.FargateToOpenSearch", version: "2.85.4" };
81
81
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\nimport * as defaults from \"@aws-solutions-constructs/core\";\nimport * as ecs from \"aws-cdk-lib/aws-ecs\";\nimport * as iam from \"aws-cdk-lib/aws-iam\";\nimport * as cognito from 'aws-cdk-lib/aws-cognito';\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\nimport * as cloudwatch from 'aws-cdk-lib/aws-cloudwatch';\nimport * as opensearch from \"aws-cdk-lib/aws-opensearchservice\";\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from \"constructs\";\n\nexport interface FargateToOpenSearchProps {\n  /**\n   * Optional custom properties for a VPC the construct will create. This VPC will\n   * be used by the new Fargate service the construct creates (that's\n   * why targetGroupProps can't include a VPC). Providing\n   * both this and existingVpc is an error.\n   *\n   * @default - none\n   */\n  readonly vpcProps?: ec2.VpcProps;\n  /**\n   * An existing VPC in which to deploy the construct. Providing both this and\n   * vpcProps is an error. If the client provides an existing Fargate service,\n   * this value must be the VPC where the service is running.\n   *\n   * @default - none\n   */\n  readonly existingVpc?: ec2.IVpc;\n  /**\n   * Whether the construct is deploying a private or public API. This has implications for the VPC deployed\n   * by this construct.\n   */\n  readonly publicApi: boolean;\n  /**\n   * Optional properties to create a new ECS cluster\n   */\n  readonly clusterProps?: ecs.ClusterProps;\n  /**\n   * The arn of an ECR Repository containing the image to use\n   * to generate the containers\n   *\n   * format:\n   *   arn:aws:ecr:[region]:[account number]:repository/[Repository Name]\n   */\n  readonly ecrRepositoryArn?: string;\n  /**\n   * The version of the image to use from the repository\n   *\n   * @default - 'latest'\n   */\n  readonly ecrImageVersion?: string;\n  /*\n   * Optional props to define the container created for the Fargate Service\n   *\n   * defaults - fargate-defaults.ts\n   */\n  readonly containerDefinitionProps?: ecs.ContainerDefinitionProps | any;\n  /*\n   * Optional props to define the Fargate Task Definition for this construct\n   *\n   * defaults - fargate-defaults.ts\n   */\n  readonly fargateTaskDefinitionProps?: ecs.FargateTaskDefinitionProps | any;\n  /**\n   * Optional values to override default Fargate Task definition properties\n   * (fargate-defaults.ts). The construct will default to launching the service\n   * is the most isolated subnets available (precedence: Isolated, Private and\n   * Public). Override those and other defaults here.\n   *\n   * defaults - fargate-defaults.ts\n   */\n  readonly fargateServiceProps?: ecs.FargateServiceProps | any;\n  /**\n   * A Fargate Service already instantiated (probably by another Solutions Construct). If\n   * this is specified, then no props defining a new service can be provided, including:\n   * existingImageObject, ecrImageVersion, containerDefinitionProps, fargateTaskDefinitionProps,\n   * ecrRepositoryArn, fargateServiceProps, clusterProps, existingClusterInterface. If this value\n   * is provided, then existingContainerDefinitionObject must be provided as well.\n   *\n   * @default - none\n   */\n  readonly existingFargateServiceObject?: ecs.FargateService;\n  /*\n   * A container definition already instantiated as part of a Fargate service. This must\n   * be the container in the existingFargateServiceObject.\n   *\n   * @default - None\n   */\n  readonly existingContainerDefinitionObject?: ecs.ContainerDefinition;\n  /**\n   * Optional user provided props to override the default props for the OpenSearch Service.\n   *\n   * @default - Default props are used\n   */\n  readonly openSearchDomainProps?: opensearch.CfnDomainProps;\n  /**\n   * Domain name for the OpenSearch Service.\n   *\n   * @default - None\n   */\n  readonly openSearchDomainName: string;\n  /**\n   * Optional Amazon Cognito domain name. If omitted the Amazon Cognito domain will default to the OpenSearch Service domain name.\n   *\n   * @default - the OpenSearch Service domain name\n   */\n  readonly cognitoDomainName?: string;\n  /**\n   * Whether to create recommended CloudWatch alarms\n   *\n   * @default - Alarms are created\n   */\n  readonly createCloudWatchAlarms?: boolean;\n  /**\n   * Optional Name for the container environment variable set to the domain endpoint.\n   *\n   * @default - DOMAIN_ENDPOINT\n   */\n  readonly domainEndpointEnvironmentVariableName?: string;\n}\n\nexport class FargateToOpenSearch extends Construct {\n  public readonly vpc: ec2.IVpc;\n  public readonly service: ecs.FargateService;\n  public readonly container: ecs.ContainerDefinition;\n  public readonly userPool: cognito.UserPool;\n  public readonly userPoolClient: cognito.UserPoolClient;\n  public readonly identityPool: cognito.CfnIdentityPool;\n  public readonly openSearchDomain: opensearch.CfnDomain;\n  public readonly openSearchRole: iam.Role;\n  public readonly cloudWatchAlarms?: cloudwatch.Alarm[];\n\n  constructor(scope: Construct, id: string, props: FargateToOpenSearchProps) {\n    super(scope, id);\n    defaults.CheckFargateProps(props);\n    defaults.CheckVpcProps(props);\n    defaults.CheckOpenSearchProps(props);\n\n    this.vpc = defaults.buildVpc(scope, {\n      existingVpc: props.existingVpc,\n      defaultVpcProps: props.publicApi ? defaults.DefaultPublicPrivateVpcProps() : defaults.DefaultIsolatedVpcProps(),\n      userVpcProps: props.vpcProps,\n      constructVpcProps: { enableDnsHostnames: true, enableDnsSupport: true }\n    });\n\n    if (props.existingFargateServiceObject) {\n      this.service = props.existingFargateServiceObject;\n      // CheckFargateProps confirms that the container is provided\n      this.container = props.existingContainerDefinitionObject!;\n    } else {\n      const createFargateServiceResponse = defaults.CreateFargateService(scope, id, {\n        constructVpc: this.vpc,\n        clientClusterProps: props.clusterProps,\n        ecrRepositoryArn: props.ecrRepositoryArn,\n        ecrImageVersion: props.ecrImageVersion,\n        clientFargateTaskDefinitionProps: props.fargateTaskDefinitionProps,\n        clientContainerDefinitionProps: props.containerDefinitionProps,\n        clientFargateServiceProps: props.fargateServiceProps\n      });\n      this.service = createFargateServiceResponse.service;\n      this.container = createFargateServiceResponse.containerDefinition;\n    }\n\n    let cognitoAuthorizedRole: iam.Role;\n\n    [this.userPool, this.userPoolClient, this.identityPool, cognitoAuthorizedRole] =\n      defaults.buildCognitoForSearchService(this, props.cognitoDomainName ?? props.openSearchDomainName);\n\n    let securityGroupIds;\n\n    if (this.vpc) {\n      securityGroupIds = defaults.getServiceVpcSecurityGroupIds(this.service);\n    }\n\n    const buildOpenSearchProps: defaults.BuildOpenSearchProps = {\n      userpool: this.userPool,\n      identitypool: this.identityPool,\n      cognitoAuthorizedRoleARN: cognitoAuthorizedRole.roleArn,\n      vpc: this.vpc,\n      openSearchDomainName: props.openSearchDomainName,\n      clientDomainProps: props.openSearchDomainProps,\n      securityGroupIds\n    };\n\n    const buildOpenSearchResponse = defaults.buildOpenSearch(this, buildOpenSearchProps);\n    this.openSearchDomain = buildOpenSearchResponse.domain;\n    this.openSearchRole = buildOpenSearchResponse.role;\n\n    if (props.createCloudWatchAlarms === undefined || props.createCloudWatchAlarms) {\n      this.cloudWatchAlarms = defaults.buildOpenSearchCWAlarms(this);\n    }\n\n    // Add environment variables\n    const domainEndpointEnvironmentVariableName = props.domainEndpointEnvironmentVariableName || 'DOMAIN_ENDPOINT';\n    this.container.addEnvironment(domainEndpointEnvironmentVariableName, this.openSearchDomain.attrDomainEndpoint);\n\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-solutions-constructs/aws-fargate-opensearch",
3
- "version": "2.85.2",
3
+ "version": "2.85.4",
4
4
  "description": "CDK Constructs for AWS Fargate to Amazon OpenSearch Service",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -22,12 +22,13 @@
22
22
  "test": "jest --coverage",
23
23
  "clean": "tsc -b --clean",
24
24
  "watch": "tsc -b -w",
25
+ "asciidoc": "asciidoctor --failure-level WARNING -o /dev/null README.adoc",
25
26
  "integ": "integ-runner --update-on-failed",
26
27
  "integ-no-clean": "integ-runner --update-on-failed --no-clean",
27
28
  "integ-assert": "integ-runner",
28
29
  "jsii": "jsii",
29
30
  "jsii-pacmak": "jsii-pacmak",
30
- "build+lint+test": "npm run jsii && npm run lint && npm test && npm run integ-assert",
31
+ "build+lint+test": "npm run jsii && npm run lint && npm run asciidoc && npm test && npm run integ-assert",
31
32
  "blt": "npm run build+lint+test",
32
33
  "snapshot-update": "npm run jsii && npm test -- -u && npm run integ-assert"
33
34
  },
@@ -54,7 +55,7 @@
54
55
  }
55
56
  },
56
57
  "dependencies": {
57
- "@aws-solutions-constructs/core": "2.85.2",
58
+ "@aws-solutions-constructs/core": "2.85.4",
58
59
  "constructs": "^10.0.0"
59
60
  },
60
61
  "devDependencies": {
@@ -78,7 +79,7 @@
78
79
  ]
79
80
  },
80
81
  "peerDependencies": {
81
- "@aws-solutions-constructs/core": "2.85.2",
82
+ "@aws-solutions-constructs/core": "2.85.4",
82
83
  "constructs": "^10.0.0",
83
84
  "aws-cdk-lib": "^2.193.0"
84
85
  },