@rio-cloud/cdk-v2-constructs 7.6.0 → 7.8.1-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/docs/API.md CHANGED
@@ -1728,8 +1728,7 @@ Per default, it will disable all additional features, that cause Datadog chargin
1728
1728
  So just change it, if you need the advanced features.
1729
1729
 
1730
1730
  Additionally, some defaults from the datadog-integration account module are applied:
1731
- - the secret for the API key is read from the secret manager `/rio/config/datadog-integration/api-key`
1732
- - the site is read from the parameter store `/rio/config/datadog-integration/site`
1731
+ - the secret and site for the API key is read from a shared secret in rio-developer-tools account
1733
1732
 
1734
1733
  To use it, install Datadog CDK Constructs package:
1735
1734
  ```bash
@@ -2818,11 +2817,456 @@ The tree node.
2818
2817
  ---
2819
2818
 
2820
2819
 
2820
+ ### DatadogSharedCredentials <a name="DatadogSharedCredentials" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials"></a>
2821
+
2822
+ - *Implements:* aws-cdk-lib.aws_secretsmanager.ISecret
2823
+
2824
+ #### Initializers <a name="Initializers" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.Initializer"></a>
2825
+
2826
+ ```typescript
2827
+ import { datadogv2 } from '@rio-cloud/cdk-v2-constructs'
2828
+
2829
+ new datadogv2.DatadogSharedCredentials(scope: IConstruct, id: string, secretName: string)
2830
+ ```
2831
+
2832
+ | **Name** | **Type** | **Description** |
2833
+ | --- | --- | --- |
2834
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.Initializer.parameter.scope">scope</a></code> | <code>constructs.IConstruct</code> | *No description.* |
2835
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.Initializer.parameter.id">id</a></code> | <code>string</code> | *No description.* |
2836
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.Initializer.parameter.secretName">secretName</a></code> | <code>string</code> | The name of the secret. |
2837
+
2838
+ ---
2839
+
2840
+ ##### `scope`<sup>Required</sup> <a name="scope" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.Initializer.parameter.scope"></a>
2841
+
2842
+ - *Type:* constructs.IConstruct
2843
+
2844
+ ---
2845
+
2846
+ ##### `id`<sup>Required</sup> <a name="id" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.Initializer.parameter.id"></a>
2847
+
2848
+ - *Type:* string
2849
+
2850
+ ---
2851
+
2852
+ ##### `secretName`<sup>Required</sup> <a name="secretName" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.Initializer.parameter.secretName"></a>
2853
+
2854
+ - *Type:* string
2855
+
2856
+ The name of the secret.
2857
+
2858
+ For "owned" secrets, this will be the full resource name (secret name + suffix), unless the
2859
+ '@aws-cdk/aws-secretsmanager:parseOwnedSecretName' feature flag is set.
2860
+
2861
+ ---
2862
+
2863
+ #### Methods <a name="Methods" id="Methods"></a>
2864
+
2865
+ | **Name** | **Description** |
2866
+ | --- | --- |
2867
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.toString">toString</a></code> | Returns a string representation of this construct. |
2868
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.addRotationSchedule">addRotationSchedule</a></code> | Adds a rotation schedule to the secret. |
2869
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.addToResourcePolicy">addToResourcePolicy</a></code> | Adds a statement to the IAM resource policy associated with this secret. |
2870
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.applyRemovalPolicy">applyRemovalPolicy</a></code> | Apply the given removal policy to this resource. |
2871
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.attach">attach</a></code> | Attach a target to this secret. |
2872
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.denyAccountRootDelete">denyAccountRootDelete</a></code> | Denies the `DeleteSecret` action to all principals within the current account. |
2873
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.getSecret">getSecret</a></code> | *No description.* |
2874
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.getSecretValue">getSecretValue</a></code> | *No description.* |
2875
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.grantRead">grantRead</a></code> | Grants reading the secret value to some role. |
2876
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.grantWrite">grantWrite</a></code> | Grants writing and updating the secret value to some role. |
2877
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.secretValueFromJson">secretValueFromJson</a></code> | Interpret the secret as a JSON object and return a field's value from it as a `SecretValue`. |
2878
+
2879
+ ---
2880
+
2881
+ ##### `toString` <a name="toString" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.toString"></a>
2882
+
2883
+ ```typescript
2884
+ public toString(): string
2885
+ ```
2886
+
2887
+ Returns a string representation of this construct.
2888
+
2889
+ ##### `addRotationSchedule` <a name="addRotationSchedule" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.addRotationSchedule"></a>
2890
+
2891
+ ```typescript
2892
+ public addRotationSchedule(_id: string, _options: RotationScheduleOptions): RotationSchedule
2893
+ ```
2894
+
2895
+ Adds a rotation schedule to the secret.
2896
+
2897
+ ###### `_id`<sup>Required</sup> <a name="_id" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.addRotationSchedule.parameter._id"></a>
2898
+
2899
+ - *Type:* string
2900
+
2901
+ ---
2902
+
2903
+ ###### `_options`<sup>Required</sup> <a name="_options" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.addRotationSchedule.parameter._options"></a>
2904
+
2905
+ - *Type:* aws-cdk-lib.aws_secretsmanager.RotationScheduleOptions
2906
+
2907
+ ---
2908
+
2909
+ ##### `addToResourcePolicy` <a name="addToResourcePolicy" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.addToResourcePolicy"></a>
2910
+
2911
+ ```typescript
2912
+ public addToResourcePolicy(_statement: PolicyStatement): AddToResourcePolicyResult
2913
+ ```
2914
+
2915
+ Adds a statement to the IAM resource policy associated with this secret.
2916
+
2917
+ If this secret was created in this stack, a resource policy will be
2918
+ automatically created upon the first call to `addToResourcePolicy`. If
2919
+ the secret is imported, then this is a no-op.
2920
+
2921
+ ###### `_statement`<sup>Required</sup> <a name="_statement" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.addToResourcePolicy.parameter._statement"></a>
2922
+
2923
+ - *Type:* aws-cdk-lib.aws_iam.PolicyStatement
2924
+
2925
+ ---
2926
+
2927
+ ##### `applyRemovalPolicy` <a name="applyRemovalPolicy" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.applyRemovalPolicy"></a>
2928
+
2929
+ ```typescript
2930
+ public applyRemovalPolicy(_policy: RemovalPolicy): void
2931
+ ```
2932
+
2933
+ Apply the given removal policy to this resource.
2934
+
2935
+ The Removal Policy controls what happens to this resource when it stops
2936
+ being managed by CloudFormation, either because you've removed it from the
2937
+ CDK application or because you've made a change that requires the resource
2938
+ to be replaced.
2939
+
2940
+ The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
2941
+ account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
2942
+
2943
+ ###### `_policy`<sup>Required</sup> <a name="_policy" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.applyRemovalPolicy.parameter._policy"></a>
2944
+
2945
+ - *Type:* aws-cdk-lib.RemovalPolicy
2946
+
2947
+ ---
2948
+
2949
+ ##### `attach` <a name="attach" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.attach"></a>
2950
+
2951
+ ```typescript
2952
+ public attach(_target: ISecretAttachmentTarget): ISecret
2953
+ ```
2954
+
2955
+ Attach a target to this secret.
2956
+
2957
+ ###### `_target`<sup>Required</sup> <a name="_target" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.attach.parameter._target"></a>
2958
+
2959
+ - *Type:* aws-cdk-lib.aws_secretsmanager.ISecretAttachmentTarget
2960
+
2961
+ ---
2962
+
2963
+ ##### `denyAccountRootDelete` <a name="denyAccountRootDelete" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.denyAccountRootDelete"></a>
2964
+
2965
+ ```typescript
2966
+ public denyAccountRootDelete(): void
2967
+ ```
2968
+
2969
+ Denies the `DeleteSecret` action to all principals within the current account.
2970
+
2971
+ ##### `getSecret` <a name="getSecret" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.getSecret"></a>
2972
+
2973
+ ```typescript
2974
+ public getSecret(field: string): Secret
2975
+ ```
2976
+
2977
+ ###### `field`<sup>Required</sup> <a name="field" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.getSecret.parameter.field"></a>
2978
+
2979
+ - *Type:* string
2980
+
2981
+ ---
2982
+
2983
+ ##### `getSecretValue` <a name="getSecretValue" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.getSecretValue"></a>
2984
+
2985
+ ```typescript
2986
+ public getSecretValue(field: string): SecretValue
2987
+ ```
2988
+
2989
+ ###### `field`<sup>Required</sup> <a name="field" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.getSecretValue.parameter.field"></a>
2990
+
2991
+ - *Type:* string
2992
+
2993
+ ---
2994
+
2995
+ ##### `grantRead` <a name="grantRead" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.grantRead"></a>
2996
+
2997
+ ```typescript
2998
+ public grantRead(grantee: IGrantable, versionStages?: string[]): Grant
2999
+ ```
3000
+
3001
+ Grants reading the secret value to some role.
3002
+
3003
+ ###### `grantee`<sup>Required</sup> <a name="grantee" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.grantRead.parameter.grantee"></a>
3004
+
3005
+ - *Type:* aws-cdk-lib.aws_iam.IGrantable
3006
+
3007
+ ---
3008
+
3009
+ ###### `versionStages`<sup>Optional</sup> <a name="versionStages" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.grantRead.parameter.versionStages"></a>
3010
+
3011
+ - *Type:* string[]
3012
+
3013
+ ---
3014
+
3015
+ ##### `grantWrite` <a name="grantWrite" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.grantWrite"></a>
3016
+
3017
+ ```typescript
3018
+ public grantWrite(_grantee: IGrantable): Grant
3019
+ ```
3020
+
3021
+ Grants writing and updating the secret value to some role.
3022
+
3023
+ ###### `_grantee`<sup>Required</sup> <a name="_grantee" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.grantWrite.parameter._grantee"></a>
3024
+
3025
+ - *Type:* aws-cdk-lib.aws_iam.IGrantable
3026
+
3027
+ ---
3028
+
3029
+ ##### `secretValueFromJson` <a name="secretValueFromJson" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.secretValueFromJson"></a>
3030
+
3031
+ ```typescript
3032
+ public secretValueFromJson(key: string): SecretValue
3033
+ ```
3034
+
3035
+ Interpret the secret as a JSON object and return a field's value from it as a `SecretValue`.
3036
+
3037
+ ###### `key`<sup>Required</sup> <a name="key" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.secretValueFromJson.parameter.key"></a>
3038
+
3039
+ - *Type:* string
3040
+
3041
+ ---
3042
+
3043
+ #### Static Functions <a name="Static Functions" id="Static Functions"></a>
3044
+
3045
+ | **Name** | **Description** |
3046
+ | --- | --- |
3047
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.isConstruct">isConstruct</a></code> | Checks if `x` is a construct. |
3048
+
3049
+ ---
3050
+
3051
+ ##### `isConstruct` <a name="isConstruct" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.isConstruct"></a>
3052
+
3053
+ ```typescript
3054
+ import { datadogv2 } from '@rio-cloud/cdk-v2-constructs'
3055
+
3056
+ datadogv2.DatadogSharedCredentials.isConstruct(x: any)
3057
+ ```
3058
+
3059
+ Checks if `x` is a construct.
3060
+
3061
+ Use this method instead of `instanceof` to properly detect `Construct`
3062
+ instances, even when the construct library is symlinked.
3063
+
3064
+ Explanation: in JavaScript, multiple copies of the `constructs` library on
3065
+ disk are seen as independent, completely different libraries. As a
3066
+ consequence, the class `Construct` in each copy of the `constructs` library
3067
+ is seen as a different class, and an instance of one class will not test as
3068
+ `instanceof` the other class. `npm install` will not create installations
3069
+ like this, but users may manually symlink construct libraries together or
3070
+ use a monorepo tool: in those cases, multiple copies of the `constructs`
3071
+ library can be accidentally installed, and `instanceof` will behave
3072
+ unpredictably. It is safest to avoid using `instanceof`, and using
3073
+ this type-testing method instead.
3074
+
3075
+ ###### `x`<sup>Required</sup> <a name="x" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.isConstruct.parameter.x"></a>
3076
+
3077
+ - *Type:* any
3078
+
3079
+ Any object.
3080
+
3081
+ ---
3082
+
3083
+ #### Properties <a name="Properties" id="Properties"></a>
3084
+
3085
+ | **Name** | **Type** | **Description** |
3086
+ | --- | --- | --- |
3087
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.node">node</a></code> | <code>constructs.Node</code> | The tree node. |
3088
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.env">env</a></code> | <code>aws-cdk-lib.ResourceEnvironment</code> | The environment this resource belongs to. |
3089
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.secretArn">secretArn</a></code> | <code>string</code> | The ARN of the secret in AWS Secrets Manager. |
3090
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.secretName">secretName</a></code> | <code>string</code> | The name of the secret. |
3091
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.secretValue">secretValue</a></code> | <code>aws-cdk-lib.SecretValue</code> | Retrieve the value of the stored secret as a `SecretValue`. |
3092
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.stack">stack</a></code> | <code>aws-cdk-lib.Stack</code> | The stack in which this resource is defined. |
3093
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.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. |
3094
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.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. |
3095
+
3096
+ ---
3097
+
3098
+ ##### `node`<sup>Required</sup> <a name="node" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.node"></a>
3099
+
3100
+ ```typescript
3101
+ public readonly node: Node;
3102
+ ```
3103
+
3104
+ - *Type:* constructs.Node
3105
+
3106
+ The tree node.
3107
+
3108
+ ---
3109
+
3110
+ ##### `env`<sup>Required</sup> <a name="env" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.env"></a>
3111
+
3112
+ ```typescript
3113
+ public readonly env: ResourceEnvironment;
3114
+ ```
3115
+
3116
+ - *Type:* aws-cdk-lib.ResourceEnvironment
3117
+
3118
+ The environment this resource belongs to.
3119
+
3120
+ For resources that are created and managed by the CDK
3121
+ (generally, those created by creating new class instances like Role, Bucket, etc.),
3122
+ this is always the same as the environment of the stack they belong to;
3123
+ however, for imported resources
3124
+ (those obtained from static methods like fromRoleArn, fromBucketName, etc.),
3125
+ that might be different than the stack they were imported into.
3126
+
3127
+ ---
3128
+
3129
+ ##### `secretArn`<sup>Required</sup> <a name="secretArn" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.secretArn"></a>
3130
+
3131
+ ```typescript
3132
+ public readonly secretArn: string;
3133
+ ```
3134
+
3135
+ - *Type:* string
3136
+
3137
+ The ARN of the secret in AWS Secrets Manager.
3138
+
3139
+ Will return the full ARN if available, otherwise a partial arn.
3140
+ For secrets imported by the deprecated `fromSecretName`, it will return the `secretName`.
3141
+
3142
+ ---
3143
+
3144
+ ##### `secretName`<sup>Required</sup> <a name="secretName" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.secretName"></a>
3145
+
3146
+ ```typescript
3147
+ public readonly secretName: string;
3148
+ ```
3149
+
3150
+ - *Type:* string
3151
+
3152
+ The name of the secret.
3153
+
3154
+ For "owned" secrets, this will be the full resource name (secret name + suffix), unless the
3155
+ '@aws-cdk/aws-secretsmanager:parseOwnedSecretName' feature flag is set.
3156
+
3157
+ ---
3158
+
3159
+ ##### `secretValue`<sup>Required</sup> <a name="secretValue" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.secretValue"></a>
3160
+
3161
+ ```typescript
3162
+ public readonly secretValue: SecretValue;
3163
+ ```
3164
+
3165
+ - *Type:* aws-cdk-lib.SecretValue
3166
+
3167
+ Retrieve the value of the stored secret as a `SecretValue`.
3168
+
3169
+ ---
3170
+
3171
+ ##### `stack`<sup>Required</sup> <a name="stack" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.stack"></a>
3172
+
3173
+ ```typescript
3174
+ public readonly stack: Stack;
3175
+ ```
3176
+
3177
+ - *Type:* aws-cdk-lib.Stack
3178
+
3179
+ The stack in which this resource is defined.
3180
+
3181
+ ---
3182
+
3183
+ ##### `encryptionKey`<sup>Optional</sup> <a name="encryptionKey" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.encryptionKey"></a>
3184
+
3185
+ ```typescript
3186
+ public readonly encryptionKey: IKey;
3187
+ ```
3188
+
3189
+ - *Type:* aws-cdk-lib.aws_kms.IKey
3190
+
3191
+ The customer-managed encryption key that is used to encrypt this secret, if any.
3192
+
3193
+ When not specified, the default
3194
+ KMS key for the account and region is being used.
3195
+
3196
+ ---
3197
+
3198
+ ##### `secretFullArn`<sup>Optional</sup> <a name="secretFullArn" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials.property.secretFullArn"></a>
3199
+
3200
+ ```typescript
3201
+ public readonly secretFullArn: string;
3202
+ ```
3203
+
3204
+ - *Type:* string
3205
+
3206
+ The full ARN of the secret in AWS Secrets Manager, which is the ARN including the Secrets Manager-supplied 6-character suffix.
3207
+
3208
+ This is equal to `secretArn` in most cases, but is undefined when a full ARN is not available (e.g., secrets imported by name).
3209
+
3210
+ ---
3211
+
3212
+
2821
3213
  ### DatadogSharedSecret <a name="DatadogSharedSecret" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret"></a>
2822
3214
 
2823
3215
  - *Implements:* aws-cdk-lib.aws_secretsmanager.ISecret
2824
3216
 
2825
- A custom resource that resolves the secret ARN based on the organization ID.
3217
+ A custom resource that resolves the Datadog API keys from a shared secret.
3218
+
3219
+ *Example*
3220
+
3221
+ ```typescript
3222
+ const datadogApiKey = DatadogSharedSecret.apiKeySecret(this);
3223
+
3224
+ const datadogSecret = DatadogSharedSecret.credentialsSecret(this);
3225
+ const datadogSite = datadogSecret.getSecret('Site');
3226
+ const datadogApiKey = datadogSecret.getSecret('ApiKey');
3227
+ const datadogApiKeyValue = datadogSecret.getSecretValue('ApiKey');
3228
+ const datadogApiKeyValue = datadogSecret.getSecretValue('ApplicationKey');
3229
+ ```
3230
+
3231
+
3232
+ #### Initializers <a name="Initializers" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.Initializer"></a>
3233
+
3234
+ ```typescript
3235
+ import { datadogv2 } from '@rio-cloud/cdk-v2-constructs'
3236
+
3237
+ new datadogv2.DatadogSharedSecret(scope: IConstruct, id: string, secretName: string)
3238
+ ```
3239
+
3240
+ | **Name** | **Type** | **Description** |
3241
+ | --- | --- | --- |
3242
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.Initializer.parameter.scope">scope</a></code> | <code>constructs.IConstruct</code> | *No description.* |
3243
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.Initializer.parameter.id">id</a></code> | <code>string</code> | *No description.* |
3244
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.Initializer.parameter.secretName">secretName</a></code> | <code>string</code> | The name of the secret. |
3245
+
3246
+ ---
3247
+
3248
+ ##### `scope`<sup>Required</sup> <a name="scope" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.Initializer.parameter.scope"></a>
3249
+
3250
+ - *Type:* constructs.IConstruct
3251
+
3252
+ ---
3253
+
3254
+ ##### `id`<sup>Required</sup> <a name="id" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.Initializer.parameter.id"></a>
3255
+
3256
+ - *Type:* string
3257
+
3258
+ ---
3259
+
3260
+ ##### `secretName`<sup>Required</sup> <a name="secretName" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret.Initializer.parameter.secretName"></a>
3261
+
3262
+ - *Type:* string
3263
+
3264
+ The name of the secret.
3265
+
3266
+ For "owned" secrets, this will be the full resource name (secret name + suffix), unless the
3267
+ '@aws-cdk/aws-secretsmanager:parseOwnedSecretName' feature flag is set.
3268
+
3269
+ ---
2826
3270
 
2827
3271
  #### Methods <a name="Methods" id="Methods"></a>
2828
3272
 
package/docs/changelog.md CHANGED
@@ -2,6 +2,26 @@
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
+ ## [7.8.1-alpha.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv7.8.0&sourceBranch=refs%2Ftags%2Fv7.8.1-alpha.0) (2025-08-05)
6
+
7
+ ## [7.8.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv7.7.1&sourceBranch=refs%2Ftags%2Fv7.8.0) (2025-07-31)
8
+
9
+
10
+ ### Features
11
+
12
+ * returning string (instead of unsafeUnwrapped string) from datadog secret for better security ([5a06162](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/5a061622622526e1c82a1fa7e0e089cabc0c6f2e))
13
+
14
+ ## [7.7.1](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv7.7.0&sourceBranch=refs%2Ftags%2Fv7.7.1) (2025-07-30)
15
+
16
+ ## [7.7.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv7.7.0-alpha.0&sourceBranch=refs%2Ftags%2Fv7.7.0) (2025-07-30)
17
+
18
+ ## [7.7.0-alpha.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv7.6.0&sourceBranch=refs%2Ftags%2Fv7.7.0-alpha.0) (2025-07-30)
19
+
20
+
21
+ ### Features
22
+
23
+ * using shared datadog secret instead of ssm parameter in rio-fargate-service ([e376e3e](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/e376e3e7cf5367e0de63180b1c0c7b42d6a5fbdd))
24
+
5
25
  ## [7.6.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv7.5.4&sourceBranch=refs%2Ftags%2Fv7.6.0) (2025-07-24)
6
26
 
7
27
 
@@ -62,8 +62,7 @@ export interface DatadogLambdaInstrumentationProps {
62
62
  * So just change it, if you need the advanced features.
63
63
  *
64
64
  * Additionally, some defaults from the datadog-integration account module are applied:
65
- * - the secret for the API key is read from the secret manager `/rio/config/datadog-integration/api-key`
66
- * - the site is read from the parameter store `/rio/config/datadog-integration/site`
65
+ * - the secret and site for the API key is read from a shared secret in rio-developer-tools account
67
66
  *
68
67
  * To use it, install Datadog CDK Constructs package:
69
68
  * ```bash
