@rio-cloud/cdk-v2-constructs 5.0.0 → 5.1.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
CHANGED
|
@@ -3671,7 +3671,7 @@
|
|
|
3671
3671
|
},
|
|
3672
3672
|
"name": "@rio-cloud/cdk-v2-constructs",
|
|
3673
3673
|
"readme": {
|
|
3674
|
-
"markdown": "# RIO CDK Constructs\n\nThis package contains CDK2 constructs for RIO teams.\n\n> NPM: `@rio-cloud/cdk-v2-constructs`\n\n## Bootstrapping of CDK project\n\n```\n$ npx cdk init --language typescript\n```\n\n## Installation\n\n```\n$ npm install --save @rio-cloud/cdk-v2-constructs\n```\n\n## See also\n\n * [How to contribute](./CONTRIBUTION.md)\n * [Changelog](./CHANGELOG.md)\n * [brief API description](./API.md)\n\n## Internal documentation for library devs\n[Documentation](./developers-readme.md)\n\n## Constructs overview (Under construction...)\n\n### Watchful\n\nWatchful constructs help generate some default monitors based on the resouces defined in your stack. Eg - If your stack contains a lambda function and you configure watchful construct, then it will create out of box metric monitors for Throttling, Lambda error and Log error monitors. The ever growing list of resources that watchful creates monitors for as of today are:\n\n- Application load balancer\n- Cloudfront\n- Documentdb\n- Dynamodb\n- Fargate\n- Lambda\n- RDS\n\nSimply add the following to your CDK stack to get started.\n```\n import * as rio from '@rio-cloud/cdk-v2-constructs';\n ...\n const dw = new rio.watchfulv2.Watchful(this, 'Watchful', {\n serviceName,\n });\n dw.watchScope(this); // Generates alarms for all supported resources\n ...\n```\n\nThere are options to override some defaults too. Please be aware that the library is very opinionated and is written with the most general use cases in mind. It is necessary to keep the use of the library simple enough, which means that there is only limited flexibility regarding the configuration options. Having said that, feel free to reach out to team CLAID over slack #rio-platform-support in case of feature requests.\n\nThe broad classification of the monitors created by watchful are\n- Log error monitors\n- Metrics Query monitors: Basically everything other than log error monitors\n\nFor Metrics query monitors, you can configure the priority (defaults as 3). For log error monitors, you can
|
|
3674
|
+
"markdown": "# RIO CDK Constructs\n\nThis package contains CDK2 constructs for RIO teams.\n\n> NPM: `@rio-cloud/cdk-v2-constructs`\n\n## Bootstrapping of CDK project\n\n```\n$ npx cdk init --language typescript\n```\n\n## Installation\n\n```\n$ npm install --save @rio-cloud/cdk-v2-constructs\n```\n\n## See also\n\n * [How to contribute](./CONTRIBUTION.md)\n * [Changelog](./CHANGELOG.md)\n * [brief API description](./API.md)\n\n## Internal documentation for library devs\n[Documentation](./developers-readme.md)\n\n## Constructs overview (Under construction...)\n\n### Watchful\n\nWatchful constructs help generate some default monitors based on the resouces defined in your stack. Eg - If your stack contains a lambda function and you configure watchful construct, then it will create out of box metric monitors for Throttling, Lambda error and Log error monitors. The ever growing list of resources that watchful creates monitors for as of today are:\n\n- Application load balancer\n- Cloudfront\n- Documentdb\n- Dynamodb\n- Fargate\n- Lambda\n- RDS\n\nSimply add the following to your CDK stack to get started.\n```\n import * as rio from '@rio-cloud/cdk-v2-constructs';\n ...\n const dw = new rio.watchfulv2.Watchful(this, 'Watchful', {\n serviceName,\n });\n dw.watchScope(this); // Generates alarms for all supported resources\n ...\n```\n\nThere are options to override some defaults too. Please be aware that the library is very opinionated and is written with the most general use cases in mind. It is necessary to keep the use of the library simple enough, which means that there is only limited flexibility regarding the configuration options. Having said that, feel free to reach out to team CLAID over slack #rio-platform-support in case of feature requests.\n\nThe broad classification of the monitors created by watchful are\n- Log error monitors\n- Metrics Query monitors: Basically everything other than log error monitors\n\nFor Metrics query monitors, you can configure the priority (defaults as 3). For log error monitors, you can configure priority, renotification interval and can configure if the auto close of the monitor is disabled.\n```\n ...\n const dw = new Watchful(stack, 'Watchful2', {\n logErrorMonitorConfig: {\n disableAutoClose: true,\n renotifyInterval: 150,\n priority: 4,\n },\n queryErrorMonitorConfig: {\n priority: 4\n }\n });\n dw.watchScope(stack);\n```\n\nThere is an `overrideAlarmThreshold` method which can be used to override the default watchful thresholds. Please make sure to use the method before the `watchscope` function.\nEg -\n```\n...\nconst dw = new Watchful(stack, 'Watchful', {});\ndw.overrideAlarmThreshold({\n monitoredResourceScope: lambdaA,\n monitorType: MonitorType.ERRORS,\n threshold: 5,\n});\ndw.watchScope(stack);\n```\n\n### ClassifyPipelineType\n\nThe pipelines can be tagged with key 'pipeline_type' to the following values:\n\n* deploy: To tag the production pipeline releasing the application\n* branch: The branch pipeline. Mostly used to test contributions / renovate updates\n* vulnerability: The vulnerability pipeline\n\nThe construct `ClassifyPipelineType` can be used to tag the pipeline accordingly. This tag is also picked up by the Datadog pipeline metric used to monitor the pipelines. It is added as a tag to the metric. This gives you more flexibility with managing the monitors also. E.g. some teams don't want to get alerted for branch pipelines. You can then leverage this metric tag to filter the pipelines.\n\nExample:\n\n```typescript\nconst pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n ...\n });\nrio.ClassifyPipelineType.apply(pipeline, rio.RioPipelineType.DEPLOY);\n```\n"
|
|
3675
3675
|
},
|
|
3676
3676
|
"repository": {
|
|
3677
3677
|
"type": "git",
|
|
@@ -16254,5 +16254,5 @@
|
|
|
16254
16254
|
}
|
|
16255
16255
|
},
|
|
16256
16256
|
"version": "0.0.0",
|
|
16257
|
-
"fingerprint": "
|
|
16257
|
+
"fingerprint": "+cFufSaZ5kmzgG20jmbchKfmEGh+MkNUFPaJGiDif6A="
|
|
16258
16258
|
}
|
package/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
|
+
## [5.1.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv5.0.0&sourceBranch=refs%2Ftags%2Fv5.1.0) (2024-06-27)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
* replace deprecated logforwarder by the new one ([db3710b](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/db3710bcd1e34689da7454822ada2e038ac5b319))
|
|
11
|
+
|
|
5
12
|
## [5.0.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.36.1&sourceBranch=refs%2Ftags%2Fv5.0.0) (2024-06-07)
|
|
6
13
|
|
|
7
14
|
|
package/README.md
CHANGED
|
@@ -56,7 +56,7 @@ The broad classification of the monitors created by watchful are
|
|
|
56
56
|
- Log error monitors
|
|
57
57
|
- Metrics Query monitors: Basically everything other than log error monitors
|
|
58
58
|
|
|
59
|
-
For Metrics query monitors, you can configure the priority (defaults as 3). For log error monitors, you can
|
|
59
|
+
For Metrics query monitors, you can configure the priority (defaults as 3). For log error monitors, you can configure priority, renotification interval and can configure if the auto close of the monitor is disabled.
|
|
60
60
|
```
|
|
61
61
|
...
|
|
62
62
|
const dw = new Watchful(stack, 'Watchful2', {
|
|
@@ -72,7 +72,7 @@ For Metrics query monitors, you can configure the priority (defaults as 3). For
|
|
|
72
72
|
dw.watchScope(stack);
|
|
73
73
|
```
|
|
74
74
|
|
|
75
|
-
There is an `overrideAlarmThreshold` method which can be used to override the default watchful thresholds. Please make
|
|
75
|
+
There is an `overrideAlarmThreshold` method which can be used to override the default watchful thresholds. Please make sure to use the method before the `watchscope` function.
|
|
76
76
|
Eg -
|
|
77
77
|
```
|
|
78
78
|
...
|
|
@@ -87,17 +87,19 @@ dw.watchScope(stack);
|
|
|
87
87
|
|
|
88
88
|
### ClassifyPipelineType
|
|
89
89
|
|
|
90
|
-
The pipelines can be tagged with key 'pipeline_type' to the following values
|
|
90
|
+
The pipelines can be tagged with key 'pipeline_type' to the following values:
|
|
91
|
+
|
|
91
92
|
* deploy: To tag the production pipeline releasing the application
|
|
92
93
|
* branch: The branch pipeline. Mostly used to test contributions / renovate updates
|
|
93
|
-
*
|
|
94
|
+
* vulnerability: The vulnerability pipeline
|
|
94
95
|
|
|
95
|
-
The construct `ClassifyPipelineType` can be used to tag the pipeline accordingly. This tag is also picked up by the
|
|
96
|
+
The construct `ClassifyPipelineType` can be used to tag the pipeline accordingly. This tag is also picked up by the Datadog pipeline metric used to monitor the pipelines. It is added as a tag to the metric. This gives you more flexibility with managing the monitors also. E.g. some teams don't want to get alerted for branch pipelines. You can then leverage this metric tag to filter the pipelines.
|
|
96
97
|
|
|
97
|
-
Example
|
|
98
|
-
|
|
98
|
+
Example:
|
|
99
|
+
|
|
100
|
+
```typescript
|
|
99
101
|
const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {
|
|
100
102
|
...
|
|
101
103
|
});
|
|
102
104
|
rio.ClassifyPipelineType.apply(pipeline, rio.RioPipelineType.DEPLOY);
|
|
103
|
-
```
|
|
105
|
+
```
|
|
@@ -49,7 +49,7 @@ class AwsEcsAbruptlyStoppedMonitor extends constructs_1.Construct {
|
|
|
49
49
|
targets: [new cdk.aws_events_targets.CloudWatchLogGroup(ecsStateChangeLogGroup)],
|
|
50
50
|
});
|
|
51
51
|
const logForwarderLambda = cdk.aws_lambda.Function.fromFunctionAttributes(this, 'EcsStateChangeLogForwarderLambda', {
|
|
52
|
-
functionArn: cdk.Fn.importValue('
|
|
52
|
+
functionArn: cdk.Fn.importValue('datadog-forwarder-ForwarderArn'),
|
|
53
53
|
sameEnvironment: true,
|
|
54
54
|
});
|
|
55
55
|
new cdk.aws_logs.SubscriptionFilter(this, 'EcsStateChangeLogFilter', {
|
|
@@ -73,4 +73,4 @@ class AwsEcsAbruptlyStoppedMonitor extends constructs_1.Construct {
|
|
|
73
73
|
exports.AwsEcsAbruptlyStoppedMonitor = AwsEcsAbruptlyStoppedMonitor;
|
|
74
74
|
_a = JSII_RTTI_SYMBOL_1;
|
|
75
75
|
AwsEcsAbruptlyStoppedMonitor[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.AwsEcsAbruptlyStoppedMonitor", version: "0.0.0" };
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-ecs-abruptly-stopped-monitor.js","sourceRoot":"","sources":["../../../../src/contributions/team-oubout-order-book/aws-ecs-abruptly-stopped-monitor/aws-ecs-abruptly-stopped-monitor.ts"],"names":[],"mappings":";;;;;AAAA,mCAAmC;AACnC,2CAAuC;AACvC,kDAAiG;AAoCjG;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAa,4BAA6B,SAAQ,sBAAS;IACzD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAqC;QAC7E,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,sBAAsB,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,wBAAwB,CAAC,CAAC;QAEzF,IAAI,GAAG,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,4BAA4B,EAAE;YAChE,YAAY,EAAE,sBAAsB,CAAC,YAAY;YACjD,SAAS,EAAE,CAAC;SACb,CAAC,CAAC;QAEH,4CAA4C;QAC5C,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,oBAAoB,EAAE;YAClD,YAAY,EAAE;gBACZ,MAAM,EAAE,CAAC,SAAS,CAAC;gBACnB,UAAU,EAAE,CAAC,uBAAuB,EAAE,qCAAqC,EAAE,oBAAoB,CAAC;gBAClG,MAAM,EAAE;oBACN,aAAa,EAAE,CAAC,SAAS,CAAC;oBAC1B,UAAU,EAAE,CAAC,SAAS,CAAC;oBACvB,GAAG,CAAC,KAAK,CAAC,UAAU,IAAI,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;iBAC5D;aACF;YACD,OAAO,EAAE,CAAC,IAAI,GAAG,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,CAAC;SACjF,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,GAAG,CAAC,UAAU,CAAC,QAAQ,CAAC,sBAAsB,CACvE,IAAI,EACJ,kCAAkC,EAClC;YACE,WAAW,EAAE,GAAG,CAAC,EAAE,CAAC,WAAW,CAAC,gCAAgC,CAAC;YACjE,eAAe,EAAE,IAAI;SACtB,CACF,CAAC;QAEF,IAAI,GAAG,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,EAAE,yBAAyB,EAAE;YACnE,WAAW,EAAE,IAAI,GAAG,CAAC,qBAAqB,CAAC,iBAAiB,CAAC,kBAAkB,CAAC;YAChF,aAAa,EAAE,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAC/C,yBAAyB,EACzB,qCAAqC,CACtC;YACD,QAAQ,EAAE,sBAAsB;SACjC,CAAC,CAAC;QAEH,4FAA4F;QAC5F,IAAI,0BAAc,CAAC,IAAI,EAAE,+BAA+B,EAAE;YACxD,IAAI,EAAE,+BAA+B;YACrC,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,WAAW,EAAE,wCAA4B,CAAC,SAAS;YACnD,KAAK,EAAE,oBAAoB,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,4BACnD,sBAAsB,CAAC,YACzB,iDAAiD;YACjD,OAAO,EAAE,sEAAsE;gBACrE,uEAAuE;YACjF,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,0BAAc,CAAC,gBAAgB;YAC3D,YAAY,EAAE,KAAK,CAAC,YAAY;SACjC,CAAC,CAAC;IACL,CAAC;;AAxDH,oEAyDC","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { DatadogMonitor, DatadogMonitorQueryAlertType, INotification } from '../../../datadogv2';\n\nexport interface EcsAbruptlyStoppedMonitorProps {\n\n  /**\n     * The name of the service to which the monitor belongs.\n     *\n     * Used to generate the monitor name as well a apply the `service` tag.\n     */\n  readonly serviceName: string;\n\n  /**\n     * To explicitly disable notifications use {@link NoNotification}.\n     *\n     * @defaultValue {@link DefaultSlackNotification}\n     *\n     * @see https://docs.datadoghq.com/monitors/notify\n     */\n\n  readonly notification?: INotification;\n\n  /**\n     * The alert priority of the monitor\n     *\n     * @defaultValue {@link DatadogMonitor.DEFAULT_PRIORITY}\n     */\n\n  readonly priority?: number;\n\n  /**\n     * ARN of the cluster that should be monitored, consuming only ECS events belonging to the cluster.\n     * If no cluster is provided, the monitor will consume ECS events for all clusters within the account.\n     */\n  readonly clusterArn?: string;\n}\n\n/**\n * # WARNING: This construct is still in the beta phase.\n *\n * The construct creates monitoring for detecting ECS containers that were stopped abruptly by AWS for reasons such as,\n * out of memory, or failed health checks.\n *\n * This monitor adds transparency to such cases, which otherwise would happen without being noticed and could escalate\n * to bigger issues, like a service that requires more resources to run properly.\n *\n * The construct will consume the ECS events and send them to a CloudWatch log group, which are forwarded to Datadog,\n * allowing better analyses since AWS keeps the stopped task details for only one hour and will be used to create a\n * monitor.\n *\n * Contributions are more than welcome, please get in touch with Team Outbound to ensure compatibility.\n *\n * This construct was based on an AWS blog post about ECS anomaly detection, see here:\n * {@link https://aws.amazon.com/blogs/containers/amazon-elastic-container-service-anomaly-detection-using-amazon-eventbridge/}.\n *\n * More details on the AWS ECS events can be found here:\n * {@link https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs_cwe_events.html}.\n */\nexport class AwsEcsAbruptlyStoppedMonitor extends Construct {\n  constructor(scope: Construct, id: string, props: EcsAbruptlyStoppedMonitorProps) {\n    super(scope, id);\n\n    const ecsStateChangeLogGroup = new cdk.aws_logs.LogGroup(this, 'EcsStateChangeLogGroup');\n\n    new cdk.aws_logs.LogRetention(this, 'EcsStateChangeLogRetention', {\n      logGroupName: ecsStateChangeLogGroup.logGroupName,\n      retention: 3,\n    });\n\n    // Rule to cover all clusters status changes\n    new cdk.aws_events.Rule(this, 'EcsStateChangeRule', {\n      eventPattern: {\n        source: ['aws.ecs'],\n        detailType: ['ECS Task State Change', 'ECS Container Instance State Change', 'ECS Service Action'],\n        detail: {\n          desiredStatus: ['STOPPED'],\n          lastStatus: ['STOPPED'],\n          ...(props.clusterArn && { clusterArn: [props.clusterArn] }),\n        },\n      },\n      targets: [new cdk.aws_events_targets.CloudWatchLogGroup(ecsStateChangeLogGroup)],\n    });\n\n    const logForwarderLambda = cdk.aws_lambda.Function.fromFunctionAttributes(\n      this,\n      'EcsStateChangeLogForwarderLambda',\n      {\n        functionArn: cdk.Fn.importValue('datadog-forwarder-ForwarderArn'),\n        sameEnvironment: true,\n      },\n    );\n\n    new cdk.aws_logs.SubscriptionFilter(this, 'EcsStateChangeLogFilter', {\n      destination: new cdk.aws_logs_destinations.LambdaDestination(logForwarderLambda),\n      filterPattern: cdk.aws_logs.FilterPattern.anyTerm(\n        'Container killed due to',\n        'Task failed container health checks',\n      ),\n      logGroup: ecsStateChangeLogGroup,\n    });\n\n    // After being migrated to the new version it can be added to the CLAID construct repository\n    new DatadogMonitor(this, 'EcsStateChangeLogGroupMonitor', {\n      name: 'Unexpected ECS status changes',\n      serviceName: props.serviceName,\n      monitorType: DatadogMonitorQueryAlertType.LOG_ALERT,\n      query: `logs(\"account_id:${cdk.Stack.of(this).account} @aws.awslogs.logGroup:\\\"${\n        ecsStateChangeLogGroup.logGroupName\n      }\\\"\").index(\"*\").rollup(\"count\").last(\"5m\") >= 1`,\n      message: '{{#is_alert}}There are unexpected ECS status changes in the account ' +\n                '{{log.tags.account_id}}, more details here {{log.link}} {{/is_alert}}',\n      priority: props.priority ?? DatadogMonitor.DEFAULT_PRIORITY,\n      notification: props.notification,\n    });\n  }\n}\n\n"]}
|
package/package.json
CHANGED
package/version.json
CHANGED