@rio-cloud/cdk-v2-constructs 6.12.1 → 6.12.2

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
@@ -19,8 +19,8 @@
19
19
  "js-yaml": "~4.1.0"
20
20
  },
21
21
  "dependencies": {
22
- "aws-cdk-lib": "^2.161.1",
23
- "constructs": "^10.3.0"
22
+ "aws-cdk-lib": "^2.163.0",
23
+ "constructs": "^10.4.2"
24
24
  },
25
25
  "dependencyClosure": {
26
26
  "@aws-cdk/asset-awscli-v1": {
@@ -14586,7 +14586,7 @@
14586
14586
  },
14587
14587
  "locationInModule": {
14588
14588
  "filename": "src/datadogv2/datadog-lambda-instrumentation.ts",
14589
- "line": 119
14589
+ "line": 118
14590
14590
  },
14591
14591
  "name": "addForwarderToNonLambdaLogGroups",
14592
14592
  "parameters": [
@@ -14609,7 +14609,7 @@
14609
14609
  },
14610
14610
  "locationInModule": {
14611
14611
  "filename": "src/datadogv2/datadog-lambda-instrumentation.ts",
14612
- "line": 116
14612
+ "line": 115
14613
14613
  },
14614
14614
  "name": "addGitCommitMetadata",
14615
14615
  "parameters": [
@@ -14655,7 +14655,7 @@
14655
14655
  },
14656
14656
  "locationInModule": {
14657
14657
  "filename": "src/datadogv2/datadog-lambda-instrumentation.ts",
14658
- "line": 109
14658
+ "line": 108
14659
14659
  },
14660
14660
  "name": "addLambdaFunctions",
14661
14661
  "parameters": [
@@ -15916,6 +15916,9 @@
15916
15916
  "summary": "A custom resource that resolves the secret ARN based on the organization ID."
15917
15917
  },
15918
15918
  "fqn": "@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret",
15919
+ "interfaces": [
15920
+ "aws-cdk-lib.aws_secretsmanager.ISecret"
15921
+ ],
15919
15922
  "kind": "class",
15920
15923
  "locationInModule": {
15921
15924
  "filename": "src/datadogv2/datadog-shared-secrets.ts",
@@ -15983,6 +15986,208 @@
15983
15986
  }
15984
15987
  },
15985
15988
  "static": true
15989
+ },
15990
+ {
15991
+ "docs": {
15992
+ "stability": "stable",
15993
+ "summary": "Adds a rotation schedule to the secret."
15994
+ },
15995
+ "locationInModule": {
15996
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
15997
+ "line": 150
15998
+ },
15999
+ "name": "addRotationSchedule",
16000
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16001
+ "parameters": [
16002
+ {
16003
+ "name": "_id",
16004
+ "type": {
16005
+ "primitive": "string"
16006
+ }
16007
+ },
16008
+ {
16009
+ "name": "_options",
16010
+ "type": {
16011
+ "fqn": "aws-cdk-lib.aws_secretsmanager.RotationScheduleOptions"
16012
+ }
16013
+ }
16014
+ ],
16015
+ "returns": {
16016
+ "type": {
16017
+ "fqn": "aws-cdk-lib.aws_secretsmanager.RotationSchedule"
16018
+ }
16019
+ }
16020
+ },
16021
+ {
16022
+ "docs": {
16023
+ "remarks": "If this secret was created in this stack, a resource policy will be\nautomatically created upon the first call to `addToResourcePolicy`. If\nthe secret is imported, then this is a no-op.",
16024
+ "stability": "stable",
16025
+ "summary": "Adds a statement to the IAM resource policy associated with this secret."
16026
+ },
16027
+ "locationInModule": {
16028
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16029
+ "line": 154
16030
+ },
16031
+ "name": "addToResourcePolicy",
16032
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16033
+ "parameters": [
16034
+ {
16035
+ "name": "_statement",
16036
+ "type": {
16037
+ "fqn": "aws-cdk-lib.aws_iam.PolicyStatement"
16038
+ }
16039
+ }
16040
+ ],
16041
+ "returns": {
16042
+ "type": {
16043
+ "fqn": "aws-cdk-lib.aws_iam.AddToResourcePolicyResult"
16044
+ }
16045
+ }
16046
+ },
16047
+ {
16048
+ "docs": {
16049
+ "remarks": "The Removal Policy controls what happens to this resource when it stops\nbeing managed by CloudFormation, either because you've removed it from the\nCDK application or because you've made a change that requires the resource\nto be replaced.\n\nThe resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS\naccount for data recovery and cleanup later (`RemovalPolicy.RETAIN`).",
16050
+ "stability": "stable",
16051
+ "summary": "Apply the given removal policy to this resource."
16052
+ },
16053
+ "locationInModule": {
16054
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16055
+ "line": 166
16056
+ },
16057
+ "name": "applyRemovalPolicy",
16058
+ "overrides": "aws-cdk-lib.IResource",
16059
+ "parameters": [
16060
+ {
16061
+ "name": "_policy",
16062
+ "type": {
16063
+ "fqn": "aws-cdk-lib.RemovalPolicy"
16064
+ }
16065
+ }
16066
+ ]
16067
+ },
16068
+ {
16069
+ "docs": {
16070
+ "stability": "stable",
16071
+ "summary": "Attach a target to this secret."
16072
+ },
16073
+ "locationInModule": {
16074
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16075
+ "line": 162
16076
+ },
16077
+ "name": "attach",
16078
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16079
+ "parameters": [
16080
+ {
16081
+ "name": "_target",
16082
+ "type": {
16083
+ "fqn": "aws-cdk-lib.aws_secretsmanager.ISecretAttachmentTarget"
16084
+ }
16085
+ }
16086
+ ],
16087
+ "returns": {
16088
+ "type": {
16089
+ "fqn": "aws-cdk-lib.aws_secretsmanager.ISecret"
16090
+ }
16091
+ }
16092
+ },
16093
+ {
16094
+ "docs": {
16095
+ "stability": "stable",
16096
+ "summary": "Denies the `DeleteSecret` action to all principals within the current account."
16097
+ },
16098
+ "locationInModule": {
16099
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16100
+ "line": 158
16101
+ },
16102
+ "name": "denyAccountRootDelete",
16103
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret"
16104
+ },
16105
+ {
16106
+ "docs": {
16107
+ "stability": "stable",
16108
+ "summary": "Grants reading the secret value to some role."
16109
+ },
16110
+ "locationInModule": {
16111
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16112
+ "line": 130
16113
+ },
16114
+ "name": "grantRead",
16115
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16116
+ "parameters": [
16117
+ {
16118
+ "name": "grantee",
16119
+ "type": {
16120
+ "fqn": "aws-cdk-lib.aws_iam.IGrantable"
16121
+ }
16122
+ },
16123
+ {
16124
+ "name": "versionStages",
16125
+ "optional": true,
16126
+ "type": {
16127
+ "collection": {
16128
+ "elementtype": {
16129
+ "primitive": "string"
16130
+ },
16131
+ "kind": "array"
16132
+ }
16133
+ }
16134
+ }
16135
+ ],
16136
+ "returns": {
16137
+ "type": {
16138
+ "fqn": "aws-cdk-lib.aws_iam.Grant"
16139
+ }
16140
+ }
16141
+ },
16142
+ {
16143
+ "docs": {
16144
+ "stability": "stable",
16145
+ "summary": "Grants writing and updating the secret value to some role."
16146
+ },
16147
+ "locationInModule": {
16148
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16149
+ "line": 146
16150
+ },
16151
+ "name": "grantWrite",
16152
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16153
+ "parameters": [
16154
+ {
16155
+ "name": "_grantee",
16156
+ "type": {
16157
+ "fqn": "aws-cdk-lib.aws_iam.IGrantable"
16158
+ }
16159
+ }
16160
+ ],
16161
+ "returns": {
16162
+ "type": {
16163
+ "fqn": "aws-cdk-lib.aws_iam.Grant"
16164
+ }
16165
+ }
16166
+ },
16167
+ {
16168
+ "docs": {
16169
+ "stability": "stable",
16170
+ "summary": "Interpret the secret as a JSON object and return a field's value from it as a `SecretValue`."
16171
+ },
16172
+ "locationInModule": {
16173
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16174
+ "line": 126
16175
+ },
16176
+ "name": "secretValueFromJson",
16177
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16178
+ "parameters": [
16179
+ {
16180
+ "name": "key",
16181
+ "type": {
16182
+ "primitive": "string"
16183
+ }
16184
+ }
16185
+ ],
16186
+ "returns": {
16187
+ "type": {
16188
+ "fqn": "aws-cdk-lib.SecretValue"
16189
+ }
16190
+ }
15986
16191
  }
