@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/.jsii +635 -146
- package/docs/API.md +447 -3
- package/docs/changelog.md +20 -0
- package/lib/datadogv2/datadog-lambda-instrumentation.d.ts +2 -3
- package/lib/datadogv2/datadog-lambda-instrumentation.js +3 -4
- package/lib/datadogv2/datadog-shared-secrets.d.ts +30 -14
- package/lib/datadogv2/datadog-shared-secrets.js +54 -32
- package/lib/fargate/datadog.d.ts +4 -5
- package/lib/fargate/datadog.js +7 -7
- package/lib/fargate/rio-fargate-service-blue-green-alpha.js +7 -5
- package/lib/fargate/rio-fargate-service.js +6 -5
- package/package.json +1 -1
- package/version.json +1 -1
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
|
|
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
|
|
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
|
|
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
|
|
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.
|
|
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,
|
|
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
|
-
|
|
7
|
+
protected readonly secret: sec.ISecret;
|
|
19
8
|
private customResource;
|
|
20
|
-
|
|
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 {};
|