@aws-mdaa/ddb-constructs 1.2.0

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/README.md ADDED
@@ -0,0 +1,12 @@
1
+ # Construct Overview
2
+
3
+ Opinionated L2 Constructs for DDB Tables.
4
+
5
+ ## Security/Compliance
6
+
7
+ ### DDB Table
8
+ * Enforce Table Name
9
+ * Enforce KMS CMK encryption
10
+ * Enforce retention on stack deletion
11
+ * Enforce Point in Time Recovery
12
+ * Enforce deletion protection
package/lib/index.d.ts ADDED
@@ -0,0 +1,110 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+ import * as mdaa_construct from '@aws-mdaa/construct';
6
+ import { Duration } from 'aws-cdk-lib';
7
+ import { Attribute, BillingMode, StreamViewType, Table, TableClass } from 'aws-cdk-lib/aws-dynamodb';
8
+ import { IStream } from 'aws-cdk-lib/aws-kinesis';
9
+ import { IKey } from 'aws-cdk-lib/aws-kms';
10
+ import { Construct } from 'constructs';
11
+ export interface MdaaDDBTableProps extends mdaa_construct.MdaaConstructProps {
12
+ /**
13
+ * Q-ENHANCED-PROPERTY
14
+ * Optional physical table name override for custom naming requirements bypassing automatic MDAA naming conventions. When specified, provides exact control over DynamoDB table naming for integration with existing systems or specific naming requirements.
15
+ *
16
+ * Use cases: Custom naming requirements; Legacy system integration; Specific naming conventions; External tool integration
17
+ *
18
+ * AWS: DynamoDB table name specification for custom naming and integration requirements
19
+ *
20
+ * Validation: Must be valid DynamoDB table name if provided; overrides automatic MDAA naming when specified
21
+ **/
22
+ readonly tableName?: string;
23
+ readonly kinesisStream?: IStream;
24
+ /**
25
+ * Q-ENHANCED-PROPERTY
26
+ * Optional read capacity units for provisioned throughput controlling read performance and cost management. Defines the number of read capacity units for the table when using provisioned billing mode for predictable performance and cost control.
27
+ *
28
+ * Use cases: Performance tuning; Cost management; Predictable workloads; Capacity planning
29
+ *
30
+ * AWS: DynamoDB read capacity units for provisioned throughput and performance control
31
+ *
32
+ * Validation: Must be positive integer if provided; only valid with PROVISIONED billing mode; defaults to 5
33
+ **/
34
+ readonly readCapacity?: number;
35
+ /**
36
+ * Q-ENHANCED-PROPERTY
37
+ * Optional write capacity units for provisioned throughput controlling write performance and cost management. Defines the number of write capacity units for the table when using provisioned billing mode for predictable performance and cost control.
38
+ *
39
+ * Use cases: Performance tuning; Cost management; Predictable workloads; Capacity planning
40
+ *
41
+ * AWS: DynamoDB write capacity units for provisioned throughput and performance control
42
+ *
43
+ * Validation: Must be positive integer if provided; only valid with PROVISIONED billing mode; defaults to 5
44
+ **/
45
+ readonly writeCapacity?: number;
46
+ /**
47
+ * Q-ENHANCED-PROPERTY
48
+ * Optional billing mode specification controlling cost model and capacity management for the DynamoDB table. Determines whether the table uses provisioned capacity with predictable costs or pay-per-request for variable workloads.
49
+ *
50
+ * Use cases: Cost optimization; Capacity management; Workload matching; Performance predictability
51
+ *
52
+ * AWS: DynamoDB billing mode for cost control and capacity management configuration
53
+ *
54
+ * Validation: Must be PROVISIONED or PAY_PER_REQUEST; defaults based on replication configuration
55
+ **/
56
+ readonly billingMode?: BillingMode;
57
+ readonly tableClass?: TableClass;
58
+ readonly encryptionKey: IKey;
59
+ /**
60
+ * Q-ENHANCED-PROPERTY
61
+ * Optional TTL attribute name for automatic item expiration enabling data lifecycle management and storage cost optimization. Provides automatic cleanup of expired items based on timestamp values for efficient data management and cost control.
62
+ *
63
+ * Use cases: Data lifecycle management; Automatic cleanup; Cost optimization; Storage management
64
+ *
65
+ * AWS: DynamoDB TTL attribute for automatic item expiration and data lifecycle management
66
+ *
67
+ * Validation: Must be valid attribute name if provided; enables automatic item expiration based on timestamp
68
+ **/
69
+ readonly timeToLiveAttribute?: string;
70
+ readonly stream?: StreamViewType;
71
+ readonly replicationRegions?: string[];
72
+ readonly replicationTimeout?: Duration;
73
+ readonly waitForReplicationToFinish?: boolean;
74
+ readonly contributorInsightsEnabled?: boolean;
75
+ /**
76
+ * Q-ENHANCED-PROPERTY
77
+ * Required partition key attribute definition for table primary key structure enabling data distribution and access patterns. Defines the primary key attribute that determines data distribution across partitions for optimal performance and access patterns.
78
+ *
79
+ * Use cases: Primary key definition; Data distribution; Access pattern optimization; Table structure design
80
+ *
81
+ * AWS: DynamoDB partition key attribute for primary key structure and data distribution
82
+ *
83
+ * Validation: Must be valid Attribute definition; required for table primary key structure and data distribution
84
+ **/
85
+ readonly partitionKey: Attribute;
86
+ /**
87
+ * Q-ENHANCED-PROPERTY
88
+ * Optional sort key attribute definition for composite primary key structure enabling range queries and data organization. Provides secondary key component for composite primary keys enabling range queries and hierarchical data organization within partitions.
89
+ *
90
+ * Use cases: Composite primary keys; Range queries; Data organization; Hierarchical data structure
91
+ *
92
+ * AWS: DynamoDB sort key attribute for composite primary key structure and range query capabilities
93
+ *
94
+ * Validation: Must be valid Attribute definition if provided; enables composite primary keys and range queries
95
+ **/
96
+ readonly sortKey?: Attribute;
97
+ }
98
+ /**
99
+ * Compliance construct for DDB Table
100
+ * Enforces:
101
+ * Table name convention
102
+ * KMS Encryption at Rest
103
+ * Deletion Protection
104
+ * PITR
105
+ * RETAIN RemovalPolicy
106
+ */
107
+ export declare class MdaaDDBTable extends Table {
108
+ private static setProps;
109
+ constructor(scope: Construct, id: string, props: MdaaDDBTableProps);
110
+ }
package/lib/index.js ADDED
@@ -0,0 +1,89 @@
1
+ /*!
2
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3
+ * SPDX-License-Identifier: Apache-2.0
4
+ */
5
+
6
+ "use strict";
7
+ var _a;
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.MdaaDDBTable = void 0;
10
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
11
+
12
+ const mdaa_construct = require("@aws-mdaa/construct"); //NOSONAR
13
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
14
+ const aws_dynamodb_1 = require("aws-cdk-lib/aws-dynamodb");
15
+ const construct_1 = require("@aws-mdaa/construct"); //NOSONAR
16
+ /**
17
+ * Compliance construct for DDB Table
18
+ * Enforces:
19
+ * Table name convention
20
+ * KMS Encryption at Rest
21
+ * Deletion Protection
22
+ * PITR
23
+ * RETAIN RemovalPolicy
24
+ */
25
+ class MdaaDDBTable extends aws_dynamodb_1.Table {
26
+ static setProps(props) {
27
+ const overrideProps = {
28
+ tableName: props.naming.resourceName(props.tableName, 254),
29
+ encryption: aws_dynamodb_1.TableEncryption.CUSTOMER_MANAGED,
30
+ removalPolicy: aws_cdk_lib_1.RemovalPolicy.RETAIN,
31
+ deletionProtection: true,
32
+ pointInTimeRecovery: true,
33
+ };
34
+ return { ...props, ...overrideProps };
35
+ }
36
+ constructor(scope, id, props) {
37
+ super(scope, id, MdaaDDBTable.setProps(props));
38
+ construct_1.MdaaNagSuppressions.addCodeResourceSuppressions(this, [
39
+ { id: 'HIPAA.Security-DynamoDBInBackupPlan', reason: 'MDAA does not enforce use of AWS Backup' },
40
+ { id: 'PCI.DSS.321-DynamoDBInBackupPlan', reason: 'MDAA does not enforce use of AWS Backup' },
41
+ { id: 'NIST.800.53.R5-DynamoDBInBackupPlan', reason: 'MDAA does not enforce use of AWS Backup' },
42
+ {
43
+ id: 'NIST.800.53.R5-DynamoDBAutoScalingEnabled',
44
+ reason: 'MDAA does not enforce use of Auto Scaling on Provisioned Capacity tables.',
45
+ },
46
+ {
47
+ id: 'HIPAA.Security-DynamoDBAutoScalingEnabled',
48
+ reason: 'MDAA does not enforce use of Auto Scaling on Provisioned Capacity tables.',
49
+ },
50
+ {
51
+ id: 'PCI.DSS.321-DynamoDBAutoScalingEnabled',
52
+ reason: 'MDAA does not enforce use of Auto Scaling on Provisioned Capacity tables.',
53
+ },
54
+ ], true);
55
+ new mdaa_construct.MdaaParamAndOutput(this, {
56
+ ...{
57
+ resourceType: 'table',
58
+ resourceId: props.tableName,
59
+ name: 'name',
60
+ value: this.tableName,
61
+ },
62
+ ...props,
63
+ });
64
+ new mdaa_construct.MdaaParamAndOutput(this, {
65
+ ...{
66
+ resourceType: 'table',
67
+ resourceId: props.tableName,
68
+ name: 'arn',
69
+ value: this.tableArn,
70
+ },
71
+ ...props,
72
+ });
73
+ if (this.tableStreamArn) {
74
+ new mdaa_construct.MdaaParamAndOutput(this, {
75
+ ...{
76
+ resourceType: 'table',
77
+ resourceId: props.tableName,
78
+ name: 'streamArn',
79
+ value: this.tableStreamArn,
80
+ },
81
+ ...props,
82
+ });
83
+ }
84
+ }
85
+ }
86
+ exports.MdaaDDBTable = MdaaDDBTable;
87
+ _a = JSII_RTTI_SYMBOL_1;
88
+ MdaaDDBTable[_a] = { fqn: "@aws-mdaa/ddb-constructs.MdaaDDBTable", version: "1.2.0" };
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAAA;;;GAGG;AAEH,sDAAsD,CAAC,SAAS;AAChE,6CAAsD;AACtD,2DAQkC;AAIlC,mDAA0D,CAAC,SAAS;AA2FpE;;;;;;;;GAQG;AACH,MAAa,YAAa,SAAQ,oBAAK;IAC7B,MAAM,CAAC,QAAQ,CAAC,KAAwB;QAC9C,MAAM,aAAa,GAAG;YACpB,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,CAAC;YAC1D,UAAU,EAAE,8BAAe,CAAC,gBAAgB;YAC5C,aAAa,EAAE,2BAAa,CAAC,MAAM;YACnC,kBAAkB,EAAE,IAAI;YACxB,mBAAmB,EAAE,IAAI;SAC1B,CAAC;QACF,OAAO,EAAE,GAAG,KAAK,EAAE,GAAG,aAAa,EAAE,CAAC;IACxC,CAAC;IACD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAwB;QAChE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAE/C,+BAAmB,CAAC,2BAA2B,CAC7C,IAAI,EACJ;YACE,EAAE,EAAE,EAAE,qCAAqC,EAAE,MAAM,EAAE,yCAAyC,EAAE;YAChG,EAAE,EAAE,EAAE,kCAAkC,EAAE,MAAM,EAAE,yCAAyC,EAAE;YAC7F,EAAE,EAAE,EAAE,qCAAqC,EAAE,MAAM,EAAE,yCAAyC,EAAE;YAChG;gBACE,EAAE,EAAE,2CAA2C;gBAC/C,MAAM,EAAE,2EAA2E;aACpF;YACD;gBACE,EAAE,EAAE,2CAA2C;gBAC/C,MAAM,EAAE,2EAA2E;aACpF;YACD;gBACE,EAAE,EAAE,wCAAwC;gBAC5C,MAAM,EAAE,2EAA2E;aACpF;SACF,EACD,IAAI,CACL,CAAC;QAEF,IAAI,cAAc,CAAC,kBAAkB,CAAC,IAAI,EAAE;YAC1C,GAAG;gBACD,YAAY,EAAE,OAAO;gBACrB,UAAU,EAAE,KAAK,CAAC,SAAS;gBAC3B,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,IAAI,CAAC,SAAS;aACtB;YACD,GAAG,KAAK;SACT,CAAC,CAAC;QAEH,IAAI,cAAc,CAAC,kBAAkB,CAAC,IAAI,EAAE;YAC1C,GAAG;gBACD,YAAY,EAAE,OAAO;gBACrB,UAAU,EAAE,KAAK,CAAC,SAAS;gBAC3B,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,IAAI,CAAC,QAAQ;aACrB;YACD,GAAG,KAAK;SACT,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,cAAc,CAAC,kBAAkB,CAAC,IAAI,EAAE;gBAC1C,GAAG;oBACD,YAAY,EAAE,OAAO;oBACrB,UAAU,EAAE,KAAK,CAAC,SAAS;oBAC3B,IAAI,EAAE,WAAW;oBACjB,KAAK,EAAE,IAAI,CAAC,cAAc;iBAC3B;gBACD,GAAG,KAAK;aACT,CAAC,CAAC;QACL,CAAC;IACH,CAAC;;AAlEH,oCAmEC","sourcesContent":["/*!\n * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport * as mdaa_construct from '@aws-mdaa/construct'; //NOSONAR\nimport { Duration, RemovalPolicy } from 'aws-cdk-lib';\nimport {\n  Attribute,\n  BillingMode,\n  StreamViewType,\n  Table,\n  TableClass,\n  TableEncryption,\n  TableProps,\n} from 'aws-cdk-lib/aws-dynamodb';\nimport { IStream } from 'aws-cdk-lib/aws-kinesis';\nimport { IKey } from 'aws-cdk-lib/aws-kms';\n\nimport { MdaaNagSuppressions } from '@aws-mdaa/construct'; //NOSONAR\nimport { Construct } from 'constructs';\n\nexport interface MdaaDDBTableProps extends mdaa_construct.MdaaConstructProps {\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional physical table name override for custom naming requirements bypassing automatic MDAA naming conventions. When specified, provides exact control over DynamoDB table naming for integration with existing systems or specific naming requirements.\n   *\n   * Use cases: Custom naming requirements; Legacy system integration; Specific naming conventions; External tool integration\n   *\n   * AWS: DynamoDB table name specification for custom naming and integration requirements\n   *\n   * Validation: Must be valid DynamoDB table name if provided; overrides automatic MDAA naming when specified\n   **/\n  readonly tableName?: string;\n  readonly kinesisStream?: IStream;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional read capacity units for provisioned throughput controlling read performance and cost management. Defines the number of read capacity units for the table when using provisioned billing mode for predictable performance and cost control.\n   *\n   * Use cases: Performance tuning; Cost management; Predictable workloads; Capacity planning\n   *\n   * AWS: DynamoDB read capacity units for provisioned throughput and performance control\n   *\n   * Validation: Must be positive integer if provided; only valid with PROVISIONED billing mode; defaults to 5\n   **/\n  readonly readCapacity?: number;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional write capacity units for provisioned throughput controlling write performance and cost management. Defines the number of write capacity units for the table when using provisioned billing mode for predictable performance and cost control.\n   *\n   * Use cases: Performance tuning; Cost management; Predictable workloads; Capacity planning\n   *\n   * AWS: DynamoDB write capacity units for provisioned throughput and performance control\n   *\n   * Validation: Must be positive integer if provided; only valid with PROVISIONED billing mode; defaults to 5\n   **/\n  readonly writeCapacity?: number;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional billing mode specification controlling cost model and capacity management for the DynamoDB table. Determines whether the table uses provisioned capacity with predictable costs or pay-per-request for variable workloads.\n   *\n   * Use cases: Cost optimization; Capacity management; Workload matching; Performance predictability\n   *\n   * AWS: DynamoDB billing mode for cost control and capacity management configuration\n   *\n   * Validation: Must be PROVISIONED or PAY_PER_REQUEST; defaults based on replication configuration\n   **/\n  readonly billingMode?: BillingMode;\n  readonly tableClass?: TableClass;\n  readonly encryptionKey: IKey;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional TTL attribute name for automatic item expiration enabling data lifecycle management and storage cost optimization. Provides automatic cleanup of expired items based on timestamp values for efficient data management and cost control.\n   *\n   * Use cases: Data lifecycle management; Automatic cleanup; Cost optimization; Storage management\n   *\n   * AWS: DynamoDB TTL attribute for automatic item expiration and data lifecycle management\n   *\n   * Validation: Must be valid attribute name if provided; enables automatic item expiration based on timestamp\n   **/\n  readonly timeToLiveAttribute?: string;\n  readonly stream?: StreamViewType;\n  readonly replicationRegions?: string[];\n  readonly replicationTimeout?: Duration;\n  readonly waitForReplicationToFinish?: boolean;\n  readonly contributorInsightsEnabled?: boolean;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Required partition key attribute definition for table primary key structure enabling data distribution and access patterns. Defines the primary key attribute that determines data distribution across partitions for optimal performance and access patterns.\n   *\n   * Use cases: Primary key definition; Data distribution; Access pattern optimization; Table structure design\n   *\n   * AWS: DynamoDB partition key attribute for primary key structure and data distribution\n   *\n   * Validation: Must be valid Attribute definition; required for table primary key structure and data distribution\n   **/\n  readonly partitionKey: Attribute;\n  /**\n   * Q-ENHANCED-PROPERTY\n   * Optional sort key attribute definition for composite primary key structure enabling range queries and data organization. Provides secondary key component for composite primary keys enabling range queries and hierarchical data organization within partitions.\n   *\n   * Use cases: Composite primary keys; Range queries; Data organization; Hierarchical data structure\n   *\n   * AWS: DynamoDB sort key attribute for composite primary key structure and range query capabilities\n   *\n   * Validation: Must be valid Attribute definition if provided; enables composite primary keys and range queries\n   **/\n  readonly sortKey?: Attribute;\n}\n\n/**\n * Compliance construct for DDB Table\n * Enforces:\n * Table name convention\n * KMS Encryption at Rest\n * Deletion Protection\n * PITR\n * RETAIN RemovalPolicy\n */\nexport class MdaaDDBTable extends Table {\n  private static setProps(props: MdaaDDBTableProps): TableProps {\n    const overrideProps = {\n      tableName: props.naming.resourceName(props.tableName, 254),\n      encryption: TableEncryption.CUSTOMER_MANAGED,\n      removalPolicy: RemovalPolicy.RETAIN,\n      deletionProtection: true,\n      pointInTimeRecovery: true,\n    };\n    return { ...props, ...overrideProps };\n  }\n  constructor(scope: Construct, id: string, props: MdaaDDBTableProps) {\n    super(scope, id, MdaaDDBTable.setProps(props));\n\n    MdaaNagSuppressions.addCodeResourceSuppressions(\n      this,\n      [\n        { id: 'HIPAA.Security-DynamoDBInBackupPlan', reason: 'MDAA does not enforce use of AWS Backup' },\n        { id: 'PCI.DSS.321-DynamoDBInBackupPlan', reason: 'MDAA does not enforce use of AWS Backup' },\n        { id: 'NIST.800.53.R5-DynamoDBInBackupPlan', reason: 'MDAA does not enforce use of AWS Backup' },\n        {\n          id: 'NIST.800.53.R5-DynamoDBAutoScalingEnabled',\n          reason: 'MDAA does not enforce use of Auto Scaling on Provisioned Capacity tables.',\n        },\n        {\n          id: 'HIPAA.Security-DynamoDBAutoScalingEnabled',\n          reason: 'MDAA does not enforce use of Auto Scaling on Provisioned Capacity tables.',\n        },\n        {\n          id: 'PCI.DSS.321-DynamoDBAutoScalingEnabled',\n          reason: 'MDAA does not enforce use of Auto Scaling on Provisioned Capacity tables.',\n        },\n      ],\n      true,\n    );\n\n    new mdaa_construct.MdaaParamAndOutput(this, {\n      ...{\n        resourceType: 'table',\n        resourceId: props.tableName,\n        name: 'name',\n        value: this.tableName,\n      },\n      ...props,\n    });\n\n    new mdaa_construct.MdaaParamAndOutput(this, {\n      ...{\n        resourceType: 'table',\n        resourceId: props.tableName,\n        name: 'arn',\n        value: this.tableArn,\n      },\n      ...props,\n    });\n    if (this.tableStreamArn) {\n      new mdaa_construct.MdaaParamAndOutput(this, {\n        ...{\n          resourceType: 'table',\n          resourceId: props.tableName,\n          name: 'streamArn',\n          value: this.tableStreamArn,\n        },\n        ...props,\n      });\n    }\n  }\n}\n"]}
package/package.json ADDED
@@ -0,0 +1,80 @@
1
+ {
2
+ "name": "@aws-mdaa/ddb-constructs",
3
+ "version": "1.2.0",
4
+ "description": "MDAA DDB Constructs",
5
+ "license": "Apache-2.0",
6
+ "author": {
7
+ "name": "Amazon Web Services",
8
+ "url": "https://aws.amazon.com/solutions"
9
+ },
10
+ "repository": {
11
+ "type": "git",
12
+ "url": "https://github.com/aws/modern-data-architecture-accelerator"
13
+ },
14
+ "main": "lib/index.js",
15
+ "types": "lib/index.d.ts",
16
+ "scripts": {
17
+ "build": "export JSII_SILENCE_WARNING_UNTESTED_NODE_VERSION=1 && jsii --project-references",
18
+ "watch": "jsii -w --project-references",
19
+ "package": "jsii-pacmak --npmignore=false",
20
+ "test": "jest --passWithNoTests --coverage",
21
+ "lint": "eslint --max-warnings 0 -c ../../../../.eslintrc.json '**/*.{ts,tsx}' --ignore-pattern 'dist/*' --ignore-pattern 'node_modules/*' --ignore-pattern \"*.d.ts\" ",
22
+ "test-coverage": "jest --passWithNoTests --coverage"
23
+ },
24
+ "devDependencies": {
25
+ "@aws-mdaa/construct": "1.2.0",
26
+ "@aws-mdaa/kms-constructs": "1.2.0",
27
+ "@aws-mdaa/naming": "1.2.0",
28
+ "@aws-mdaa/testing": "1.2.0",
29
+ "@types/jest": "29.5.0",
30
+ "@types/node": "17.0.23",
31
+ "@types/prettier": "2.6.0",
32
+ "aws-cdk-lib": "2.201.0",
33
+ "cdk-nag": "2.37.1",
34
+ "constructs": "10.0.96",
35
+ "jest": "29.5.0",
36
+ "ts-jest": "29.1.0",
37
+ "ts-node": "10.9.1",
38
+ "typescript": "4.6.3",
39
+ "typescript-json-schema": "0.63.0"
40
+ },
41
+ "overrides": {
42
+ "aws-cdk-lib": "2.201.0",
43
+ "@types/babel__traverse": "7.18.2"
44
+ },
45
+ "dependencies": {
46
+ "@aws-mdaa/construct": "1.2.0",
47
+ "@aws-mdaa/kms-constructs": "1.2.0",
48
+ "@aws-mdaa/naming": "1.2.0",
49
+ "aws-cdk-lib": "2.201.0",
50
+ "cdk-nag": "2.37.1",
51
+ "constructs": "10.0.96"
52
+ },
53
+ "peerDependencies": {
54
+ "@aws-mdaa/construct": "1.2.0",
55
+ "@aws-mdaa/kms-constructs": "1.2.0",
56
+ "@aws-mdaa/naming": "1.2.0",
57
+ "aws-cdk-lib": "2.201.0",
58
+ "cdk-nag": "2.37.1",
59
+ "constructs": "10.0.96"
60
+ },
61
+ "gitHead": "8b49a2b371014baec046605ffdbfe38951099c31",
62
+ "stability": "experimental",
63
+ "jsii": {
64
+ "outdir": "jsii-dist",
65
+ "versionFormat": "full",
66
+ "targets": {
67
+ "java_disabled": {
68
+ "package": "software.amazon.awsmdaa.construct.ddb",
69
+ "maven": {
70
+ "groupId": "software.amazon.awsmdaa.construct",
71
+ "artifactId": "ddb"
72
+ }
73
+ },
74
+ "python_disabled": {
75
+ "distName": "aws-mdaa.ddb-constructs",
76
+ "module": "aws_mdaa.ddb_constructs"
77
+ }
78
+ }
79
+ }
80
+ }