15987
16192
  ],
15988
16193
  "name": "DatadogSharedSecret",
@@ -15990,16 +16195,121 @@
15990
16195
  "properties": [
15991
16196
  {
15992
16197
  "docs": {
15993
- "stability": "stable"
16198
+ "remarks": "For resources that are created and managed by the CDK\n(generally, those created by creating new class instances like Role, Bucket, etc.),\nthis is always the same as the environment of the stack they belong to;\nhowever, for imported resources\n(those obtained from static methods like fromRoleArn, fromBucketName, etc.),\nthat might be different than the stack they were imported into.",
16199
+ "stability": "stable",
16200
+ "summary": "The environment this resource belongs to."
15994
16201
  },
15995
16202
  "immutable": true,
15996
16203
  "locationInModule": {
15997
16204
  "filename": "src/datadogv2/datadog-shared-secrets.ts",
15998
- "line": 74
16205
+ "line": 102
15999
16206
  },
16000
- "name": "secret",
16207
+ "name": "env",
16208
+ "overrides": "aws-cdk-lib.IResource",
16001
16209
  "type": {
16002
- "fqn": "aws-cdk-lib.aws_secretsmanager.ISecret"
16210
+ "fqn": "aws-cdk-lib.ResourceEnvironment"
16211
+ }
16212
+ },
16213
+ {
16214
+ "docs": {
16215
+ "remarks": "Will return the full ARN if available, otherwise a partial arn.\nFor secrets imported by the deprecated `fromSecretName`, it will return the `secretName`.",
16216
+ "stability": "stable",
16217
+ "summary": "The ARN of the secret in AWS Secrets Manager."
16218
+ },
16219
+ "immutable": true,
16220
+ "locationInModule": {
16221
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16222
+ "line": 110
16223
+ },
16224
+ "name": "secretArn",
16225
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16226
+ "type": {
16227
+ "primitive": "string"
16228
+ }
16229
+ },
16230
+ {
16231
+ "docs": {
16232
+ "remarks": "For \"owned\" secrets, this will be the full resource name (secret name + suffix), unless the\n'@aws-cdk/aws-secretsmanager:parseOwnedSecretName' feature flag is set.",
16233
+ "stability": "stable",
16234
+ "summary": "The name of the secret."
16235
+ },
16236
+ "immutable": true,
16237
+ "locationInModule": {
16238
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16239
+ "line": 118
16240
+ },
16241
+ "name": "secretName",
16242
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16243
+ "type": {
16244
+ "primitive": "string"
16245
+ }
16246
+ },
16247
+ {
16248
+ "docs": {
16249
+ "stability": "stable",
16250
+ "summary": "Retrieve the value of the stored secret as a `SecretValue`."
16251
+ },
16252
+ "immutable": true,
16253
+ "locationInModule": {
16254
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16255
+ "line": 122
16256
+ },
16257
+ "name": "secretValue",
16258
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16259
+ "type": {
16260
+ "fqn": "aws-cdk-lib.SecretValue"
16261
+ }
16262
+ },
16263
+ {
16264
+ "docs": {
16265
+ "stability": "stable",
16266
+ "summary": "The stack in which this resource is defined."
16267
+ },
16268
+ "immutable": true,
16269
+ "locationInModule": {
16270
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16271
+ "line": 98
16272
+ },
16273
+ "name": "stack",
16274
+ "overrides": "aws-cdk-lib.IResource",
16275
+ "type": {
16276
+ "fqn": "aws-cdk-lib.Stack"
16277
+ }
16278
+ },
16279
+ {
16280
+ "docs": {
16281
+ "remarks": "When not specified, the default\nKMS key for the account and region is being used.",
16282
+ "stability": "stable",
16283
+ "summary": "The customer-managed encryption key that is used to encrypt this secret, if any."
16284
+ },
16285
+ "immutable": true,
16286
+ "locationInModule": {
16287
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16288
+ "line": 106
16289
+ },
16290
+ "name": "encryptionKey",
16291
+ "optional": true,
16292
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16293
+ "type": {
16294
+ "fqn": "aws-cdk-lib.aws_kms.IKey"
16295
+ }
16296
+ },
16297
+ {
16298
+ "docs": {
16299
+ "remarks": "This is equal to `secretArn` in most cases, but is undefined when a full ARN is not available (e.g., secrets imported by name).",
16300
+ "stability": "stable",
16301
+ "summary": "The full ARN of the secret in AWS Secrets Manager, which is the ARN including the Secrets Manager-supplied 6-character suffix."
16302
+ },
16303
+ "immutable": true,
16304
+ "locationInModule": {
16305
+ "filename": "src/datadogv2/datadog-shared-secrets.ts",
16306
+ "line": 114
16307
+ },
16308
+ "name": "secretFullArn",
16309
+ "optional": true,
16310
+ "overrides": "aws-cdk-lib.aws_secretsmanager.ISecret",
16311
+ "type": {
16312
+ "primitive": "string"
16003
16313
  }
16004
16314
  }
16005
16315
  ],
@@ -19546,5 +19856,5 @@
19546
19856
  }
19547
19857
  },
19548
19858
  "version": "0.0.0",
19549
- "fingerprint": "nne4l7I6QYKfeWWj+aKn0szZGv9LSdFjX9d+76vMGkw="
19859
+ "fingerprint": "jy2qX2b1QCqrf5ImjcMOVjqERQbFWoeaLJf5sL/m1+w="
19550
19860
  }
package/docs/API.md CHANGED
@@ -1983,6 +1983,8 @@ Default priority of a monitor.
1983
1983
 
1984
1984
  ### DatadogSharedSecret <a name="DatadogSharedSecret" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret"></a>
1985
1985
 
1986
+ - *Implements:* aws-cdk-lib.aws_secretsmanager.ISecret
1987
+
1986
1988
  A custom resource that resolves the secret ARN based on the organization ID.
1987
1989
 
1988
1990
  #### Methods <a name="Methods" id="Methods"></a>
@@ -1990,6 +1992,14 @@ A custom resource that resolves the secret ARN based on the organization ID.
1990
1992
  | **Name** | **Description** |
1991
1993
  | --- | --- |
1992
1994
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.toString">toString</a></code> | Returns a string representation of this construct. |
1995
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.addRotationSchedule">addRotationSchedule</a></code> | Adds a rotation schedule to the secret. |
1996
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.addToResourcePolicy">addToResourcePolicy</a></code> | Adds a statement to the IAM resource policy associated with this secret. |
1997
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.applyRemovalPolicy">applyRemovalPolicy</a></code> | Apply the given removal policy to this resource. |
1998
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.attach">attach</a></code> | Attach a target to this secret. |
1999
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.denyAccountRootDelete">denyAccountRootDelete</a></code> | Denies the `DeleteSecret` action to all principals within the current account. |
2000
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.grantRead">grantRead</a></code> | Grants reading the secret value to some role. |
2001
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.grantWrite">grantWrite</a></code> | Grants writing and updating the secret value to some role. |
2002
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.secretValueFromJson">secretValueFromJson</a></code> | Interpret the secret as a JSON object and return a field's value from it as a `SecretValue`. |
1993
2003
 
