@gammarers/aws-rds-database-auto-running-protection-stack 2.3.0 → 2.3.1

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
@@ -3719,7 +3719,7 @@
3719
3719
  },
3720
3720
  "name": "@gammarers/aws-rds-database-auto-running-protection-stack",
3721
3721
  "readme": {
3722
- "markdown": "# AWS RDS Database Auto Running Protection Stack\n\n[![GitHub](https://img.shields.io/github/license/gammarers/aws-rds-database-auto-running-protection-stack?style=flat-square)](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/blob/main/LICENSE)\n[![npm (scoped)](https://img.shields.io/npm/v/@gammarers/aws-rds-database-auto-running-protection-stack?style=flat-square)](https://www.npmjs.com/package/@gammarers/aws-rds-database-auto-running-protection-stack)\n[![GitHub Workflow Status (branch)](https://img.shields.io/github/actions/workflow/status/gammarers/aws-rds-database-auto-running-protection-stack/release.yml?branch=main&label=release&style=flat-square)](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/actions/workflows/release.yml)\n[![GitHub release (latest SemVer)](https://img.shields.io/github/v/release/gammarers/aws-rds-database-auto-running-protection-stack?sort=semver&style=flat-square)](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/releases)\n\n[![View on Construct Hub](https://constructs.dev/badge?package=@gammarers/aws-rds-database-auto-running-protection-stack)](https://constructs.dev/packages/@gammarers/aws-rds-database-auto-running-protection-stack)\n\nThis constructor stack includes a function to automatically stop a database or cluster that will automatically start in 7 days.\n\n> [!WARNING]\n> v2.1.0:\n> Stack props add option resourceNamingOption\n> default ResourceNamingType.DEFAULT is cdk generated name\n> if you want to maintain compatibility with versions below `v2.1.0`, please include the following settings (ResourceNamingType.AUTO).\n> ```typescript\n> new RDSDatabaseAutoRunningProtectionStack(app, 'RDSDatabaseAutoRunningProtectionStack', {\n> stackName: 'rds-database-auto-running-protection-stack',\n> targetResource: {\n> tagKey: 'AutoRunningProtection',\n> tagValues: ['YES'],\n> },\n> resourceNamingOption: {\n> type: RDSDatabaseAutoRunningProtectionStackResourceNamingType.AUTO, // HERE\n> },\n> });\n> ```\n\n## Resources\n\nThis construct creating resource list.\n\n- StepFunctions(StateMachine)\n- IAM Role (StepFunctions)\n- IAM Policy (StepFunctions)\n- EventBridge\n- IAM Role (EventBridge)\n\n## Install\n\n### TypeScript\n\n#### install by npm\n\n```shell\nnpm install @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n#### install by yarn\n\n```shell\nyarn add @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n#### install by pnpm\n\n```shell\npnpm add @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n#### install by bun\n\n```shell\nbun add @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n## Example\n\n```typescript\nimport { RDSDatabaseAutoRunningProtectionStack } from '@gammarers/aws-rds-database-auto-running-protection-stack';\n\nnew RDSDatabaseAutoRunningProtectionStack(app, 'RDSDatabaseAutoRunningProtectionStack', {\n stackName: 'rds-database-auto-running-protection-stack',\n targetResource: {\n tagKey: 'AutoRunningProtection',\n tagValues: ['YES'],\n },\n});\n\n```\n\n## License\n\nThis project is licensed under the Apache-2.0 License.\n"
3722
+ "markdown": "# AWS RDS Database Auto Running Protection Stack\n\n[![GitHub](https://img.shields.io/github/license/gammarers/aws-rds-database-auto-running-protection-stack?style=flat-square)](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/blob/main/LICENSE)\n[![npm (scoped)](https://img.shields.io/npm/v/@gammarers/aws-rds-database-auto-running-protection-stack?style=flat-square)](https://www.npmjs.com/package/@gammarers/aws-rds-database-auto-running-protection-stack)\n[![GitHub Workflow Status (branch)](https://img.shields.io/github/actions/workflow/status/gammarers/aws-rds-database-auto-running-protection-stack/release.yml?branch=main&label=release&style=flat-square)](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/actions/workflows/release.yml)\n[![GitHub release (latest SemVer)](https://img.shields.io/github/v/release/gammarers/aws-rds-database-auto-running-protection-stack?sort=semver&style=flat-square)](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/releases)\n\n[![View on Construct Hub](https://constructs.dev/badge?package=@gammarers/aws-rds-database-auto-running-protection-stack)](https://constructs.dev/packages/@gammarers/aws-rds-database-auto-running-protection-stack)\n\nThis constructor stack includes a function to automatically stop a database or cluster that will automatically start in 7 days.\n\n> [!WARNING]\n> v2.1.0:\n> Stack props add option resourceNamingOption\n> default ResourceNamingType.DEFAULT is cdk generated name\n> if you want to maintain compatibility with versions below `v2.1.0`, please include the following settings (ResourceNamingType.AUTO).\n> ```typescript\n> new RDSDatabaseAutoRunningProtectionStack(app, 'RDSDatabaseAutoRunningProtectionStack', {\n> stackName: 'rds-database-auto-running-protection-stack',\n> targetResource: {\n> tagKey: 'AutoRunningProtection',\n> tagValues: ['YES'],\n> },\n> resourceNamingOption: {\n> type: RDSDatabaseAutoRunningProtectionStackResourceNamingType.AUTO, // HERE\n> },\n> });\n> ```\n\n## Resources\n\nThis construct creating resource list.\n\n- StepFunctions(StateMachine)\n- IAM Role (StepFunctions)\n- IAM Policy (StepFunctions)\n- EventBridge\n- IAM Role (EventBridge)\n\n## Install\n\n### TypeScript\n\n#### install by npm\n\n```shell\nnpm install @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n#### install by yarn\n\n```shell\nyarn add @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n#### install by pnpm\n\n```shell\npnpm add @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n#### install by bun\n\n```shell\nbun add @gammarers/aws-rds-database-auto-running-protection-stack\n```\n\n## Example\n\n### Code\n\n```typescript\nimport { RDSDatabaseAutoRunningProtectionStack } from '@gammarers/aws-rds-database-auto-running-protection-stack';\n\nnew RDSDatabaseAutoRunningProtectionStack(app, 'RDSDatabaseAutoRunningProtectionStack', {\n stackName: 'rds-database-auto-running-protection-stack',\n targetResource: {\n tagKey: 'AutoRunningProtection',\n tagValues: ['YES'],\n },\n resourceNamingOption: {\n type: RDSDatabaseAutoRunningProtectionStackResourceNamingType.DEFAULT,\n },\n notifications: {\n emails: [ // \"Incoming Sample Message - EMAIL\"\n 'foo@example.com',\n 'bar@example.net',\n ],\n slack: { // \"Incoming Sample Message - Slack\"\n webhookSecretName: 'example/slack/webhook', // Slack webhook secret\n },\n },\n});\n```\n\n### Slack webhook secret\n\nPlease save it in AWS Secrets Manager in the following format.\n\nget your slack webhook url parts\n\n```text\nhttps://hooks.slack.com/services/<workspace>/<channel>/<whebook>\n```\n\n| SecretKey \t | SecretValue \t |\n|-------------|-----------------|\n| Workspace \t | \\<workspace\\> \t |\n| Channel \t | \\<channel\\> \t |\n| Webhook \t | \\<whebook\\> \t |\n\n## Incoming Sample Message\n\n### EMAIL\n\n![](./images/example-email.png)\n\n### Slack\n\n![](./images/example-slack.png)\n\n## License\n\nThis project is licensed under the Apache-2.0 License.\n"
3723
3723
  },
