@gammarers/aws-rds-database-auto-running-protection-stack 2.3.3 → 2.3.5
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 +3 -3
- package/README.md +14 -0
- package/lib/index.js +1 -1
- package/package.json +1 -1
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[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/blob/main/LICENSE)\n[](https://www.npmjs.com/package/@gammarers/aws-rds-database-auto-running-protection-stack)\n[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/actions/workflows/release.yml)\n[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/releases)\n\n[](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\n\n### Slack\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[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/blob/main/LICENSE)\n[](https://www.npmjs.com/package/@gammarers/aws-rds-database-auto-running-protection-stack)\n[](https://pypi.org/project/gammarers.aws-rds-database-auto-running-protection-stack/)\n[](https://www.nuget.org/packages/Gammarers.CDK.AWS.RDSDatabaseAutoRunningProtectionStack/)\n[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/actions/workflows/release.yml)\n[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/releases)\n\n[](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### Python\n\n```shell\npip install gammarers.aws-rds-database-auto-running-protection-stack\n```\n\n### C# / .NET\n\n```shell\ndotnet add package Gammarers.CDK.AWS.RDSDatabaseAutoRunningProtectionStack\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\n\n### Slack\n\n\n\n## License\n\nThis project is licensed under the Apache-2.0 License.\n"
|
|
3723
3723
|
},
|
|
3724
3724
|
"repository": {
|
|
3725
3725
|
"type": "git",
|
|
@@ -4125,6 +4125,6 @@
|
|
|
4125
4125
|
"symbolId": "src/index:TargetResource"
|
|
4126
4126
|
}
|
|
4127
4127
|
},
|
|
4128
|
-
"version": "2.3.
|
|
4129
|
-
"fingerprint": "
|
|
4128
|
+
"version": "2.3.5",
|
|
4129
|
+
"fingerprint": "6kAhvzlfziOIZMTXTsUpkBlbO8IQSDddxYwf2qTWVAw="
|
|
4130
4130
|
}
|
package/README.md
CHANGED
|
@@ -2,6 +2,8 @@
|
|
|
2
2
|
|
|
3
3
|
[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/blob/main/LICENSE)
|
|
4
4
|
[](https://www.npmjs.com/package/@gammarers/aws-rds-database-auto-running-protection-stack)
|
|
5
|
+
[](https://pypi.org/project/gammarers.aws-rds-database-auto-running-protection-stack/)
|
|
6
|
+
[](https://www.nuget.org/packages/Gammarers.CDK.AWS.RDSDatabaseAutoRunningProtectionStack/)
|
|
5
7
|
[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/actions/workflows/release.yml)
|
|
6
8
|
[](https://github.com/gammarers/aws-rds-database-auto-running-protection-stack/releases)
|
|
7
9
|
|
|
@@ -65,6 +67,18 @@ pnpm add @gammarers/aws-rds-database-auto-running-protection-stack
|
|
|
65
67
|
bun add @gammarers/aws-rds-database-auto-running-protection-stack
|
|
66
68
|
```
|
|
67
69
|
|
|
70
|
+
### Python
|
|
71
|
+
|
|
72
|
+
```shell
|
|
73
|
+
pip install gammarers.aws-rds-database-auto-running-protection-stack
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### C# / .NET
|
|
77
|
+
|
|
78
|
+
```shell
|
|
79
|
+
dotnet add package Gammarers.CDK.AWS.RDSDatabaseAutoRunningProtectionStack
|
|
80
|
+
```
|
|
81
|
+
|
|
68
82
|
## Example
|
|
69
83
|
|
|
70
84
|
### Code
|
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.
|
|
138
|
+
RDSDatabaseAutoRunningProtectionStack[_a] = { fqn: "@gammarers/aws-rds-database-auto-running-protection-stack.RDSDatabaseAutoRunningProtectionStack", version: "2.3.5" };
|
|
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}"]}
|