1994
2004
  ---
1995
2005
 
@@ -2001,6 +2011,136 @@ public toString(): string
2001
2011
 
2002
2012
  Returns a string representation of this construct.
2003
2013
 
2014
+ ##### `addRotationSchedule` <a name="addRotationSchedule" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.addRotationSchedule"></a>
2015
+
2016
+ ```typescript
2017
+ public addRotationSchedule(_id: string, _options: RotationScheduleOptions): RotationSchedule
2018
+ ```
2019
+
2020
+ Adds a rotation schedule to the secret.
2021
+
2022
+ ###### `_id`<sup>Required</sup> <a name="_id" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.addRotationSchedule.parameter._id"></a>
2023
+
2024
+ - *Type:* string
2025
+
2026
+ ---
2027
+
2028
+ ###### `_options`<sup>Required</sup> <a name="_options" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.addRotationSchedule.parameter._options"></a>
2029
+
2030
+ - *Type:* aws-cdk-lib.aws_secretsmanager.RotationScheduleOptions
2031
+
2032
+ ---
2033
+
2034
+ ##### `addToResourcePolicy` <a name="addToResourcePolicy" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.addToResourcePolicy"></a>
2035
+
2036
+ ```typescript
2037
+ public addToResourcePolicy(_statement: PolicyStatement): AddToResourcePolicyResult
2038
+ ```
2039
+
2040
+ Adds a statement to the IAM resource policy associated with this secret.
2041
+
2042
+ If this secret was created in this stack, a resource policy will be
2043
+ automatically created upon the first call to `addToResourcePolicy`. If
2044
+ the secret is imported, then this is a no-op.
2045
+
2046
+ ###### `_statement`<sup>Required</sup> <a name="_statement" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.addToResourcePolicy.parameter._statement"></a>
2047
+
2048
+ - *Type:* aws-cdk-lib.aws_iam.PolicyStatement
2049
+
2050
+ ---
2051
+
2052
+ ##### `applyRemovalPolicy` <a name="applyRemovalPolicy" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.applyRemovalPolicy"></a>
2053
+
2054
+ ```typescript
2055
+ public applyRemovalPolicy(_policy: RemovalPolicy): void
2056
+ ```
2057
+
2058
+ Apply the given removal policy to this resource.
2059
+
2060
+ The Removal Policy controls what happens to this resource when it stops
2061
+ being managed by CloudFormation, either because you've removed it from the
2062
+ CDK application or because you've made a change that requires the resource
2063
+ to be replaced.
2064
+
2065
+ The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
2066
+ account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
2067
+
2068
+ ###### `_policy`<sup>Required</sup> <a name="_policy" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.applyRemovalPolicy.parameter._policy"></a>
2069
+
2070
+ - *Type:* aws-cdk-lib.RemovalPolicy
2071
+
2072
+ ---
2073
+
2074
+ ##### `attach` <a name="attach" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.attach"></a>
2075
+
2076
+ ```typescript
2077
+ public attach(_target: ISecretAttachmentTarget): ISecret
2078
+ ```
2079
+
2080
+ Attach a target to this secret.
2081
+
2082
+ ###### `_target`<sup>Required</sup> <a name="_target" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.attach.parameter._target"></a>
2083
+
2084
+ - *Type:* aws-cdk-lib.aws_secretsmanager.ISecretAttachmentTarget
2085
+
2086
+ ---
2087
+
2088
+ ##### `denyAccountRootDelete` <a name="denyAccountRootDelete" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.denyAccountRootDelete"></a>
2089
+
2090
+ ```typescript
2091
+ public denyAccountRootDelete(): void
2092
+ ```
2093
+
2094
+ Denies the `DeleteSecret` action to all principals within the current account.
2095
+
2096
+ ##### `grantRead` <a name="grantRead" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.grantRead"></a>
2097
+
2098
+ ```typescript
2099
+ public grantRead(grantee: IGrantable, versionStages?: string[]): Grant
2100
+ ```
2101
+
2102
+ Grants reading the secret value to some role.
2103
+
2104
+ ###### `grantee`<sup>Required</sup> <a name="grantee" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.grantRead.parameter.grantee"></a>
2105
+
2106
+ - *Type:* aws-cdk-lib.aws_iam.IGrantable
2107
+
2108
+ ---
2109
+
2110
+ ###### `versionStages`<sup>Optional</sup> <a name="versionStages" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.grantRead.parameter.versionStages"></a>
2111
+
2112
+ - *Type:* string[]
2113
+
2114
+ ---
2115
+
2116
+ ##### `grantWrite` <a name="grantWrite" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.grantWrite"></a>
2117
+
2118
+ ```typescript
2119
+ public grantWrite(_grantee: IGrantable): Grant
2120
+ ```
2121
+
2122
+ Grants writing and updating the secret value to some role.
2123
+
2124
+ ###### `_grantee`<sup>Required</sup> <a name="_grantee" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.grantWrite.parameter._grantee"></a>
2125
+
2126
+ - *Type:* aws-cdk-lib.aws_iam.IGrantable
2127
+
2128
+ ---
2129
+
2130
+ ##### `secretValueFromJson` <a name="secretValueFromJson" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.secretValueFromJson"></a>
2131
+
2132
+ ```typescript
2133
+ public secretValueFromJson(key: string): SecretValue
2134
+ ```
2135
+
2136
+ Interpret the secret as a JSON object and return a field's value from it as a `SecretValue`.
2137
+
2138
+ ###### `key`<sup>Required</sup> <a name="key" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.secretValueFromJson.parameter.key"></a>
2139
+
2140
+ - *Type:* string
2141
+
2142
+ ---
2143
+
2004
2144
  #### Static Functions <a name="Static Functions" id="Static Functions"></a>
2005
2145
 
2006
2146
  | **Name** | **Description** |