3724
3724
  "repository": {
3725
3725
  "type": "git",
@@ -4117,6 +4117,6 @@
4117
4117
  "symbolId": "src/index:TargetResource"
4118
4118
  }
4119
4119
  },
4120
- "version": "2.3.0",
4121
- "fingerprint": "8o1++8dW9SNR+x1WuW+JTN5fBro5gep979b358ULnoU="
4120
+ "version": "2.3.1",
4121
+ "fingerprint": "F7VvE49Itz9RrKodmW588iRZH8E0sWuT8cpmEumweFI="
4122
4122
  }
package/README.md CHANGED
@@ -67,6 +67,8 @@ bun add @gammarers/aws-rds-database-auto-running-protection-stack
67
67
 
68
68
  ## Example
69
69
 
70
+ ### Code
71
+
70
72
  ```typescript
71
73
  import { RDSDatabaseAutoRunningProtectionStack } from '@gammarers/aws-rds-database-auto-running-protection-stack';
72
74
 
@@ -76,10 +78,47 @@ new RDSDatabaseAutoRunningProtectionStack(app, 'RDSDatabaseAutoRunningProtection
76
78
  tagKey: 'AutoRunningProtection',
77
79
  tagValues: ['YES'],
78
80
  },
81
+ resourceNamingOption: {
82
+ type: RDSDatabaseAutoRunningProtectionStackResourceNamingType.DEFAULT,
83
+ },
84
+ notifications: {
85
+ emails: [ // "Incoming Sample Message - EMAIL"
86
+ 'foo@example.com',
87
+ 'bar@example.net',
88
+ ],
89
+ slack: { // "Incoming Sample Message - Slack"
90
+ webhookSecretName: 'example/slack/webhook', // Slack webhook secret
91
+ },
92
+ },
79
93
  });
94
+ ```
95
+
96
+ ### Slack webhook secret
97
+
98
+ Please save it in AWS Secrets Manager in the following format.
99
+
100
+ get your slack webhook url parts
80
101
 