@@ -73,7 +72,7 @@ export interface DatadogLambdaInstrumentationProps {
73
72
  export declare class DatadogLambdaInstrumentation extends Construct {
74
73
  private delegate;
75
74
  private datadogSecret;
76
- private site;
75
+ private readonly site;
77
76
  private readonly enhancedMetricsEnabled;
78
77
  constructor(scope: Construct, id: string, props: DatadogLambdaInstrumentationProps);
79
78
  addLambdaFunctions(lambdaFunctions: dd.LambdaFunction[], construct?: Construct): void;
@@ -14,8 +14,7 @@ const datadog_shared_secrets_1 = require("./datadog-shared-secrets");
14
14
  * So just change it, if you need the advanced features.
15
15
  *
16
16
  * Additionally, some defaults from the datadog-integration account module are applied:
17
- * - the secret for the API key is read from the secret manager `/rio/config/datadog-integration/api-key`
18
- * - the site is read from the parameter store `/rio/config/datadog-integration/site`
17
+ * - the secret and site for the API key is read from a shared secret in rio-developer-tools account
19
18
  *
20
19
  * To use it, install Datadog CDK Constructs package:
21
20
  * ```bash
@@ -27,7 +26,7 @@ class DatadogLambdaInstrumentation extends constructs_1.Construct {
27
26
  super(scope, id);
28
27
  this.datadogSecret = datadog_shared_secrets_1.DatadogSharedSecret.apiKeySecret(this);
29
28
  const resolvedDatadogSecret = datadog_shared_secrets_1.DatadogSharedSecret.credentialsSecret(this);
30
- this.site = resolvedDatadogSecret.secretValueFromJson('Site').unsafeUnwrap();
29
+ this.site = resolvedDatadogSecret.getSecretValue('Site').unsafeUnwrap();
31
30
  const finalProps = {
32
31
  env: 'prod',
33
32
  apiKeySecretArn: this.datadogSecret.secretArn,
@@ -73,4 +72,4 @@ const getSourceCodeIntegrationDefault = (node) => {
73
72
  const isDisabled = value === 'false' || value === false;
74
73
  return !isDisabled;
75
74
  };
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;AAyD/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,CAAC,CAAC;QAE5D,MAAM,qBAAqB,GAAG,4CAAmB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAC1E,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 * latest version for nodeLayerVersion: https://github.com/DataDog/datadog-lambda-js/releases\n *\n * latest version for extensionLayerVersion: https://github.com/DataDog/datadog-lambda-extension/releases\n *\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);\n\n    const resolvedDatadogSecret = DatadogSharedSecret.credentialsSecret(this);\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"]}
75
+ //# 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;AAyD/D;;;;;;;;;;;;;GAaG;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,CAAC,CAAC;QAE5D,MAAM,qBAAqB,GAAG,4CAAmB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAC1E,IAAI,CAAC,IAAI,GAAG,qBAAqB,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,CAAC;QAExE,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 * latest version for nodeLayerVersion: https://github.com/DataDog/datadog-lambda-js/releases\n *\n * latest version for extensionLayerVersion: https://github.com/DataDog/datadog-lambda-extension/releases\n *\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 and site for the API key is read from a shared secret in rio-developer-tools account\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 readonly 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);\n\n    const resolvedDatadogSecret = DatadogSharedSecret.credentialsSecret(this);\n    this.site = resolvedDatadogSecret.getSecretValue('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"]}
@@ -2,22 +2,11 @@ import * as cdk from 'aws-cdk-lib';
2
2
  import * as iam from 'aws-cdk-lib/aws-iam';
3
3
  import * as sec from 'aws-cdk-lib/aws-secretsmanager';
4
4
  import * as constructs from 'constructs';
5
- /**
6
- * A custom resource that resolves the secret ARN based on the organization ID.
7
- */
8
- export declare class DatadogSharedSecret extends constructs.Construct implements sec.ISecret {
9
- /**
10
- * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.
11
- */
12
- static apiKeySecret(scope: constructs.Construct): DatadogSharedSecret;
13
- /**
14
- * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].
15
- */
16
- static credentialsSecret(scope: constructs.Construct): DatadogSharedSecret;
5
+ declare abstract class SharedSecret extends constructs.Construct implements sec.ISecret {
17
6
  private static setupCustomResource;
18
- private secret;
7
+ protected readonly secret: sec.ISecret;
19
8
  private customResource;
20
- private constructor();
9
+ protected constructor(scope: constructs.IConstruct, id: string, secretName: string);
21
10
  get stack(): cdk.Stack;
22
11
  get env(): cdk.ResourceEnvironment;
23
12
  get encryptionKey(): cdk.aws_kms.IKey | undefined;
@@ -34,3 +23,30 @@ export declare class DatadogSharedSecret extends constructs.Construct implements
34
23
  attach(_target: sec.ISecretAttachmentTarget): sec.ISecret;
35
24
  applyRemovalPolicy(_policy: cdk.RemovalPolicy): void;
36
25
  }
26
+ /**
27
+ * A custom resource that resolves the Datadog API keys from a shared secret
28
+ * @example
29
+ * const datadogApiKey = DatadogSharedSecret.apiKeySecret(this);
30
+ *
31
+ * const datadogSecret = DatadogSharedSecret.credentialsSecret(this);
32
+ * const datadogSite = datadogSecret.getSecret('Site');
33
+ * const datadogApiKey = datadogSecret.getSecret('ApiKey');
34
+ * const datadogApiKeyValue = datadogSecret.getSecretValue('ApiKey');
35
+ * const datadogApiKeyValue = datadogSecret.getSecretValue('ApplicationKey');
36
+ */
37
+ export declare class DatadogSharedSecret extends SharedSecret {
38
+ /**
39
+ * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.
40
+ */
41
+ static apiKeySecret(scope: constructs.Construct): DatadogSharedSecret;
42
+ /**
43
+ * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].
44
+ */
45
+ static credentialsSecret(scope: constructs.Construct): DatadogSharedCredentials;
46
+ }
47
+ type Field = 'ApplicationKey' | 'Site' | 'ApiKey';
48
+ export declare class DatadogSharedCredentials extends SharedSecret {
49
+ getSecretValue(field: Field): cdk.SecretValue;
50
+ getSecret(field: Field): cdk.aws_ecs.Secret;
51
+ }
52
+ export {};