@@ -2092,7 +2232,13 @@ This static function resolves to the json credentials secret that contains ['Api
2092
2232
  | **Name** | **Type** | **Description** |
2093
2233
  | --- | --- | --- |
2094
2234
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
2095
- | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secret">secret</a></code> | <code>aws-cdk-lib.aws_secretsmanager.ISecret</code> | *No description.* |
2235
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.env">env</a></code> | <code>aws-cdk-lib.ResourceEnvironment</code> | The environment this resource belongs to. |
2236
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretArn">secretArn</a></code> | <code>string</code> | The ARN of the secret in AWS Secrets Manager. |
2237
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretName">secretName</a></code> | <code>string</code> | The name of the secret. |
2238
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretValue">secretValue</a></code> | <code>aws-cdk-lib.SecretValue</code> | Retrieve the value of the stored secret as a `SecretValue`. |
2239
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.stack">stack</a></code> | <code>aws-cdk-lib.Stack</code> | The stack in which this resource is defined. |
2240
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.encryptionKey">encryptionKey</a></code> | <code>aws-cdk-lib.aws_kms.IKey</code> | The customer-managed encryption key that is used to encrypt this secret, if any. |
2241
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretFullArn">secretFullArn</a></code> | <code>string</code> | The full ARN of the secret in AWS Secrets Manager, which is the ARN including the Secrets Manager-supplied 6-character suffix. |
2096
2242
 
2097
2243
  ---
2098
2244
 
@@ -2108,13 +2254,105 @@ The tree node.
2108
2254
 
2109
2255
  ---
2110
2256
 
2111
- ##### `secret`<sup>Required</sup> <a name="secret" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secret"></a>
2257
+ ##### `env`<sup>Required</sup> <a name="env" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.env"></a>
2112
2258
 
2113
2259
  ```typescript
2114
- public readonly secret: ISecret;
2260
+ public readonly env: ResourceEnvironment;
2115
2261
  ```
2116
2262
 
2117
- - *Type:* aws-cdk-lib.aws_secretsmanager.ISecret
2263
+ - *Type:* aws-cdk-lib.ResourceEnvironment
2264
+
2265
+ The environment this resource belongs to.
2266
+
2267
+ For resources that are created and managed by the CDK
2268
+ (generally, those created by creating new class instances like Role, Bucket, etc.),
2269
+ this is always the same as the environment of the stack they belong to;
2270
+ however, for imported resources
2271
+ (those obtained from static methods like fromRoleArn, fromBucketName, etc.),
2272
+ that might be different than the stack they were imported into.
2273
+
2274
+ ---
2275
+
2276
+ ##### `secretArn`<sup>Required</sup> <a name="secretArn" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretArn"></a>
2277
+
2278
+ ```typescript
2279
+ public readonly secretArn: string;
2280
+ ```
2281
+
2282
+ - *Type:* string
2283
+
2284
+ The ARN of the secret in AWS Secrets Manager.
2285
+
2286
+ Will return the full ARN if available, otherwise a partial arn.
2287
+ For secrets imported by the deprecated `fromSecretName`, it will return the `secretName`.
2288
+
2289
+ ---
2290
+
2291
+ ##### `secretName`<sup>Required</sup> <a name="secretName" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretName"></a>
2292
+
2293
+ ```typescript
2294
+ public readonly secretName: string;
2295
+ ```
2296
+
2297
+ - *Type:* string
2298
+
2299
+ The name of the secret.
2300
+
2301
+ For "owned" secrets, this will be the full resource name (secret name + suffix), unless the
2302
+ '@aws-cdk/aws-secretsmanager:parseOwnedSecretName' feature flag is set.
2303
+
2304
+ ---
2305
+
2306
+ ##### `secretValue`<sup>Required</sup> <a name="secretValue" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretValue"></a>
2307
+
2308
+ ```typescript
2309
+ public readonly secretValue: SecretValue;
2310
+ ```
2311
+
2312
+ - *Type:* aws-cdk-lib.SecretValue
2313
+
2314
+ Retrieve the value of the stored secret as a `SecretValue`.
2315
+
2316
+ ---
2317
+
2318
+ ##### `stack`<sup>Required</sup> <a name="stack" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.stack"></a>
2319
+
2320
+ ```typescript
2321
+ public readonly stack: Stack;
2322
+ ```
2323
+
2324
+ - *Type:* aws-cdk-lib.Stack
2325
+
2326
+ The stack in which this resource is defined.
2327
+
2328
+ ---
2329
+
2330
+ ##### `encryptionKey`<sup>Optional</sup> <a name="encryptionKey" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.encryptionKey"></a>
2331
+
2332
+ ```typescript
2333
+ public readonly encryptionKey: IKey;
2334
+ ```
2335
+
2336
+ - *Type:* aws-cdk-lib.aws_kms.IKey
2337
+
2338
+ The customer-managed encryption key that is used to encrypt this secret, if any.
2339
+
2340
+ When not specified, the default
2341
+ KMS key for the account and region is being used.
2342
+
2343
+ ---
2344
+
2345
+ ##### `secretFullArn`<sup>Optional</sup> <a name="secretFullArn" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.property.secretFullArn"></a>
2346
+
2347
+ ```typescript
2348
+ public readonly secretFullArn: string;
2349
+ ```
2350
+
2351
+ - *Type:* string
2352
+
2353
+ The full ARN of the secret in AWS Secrets Manager, which is the ARN including the Secrets Manager-supplied 6-character suffix.
2354
+
2355
+ This is equal to `secretArn` in most cases, but is undefined when a full ARN is not available (e.g., secrets imported by name).
2118
2356
 
2119
2357
  ---
2120
2358
 
package/docs/changelog.md CHANGED
@@ -2,6 +2,13 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version) for commit guidelines.
4
4
 
5
+ ## [6.12.2](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.12.1&sourceBranch=refs%2Ftags%2Fv6.12.2) (2024-11-04)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * dependencies updated by renovate ([533396a](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/533396aa1fcc89f0a46099f90c20b2957b266ee4))
11
+
5
12
  ## [6.12.1](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.12.0&sourceBranch=refs%2Ftags%2Fv6.12.1) (2024-10-29)
6
13
 
7
14
  ## [6.12.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.12.0-beta.0&sourceBranch=refs%2Ftags%2Fv6.12.0) (2024-10-22)