102
+ ```text
103
+ https://hooks.slack.com/services/<workspace>/<channel>/<whebook>
81
104
  ```
82
105
 
106
+ | SecretKey | SecretValue |
107
+ |-------------|-----------------|
108
+ | Workspace | \<workspace\> |
109
+ | Channel | \<channel\> |
110
+ | Webhook | \<whebook\> |
111
+
112
+ ## Incoming Sample Message
113
+
114
+ ### EMAIL
115
+
116
+ ![](./images/example-email.png)
117
+
118
+ ### Slack
119
+
120
+ ![](./images/example-slack.png)
121
+
83
122
  ## License
84
123
 
85
124
  This project is licensed under the Apache-2.0 License.
Binary file
Binary file
package/lib/index.js CHANGED
@@ -135,5 +135,5 @@ class RDSDatabaseAutoRunningProtectionStack extends aws_cdk_lib_1.Stack {
135
135
  }
136
136
  exports.RDSDatabaseAutoRunningProtectionStack = RDSDatabaseAutoRunningProtectionStack;
137
137
  _a = JSII_RTTI_SYMBOL_1;
138
- RDSDatabaseAutoRunningProtectionStack[_a] = { fqn: "@gammarers/aws-rds-database-auto-running-protection-stack.RDSDatabaseAutoRunningProtectionStack", version: "2.3.0" };
138
+ RDSDatabaseAutoRunningProtectionStack[_a] = { fqn: "@gammarers/aws-rds-database-auto-running-protection-stack.RDSDatabaseAutoRunningProtectionStack", version: "2.3.1" };
139
139
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { ResourceAutoNaming, ResourceDefaultNaming, ResourceNaming, ResourceNamingType as RDSDatabaseAutoRunningProtectionStackResourceNamingType } from '@gammarers/aws-resource-naming';\nimport { SNSSlackMessageLambdaSubscription } from '@gammarers/aws-sns-slack-message-lambda-subscription';\nimport { Names, Stack, StackProps } from 'aws-cdk-lib';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as subscriptions from 'aws-cdk-lib/aws-sns-subscriptions';\nimport { Construct } from 'constructs';\nimport { ProtectionStateMachine } from './resources/protection-state-machine';\n\nexport { RDSDatabaseAutoRunningProtectionStackResourceNamingType };\n\nexport interface TargetResource {\n  readonly tagKey: string;\n  readonly tagValues: string[];\n}\n\nexport interface Slack {\n  readonly webhookSecretName: string;\n}\n\nexport interface Notifications {\n  readonly emails?: string[];\n  readonly slack?: Slack;\n}\n\nexport interface RDSDatabaseAutoRunningProtectionStackProps extends StackProps {\n  readonly targetResource: TargetResource;\n  readonly enableRule?: boolean;\n  readonly notifications?: Notifications;\n  readonly resourceNamingOption?: ResourceNamingOption;\n}\n\nexport interface ResourceCustomNaming {\n  readonly type: RDSDatabaseAutoRunningProtectionStackResourceNamingType.CUSTOM;\n  readonly stateMachineName: string;\n  readonly stateMachineRoleName: string;\n  readonly startEventCatchRuleRoleName: string;\n  readonly startInstanceEventCatchRuleName: string;\n  readonly startClusterEventCatchRuleName: string;\n}\n\nexport type ResourceNamingOption = ResourceDefaultNaming | ResourceAutoNaming | ResourceCustomNaming;\n\nexport class RDSDatabaseAutoRunningProtectionStack extends Stack {\n  constructor(scope: Construct, id: string, props: RDSDatabaseAutoRunningProtectionStackProps) {\n    super(scope, id, props);\n\n    // 👇 Create random 8 length string\n    const random = ResourceNaming.createRandomString(`${Names.uniqueId(scope)}.${Names.uniqueId(this)}`);\n    // 👇 Auto naeming\n    const autoNaming = {\n      stateMachineName: `rds-db-auto-running-stop-${random}-state-machine`,\n      stateMachineRoleName: `rds-db-auto-running-stop-state-machine-${random}-role`,\n      startEventCatchRuleRoleName: `rds-db-auto-running-catch-event-${random}-role`,\n      startInstanceEventCatchRuleName: `rds-db-instance-running-event-catch-${random}-rule`,\n      startClusterEventCatchRuleName: `rds-db-cluster-running-event-catch-${random}-rule`,\n    };\n    const names = ResourceNaming.naming(autoNaming, props.resourceNamingOption as ResourceNaming.ResourceNamingOption);\n\n    // 👇 SNS Topic for notifications\n    const topic: sns.Topic = new sns.Topic(this, 'NotificationTopic', {\n      topicName: names.notificationTopicName,\n      displayName: names.notificationTopicDisplayName,\n    });\n\n    // 👇 Subscribe an email endpoint to the topic\n    const emails = props.notifications?.emails ?? [];\n    for (const email of emails) {\n      topic.addSubscription(new subscriptions.EmailSubscription(email));\n    }\n\n    // 👇 Subscription slack webhook\n    if (props.notifications?.slack) {\n      new SNSSlackMessageLambdaSubscription(this, 'SNSSlackMessageLambdaSubscription', {\n        topic,\n        slackWebhookSecretName: props.notifications.slack.webhookSecretName,\n      });\n    }\n\n    // 👇 StepFunctions\n    const stateMachine = new ProtectionStateMachine(this, 'StateMachine', {\n      stateMachineName: names.stateMachineName,\n      notificationTopic: topic,\n    });\n    if (names.stateMachineRoleName) {\n      const role = stateMachine.node.findChild('Role') as iam.Role;\n      const cfnRole = role.node.defaultChild as iam.CfnRole;\n      cfnRole.addPropertyOverride('RoleName', names.stateMachineRoleName);\n      cfnRole.addPropertyOverride('Description', 'rds database auto running stop state machine role.');\n      const policy = role.node.findChild('DefaultPolicy') as iam.Policy;\n      const cfnPolicy = policy.node.defaultChild as iam.CfnPolicy;\n      cfnPolicy.addPropertyOverride('PolicyName', `rds-db-auto-running-stop-state-machine-${random}-policy`);\n    }\n\n    const execRole = new iam.Role(this, 'EventExecRole', {\n      roleName: names.startEventCatchRuleRoleName,\n      description: 'db auto start catch with start state machine event role',\n      assumedBy: new iam.ServicePrincipal('events.amazonaws.com'),\n      inlinePolicies: {\n        'state-machine-exec': new iam.PolicyDocument({\n          statements: [\n            new iam.PolicyStatement({\n              effect: iam.Effect.ALLOW,\n              actions: [\n                'states:StartExecution',\n              ],\n              resources: [\n                stateMachine.stateMachineArn,\n              ],\n            }),\n          ],\n        }),\n      },\n    });\n\n    const enableRule: boolean = (() => {\n      return props.enableRule === undefined || props.enableRule;\n    })();\n\n    // 👇 EventBridge by RDS DB Instance Auto Start Event\n    new events.Rule(this, 'DBInstanceEvent', {\n      ruleName: names.startInstanceEventCatchRuleName,\n      description: 'rds db instance running event catch rule.',\n      enabled: enableRule,\n      eventPattern: {\n        source: ['aws.rds'],\n        detailType: ['RDS DB Instance Event'],\n        detail: {\n          EventID: ['RDS-EVENT-0154'],\n        },\n      },\n      targets: [\n        new targets.SfnStateMachine(stateMachine, {\n          role: execRole,\n          input: events.RuleTargetInput.fromObject({\n            event: events.EventField.fromPath('$'),\n            params: {\n              tagKey: props.targetResource.tagKey,\n              tagValues: props.targetResource.tagValues,\n            },\n          }),\n        }),\n      ],\n    });\n\n    // 👇 EventBridge by RDS DB Instance Auto Start Event\n    new events.Rule(this, 'DBClusterEvent', {\n      ruleName: names.startClusterEventCatchRuleName,\n      description: 'db cluster running event catch rule',\n      enabled: enableRule,\n      eventPattern: {\n        source: ['aws.rds'],\n        detailType: ['RDS DB Cluster Event'],\n        detail: {\n          EventID: ['RDS-EVENT-0153'],\n        },\n      },\n      targets: [\n        new targets.SfnStateMachine(stateMachine, {\n          role: execRole,\n          input: events.RuleTargetInput.fromObject({\n            event: events.EventField.fromPath('$'),\n            params: {\n              tagKey: props.targetResource.tagKey,\n              tagValues: props.targetResource.tagValues,\n            },\n          }),\n        }),\n      ],\n    });\n  }\n}"]}
package/package.json CHANGED
@@ -85,7 +85,7 @@
85
85
  "publishConfig": {
86
86
  "access": "public"
87
87
  },
88
- "version": "2.3.0",
88
+ "version": "2.3.1",
89
89
  "jest": {
90
90
  "coverageProvider": "v8",
91
91
  "testMatch": [