@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 +320 -10
- package/docs/API.md +242 -4
- package/docs/changelog.md +7 -0
- package/lib/datadogv2/datadog-lambda-instrumentation.js +3 -4
- package/lib/datadogv2/datadog-shared-secrets.d.ts +19 -2
- package/lib/datadogv2/datadog-shared-secrets.js +59 -1
- package/package.json +3 -3
- package/version.json +1 -1
package/.jsii
CHANGED
|
@@ -19,8 +19,8 @@
|
|
|
19
19
|
"js-yaml": "~4.1.0"
|
|
20
20
|
},
|
|
21
21
|
"dependencies": {
|
|
22
|
-
"aws-cdk-lib": "^2.
|
|
23
|
-
"constructs": "^10.
|
|
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":
|
|
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":
|
|
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":
|
|
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
|
-
"
|
|
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":
|
|
16205
|
+
"line": 102
|
|
15999
16206
|
},
|
|
16000
|
-
"name": "
|
|
16207
|
+
"name": "env",
|
|
16208
|
+
"overrides": "aws-cdk-lib.IResource",
|
|
16001
16209
|
"type": {
|
|
16002
|
-
"fqn": "aws-cdk-lib.
|
|
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": "
|
|
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.
|
|
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
|
-
##### `
|
|
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
|
|
2260
|
+
public readonly env: ResourceEnvironment;
|
|
2115
2261
|
```
|
|
2116
2262
|
|
|
2117
|
-
- *Type:* aws-cdk-lib.
|
|
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
|
-
|
|
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.
|
|
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,
|
|
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
|
-
|
|
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.
|
|
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.
|
|
96
|
-
"constructs": "^10.
|
|
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