@@ -25,10 +25,9 @@ const datadog_shared_secrets_1 = require("./datadog-shared-secrets");
25
25
  class DatadogLambdaInstrumentation extends constructs_1.Construct {
26
26
  constructor(scope, id, props) {
27
27
  super(scope, id);
28
- const resolvedDatadogApiKey = datadog_shared_secrets_1.DatadogSharedSecret.apiKeySecret(this, 'DatadogApiKeySecret');
29
- this.datadogSecret = resolvedDatadogApiKey.secret;
28
+ this.datadogSecret = datadog_shared_secrets_1.DatadogSharedSecret.apiKeySecret(this, 'DatadogApiKeySecret');
30
29
  const resolvedDatadogSecret = datadog_shared_secrets_1.DatadogSharedSecret.credentialsSecret(this, 'DatadogCredentialsSecret');
31
- this.site = resolvedDatadogSecret.secret.secretValueFromJson('Site').unsafeUnwrap();
30
+ this.site = resolvedDatadogSecret.secretValueFromJson('Site').unsafeUnwrap();
32
31
  const finalProps = {
33
32
  env: 'prod',
34
33
  apiKeySecretArn: this.datadogSecret.secretArn,
@@ -74,4 +73,4 @@ const getSourceCodeIntegrationDefault = (node) => {
74
73
  const isDisabled = value === 'false' || value === false;
75
74
  return !isDisabled;
76
75
  };
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-lambda-instrumentation.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-lambda-instrumentation.ts"],"names":[],"mappings":";;;;;AAEA,2CAA6C;AAC7C,6DAA6D;AAC7D,gDAAgD;AAChD,qEAA+D;AAoD/D;;;;;;;;;;;;;;GAcG;AACH,MAAa,4BAA6B,SAAQ,sBAAS;IAKzD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAwC;QAChF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,qBAAqB,GAAG,4CAAmB,CAAC,YAAY,CAAC,IAAI,EAAE,qBAAqB,CAAC,CAAC;QAC5F,IAAI,CAAC,aAAa,GAAG,qBAAqB,CAAC,MAAM,CAAC;QAElD,MAAM,qBAAqB,GAAG,4CAAmB,CAAC,iBAAiB,CAAC,IAAI,EAAE,0BAA0B,CAAC,CAAC;QACtG,IAAI,CAAC,IAAI,GAAG,qBAAqB,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,CAAC;QAEpF,MAAM,UAAU,GAAG;YACjB,GAAG,EAAE,MAAM;YACX,eAAe,EAAE,IAAI,CAAC,aAAa,CAAC,SAAS;YAC7C,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,iBAAiB,EAAE,IAAI;YACvB,gBAAgB,EAAE,IAAI;YACtB,oBAAoB,EAAE,KAAK;YAC3B,sBAAsB,EAAE,KAAK;YAC7B,gBAAgB,EAAE,KAAK;YACvB,qBAAqB,EAAE,KAAK;YAC5B,eAAe,EAAE,KAAK;YACtB,qBAAqB,EAAE,+BAA+B,CAAC,IAAI,CAAC,IAAI,CAAC;YACjE,GAAG,KAAK;SACT,CAAC;QAEF,EAAE,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAC7B,EAAE,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;QAEvC,IAAI,CAAC,QAAQ,GAAG,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QAC5D,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC,qBAAqB,IAAI,KAAK,CAAC;IACrE,CAAC;IAED,kBAAkB,CAAC,eAAoC,EAAE,SAAqB;QAC5E,KAAK,MAAM,cAAc,IAAI,eAAe,EAAE,CAAC;YAC7C,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;YAC7C,cAAc,CAAC,cAAc,CAAC,qBAAqB,EAAE,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;QACzF,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC;IAC/D,CAAC;IACD,oBAAoB,CAAC,eAAoC,EAAE,YAAqB,EAAE,UAAmB;QACnG,IAAI,CAAC,QAAQ,CAAC,oBAAoB,CAAC,eAAe,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;IAChF,CAAC;IACD,gCAAgC,CAAC,SAA2B;QAC1D,IAAI,CAAC,QAAQ,CAAC,gCAAgC,CAAC,SAAS,CAAC,CAAC;IAC5D,CAAC;;AAhDH,oEAiDC;;;AAED;;;GAGG;AACH,MAAM,+BAA+B,GAAG,CAAC,IAAU,EAAW,EAAE;IAC9D,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,0DAA0D,CAAC,CAAC;IAE7F,MAAM,UAAU,GAAG,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,KAAK,CAAC;IAExD,OAAO,CAAC,UAAU,CAAC;AACrB,CAAC,CAAC","sourcesContent":["import * as logs from 'aws-cdk-lib/aws-logs';\nimport * as secrets from 'aws-cdk-lib/aws-secretsmanager';\nimport { Construct, Node } from 'constructs';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport * as dd from 'datadog-cdk-constructs-v2';\nimport { DatadogSharedSecret } from './datadog-shared-secrets';\n\n/**\n * Props for the DatadogLambdaInstrumentation construct.\n * Copied over from original Datadog construct.\n * This interface is intentionally not extending the original DatadogProps, so that the dependency needs to be bundled as well.\n *\n * @see dd.DatadogProps\n */\nexport interface DatadogLambdaInstrumentationProps {\n  readonly service: string;\n\n  /**\n   * Whether to enable enhanced metrics for the Lambda functions.\n   *\n   * @defaultValue false\n  */\n  readonly enableEnhancedMetrics?: boolean;\n  readonly nodeLayerVersion?: number;\n  readonly extensionLayerVersion?: number;\n  readonly addLayers?: boolean;\n  readonly forwarderArn?: string;\n  readonly flushMetricsToLogs?: boolean;\n  readonly site?: string;\n  readonly apiKey?: string;\n  readonly apiKeySecretArn?: string;\n  readonly apiKeySecret?: secrets.ISecret;\n  readonly apiKmsKey?: string;\n  readonly enableDatadogTracing?: boolean;\n  readonly enableDatadogASM?: boolean;\n  readonly enableMergeXrayTraces?: boolean;\n  readonly injectLogContext?: boolean;\n  readonly logLevel?: string;\n  readonly enableDatadogLogs?: boolean;\n  readonly captureLambdaPayload?: boolean;\n  readonly env?: string;\n  readonly version?: string;\n  readonly tags?: string;\n  readonly createForwarderPermissions?: boolean;\n  readonly sourceCodeIntegration?: boolean;\n  readonly enableColdStartTracing?: boolean;\n  readonly minColdStartTraceDuration?: number;\n  readonly coldStartTraceSkipLibs?: string;\n  readonly enableProfiling?: boolean;\n  readonly encodeAuthorizerContext?: boolean;\n  readonly decodeAuthorizerContext?: boolean;\n  readonly apmFlushDeadline?: string | number;\n  readonly redirectHandler?: boolean;\n  readonly grantSecretReadAccess?: boolean;\n  readonly useLayersFromAccount?: string;\n}\n\n/**\n * Wrapper construct for Datadog's Lambda instrumentation.\n * This construct will create a Datadog construct with the provided props and add the Lambda functions to it.\n * Per default, it will disable all additional features, that cause Datadog charging for Serverless Functions features.\n * So just change it, if you need the advanced features.\n *\n * Additionally, some defaults from the datadog-integration account module are applied:\n * - the secret for the API key is read from the secret manager `/rio/config/datadog-integration/api-key`\n * - the site is read from the parameter store `/rio/config/datadog-integration/site`\n *\n * To use it, install Datadog CDK Constructs package:\n * ```bash\n * npm i -D datadog-cdk-constructs-v2\n * ```\n */\nexport class DatadogLambdaInstrumentation extends Construct {\n  private delegate: dd.Datadog;\n  private datadogSecret: secrets.ISecret;\n  private site: string;\n  private readonly enhancedMetricsEnabled: boolean;\n  constructor(scope: Construct, id: string, props: DatadogLambdaInstrumentationProps) {\n    super(scope, id);\n\n    const resolvedDatadogApiKey = DatadogSharedSecret.apiKeySecret(this, 'DatadogApiKeySecret');\n    this.datadogSecret = resolvedDatadogApiKey.secret;\n\n    const resolvedDatadogSecret = DatadogSharedSecret.credentialsSecret(this, 'DatadogCredentialsSecret');\n    this.site = resolvedDatadogSecret.secret.secretValueFromJson('Site').unsafeUnwrap();\n\n    const finalProps = {\n      env: 'prod',\n      apiKeySecretArn: this.datadogSecret.secretArn,\n      site: this.site,\n      enableDatadogLogs: true,\n      injectLogContext: true,\n      enableDatadogTracing: false,\n      enableColdStartTracing: false,\n      enableDatadogASM: false,\n      enableMergeXrayTraces: false,\n      enableProfiling: false,\n      sourceCodeIntegration: getSourceCodeIntegrationDefault(this.node),\n      ...props,\n    };\n\n    dd.validateProps(finalProps);\n    dd.checkForMultipleApiKeys(finalProps);\n\n    this.delegate = new dd.Datadog(this, 'Datadog', finalProps);\n    this.enhancedMetricsEnabled = props.enableEnhancedMetrics ?? false;\n  }\n\n  addLambdaFunctions(lambdaFunctions: dd.LambdaFunction[], construct?: Construct): void {\n    for (const lambdaFunction of lambdaFunctions) {\n      this.datadogSecret.grantRead(lambdaFunction);\n      lambdaFunction.addEnvironment('DD_ENHANCED_METRICS', `${this.enhancedMetricsEnabled}`);\n    }\n    this.delegate.addLambdaFunctions(lambdaFunctions, construct);\n  }\n  addGitCommitMetadata(lambdaFunctions: dd.LambdaFunction[], gitCommitSha?: string, gitRepoUrl?: string): void {\n    this.delegate.addGitCommitMetadata(lambdaFunctions, gitCommitSha, gitRepoUrl);\n  }\n  addForwarderToNonLambdaLogGroups(logGroups: logs.ILogGroup[]): void {\n    this.delegate.addForwarderToNonLambdaLogGroups(logGroups);\n  }\n}\n\n/**\n * @param node - The node to check for the context value\n * @returns true as a default if not disabled via context\n */\nconst getSourceCodeIntegrationDefault = (node: Node): boolean => {\n  const value = node.tryGetContext('@rio-cloud/cdk-v2-constructs:enableSourceCodeIntegration');\n\n  const isDisabled = value === 'false' || value === false;\n\n  return !isDisabled;\n};\n"]}
76
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-lambda-instrumentation.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-lambda-instrumentation.ts"],"names":[],"mappings":";;;;;AAEA,2CAA6C;AAC7C,6DAA6D;AAC7D,gDAAgD;AAChD,qEAA+D;AAoD/D;;;;;;;;;;;;;;GAcG;AACH,MAAa,4BAA6B,SAAQ,sBAAS;IAKzD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAwC;QAChF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,aAAa,GAAG,4CAAmB,CAAC,YAAY,CAAC,IAAI,EAAE,qBAAqB,CAAC,CAAC;QAEnF,MAAM,qBAAqB,GAAG,4CAAmB,CAAC,iBAAiB,CAAC,IAAI,EAAE,0BAA0B,CAAC,CAAC;QACtG,IAAI,CAAC,IAAI,GAAG,qBAAqB,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,CAAC;QAE7E,MAAM,UAAU,GAAG;YACjB,GAAG,EAAE,MAAM;YACX,eAAe,EAAE,IAAI,CAAC,aAAa,CAAC,SAAS;YAC7C,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,iBAAiB,EAAE,IAAI;YACvB,gBAAgB,EAAE,IAAI;YACtB,oBAAoB,EAAE,KAAK;YAC3B,sBAAsB,EAAE,KAAK;YAC7B,gBAAgB,EAAE,KAAK;YACvB,qBAAqB,EAAE,KAAK;YAC5B,eAAe,EAAE,KAAK;YACtB,qBAAqB,EAAE,+BAA+B,CAAC,IAAI,CAAC,IAAI,CAAC;YACjE,GAAG,KAAK;SACT,CAAC;QAEF,EAAE,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAC7B,EAAE,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;QAEvC,IAAI,CAAC,QAAQ,GAAG,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QAC5D,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC,qBAAqB,IAAI,KAAK,CAAC;IACrE,CAAC;IAED,kBAAkB,CAAC,eAAoC,EAAE,SAAqB;QAC5E,KAAK,MAAM,cAAc,IAAI,eAAe,EAAE,CAAC;YAC7C,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;YAC7C,cAAc,CAAC,cAAc,CAAC,qBAAqB,EAAE,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;QACzF,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC;IAC/D,CAAC;IACD,oBAAoB,CAAC,eAAoC,EAAE,YAAqB,EAAE,UAAmB;QACnG,IAAI,CAAC,QAAQ,CAAC,oBAAoB,CAAC,eAAe,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;IAChF,CAAC;IACD,gCAAgC,CAAC,SAA2B;QAC1D,IAAI,CAAC,QAAQ,CAAC,gCAAgC,CAAC,SAAS,CAAC,CAAC;IAC5D,CAAC;;AA/CH,oEAgDC;;;AAED;;;GAGG;AACH,MAAM,+BAA+B,GAAG,CAAC,IAAU,EAAW,EAAE;IAC9D,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,0DAA0D,CAAC,CAAC;IAE7F,MAAM,UAAU,GAAG,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,KAAK,CAAC;IAExD,OAAO,CAAC,UAAU,CAAC;AACrB,CAAC,CAAC","sourcesContent":["import * as logs from 'aws-cdk-lib/aws-logs';\nimport * as secrets from 'aws-cdk-lib/aws-secretsmanager';\nimport { Construct, Node } from 'constructs';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport * as dd from 'datadog-cdk-constructs-v2';\nimport { DatadogSharedSecret } from './datadog-shared-secrets';\n\n/**\n * Props for the DatadogLambdaInstrumentation construct.\n * Copied over from original Datadog construct.\n * This interface is intentionally not extending the original DatadogProps, so that the dependency needs to be bundled as well.\n *\n * @see dd.DatadogProps\n */\nexport interface DatadogLambdaInstrumentationProps {\n  readonly service: string;\n\n  /**\n   * Whether to enable enhanced metrics for the Lambda functions.\n   *\n   * @defaultValue false\n  */\n  readonly enableEnhancedMetrics?: boolean;\n  readonly nodeLayerVersion?: number;\n  readonly extensionLayerVersion?: number;\n  readonly addLayers?: boolean;\n  readonly forwarderArn?: string;\n  readonly flushMetricsToLogs?: boolean;\n  readonly site?: string;\n  readonly apiKey?: string;\n  readonly apiKeySecretArn?: string;\n  readonly apiKeySecret?: secrets.ISecret;\n  readonly apiKmsKey?: string;\n  readonly enableDatadogTracing?: boolean;\n  readonly enableDatadogASM?: boolean;\n  readonly enableMergeXrayTraces?: boolean;\n  readonly injectLogContext?: boolean;\n  readonly logLevel?: string;\n  readonly enableDatadogLogs?: boolean;\n  readonly captureLambdaPayload?: boolean;\n  readonly env?: string;\n  readonly version?: string;\n  readonly tags?: string;\n  readonly createForwarderPermissions?: boolean;\n  readonly sourceCodeIntegration?: boolean;\n  readonly enableColdStartTracing?: boolean;\n  readonly minColdStartTraceDuration?: number;\n  readonly coldStartTraceSkipLibs?: string;\n  readonly enableProfiling?: boolean;\n  readonly encodeAuthorizerContext?: boolean;\n  readonly decodeAuthorizerContext?: boolean;\n  readonly apmFlushDeadline?: string | number;\n  readonly redirectHandler?: boolean;\n  readonly grantSecretReadAccess?: boolean;\n  readonly useLayersFromAccount?: string;\n}\n\n/**\n * Wrapper construct for Datadog's Lambda instrumentation.\n * This construct will create a Datadog construct with the provided props and add the Lambda functions to it.\n * Per default, it will disable all additional features, that cause Datadog charging for Serverless Functions features.\n * So just change it, if you need the advanced features.\n *\n * Additionally, some defaults from the datadog-integration account module are applied:\n * - the secret for the API key is read from the secret manager `/rio/config/datadog-integration/api-key`\n * - the site is read from the parameter store `/rio/config/datadog-integration/site`\n *\n * To use it, install Datadog CDK Constructs package:\n * ```bash\n * npm i -D datadog-cdk-constructs-v2\n * ```\n */\nexport class DatadogLambdaInstrumentation extends Construct {\n  private delegate: dd.Datadog;\n  private datadogSecret: DatadogSharedSecret;\n  private site: string;\n  private readonly enhancedMetricsEnabled: boolean;\n  constructor(scope: Construct, id: string, props: DatadogLambdaInstrumentationProps) {\n    super(scope, id);\n\n    this.datadogSecret = DatadogSharedSecret.apiKeySecret(this, 'DatadogApiKeySecret');\n\n    const resolvedDatadogSecret = DatadogSharedSecret.credentialsSecret(this, 'DatadogCredentialsSecret');\n    this.site = resolvedDatadogSecret.secretValueFromJson('Site').unsafeUnwrap();\n\n    const finalProps = {\n      env: 'prod',\n      apiKeySecretArn: this.datadogSecret.secretArn,\n      site: this.site,\n      enableDatadogLogs: true,\n      injectLogContext: true,\n      enableDatadogTracing: false,\n      enableColdStartTracing: false,\n      enableDatadogASM: false,\n      enableMergeXrayTraces: false,\n      enableProfiling: false,\n      sourceCodeIntegration: getSourceCodeIntegrationDefault(this.node),\n      ...props,\n    };\n\n    dd.validateProps(finalProps);\n    dd.checkForMultipleApiKeys(finalProps);\n\n    this.delegate = new dd.Datadog(this, 'Datadog', finalProps);\n    this.enhancedMetricsEnabled = props.enableEnhancedMetrics ?? false;\n  }\n\n  addLambdaFunctions(lambdaFunctions: dd.LambdaFunction[], construct?: Construct): void {\n    for (const lambdaFunction of lambdaFunctions) {\n      this.datadogSecret.grantRead(lambdaFunction);\n      lambdaFunction.addEnvironment('DD_ENHANCED_METRICS', `${this.enhancedMetricsEnabled}`);\n    }\n    this.delegate.addLambdaFunctions(lambdaFunctions, construct);\n  }\n  addGitCommitMetadata(lambdaFunctions: dd.LambdaFunction[], gitCommitSha?: string, gitRepoUrl?: string): void {\n    this.delegate.addGitCommitMetadata(lambdaFunctions, gitCommitSha, gitRepoUrl);\n  }\n  addForwarderToNonLambdaLogGroups(logGroups: logs.ILogGroup[]): void {\n    this.delegate.addForwarderToNonLambdaLogGroups(logGroups);\n  }\n}\n\n/**\n * @param node - The node to check for the context value\n * @returns true as a default if not disabled via context\n */\nconst getSourceCodeIntegrationDefault = (node: Node): boolean => {\n  const value = node.tryGetContext('@rio-cloud/cdk-v2-constructs:enableSourceCodeIntegration');\n\n  const isDisabled = value === 'false' || value === false;\n\n  return !isDisabled;\n};\n"]}
@@ -1,9 +1,11 @@
1
+ import * as cdk from 'aws-cdk-lib';
2
+ import * as iam from 'aws-cdk-lib/aws-iam';
1
3
  import * as sec from 'aws-cdk-lib/aws-secretsmanager';
2
4
  import * as constructs from 'constructs';
3
5
  /**
4
6
  * A custom resource that resolves the secret ARN based on the organization ID.
5
7
  */
6
- export declare class DatadogSharedSecret extends constructs.Construct {
8
+ export declare class DatadogSharedSecret extends constructs.Construct implements sec.ISecret {
7
9
  /**
8
10
  * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.
9
11
  */
@@ -13,7 +15,22 @@ export declare class DatadogSharedSecret extends constructs.Construct {
13
15
  */
14
16
  static credentialsSecret(scope: constructs.Construct, id: string): DatadogSharedSecret;
15
17
  private static setupCustomResource;
16
- readonly secret: sec.ISecret;
18
+ private secret;
17
19
  private customResource;
18
20
  private constructor();
21
+ get stack(): cdk.Stack;
22
+ get env(): cdk.ResourceEnvironment;
23
+ get encryptionKey(): cdk.aws_kms.IKey | undefined;
24
+ get secretArn(): string;
25
+ get secretFullArn(): string | undefined;
26
+ get secretName(): string;
27
+ get secretValue(): cdk.SecretValue;
28
+ secretValueFromJson(key: string): cdk.SecretValue;
29
+ grantRead(grantee: iam.IGrantable, versionStages?: string[]): iam.Grant;
30
+ grantWrite(_grantee: iam.IGrantable): iam.Grant;
31
+ addRotationSchedule(_id: string, _options: sec.RotationScheduleOptions): sec.RotationSchedule;
32
+ addToResourcePolicy(_statement: iam.PolicyStatement): iam.AddToResourcePolicyResult;
33
+ denyAccountRootDelete(): void;
34
+ attach(_target: sec.ISecretAttachmentTarget): sec.ISecret;
35
+ applyRemovalPolicy(_policy: cdk.RemovalPolicy): void;
19
36
  }
@@ -79,8 +79,66 @@ class DatadogSharedSecret extends constructs.Construct {
79
79
  });
80
80
  this.secret = sec.Secret.fromSecretCompleteArn(this, 'Resource', secretLocator.getAtt('SecretArn').toString());
81
81
  }
82
+ get stack() {
83
+ return this.secret.stack;
84
+ }
85
+ get env() {
86
+ return this.secret.env;
87
+ }
88
+ get encryptionKey() {
89
+ return undefined;
90
+ }
91
+ get secretArn() {
92
+ return this.secret.secretArn;
93
+ }
94
+ ;
95
+ get secretFullArn() {
96
+ return this.secret.secretFullArn;
97
+ }
98
+ get secretName() {
99
+ return this.secret.secretName;
100
+ }
101
+ get secretValue() {
102
+ return this.secret.secretValue;
103
+ }
104
+ secretValueFromJson(key) {
105
+ return this.secret.secretValueFromJson(key);
106
+ }
107
+ grantRead(grantee, versionStages) {
108
+ const result = grantee.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({
109
+ actions: ['kms:Decrypt'],
110
+ resources: [`arn:aws:kms:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:key/*`],
111
+ conditions: {
112
+ 'ForAnyValue:StringLike': {
113
+ 'kms:ResourceAliases': 'alias/datadog-integration-shared-credentials-key',
114
+ },
115
+ },
116
+ }));
117
+ if (!result.statementAdded) {
118
+ cdk.Annotations.of(this).addWarning('Could not add statement to the principal policy.');
119
+ }
120
+ return this.secret.grantRead(grantee, versionStages);
121
+ }
122
+ grantWrite(_grantee) {
123
+ throw new Error('Method not allowed.');
124
+ }
125
+ addRotationSchedule(_id, _options) {
126
+ throw new Error('Method not allowed.');
127
+ }
128
+ addToResourcePolicy(_statement) {
129
+ throw new Error('Method not allowed.');
130
+ }
131
+ denyAccountRootDelete() {
132
+ throw new Error('Method not allowed.');
133
+ }
134
+ attach(_target) {
135
+ throw new Error('Method not allowed.');
136
+ }
137
+ applyRemovalPolicy(_policy) {
138
+ throw new Error('Method not allowed.');
139
+ }
82
140
  }
83
141
  exports.DatadogSharedSecret = DatadogSharedSecret;
84
142
  _a = JSII_RTTI_SYMBOL_1;
85
143
  DatadogSharedSecret[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret", version: "0.0.0" };
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-shared-secrets.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-shared-secrets.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\n\n// import * as cr from 'aws-cdk-lib/custom-resources';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as sec from 'aws-cdk-lib/aws-secretsmanager';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport * as constructs from 'constructs';\n\n\nconst EU_LANDING_ZONE_ORG_ID: string = 'o-r5jfl7mbr9';\nconst LATAM_LANDING_ZONE_ORG_ID: string = 'o-5j12ut524w';\n\nconst DEVELOPER_TOOLS_ACCOUNT_ID: string = '577146897785';\n\nconst SHARED_LATAM_SECRET_ARN_PREFIX = `arn:aws:secretsmanager:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/latam`;\nconst SHARED_EU_SECRET_ARN_PREFIX = `arn:aws:secretsmanager:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/eu`;\n\nconst RESOURCE_ID = '__OrgCredentialsSecret__';\n\n/**\n * A custom resource that resolves the secret ARN based on the organization ID.\n */\nexport class DatadogSharedSecret extends constructs.Construct {\n\n  /**\n   * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.\n   */\n  static apiKeySecret(scope: constructs.Construct, id: string) {\n    return new DatadogSharedSecret(scope, id, { secretName: 'shared-api-key' });\n  }\n\n  /**\n   * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].\n   */\n  static credentialsSecret(scope: constructs.Construct, id: string) {\n    return new DatadogSharedSecret(scope, id, { secretName: 'shared-credentials' });\n  }\n\n  private static setupCustomResource(stack: cdk.Stack): cr.Provider {\n    const secretLocatorLambda = new lambda.Function(stack, 'ResolveSecretArnHandler', {\n      code: lambda.Code.fromAsset(path.join(__dirname, 'secret-locator-custom-resource'), {\n        exclude: ['*.js', '*.d.ts'],\n      }),\n      handler: 'on-create.handler',\n      runtime: lambda.Runtime.NODEJS_20_X,\n      architecture: lambda.Architecture.ARM_64,\n      logGroup: new logs.LogGroup(stack, 'DatadogSharedSecretHandlerLogGroup', {\n        retention: logs.RetentionDays.ONE_WEEK,\n      }),\n      environment: {\n        SHARED_LATAM_SECRET_ARN_PREFIX: SHARED_LATAM_SECRET_ARN_PREFIX,\n        SHARED_EU_SECRET_ARN_PREFIX: SHARED_EU_SECRET_ARN_PREFIX,\n        LATAM_LANDING_ZONE_ORG_ID: LATAM_LANDING_ZONE_ORG_ID,\n        EU_LANDING_ZONE_ORG_ID: EU_LANDING_ZONE_ORG_ID,\n      },\n    });\n\n    secretLocatorLambda.addToRolePolicy(new iam.PolicyStatement({ actions: ['organizations:DescribeOrganization'], resources: ['*'] }));\n    secretLocatorLambda.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: ['secretsmanager:DescribeSecret'],\n        resources: [`arn:aws:secretsmanager:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:*`],\n      }),\n    );\n\n    return new cr.Provider(stack, RESOURCE_ID, {\n      onEventHandler: secretLocatorLambda,\n    });\n  }\n\n  readonly secret: sec.ISecret;\n\n  private customResource: cr.Provider;\n\n  private constructor(scope: constructs.IConstruct, id: string, props: {secretName: string}) {\n    super(scope, id);\n\n    const stack = cdk.Stack.of(this);\n    if (!stack.node.tryFindChild(RESOURCE_ID)) {\n      this.customResource = DatadogSharedSecret.setupCustomResource(stack);\n    } else {\n      this.customResource = stack.node.findChild(RESOURCE_ID) as cr.Provider;\n    }\n\n    const secretLocator = new cdk.CustomResource(this, 'DatadogSharedSecret', {\n      serviceToken: this.customResource.serviceToken,\n      pascalCaseProperties: true,\n      properties: {\n        secretName: props.secretName,\n      },\n    });\n\n    this.secret = sec.Secret.fromSecretCompleteArn(this, 'Resource', secretLocator.getAtt('SecretArn').toString());\n  }\n\n}\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-shared-secrets.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-shared-secrets.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\n\n// import * as cr from 'aws-cdk-lib/custom-resources';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as sec from 'aws-cdk-lib/aws-secretsmanager';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport * as constructs from 'constructs';\n\n\nconst EU_LANDING_ZONE_ORG_ID: string = 'o-r5jfl7mbr9';\nconst LATAM_LANDING_ZONE_ORG_ID: string = 'o-5j12ut524w';\n\nconst DEVELOPER_TOOLS_ACCOUNT_ID: string = '577146897785';\n\nconst SHARED_LATAM_SECRET_ARN_PREFIX = `arn:aws:secretsmanager:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/latam`;\nconst SHARED_EU_SECRET_ARN_PREFIX = `arn:aws:secretsmanager:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/eu`;\n\nconst RESOURCE_ID = '__OrgCredentialsSecret__';\n\n/**\n * A custom resource that resolves the secret ARN based on the organization ID.\n */\nexport class DatadogSharedSecret extends constructs.Construct implements sec.ISecret {\n\n  /**\n   * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.\n   */\n  static apiKeySecret(scope: constructs.Construct, id: string) {\n    return new DatadogSharedSecret(scope, id, { secretName: 'shared-api-key' });\n  }\n\n  /**\n   * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].\n   */\n  static credentialsSecret(scope: constructs.Construct, id: string) {\n    return new DatadogSharedSecret(scope, id, { secretName: 'shared-credentials' });\n  }\n\n  private static setupCustomResource(stack: cdk.Stack): cr.Provider {\n    const secretLocatorLambda = new lambda.Function(stack, 'ResolveSecretArnHandler', {\n      code: lambda.Code.fromAsset(path.join(__dirname, 'secret-locator-custom-resource'), {\n        exclude: ['*.js', '*.d.ts'],\n      }),\n      handler: 'on-create.handler',\n      runtime: lambda.Runtime.NODEJS_20_X,\n      architecture: lambda.Architecture.ARM_64,\n      logGroup: new logs.LogGroup(stack, 'DatadogSharedSecretHandlerLogGroup', {\n        retention: logs.RetentionDays.ONE_WEEK,\n      }),\n      environment: {\n        SHARED_LATAM_SECRET_ARN_PREFIX: SHARED_LATAM_SECRET_ARN_PREFIX,\n        SHARED_EU_SECRET_ARN_PREFIX: SHARED_EU_SECRET_ARN_PREFIX,\n        LATAM_LANDING_ZONE_ORG_ID: LATAM_LANDING_ZONE_ORG_ID,\n        EU_LANDING_ZONE_ORG_ID: EU_LANDING_ZONE_ORG_ID,\n      },\n    });\n\n    secretLocatorLambda.addToRolePolicy(new iam.PolicyStatement({ actions: ['organizations:DescribeOrganization'], resources: ['*'] }));\n    secretLocatorLambda.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: ['secretsmanager:DescribeSecret'],\n        resources: [`arn:aws:secretsmanager:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:*`],\n      }),\n    );\n\n    return new cr.Provider(stack, RESOURCE_ID, {\n      onEventHandler: secretLocatorLambda,\n    });\n  }\n\n  private secret: sec.ISecret;\n  private customResource: cr.Provider;\n\n  private constructor(scope: constructs.IConstruct, id: string, props: {secretName: string}) {\n    super(scope, id);\n\n    const stack = cdk.Stack.of(this);\n    if (!stack.node.tryFindChild(RESOURCE_ID)) {\n      this.customResource = DatadogSharedSecret.setupCustomResource(stack);\n    } else {\n      this.customResource = stack.node.findChild(RESOURCE_ID) as cr.Provider;\n    }\n\n    const secretLocator = new cdk.CustomResource(this, 'DatadogSharedSecret', {\n      serviceToken: this.customResource.serviceToken,\n      pascalCaseProperties: true,\n      properties: {\n        secretName: props.secretName,\n      },\n    });\n\n    this.secret = sec.Secret.fromSecretCompleteArn(this, 'Resource', secretLocator.getAtt('SecretArn').toString());\n  }\n\n  get stack(): cdk.Stack {\n    return this.secret.stack;\n  }\n\n  get env(): cdk.ResourceEnvironment {\n    return this.secret.env;\n  }\n\n  get encryptionKey() : cdk.aws_kms.IKey | undefined {\n    return undefined;\n  }\n\n  get secretArn(): string {\n    return this.secret.secretArn;\n  };\n\n  get secretFullArn(): string | undefined {\n    return this.secret.secretFullArn;\n  }\n\n  get secretName(): string {\n    return this.secret.secretName;\n  }\n\n  get secretValue(): cdk.SecretValue {\n    return this.secret.secretValue;\n  }\n\n  secretValueFromJson(key: string): cdk.SecretValue {\n    return this.secret.secretValueFromJson(key);\n  }\n\n  grantRead(grantee: iam.IGrantable, versionStages?: string[]): iam.Grant {\n    const result = grantee.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['kms:Decrypt'],\n      resources: [`arn:aws:kms:eu-west-1:${DEVELOPER_TOOLS_ACCOUNT_ID}:key/*`],\n      conditions: {\n        'ForAnyValue:StringLike': {\n          'kms:ResourceAliases': 'alias/datadog-integration-shared-credentials-key',\n        },\n      },\n    }));\n    if (!result.statementAdded) {\n      cdk.Annotations.of(this).addWarning('Could not add statement to the principal policy.');\n    }\n    return this.secret.grantRead(grantee, versionStages);\n  }\n\n  grantWrite(_grantee: iam.IGrantable): iam.Grant {\n    throw new Error('Method not allowed.');\n  }\n\n  addRotationSchedule(_id: string, _options: sec.RotationScheduleOptions): sec.RotationSchedule {\n    throw new Error('Method not allowed.');\n  }\n\n  addToResourcePolicy(_statement: iam.PolicyStatement): iam.AddToResourcePolicyResult {\n    throw new Error('Method not allowed.');\n  }\n\n  denyAccountRootDelete(): void {\n    throw new Error('Method not allowed.');\n  }\n\n  attach(_target: sec.ISecretAttachmentTarget): sec.ISecret {\n    throw new Error('Method not allowed.');\n  }\n\n  applyRemovalPolicy(_policy: cdk.RemovalPolicy): void {\n    throw new Error('Method not allowed.');\n  }\n\n}\n"]}
package/package.json CHANGED
@@ -15,7 +15,7 @@
15
15
  ],
16
16
  "main": "lib/index.js",
17
17
  "license": "Apache-2.0",
18
- "version": "6.12.1",
18
+ "version": "6.12.2",
19
19
  "types": "lib/index.d.ts",
20
20
  "stability": "stable",
21
21
  "exports": {
@@ -92,8 +92,8 @@
92
92
  "@types/aws-lambda": "^8.10.145"
93
93
  },
94
94
  "peerDependencies": {
95
- "aws-cdk-lib": "^2.161.1",
96
- "constructs": "^10.3.0"
95
+ "aws-cdk-lib": "^2.163.0",
96
+ "constructs": "^10.4.2"
97
97
  },
98
98
  "dependencies": {
99
99
  "@aws-sdk/client-cloudformation": "^3.675.0",
package/version.json CHANGED
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": "6.12.1"
2
+ "version": "6.12.2"
3
3
  }