@alicloud/ros-cdk-kms 1.0.12 → 1.0.13
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/lib/key.d.ts +8 -1
- package/lib/key.js +4 -3
- package/lib/kms.generated.d.ts +76 -2
- package/lib/kms.generated.js +30 -6
- package/lib/secret.d.ts +30 -0
- package/lib/secret.js +8 -3
- package/package.json +1 -1
package/lib/key.d.ts
CHANGED
|
@@ -9,6 +9,10 @@ export interface KeyProps {
|
|
|
9
9
|
* Property description: The description of the CMK. Length constraints: Minimum length of 0 characters. Maximum length of 8192 characters.
|
|
10
10
|
*/
|
|
11
11
|
readonly description?: string | ros.IResolvable;
|
|
12
|
+
/**
|
|
13
|
+
* Property dkmsInstanceId: The ID of the dedicated KMS instance.
|
|
14
|
+
*/
|
|
15
|
+
readonly dkmsInstanceId?: string | ros.IResolvable;
|
|
12
16
|
/**
|
|
13
17
|
* Property enable: Specifies whether the key is enabled. Defaults to true.
|
|
14
18
|
*/
|
|
@@ -22,7 +26,10 @@ export interface KeyProps {
|
|
|
22
26
|
*/
|
|
23
27
|
readonly keySpec?: string | ros.IResolvable;
|
|
24
28
|
/**
|
|
25
|
-
* Property keyUsage: The
|
|
29
|
+
* Property keyUsage: The usage of the CMK. Valid values:
|
|
30
|
+
* ENCRYPT/DECRYPT: encrypts or decrypts data.
|
|
31
|
+
* SIGN/VERIFY: generates or verifies a digital signature.
|
|
32
|
+
* If the CMK supports signature verification, the default value is SIGN/VERIFY. If the CMK does not support signature verification, the default value is ENCRYPT/DECRYPT.
|
|
26
33
|
*/
|
|
27
34
|
readonly keyUsage?: string | ros.IResolvable;
|
|
28
35
|
/**
|
package/lib/key.js
CHANGED
|
@@ -21,15 +21,16 @@ class Key extends ros.Resource {
|
|
|
21
21
|
protectionLevel: props.protectionLevel,
|
|
22
22
|
description: props.description,
|
|
23
23
|
rotationInterval: props.rotationInterval,
|
|
24
|
-
enableAutomaticRotation: props.enableAutomaticRotation,
|
|
25
24
|
pendingWindowInDays: props.pendingWindowInDays === undefined || props.pendingWindowInDays === null ? 30 : props.pendingWindowInDays,
|
|
25
|
+
enableAutomaticRotation: props.enableAutomaticRotation,
|
|
26
26
|
keySpec: props.keySpec,
|
|
27
27
|
enable: props.enable === undefined || props.enable === null ? true : props.enable,
|
|
28
|
-
keyUsage: props.keyUsage
|
|
28
|
+
keyUsage: props.keyUsage,
|
|
29
|
+
dkmsInstanceId: props.dkmsInstanceId,
|
|
29
30
|
}, enableResourcePropertyConstraint && this.stack.enableResourcePropertyConstraint);
|
|
30
31
|
this.resource = rosKey;
|
|
31
32
|
this.attrKeyId = rosKey.attrKeyId;
|
|
32
33
|
}
|
|
33
34
|
}
|
|
34
35
|
exports.Key = Key;
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsia2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDhDQUE4QztBQUM5QyxtREFBeUM7QUFFdEIsNEZBRlYsc0JBQU0sT0FFZTtBQTBEOUI7O0dBRUc7QUFDSCxNQUFhLEdBQUksU0FBUSxHQUFHLENBQUMsUUFBUTtJQVlqQzs7Ozs7O09BTUc7SUFDSCxZQUFZLEtBQW9CLEVBQUUsRUFBVSxFQUFFLFFBQWtCLEVBQUUsRUFBRSxtQ0FBMkMsSUFBSTtRQUMvRyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sTUFBTSxHQUFHLElBQUksc0JBQU0sQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFHO1lBQ2pDLGVBQWUsRUFBRSxLQUFLLENBQUMsZUFBZTtZQUN0QyxXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQjtZQUN4QyxtQkFBbUIsRUFBRSxLQUFLLENBQUMsbUJBQW1CLEtBQUssU0FBUyxJQUFJLEtBQUssQ0FBQyxtQkFBbUIsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLG1CQUFtQjtZQUNuSSx1QkFBdUIsRUFBRSxLQUFLLENBQUMsdUJBQXVCO1lBQ3RELE9BQU8sRUFBRSxLQUFLLENBQUMsT0FBTztZQUN0QixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sS0FBSyxTQUFTLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU07WUFDakYsUUFBUSxFQUFFLEtBQUssQ0FBQyxRQUFRO1lBQ3hCLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYztTQUN2QyxFQUFFLGdDQUFnQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztRQUNwRixJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQztRQUN2QixJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7SUFDdEMsQ0FBQztDQUNKO0FBcENELGtCQW9DQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHJvcyBmcm9tICdAYWxpY2xvdWQvcm9zLWNkay1jb3JlJztcbmltcG9ydCB7IFJvc0tleSB9IGZyb20gJy4va21zLmdlbmVyYXRlZCc7XG4vLyBHZW5lcmF0ZWQgZnJvbSB0aGUgQWxpQ2xvdWQgUk9TIFJlc291cmNlIFNwZWNpZmljYXRpb25cbmV4cG9ydCB7IFJvc0tleSBhcyBLZXlQcm9wZXJ0eSB9O1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGRlZmluaW5nIGEgYEFMSVlVTjo6S01TOjpLZXlgXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgS2V5UHJvcHMge1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgZGVzY3JpcHRpb246IFRoZSBkZXNjcmlwdGlvbiBvZiB0aGUgQ01LLiBMZW5ndGggY29uc3RyYWludHM6IE1pbmltdW0gbGVuZ3RoIG9mIDAgY2hhcmFjdGVycy4gTWF4aW11bSBsZW5ndGggb2YgODE5MiBjaGFyYWN0ZXJzLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IGRlc2NyaXB0aW9uPzogc3RyaW5nIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgZGttc0luc3RhbmNlSWQ6IFRoZSBJRCBvZiB0aGUgZGVkaWNhdGVkIEtNUyBpbnN0YW5jZS5cbiAgICAgKi9cbiAgICByZWFkb25seSBka21zSW5zdGFuY2VJZD86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IGVuYWJsZTogU3BlY2lmaWVzIHdoZXRoZXIgdGhlIGtleSBpcyBlbmFibGVkLiBEZWZhdWx0cyB0byB0cnVlLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IGVuYWJsZT86IGJvb2xlYW4gfCByb3MuSVJlc29sdmFibGU7XG5cbiAgICAvKipcbiAgICAgKiBQcm9wZXJ0eSBlbmFibGVBdXRvbWF0aWNSb3RhdGlvbjogV2hldGhlciB0byBlbmFibGUgYXV0b21hdGljIGtleSByb3RhdGlvbi4gVmFsaWQgdmFsdWU6IHRydWUvZmFsc2UgKGRlZmF1bHQpXG4gICAgICovXG4gICAgcmVhZG9ubHkgZW5hYmxlQXV0b21hdGljUm90YXRpb24/OiBib29sZWFuIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkga2V5U3BlYzogS2V5IHR5cGUuIFZhbGlkIHZhbHVlOiBBbGl5dW5fQUVTXzI1Ni9BbGl5dW5fU000L1JTQV8yMDQ4L0VDX1AyNTYvRUNfUDI1NksvRUNfU00yXG4gICAgICovXG4gICAgcmVhZG9ubHkga2V5U3BlYz86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IGtleVVzYWdlOiBUaGUgdXNhZ2Ugb2YgdGhlIENNSy4gVmFsaWQgdmFsdWVzOlxuICAgICAqIEVOQ1JZUFQvREVDUllQVDogZW5jcnlwdHMgb3IgZGVjcnlwdHMgZGF0YS5cbiAgICAgKiBTSUdOL1ZFUklGWTogZ2VuZXJhdGVzIG9yIHZlcmlmaWVzIGEgZGlnaXRhbCBzaWduYXR1cmUuXG4gICAgICogSWYgdGhlIENNSyBzdXBwb3J0cyBzaWduYXR1cmUgdmVyaWZpY2F0aW9uLCB0aGUgZGVmYXVsdCB2YWx1ZSBpcyBTSUdOL1ZFUklGWS4gSWYgdGhlIENNSyBkb2VzIG5vdCBzdXBwb3J0IHNpZ25hdHVyZSB2ZXJpZmljYXRpb24sIHRoZSBkZWZhdWx0IHZhbHVlIGlzIEVOQ1JZUFQvREVDUllQVC5cbiAgICAgKi9cbiAgICByZWFkb25seSBrZXlVc2FnZT86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHBlbmRpbmdXaW5kb3dJbkRheXM6IFRoZSB3YWl0aW5nIHBlcmlvZCwgc3BlY2lmaWVkIGluIG51bWJlciBvZiBkYXlzLiBEdXJpbmcgdGhpcyBwZXJpb2QsIHlvdSBjYW4gY2FuY2VsIHRoZSBDTUsgaW4gUGVuZGluZ0RlbGV0aW9uIHN0YXR1cy4gQWZ0ZXIgdGhlIHdhaXRpbmcgcGVyaW9kIGV4cGlyZXMsIHlvdSBjYW5ub3QgY2FuY2VsIHRoZSBkZWxldGlvbi4gVGhlIHZhbHVlIG11c3QgYmUgYmV0d2VlbiA3IGFuZCAzNjYuIERlZmF1bHQgdmFsdWUgaXMgMzAuXG4gICAgICovXG4gICAgcmVhZG9ubHkgcGVuZGluZ1dpbmRvd0luRGF5cz86IG51bWJlciB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHByb3RlY3Rpb25MZXZlbDogVGhlIHByb3RlY3Rpb24gbGV2ZWwgb2YgdGhlIENNSyB0byBjcmVhdGUuIFZhbGlkIHZhbHVlOiBTT0ZUV0FSRSBhbmQgSFNNLiBXaGVuIHRoaXMgcGFyYW1ldGVyIGlzIHNldCB0byBIU006XG4gICAgICogSWYgdGhlIE9yaWdpbiBwYXJhbWV0ZXIgaXMgc2V0IHRvIEFsaXl1bl9LTVMsIHRoZSBDTUsgaXMgY3JlYXRlZCBpbiBNYW5hZ2VkIEhTTS5cbiAgICAgKiBJZiB0aGUgT3JpZ2luIHBhcmFtZXRlciBpcyBzZXQgdG8gRVhURVJOQUwsIHlvdSBjYW4gaW1wb3J0IGV4dGVybmFsIGtleXMgdG8gTWFuYWdlZCBIU00uXG4gICAgICovXG4gICAgcmVhZG9ubHkgcHJvdGVjdGlvbkxldmVsPzogc3RyaW5nIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgcm90YXRpb25JbnRlcnZhbDogVGhlIHRpbWUgcGVyaW9kIGZvciBhdXRvbWF0aWMgcm90YXRpb24uIFRoZSBmb3JtYXQgaXMgaW50ZWdlclt1bml0XSwgd2hlcmUgaW50ZWdlciByZXByZXNlbnRzIHRoZSBsZW5ndGggb2YgdGltZSBhbmQgdW5pdCByZXByZXNlbnRzIHRoZSB0aW1lIHVuaXQuIFRoZSBsZWdhbCB1bml0IHVuaXRzIGFyZTogZCAoZGF5KSwgaCAoaG91ciksIG0gKG1pbnV0ZSksIHMgKHNlY29uZCkuIDdkIG9yIDYwNDgwMHMgYm90aCByZXByZXNlbnQgYSA3LWRheSBjeWNsZS4gVmFsdWU6IDd+NzMwIGRheXMuXG4gICAgICovXG4gICAgcmVhZG9ubHkgcm90YXRpb25JbnRlcnZhbD86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcbn1cblxuLyoqXG4gKiBBIFJPUyByZXNvdXJjZSB0eXBlOiAgYEFMSVlVTjo6S01TOjpLZXlgXG4gKi9cbmV4cG9ydCBjbGFzcyBLZXkgZXh0ZW5kcyByb3MuUmVzb3VyY2Uge1xuXG4gICAgLyoqXG4gICAgICogQSBmYWN0b3J5IG1ldGhvZCB0aGF0IGNyZWF0ZXMgYSBuZXcgaW5zdGFuY2Ugb2YgdGhpcyBjbGFzcyBmcm9tIGFuIG9iamVjdFxuICAgICAqIGNvbnRhaW5pbmcgdGhlIHByb3BlcnRpZXMgb2YgdGhpcyBST1MgcmVzb3VyY2UsIHdoaWNoIHdpbGwgYmUgYXNzaWduZWQgdG8gUk9TIHJlc291cmNlLlxuICAgICAqL1xuXG4gICAgLyoqXG4gICAgICogQXR0cmlidXRlIEtleUlkOiBUaGUgZ2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBDTUsuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGF0dHJLZXlJZDogcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgbmV3IGBBTElZVU46OktNUzo6S2V5YC5cbiAgICAgKlxuICAgICAqIFBhcmFtIHNjb3BlIC0gc2NvcGUgaW4gd2hpY2ggdGhpcyByZXNvdXJjZSBpcyBkZWZpbmVkXG4gICAgICogUGFyYW0gaWQgICAgLSBzY29wZWQgaWQgb2YgdGhlIHJlc291cmNlXG4gICAgICogUGFyYW0gcHJvcHMgLSByZXNvdXJjZSBwcm9wZXJ0aWVzXG4gICAgICovXG4gICAgY29uc3RydWN0b3Ioc2NvcGU6IHJvcy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBLZXlQcm9wcyA9IHt9LCBlbmFibGVSZXNvdXJjZVByb3BlcnR5Q29uc3RyYWludDpib29sZWFuID0gdHJ1ZSkge1xuICAgICAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgICAgIGNvbnN0IHJvc0tleSA9IG5ldyBSb3NLZXkodGhpcywgaWQsICB7XG4gICAgICAgICAgICBwcm90ZWN0aW9uTGV2ZWw6IHByb3BzLnByb3RlY3Rpb25MZXZlbCxcbiAgICAgICAgICAgIGRlc2NyaXB0aW9uOiBwcm9wcy5kZXNjcmlwdGlvbixcbiAgICAgICAgICAgIHJvdGF0aW9uSW50ZXJ2YWw6IHByb3BzLnJvdGF0aW9uSW50ZXJ2YWwsXG4gICAgICAgICAgICBwZW5kaW5nV2luZG93SW5EYXlzOiBwcm9wcy5wZW5kaW5nV2luZG93SW5EYXlzID09PSB1bmRlZmluZWQgfHwgcHJvcHMucGVuZGluZ1dpbmRvd0luRGF5cyA9PT0gbnVsbCA/IDMwIDogcHJvcHMucGVuZGluZ1dpbmRvd0luRGF5cyxcbiAgICAgICAgICAgIGVuYWJsZUF1dG9tYXRpY1JvdGF0aW9uOiBwcm9wcy5lbmFibGVBdXRvbWF0aWNSb3RhdGlvbixcbiAgICAgICAgICAgIGtleVNwZWM6IHByb3BzLmtleVNwZWMsXG4gICAgICAgICAgICBlbmFibGU6IHByb3BzLmVuYWJsZSA9PT0gdW5kZWZpbmVkIHx8IHByb3BzLmVuYWJsZSA9PT0gbnVsbCA/IHRydWUgOiBwcm9wcy5lbmFibGUsXG4gICAgICAgICAgICBrZXlVc2FnZTogcHJvcHMua2V5VXNhZ2UsXG4gICAgICAgICAgICBka21zSW5zdGFuY2VJZDogcHJvcHMuZGttc0luc3RhbmNlSWQsXG4gICAgICAgIH0sIGVuYWJsZVJlc291cmNlUHJvcGVydHlDb25zdHJhaW50ICYmIHRoaXMuc3RhY2suZW5hYmxlUmVzb3VyY2VQcm9wZXJ0eUNvbnN0cmFpbnQpO1xuICAgICAgICB0aGlzLnJlc291cmNlID0gcm9zS2V5O1xuICAgICAgICB0aGlzLmF0dHJLZXlJZCA9IHJvc0tleS5hdHRyS2V5SWQ7XG4gICAgfVxufVxuIl19
|
package/lib/kms.generated.d.ts
CHANGED
|
@@ -58,6 +58,10 @@ export interface RosKeyProps {
|
|
|
58
58
|
* @Property description: The description of the CMK. Length constraints: Minimum length of 0 characters. Maximum length of 8192 characters.
|
|
59
59
|
*/
|
|
60
60
|
readonly description?: string | ros.IResolvable;
|
|
61
|
+
/**
|
|
62
|
+
* @Property dkmsInstanceId: The ID of the dedicated KMS instance.
|
|
63
|
+
*/
|
|
64
|
+
readonly dkmsInstanceId?: string | ros.IResolvable;
|
|
61
65
|
/**
|
|
62
66
|
* @Property enable: Specifies whether the key is enabled. Defaults to true.
|
|
63
67
|
*/
|
|
@@ -71,7 +75,10 @@ export interface RosKeyProps {
|
|
|
71
75
|
*/
|
|
72
76
|
readonly keySpec?: string | ros.IResolvable;
|
|
73
77
|
/**
|
|
74
|
-
* @Property keyUsage: The
|
|
78
|
+
* @Property keyUsage: The usage of the CMK. Valid values:
|
|
79
|
+
* ENCRYPT/DECRYPT: encrypts or decrypts data.
|
|
80
|
+
* SIGN/VERIFY: generates or verifies a digital signature.
|
|
81
|
+
* If the CMK supports signature verification, the default value is SIGN/VERIFY. If the CMK does not support signature verification, the default value is ENCRYPT/DECRYPT.
|
|
75
82
|
*/
|
|
76
83
|
readonly keyUsage?: string | ros.IResolvable;
|
|
77
84
|
/**
|
|
@@ -110,6 +117,10 @@ export declare class RosKey extends ros.RosResource {
|
|
|
110
117
|
* @Property description: The description of the CMK. Length constraints: Minimum length of 0 characters. Maximum length of 8192 characters.
|
|
111
118
|
*/
|
|
112
119
|
description: string | ros.IResolvable | undefined;
|
|
120
|
+
/**
|
|
121
|
+
* @Property dkmsInstanceId: The ID of the dedicated KMS instance.
|
|
122
|
+
*/
|
|
123
|
+
dkmsInstanceId: string | ros.IResolvable | undefined;
|
|
113
124
|
/**
|
|
114
125
|
* @Property enable: Specifies whether the key is enabled. Defaults to true.
|
|
115
126
|
*/
|
|
@@ -123,7 +134,10 @@ export declare class RosKey extends ros.RosResource {
|
|
|
123
134
|
*/
|
|
124
135
|
keySpec: string | ros.IResolvable | undefined;
|
|
125
136
|
/**
|
|
126
|
-
* @Property keyUsage: The
|
|
137
|
+
* @Property keyUsage: The usage of the CMK. Valid values:
|
|
138
|
+
* ENCRYPT/DECRYPT: encrypts or decrypts data.
|
|
139
|
+
* SIGN/VERIFY: generates or verifies a digital signature.
|
|
140
|
+
* If the CMK supports signature verification, the default value is SIGN/VERIFY. If the CMK does not support signature verification, the default value is ENCRYPT/DECRYPT.
|
|
127
141
|
*/
|
|
128
142
|
keyUsage: string | ros.IResolvable | undefined;
|
|
129
143
|
/**
|
|
@@ -179,6 +193,16 @@ export interface RosSecretProps {
|
|
|
179
193
|
* @Property description: The description of the secret.
|
|
180
194
|
*/
|
|
181
195
|
readonly description?: string | ros.IResolvable;
|
|
196
|
+
/**
|
|
197
|
+
* @Property dkmsInstanceId: The ID of the dedicated KMS instance.
|
|
198
|
+
*/
|
|
199
|
+
readonly dkmsInstanceId?: string | ros.IResolvable;
|
|
200
|
+
/**
|
|
201
|
+
* @Property enableAutomaticRotation: Specifies whether to enable automatic rotation. Valid values:
|
|
202
|
+
* true: specifies to enable automatic rotation.
|
|
203
|
+
* false: specifies to disable automatic rotation. This is the default value.
|
|
204
|
+
*/
|
|
205
|
+
readonly enableAutomaticRotation?: boolean | ros.IResolvable;
|
|
182
206
|
/**
|
|
183
207
|
* @Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.
|
|
184
208
|
* If you do not specify this parameter, Secrets Manager automatically creates an encryption
|
|
@@ -186,6 +210,12 @@ export interface RosSecretProps {
|
|
|
186
210
|
* Note The KMS CMK must be a symmetric key.
|
|
187
211
|
*/
|
|
188
212
|
readonly encryptionKeyId?: string | ros.IResolvable;
|
|
213
|
+
/**
|
|
214
|
+
* @Property extendedConfig: The extended configuration of the secret. This parameter specifies the properties of the secret of the specific type.
|
|
215
|
+
*/
|
|
216
|
+
readonly extendedConfig?: {
|
|
217
|
+
[key: string]: (any | ros.IResolvable);
|
|
218
|
+
} | ros.IResolvable;
|
|
189
219
|
/**
|
|
190
220
|
* @Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:
|
|
191
221
|
* true
|
|
@@ -196,12 +226,26 @@ export interface RosSecretProps {
|
|
|
196
226
|
* @Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30
|
|
197
227
|
*/
|
|
198
228
|
readonly recoveryWindowInDays?: number | ros.IResolvable;
|
|
229
|
+
/**
|
|
230
|
+
* @Property rotationInterval: The interval for automatic rotation. Valid values: 6 hours to 8,760 hours (365 days).
|
|
231
|
+
* The value is in the integer[unit] format.
|
|
232
|
+
* The unit can be d (day), h (hour), m (minute), or s (second). For example, both 7d and 604800s indicate a seven-day interval.
|
|
233
|
+
*/
|
|
234
|
+
readonly rotationInterval?: string | ros.IResolvable;
|
|
199
235
|
/**
|
|
200
236
|
* @Property secretDataType: The type of the secret value. Valid values:
|
|
201
237
|
* text (default value)
|
|
202
238
|
* binary
|
|
203
239
|
*/
|
|
204
240
|
readonly secretDataType?: string | ros.IResolvable;
|
|
241
|
+
/**
|
|
242
|
+
* @Property secretType: The type of the secret. Valid values:
|
|
243
|
+
* Generic: specifies a generic secret.
|
|
244
|
+
* Rds: specifies a managed ApsaraDB RDS secret.
|
|
245
|
+
* RAMCredentials: specifies a managed RAM secret.
|
|
246
|
+
* ECS: specifies a managed ECS secret.
|
|
247
|
+
*/
|
|
248
|
+
readonly secretType?: string | ros.IResolvable;
|
|
205
249
|
/**
|
|
206
250
|
* @Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with "ACSCurrent".
|
|
207
251
|
*/
|
|
@@ -246,6 +290,16 @@ export declare class RosSecret extends ros.RosResource {
|
|
|
246
290
|
* @Property description: The description of the secret.
|
|
247
291
|
*/
|
|
248
292
|
description: string | ros.IResolvable | undefined;
|
|
293
|
+
/**
|
|
294
|
+
* @Property dkmsInstanceId: The ID of the dedicated KMS instance.
|
|
295
|
+
*/
|
|
296
|
+
dkmsInstanceId: string | ros.IResolvable | undefined;
|
|
297
|
+
/**
|
|
298
|
+
* @Property enableAutomaticRotation: Specifies whether to enable automatic rotation. Valid values:
|
|
299
|
+
* true: specifies to enable automatic rotation.
|
|
300
|
+
* false: specifies to disable automatic rotation. This is the default value.
|
|
301
|
+
*/
|
|
302
|
+
enableAutomaticRotation: boolean | ros.IResolvable | undefined;
|
|
249
303
|
/**
|
|
250
304
|
* @Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.
|
|
251
305
|
* If you do not specify this parameter, Secrets Manager automatically creates an encryption
|
|
@@ -253,6 +307,12 @@ export declare class RosSecret extends ros.RosResource {
|
|
|
253
307
|
* Note The KMS CMK must be a symmetric key.
|
|
254
308
|
*/
|
|
255
309
|
encryptionKeyId: string | ros.IResolvable | undefined;
|
|
310
|
+
/**
|
|
311
|
+
* @Property extendedConfig: The extended configuration of the secret. This parameter specifies the properties of the secret of the specific type.
|
|
312
|
+
*/
|
|
313
|
+
extendedConfig: {
|
|
314
|
+
[key: string]: (any | ros.IResolvable);
|
|
315
|
+
} | ros.IResolvable | undefined;
|
|
256
316
|
/**
|
|
257
317
|
* @Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:
|
|
258
318
|
* true
|
|
@@ -263,12 +323,26 @@ export declare class RosSecret extends ros.RosResource {
|
|
|
263
323
|
* @Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30
|
|
264
324
|
*/
|
|
265
325
|
recoveryWindowInDays: number | ros.IResolvable | undefined;
|
|
326
|
+
/**
|
|
327
|
+
* @Property rotationInterval: The interval for automatic rotation. Valid values: 6 hours to 8,760 hours (365 days).
|
|
328
|
+
* The value is in the integer[unit] format.
|
|
329
|
+
* The unit can be d (day), h (hour), m (minute), or s (second). For example, both 7d and 604800s indicate a seven-day interval.
|
|
330
|
+
*/
|
|
331
|
+
rotationInterval: string | ros.IResolvable | undefined;
|
|
266
332
|
/**
|
|
267
333
|
* @Property secretDataType: The type of the secret value. Valid values:
|
|
268
334
|
* text (default value)
|
|
269
335
|
* binary
|
|
270
336
|
*/
|
|
271
337
|
secretDataType: string | ros.IResolvable | undefined;
|
|
338
|
+
/**
|
|
339
|
+
* @Property secretType: The type of the secret. Valid values:
|
|
340
|
+
* Generic: specifies a generic secret.
|
|
341
|
+
* Rds: specifies a managed ApsaraDB RDS secret.
|
|
342
|
+
* RAMCredentials: specifies a managed RAM secret.
|
|
343
|
+
* ECS: specifies a managed ECS secret.
|
|
344
|
+
*/
|
|
345
|
+
secretType: string | ros.IResolvable | undefined;
|
|
272
346
|
/**
|
|
273
347
|
* @Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with "ACSCurrent".
|
|
274
348
|
*/
|
package/lib/kms.generated.js
CHANGED
|
@@ -102,7 +102,6 @@ function RosKeyPropsValidator(properties) {
|
|
|
102
102
|
}
|
|
103
103
|
errors.collect(ros.propertyValidator('description', ros.validateString)(properties.description));
|
|
104
104
|
errors.collect(ros.propertyValidator('rotationInterval', ros.validateString)(properties.rotationInterval));
|
|
105
|
-
errors.collect(ros.propertyValidator('enableAutomaticRotation', ros.validateBoolean)(properties.enableAutomaticRotation));
|
|
106
105
|
if (properties.pendingWindowInDays && (typeof properties.pendingWindowInDays) !== 'object') {
|
|
107
106
|
errors.collect(ros.propertyValidator('pendingWindowInDays', ros.validateRange)({
|
|
108
107
|
data: properties.pendingWindowInDays,
|
|
@@ -111,9 +110,11 @@ function RosKeyPropsValidator(properties) {
|
|
|
111
110
|
}));
|
|
112
111
|
}
|
|
113
112
|
errors.collect(ros.propertyValidator('pendingWindowInDays', ros.validateNumber)(properties.pendingWindowInDays));
|
|
113
|
+
errors.collect(ros.propertyValidator('enableAutomaticRotation', ros.validateBoolean)(properties.enableAutomaticRotation));
|
|
114
114
|
errors.collect(ros.propertyValidator('keySpec', ros.validateString)(properties.keySpec));
|
|
115
115
|
errors.collect(ros.propertyValidator('enable', ros.validateBoolean)(properties.enable));
|
|
116
116
|
errors.collect(ros.propertyValidator('keyUsage', ros.validateString)(properties.keyUsage));
|
|
117
|
+
errors.collect(ros.propertyValidator('dkmsInstanceId', ros.validateString)(properties.dkmsInstanceId));
|
|
117
118
|
return errors.wrap('supplied properties not correct for "RosKeyProps"');
|
|
118
119
|
}
|
|
119
120
|
/**
|
|
@@ -133,6 +134,7 @@ function rosKeyPropsToRosTemplate(properties, enableResourcePropertyConstraint)
|
|
|
133
134
|
}
|
|
134
135
|
return {
|
|
135
136
|
Description: ros.stringToRosTemplate(properties.description),
|
|
137
|
+
DKMSInstanceId: ros.stringToRosTemplate(properties.dkmsInstanceId),
|
|
136
138
|
Enable: ros.booleanToRosTemplate(properties.enable),
|
|
137
139
|
EnableAutomaticRotation: ros.booleanToRosTemplate(properties.enableAutomaticRotation),
|
|
138
140
|
KeySpec: ros.stringToRosTemplate(properties.keySpec),
|
|
@@ -158,6 +160,7 @@ class RosKey extends ros.RosResource {
|
|
|
158
160
|
this.attrKeyId = this.getAtt('KeyId');
|
|
159
161
|
this.enableResourcePropertyConstraint = enableResourcePropertyConstraint;
|
|
160
162
|
this.description = props.description;
|
|
163
|
+
this.dkmsInstanceId = props.dkmsInstanceId;
|
|
161
164
|
this.enable = props.enable;
|
|
162
165
|
this.enableAutomaticRotation = props.enableAutomaticRotation;
|
|
163
166
|
this.keySpec = props.keySpec;
|
|
@@ -169,6 +172,7 @@ class RosKey extends ros.RosResource {
|
|
|
169
172
|
get rosProperties() {
|
|
170
173
|
return {
|
|
171
174
|
description: this.description,
|
|
175
|
+
dkmsInstanceId: this.dkmsInstanceId,
|
|
172
176
|
enable: this.enable,
|
|
173
177
|
enableAutomaticRotation: this.enableAutomaticRotation,
|
|
174
178
|
keySpec: this.keySpec,
|
|
@@ -201,9 +205,9 @@ function RosSecretPropsValidator(properties) {
|
|
|
201
205
|
const errors = new ros.ValidationResults();
|
|
202
206
|
errors.collect(ros.propertyValidator('versionId', ros.requiredValidator)(properties.versionId));
|
|
203
207
|
errors.collect(ros.propertyValidator('versionId', ros.validateString)(properties.versionId));
|
|
204
|
-
errors.collect(ros.propertyValidator('secretName', ros.requiredValidator)(properties.secretName));
|
|
205
|
-
errors.collect(ros.propertyValidator('secretName', ros.validateString)(properties.secretName));
|
|
206
208
|
errors.collect(ros.propertyValidator('description', ros.validateString)(properties.description));
|
|
209
|
+
errors.collect(ros.propertyValidator('rotationInterval', ros.validateString)(properties.rotationInterval));
|
|
210
|
+
errors.collect(ros.propertyValidator('secretType', ros.validateString)(properties.secretType));
|
|
207
211
|
if (properties.secretDataType && (typeof properties.secretDataType) !== 'object') {
|
|
208
212
|
errors.collect(ros.propertyValidator('secretDataType', ros.validateAllowedValues)({
|
|
209
213
|
data: properties.secretDataType,
|
|
@@ -211,8 +215,7 @@ function RosSecretPropsValidator(properties) {
|
|
|
211
215
|
}));
|
|
212
216
|
}
|
|
213
217
|
errors.collect(ros.propertyValidator('secretDataType', ros.validateString)(properties.secretDataType));
|
|
214
|
-
errors.collect(ros.propertyValidator('
|
|
215
|
-
errors.collect(ros.propertyValidator('secretData', ros.validateString)(properties.secretData));
|
|
218
|
+
errors.collect(ros.propertyValidator('dkmsInstanceId', ros.validateString)(properties.dkmsInstanceId));
|
|
216
219
|
if (properties.versionStages && (Array.isArray(properties.versionStages) || (typeof properties.versionStages) === 'string')) {
|
|
217
220
|
errors.collect(ros.propertyValidator('versionStages', ros.validateLength)({
|
|
218
221
|
data: properties.versionStages.length,
|
|
@@ -221,6 +224,12 @@ function RosSecretPropsValidator(properties) {
|
|
|
221
224
|
}));
|
|
222
225
|
}
|
|
223
226
|
errors.collect(ros.propertyValidator('versionStages', ros.listValidator(ros.validateString))(properties.versionStages));
|
|
227
|
+
errors.collect(ros.propertyValidator('secretName', ros.requiredValidator)(properties.secretName));
|
|
228
|
+
errors.collect(ros.propertyValidator('secretName', ros.validateString)(properties.secretName));
|
|
229
|
+
errors.collect(ros.propertyValidator('enableAutomaticRotation', ros.validateBoolean)(properties.enableAutomaticRotation));
|
|
230
|
+
errors.collect(ros.propertyValidator('extendedConfig', ros.hashValidator(ros.validateAny))(properties.extendedConfig));
|
|
231
|
+
errors.collect(ros.propertyValidator('secretData', ros.requiredValidator)(properties.secretData));
|
|
232
|
+
errors.collect(ros.propertyValidator('secretData', ros.validateString)(properties.secretData));
|
|
224
233
|
errors.collect(ros.propertyValidator('encryptionKeyId', ros.validateString)(properties.encryptionKeyId));
|
|
225
234
|
errors.collect(ros.propertyValidator('recoveryWindowInDays', ros.validateNumber)(properties.recoveryWindowInDays));
|
|
226
235
|
errors.collect(ros.propertyValidator('forceDeleteWithoutRecovery', ros.validateBoolean)(properties.forceDeleteWithoutRecovery));
|
|
@@ -246,10 +255,15 @@ function rosSecretPropsToRosTemplate(properties, enableResourcePropertyConstrain
|
|
|
246
255
|
SecretName: ros.stringToRosTemplate(properties.secretName),
|
|
247
256
|
VersionId: ros.stringToRosTemplate(properties.versionId),
|
|
248
257
|
Description: ros.stringToRosTemplate(properties.description),
|
|
258
|
+
DKMSInstanceId: ros.stringToRosTemplate(properties.dkmsInstanceId),
|
|
259
|
+
EnableAutomaticRotation: ros.booleanToRosTemplate(properties.enableAutomaticRotation),
|
|
249
260
|
EncryptionKeyId: ros.stringToRosTemplate(properties.encryptionKeyId),
|
|
261
|
+
ExtendedConfig: ros.hashMapper(ros.objectToRosTemplate)(properties.extendedConfig),
|
|
250
262
|
ForceDeleteWithoutRecovery: ros.booleanToRosTemplate(properties.forceDeleteWithoutRecovery),
|
|
251
263
|
RecoveryWindowInDays: ros.numberToRosTemplate(properties.recoveryWindowInDays),
|
|
264
|
+
RotationInterval: ros.stringToRosTemplate(properties.rotationInterval),
|
|
252
265
|
SecretDataType: ros.stringToRosTemplate(properties.secretDataType),
|
|
266
|
+
SecretType: ros.stringToRosTemplate(properties.secretType),
|
|
253
267
|
VersionStages: ros.listMapper(ros.stringToRosTemplate)(properties.versionStages),
|
|
254
268
|
};
|
|
255
269
|
}
|
|
@@ -273,10 +287,15 @@ class RosSecret extends ros.RosResource {
|
|
|
273
287
|
this.secretName = props.secretName;
|
|
274
288
|
this.versionId = props.versionId;
|
|
275
289
|
this.description = props.description;
|
|
290
|
+
this.dkmsInstanceId = props.dkmsInstanceId;
|
|
291
|
+
this.enableAutomaticRotation = props.enableAutomaticRotation;
|
|
276
292
|
this.encryptionKeyId = props.encryptionKeyId;
|
|
293
|
+
this.extendedConfig = props.extendedConfig;
|
|
277
294
|
this.forceDeleteWithoutRecovery = props.forceDeleteWithoutRecovery;
|
|
278
295
|
this.recoveryWindowInDays = props.recoveryWindowInDays;
|
|
296
|
+
this.rotationInterval = props.rotationInterval;
|
|
279
297
|
this.secretDataType = props.secretDataType;
|
|
298
|
+
this.secretType = props.secretType;
|
|
280
299
|
this.versionStages = props.versionStages;
|
|
281
300
|
}
|
|
282
301
|
get rosProperties() {
|
|
@@ -285,10 +304,15 @@ class RosSecret extends ros.RosResource {
|
|
|
285
304
|
secretName: this.secretName,
|
|
286
305
|
versionId: this.versionId,
|
|
287
306
|
description: this.description,
|
|
307
|
+
dkmsInstanceId: this.dkmsInstanceId,
|
|
308
|
+
enableAutomaticRotation: this.enableAutomaticRotation,
|
|
288
309
|
encryptionKeyId: this.encryptionKeyId,
|
|
310
|
+
extendedConfig: this.extendedConfig,
|
|
289
311
|
forceDeleteWithoutRecovery: this.forceDeleteWithoutRecovery,
|
|
290
312
|
recoveryWindowInDays: this.recoveryWindowInDays,
|
|
313
|
+
rotationInterval: this.rotationInterval,
|
|
291
314
|
secretDataType: this.secretDataType,
|
|
315
|
+
secretType: this.secretType,
|
|
292
316
|
versionStages: this.versionStages,
|
|
293
317
|
};
|
|
294
318
|
}
|
|
@@ -301,4 +325,4 @@ exports.RosSecret = RosSecret;
|
|
|
301
325
|
* The resource type name for this resource class.
|
|
302
326
|
*/
|
|
303
327
|
RosSecret.ROS_RESOURCE_TYPE_NAME = "ALIYUN::KMS::Secret";
|
|
304
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kms.generated.js","sourceRoot":"","sources":["kms.generated.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated from the AliCloud ROS Resource Specification\n\nimport * as ros from '@alicloud/ros-cdk-core';\n\n/**\n * Properties for defining a `ALIYUN::KMS::Alias`\n */\nexport interface RosAliasProps {\n\n    /**\n     * @Property aliasName: - The display name of the key. You can use the alias to call APIs such as Encrypt, GenerateDataKey, and DescribeKey. - Not including the prefix, the minimum length of an alias is 1 and the maximum length is 255. - The prefix alias/ must be included.\n     */\n    readonly aliasName: string | ros.IResolvable;\n\n    /**\n     * @Property keyId: Globally unique identifier of the CMK.\n     */\n    readonly keyId: string | ros.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `RosAliasProps`\n *\n * @param properties - the TypeScript properties of a `RosAliasProps`\n *\n * @returns the result of the validation.\n */\nfunction RosAliasPropsValidator(properties: any): ros.ValidationResult {\n    if (!ros.canInspect(properties)) { return ros.VALIDATION_SUCCESS; }\n    const errors = new ros.ValidationResults();\n    errors.collect(ros.propertyValidator('aliasName', ros.requiredValidator)(properties.aliasName));\n    if(properties.aliasName && (Array.isArray(properties.aliasName) || (typeof properties.aliasName) === 'string')) {\n        errors.collect(ros.propertyValidator('aliasName', ros.validateLength)({\n            data: properties.aliasName.length,\n            min: 1,\n            max: 255,\n          }));\n    }\n    errors.collect(ros.propertyValidator('aliasName', ros.validateString)(properties.aliasName));\n    errors.collect(ros.propertyValidator('keyId', ros.requiredValidator)(properties.keyId));\n    errors.collect(ros.propertyValidator('keyId', ros.validateString)(properties.keyId));\n    return errors.wrap('supplied properties not correct for \"RosAliasProps\"');\n}\n\n/**\n * Renders the AliCloud ROS Resource properties of an `ALIYUN::KMS::Alias` resource\n *\n * @param properties - the TypeScript properties of a `RosAliasProps`\n *\n * @returns the AliCloud ROS Resource properties of an `ALIYUN::KMS::Alias` resource.\n */\n// @ts-ignore TS6133\nfunction rosAliasPropsToRosTemplate(properties: any, enableResourcePropertyConstraint: boolean): any {\n    if (!ros.canInspect(properties)) { return properties; }\n    if(enableResourcePropertyConstraint) {\n        RosAliasPropsValidator(properties).assertSuccess();\n    }\n    return {\n      AliasName: ros.stringToRosTemplate(properties.aliasName),\n      KeyId: ros.stringToRosTemplate(properties.keyId),\n    };\n}\n\n/**\n * A ROS template type:  `ALIYUN::KMS::Alias`\n */\nexport class RosAlias extends ros.RosResource {\n    /**\n     * The resource type name for this resource class.\n     */\n    public static readonly ROS_RESOURCE_TYPE_NAME = \"ALIYUN::KMS::Alias\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the properties of this ROS resource.\n     */\n\n    public enableResourcePropertyConstraint: boolean;\n\n\n    /**\n     * @Property aliasName: - The display name of the key. You can use the alias to call APIs such as Encrypt, GenerateDataKey, and DescribeKey. - Not including the prefix, the minimum length of an alias is 1 and the maximum length is 255. - The prefix alias/ must be included.\n     */\n    public aliasName: string | ros.IResolvable;\n\n    /**\n     * @Property keyId: Globally unique identifier of the CMK.\n     */\n    public keyId: string | ros.IResolvable;\n\n    /**\n     * Create a new `ALIYUN::KMS::Alias`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: ros.Construct, id: string, props: RosAliasProps, enableResourcePropertyConstraint: boolean) {\n        super(scope, id, { type: RosAlias.ROS_RESOURCE_TYPE_NAME, properties: props });\n\n        this.enableResourcePropertyConstraint = enableResourcePropertyConstraint;\n        this.aliasName = props.aliasName;\n        this.keyId = props.keyId;\n    }\n\n\n    protected get rosProperties(): { [key: string]: any }  {\n        return {\n            aliasName: this.aliasName,\n            keyId: this.keyId,\n        };\n    }\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return rosAliasPropsToRosTemplate(props, this.enableResourcePropertyConstraint);\n    }\n}\n\n/**\n * Properties for defining a `ALIYUN::KMS::Key`\n */\nexport interface RosKeyProps {\n\n    /**\n     * @Property description: The description of the CMK. Length constraints: Minimum length of 0 characters. Maximum length of 8192 characters.\n     */\n    readonly description?: string | ros.IResolvable;\n\n    /**\n     * @Property enable: Specifies whether the key is enabled. Defaults to true.\n     */\n    readonly enable?: boolean | ros.IResolvable;\n\n    /**\n     * @Property enableAutomaticRotation: Whether to enable automatic key rotation. Valid value: true/false (default)\n     */\n    readonly enableAutomaticRotation?: boolean | ros.IResolvable;\n\n    /**\n     * @Property keySpec: Key type. Valid value: Aliyun_AES_256/Aliyun_SM4/RSA_2048/EC_P256/EC_P256K/EC_SM2\n     */\n    readonly keySpec?: string | ros.IResolvable;\n\n    /**\n     * @Property keyUsage: The intended use of the CMK. Default value: ENCRYPT/DECRYPT.\n     */\n    readonly keyUsage?: string | ros.IResolvable;\n\n    /**\n     * @Property pendingWindowInDays: The waiting period, specified in number of days. During this period, you can cancel the CMK in PendingDeletion status. After the waiting period expires, you cannot cancel the deletion. The value must be between 7 and 366. Default value is 30.\n     */\n    readonly pendingWindowInDays?: number | ros.IResolvable;\n\n    /**\n     * @Property protectionLevel: The protection level of the CMK to create. Valid value: SOFTWARE and HSM. When this parameter is set to HSM:\n     * If the Origin parameter is set to Aliyun_KMS, the CMK is created in Managed HSM.\n     * If the Origin parameter is set to EXTERNAL, you can import external keys to Managed HSM.\n     */\n    readonly protectionLevel?: string | ros.IResolvable;\n\n    /**\n     * @Property rotationInterval: The time period for automatic rotation. The format is integer[unit], where integer represents the length of time and unit represents the time unit. The legal unit units are: d (day), h (hour), m (minute), s (second). 7d or 604800s both represent a 7-day cycle. Value: 7~730 days.\n     */\n    readonly rotationInterval?: string | ros.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `RosKeyProps`\n *\n * @param properties - the TypeScript properties of a `RosKeyProps`\n *\n * @returns the result of the validation.\n */\nfunction RosKeyPropsValidator(properties: any): ros.ValidationResult {\n    if (!ros.canInspect(properties)) { return ros.VALIDATION_SUCCESS; }\n    const errors = new ros.ValidationResults();\n    errors.collect(ros.propertyValidator('protectionLevel', ros.validateString)(properties.protectionLevel));\n    if(properties.description && (Array.isArray(properties.description) || (typeof properties.description) === 'string')) {\n        errors.collect(ros.propertyValidator('description', ros.validateLength)({\n            data: properties.description.length,\n            min: 0,\n            max: 8192,\n          }));\n    }\n    errors.collect(ros.propertyValidator('description', ros.validateString)(properties.description));\n    errors.collect(ros.propertyValidator('rotationInterval', ros.validateString)(properties.rotationInterval));\n    errors.collect(ros.propertyValidator('enableAutomaticRotation', ros.validateBoolean)(properties.enableAutomaticRotation));\n    if(properties.pendingWindowInDays && (typeof properties.pendingWindowInDays) !== 'object') {\n        errors.collect(ros.propertyValidator('pendingWindowInDays', ros.validateRange)({\n            data: properties.pendingWindowInDays,\n            min: 7,\n            max: 366,\n          }));\n    }\n    errors.collect(ros.propertyValidator('pendingWindowInDays', ros.validateNumber)(properties.pendingWindowInDays));\n    errors.collect(ros.propertyValidator('keySpec', ros.validateString)(properties.keySpec));\n    errors.collect(ros.propertyValidator('enable', ros.validateBoolean)(properties.enable));\n    errors.collect(ros.propertyValidator('keyUsage', ros.validateString)(properties.keyUsage));\n    return errors.wrap('supplied properties not correct for \"RosKeyProps\"');\n}\n\n/**\n * Renders the AliCloud ROS Resource properties of an `ALIYUN::KMS::Key` resource\n *\n * @param properties - the TypeScript properties of a `RosKeyProps`\n *\n * @returns the AliCloud ROS Resource properties of an `ALIYUN::KMS::Key` resource.\n */\n// @ts-ignore TS6133\nfunction rosKeyPropsToRosTemplate(properties: any, enableResourcePropertyConstraint: boolean): any {\n    if (!ros.canInspect(properties)) { return properties; }\n    if(enableResourcePropertyConstraint) {\n        RosKeyPropsValidator(properties).assertSuccess();\n    }\n    return {\n      Description: ros.stringToRosTemplate(properties.description),\n      Enable: ros.booleanToRosTemplate(properties.enable),\n      EnableAutomaticRotation: ros.booleanToRosTemplate(properties.enableAutomaticRotation),\n      KeySpec: ros.stringToRosTemplate(properties.keySpec),\n      KeyUsage: ros.stringToRosTemplate(properties.keyUsage),\n      PendingWindowInDays: ros.numberToRosTemplate(properties.pendingWindowInDays),\n      ProtectionLevel: ros.stringToRosTemplate(properties.protectionLevel),\n      RotationInterval: ros.stringToRosTemplate(properties.rotationInterval),\n    };\n}\n\n/**\n * A ROS template type:  `ALIYUN::KMS::Key`\n */\nexport class RosKey extends ros.RosResource {\n    /**\n     * The resource type name for this resource class.\n     */\n    public static readonly ROS_RESOURCE_TYPE_NAME = \"ALIYUN::KMS::Key\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the properties of this ROS resource.\n     */\n\n    /**\n     * @Attribute KeyId: The globally unique identifier for the CMK.\n     */\n    public readonly attrKeyId: ros.IResolvable;\n\n    public enableResourcePropertyConstraint: boolean;\n\n\n    /**\n     * @Property description: The description of the CMK. Length constraints: Minimum length of 0 characters. Maximum length of 8192 characters.\n     */\n    public description: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property enable: Specifies whether the key is enabled. Defaults to true.\n     */\n    public enable: boolean | ros.IResolvable | undefined;\n\n    /**\n     * @Property enableAutomaticRotation: Whether to enable automatic key rotation. Valid value: true/false (default)\n     */\n    public enableAutomaticRotation: boolean | ros.IResolvable | undefined;\n\n    /**\n     * @Property keySpec: Key type. Valid value: Aliyun_AES_256/Aliyun_SM4/RSA_2048/EC_P256/EC_P256K/EC_SM2\n     */\n    public keySpec: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property keyUsage: The intended use of the CMK. Default value: ENCRYPT/DECRYPT.\n     */\n    public keyUsage: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property pendingWindowInDays: The waiting period, specified in number of days. During this period, you can cancel the CMK in PendingDeletion status. After the waiting period expires, you cannot cancel the deletion. The value must be between 7 and 366. Default value is 30.\n     */\n    public pendingWindowInDays: number | ros.IResolvable | undefined;\n\n    /**\n     * @Property protectionLevel: The protection level of the CMK to create. Valid value: SOFTWARE and HSM. When this parameter is set to HSM:\n     * If the Origin parameter is set to Aliyun_KMS, the CMK is created in Managed HSM.\n     * If the Origin parameter is set to EXTERNAL, you can import external keys to Managed HSM.\n     */\n    public protectionLevel: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property rotationInterval: The time period for automatic rotation. The format is integer[unit], where integer represents the length of time and unit represents the time unit. The legal unit units are: d (day), h (hour), m (minute), s (second). 7d or 604800s both represent a 7-day cycle. Value: 7~730 days.\n     */\n    public rotationInterval: string | ros.IResolvable | undefined;\n\n    /**\n     * Create a new `ALIYUN::KMS::Key`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: ros.Construct, id: string, props: RosKeyProps, enableResourcePropertyConstraint: boolean) {\n        super(scope, id, { type: RosKey.ROS_RESOURCE_TYPE_NAME, properties: props });\n        this.attrKeyId = this.getAtt('KeyId');\n\n        this.enableResourcePropertyConstraint = enableResourcePropertyConstraint;\n        this.description = props.description;\n        this.enable = props.enable;\n        this.enableAutomaticRotation = props.enableAutomaticRotation;\n        this.keySpec = props.keySpec;\n        this.keyUsage = props.keyUsage;\n        this.pendingWindowInDays = props.pendingWindowInDays;\n        this.protectionLevel = props.protectionLevel;\n        this.rotationInterval = props.rotationInterval;\n    }\n\n\n    protected get rosProperties(): { [key: string]: any }  {\n        return {\n            description: this.description,\n            enable: this.enable,\n            enableAutomaticRotation: this.enableAutomaticRotation,\n            keySpec: this.keySpec,\n            keyUsage: this.keyUsage,\n            pendingWindowInDays: this.pendingWindowInDays,\n            protectionLevel: this.protectionLevel,\n            rotationInterval: this.rotationInterval,\n        };\n    }\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return rosKeyPropsToRosTemplate(props, this.enableResourcePropertyConstraint);\n    }\n}\n\n/**\n * Properties for defining a `ALIYUN::KMS::Secret`\n */\nexport interface RosSecretProps {\n\n    /**\n     * @Property secretData: The value of the secret that you want to create. Secrets Manager encrypts the secret\n     * value and stores it in the initial version.\n     */\n    readonly secretData: string | ros.IResolvable;\n\n    /**\n     * @Property secretName: The name of the secret.\n     */\n    readonly secretName: string | ros.IResolvable;\n\n    /**\n     * @Property versionId: The version number of the initial version. Version numbers are unique in each secret\n     * object.\n     */\n    readonly versionId: string | ros.IResolvable;\n\n    /**\n     * @Property description: The description of the secret.\n     */\n    readonly description?: string | ros.IResolvable;\n\n    /**\n     * @Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.\n     * If you do not specify this parameter, Secrets Manager automatically creates an encryption\n     * key to encrypt the secret.\n     * Note The KMS CMK must be a symmetric key.\n     */\n    readonly encryptionKeyId?: string | ros.IResolvable;\n\n    /**\n     * @Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:\n     * true\n     * false (default value)\n     */\n    readonly forceDeleteWithoutRecovery?: boolean | ros.IResolvable;\n\n    /**\n     * @Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30\n     */\n    readonly recoveryWindowInDays?: number | ros.IResolvable;\n\n    /**\n     * @Property secretDataType: The type of the secret value. Valid values:\n     * text (default value)\n     * binary\n     */\n    readonly secretDataType?: string | ros.IResolvable;\n\n    /**\n     * @Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with \"ACSCurrent\".\n     */\n    readonly versionStages?: Array<string | ros.IResolvable> | ros.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `RosSecretProps`\n *\n * @param properties - the TypeScript properties of a `RosSecretProps`\n *\n * @returns the result of the validation.\n */\nfunction RosSecretPropsValidator(properties: any): ros.ValidationResult {\n    if (!ros.canInspect(properties)) { return ros.VALIDATION_SUCCESS; }\n    const errors = new ros.ValidationResults();\n    errors.collect(ros.propertyValidator('versionId', ros.requiredValidator)(properties.versionId));\n    errors.collect(ros.propertyValidator('versionId', ros.validateString)(properties.versionId));\n    errors.collect(ros.propertyValidator('secretName', ros.requiredValidator)(properties.secretName));\n    errors.collect(ros.propertyValidator('secretName', ros.validateString)(properties.secretName));\n    errors.collect(ros.propertyValidator('description', ros.validateString)(properties.description));\n    if(properties.secretDataType && (typeof properties.secretDataType) !== 'object') {\n        errors.collect(ros.propertyValidator('secretDataType', ros.validateAllowedValues)({\n          data: properties.secretDataType,\n          allowedValues: [\"text\",\"binary\"],\n        }));\n    }\n    errors.collect(ros.propertyValidator('secretDataType', ros.validateString)(properties.secretDataType));\n    errors.collect(ros.propertyValidator('secretData', ros.requiredValidator)(properties.secretData));\n    errors.collect(ros.propertyValidator('secretData', ros.validateString)(properties.secretData));\n    if(properties.versionStages && (Array.isArray(properties.versionStages) || (typeof properties.versionStages) === 'string')) {\n        errors.collect(ros.propertyValidator('versionStages', ros.validateLength)({\n            data: properties.versionStages.length,\n            min: 1,\n            max: 7,\n          }));\n    }\n    errors.collect(ros.propertyValidator('versionStages', ros.listValidator(ros.validateString))(properties.versionStages));\n    errors.collect(ros.propertyValidator('encryptionKeyId', ros.validateString)(properties.encryptionKeyId));\n    errors.collect(ros.propertyValidator('recoveryWindowInDays', ros.validateNumber)(properties.recoveryWindowInDays));\n    errors.collect(ros.propertyValidator('forceDeleteWithoutRecovery', ros.validateBoolean)(properties.forceDeleteWithoutRecovery));\n    return errors.wrap('supplied properties not correct for \"RosSecretProps\"');\n}\n\n/**\n * Renders the AliCloud ROS Resource properties of an `ALIYUN::KMS::Secret` resource\n *\n * @param properties - the TypeScript properties of a `RosSecretProps`\n *\n * @returns the AliCloud ROS Resource properties of an `ALIYUN::KMS::Secret` resource.\n */\n// @ts-ignore TS6133\nfunction rosSecretPropsToRosTemplate(properties: any, enableResourcePropertyConstraint: boolean): any {\n    if (!ros.canInspect(properties)) { return properties; }\n    if(enableResourcePropertyConstraint) {\n        RosSecretPropsValidator(properties).assertSuccess();\n    }\n    return {\n      SecretData: ros.stringToRosTemplate(properties.secretData),\n      SecretName: ros.stringToRosTemplate(properties.secretName),\n      VersionId: ros.stringToRosTemplate(properties.versionId),\n      Description: ros.stringToRosTemplate(properties.description),\n      EncryptionKeyId: ros.stringToRosTemplate(properties.encryptionKeyId),\n      ForceDeleteWithoutRecovery: ros.booleanToRosTemplate(properties.forceDeleteWithoutRecovery),\n      RecoveryWindowInDays: ros.numberToRosTemplate(properties.recoveryWindowInDays),\n      SecretDataType: ros.stringToRosTemplate(properties.secretDataType),\n      VersionStages: ros.listMapper(ros.stringToRosTemplate)(properties.versionStages),\n    };\n}\n\n/**\n * A ROS template type:  `ALIYUN::KMS::Secret`\n */\nexport class RosSecret extends ros.RosResource {\n    /**\n     * The resource type name for this resource class.\n     */\n    public static readonly ROS_RESOURCE_TYPE_NAME = \"ALIYUN::KMS::Secret\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the properties of this ROS resource.\n     */\n\n    /**\n     * @Attribute Arn: The Alibaba Cloud Resource Name (ARN).\n     */\n    public readonly attrArn: ros.IResolvable;\n\n    /**\n     * @Attribute SecretName: The name of the secret.\n     */\n    public readonly attrSecretName: ros.IResolvable;\n\n    public enableResourcePropertyConstraint: boolean;\n\n\n    /**\n     * @Property secretData: The value of the secret that you want to create. Secrets Manager encrypts the secret\n     * value and stores it in the initial version.\n     */\n    public secretData: string | ros.IResolvable;\n\n    /**\n     * @Property secretName: The name of the secret.\n     */\n    public secretName: string | ros.IResolvable;\n\n    /**\n     * @Property versionId: The version number of the initial version. Version numbers are unique in each secret\n     * object.\n     */\n    public versionId: string | ros.IResolvable;\n\n    /**\n     * @Property description: The description of the secret.\n     */\n    public description: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.\n     * If you do not specify this parameter, Secrets Manager automatically creates an encryption\n     * key to encrypt the secret.\n     * Note The KMS CMK must be a symmetric key.\n     */\n    public encryptionKeyId: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:\n     * true\n     * false (default value)\n     */\n    public forceDeleteWithoutRecovery: boolean | ros.IResolvable | undefined;\n\n    /**\n     * @Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30\n     */\n    public recoveryWindowInDays: number | ros.IResolvable | undefined;\n\n    /**\n     * @Property secretDataType: The type of the secret value. Valid values:\n     * text (default value)\n     * binary\n     */\n    public secretDataType: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with \"ACSCurrent\".\n     */\n    public versionStages: Array<string | ros.IResolvable> | ros.IResolvable | undefined;\n\n    /**\n     * Create a new `ALIYUN::KMS::Secret`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: ros.Construct, id: string, props: RosSecretProps, enableResourcePropertyConstraint: boolean) {\n        super(scope, id, { type: RosSecret.ROS_RESOURCE_TYPE_NAME, properties: props });\n        this.attrArn = this.getAtt('Arn');\n        this.attrSecretName = this.getAtt('SecretName');\n\n        this.enableResourcePropertyConstraint = enableResourcePropertyConstraint;\n        this.secretData = props.secretData;\n        this.secretName = props.secretName;\n        this.versionId = props.versionId;\n        this.description = props.description;\n        this.encryptionKeyId = props.encryptionKeyId;\n        this.forceDeleteWithoutRecovery = props.forceDeleteWithoutRecovery;\n        this.recoveryWindowInDays = props.recoveryWindowInDays;\n        this.secretDataType = props.secretDataType;\n        this.versionStages = props.versionStages;\n    }\n\n\n    protected get rosProperties(): { [key: string]: any }  {\n        return {\n            secretData: this.secretData,\n            secretName: this.secretName,\n            versionId: this.versionId,\n            description: this.description,\n            encryptionKeyId: this.encryptionKeyId,\n            forceDeleteWithoutRecovery: this.forceDeleteWithoutRecovery,\n            recoveryWindowInDays: this.recoveryWindowInDays,\n            secretDataType: this.secretDataType,\n            versionStages: this.versionStages,\n        };\n    }\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return rosSecretPropsToRosTemplate(props, this.enableResourcePropertyConstraint);\n    }\n}\n"]}
|
|
328
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kms.generated.js","sourceRoot":"","sources":["kms.generated.ts"],"names":[],"mappings":"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","sourcesContent":["// Generated from the AliCloud ROS Resource Specification\n\nimport * as ros from '@alicloud/ros-cdk-core';\n\n/**\n * Properties for defining a `ALIYUN::KMS::Alias`\n */\nexport interface RosAliasProps {\n\n    /**\n     * @Property aliasName: - The display name of the key. You can use the alias to call APIs such as Encrypt, GenerateDataKey, and DescribeKey. - Not including the prefix, the minimum length of an alias is 1 and the maximum length is 255. - The prefix alias/ must be included.\n     */\n    readonly aliasName: string | ros.IResolvable;\n\n    /**\n     * @Property keyId: Globally unique identifier of the CMK.\n     */\n    readonly keyId: string | ros.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `RosAliasProps`\n *\n * @param properties - the TypeScript properties of a `RosAliasProps`\n *\n * @returns the result of the validation.\n */\nfunction RosAliasPropsValidator(properties: any): ros.ValidationResult {\n    if (!ros.canInspect(properties)) { return ros.VALIDATION_SUCCESS; }\n    const errors = new ros.ValidationResults();\n    errors.collect(ros.propertyValidator('aliasName', ros.requiredValidator)(properties.aliasName));\n    if(properties.aliasName && (Array.isArray(properties.aliasName) || (typeof properties.aliasName) === 'string')) {\n        errors.collect(ros.propertyValidator('aliasName', ros.validateLength)({\n            data: properties.aliasName.length,\n            min: 1,\n            max: 255,\n          }));\n    }\n    errors.collect(ros.propertyValidator('aliasName', ros.validateString)(properties.aliasName));\n    errors.collect(ros.propertyValidator('keyId', ros.requiredValidator)(properties.keyId));\n    errors.collect(ros.propertyValidator('keyId', ros.validateString)(properties.keyId));\n    return errors.wrap('supplied properties not correct for \"RosAliasProps\"');\n}\n\n/**\n * Renders the AliCloud ROS Resource properties of an `ALIYUN::KMS::Alias` resource\n *\n * @param properties - the TypeScript properties of a `RosAliasProps`\n *\n * @returns the AliCloud ROS Resource properties of an `ALIYUN::KMS::Alias` resource.\n */\n// @ts-ignore TS6133\nfunction rosAliasPropsToRosTemplate(properties: any, enableResourcePropertyConstraint: boolean): any {\n    if (!ros.canInspect(properties)) { return properties; }\n    if(enableResourcePropertyConstraint) {\n        RosAliasPropsValidator(properties).assertSuccess();\n    }\n    return {\n      AliasName: ros.stringToRosTemplate(properties.aliasName),\n      KeyId: ros.stringToRosTemplate(properties.keyId),\n    };\n}\n\n/**\n * A ROS template type:  `ALIYUN::KMS::Alias`\n */\nexport class RosAlias extends ros.RosResource {\n    /**\n     * The resource type name for this resource class.\n     */\n    public static readonly ROS_RESOURCE_TYPE_NAME = \"ALIYUN::KMS::Alias\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the properties of this ROS resource.\n     */\n\n    public enableResourcePropertyConstraint: boolean;\n\n\n    /**\n     * @Property aliasName: - The display name of the key. You can use the alias to call APIs such as Encrypt, GenerateDataKey, and DescribeKey. - Not including the prefix, the minimum length of an alias is 1 and the maximum length is 255. - The prefix alias/ must be included.\n     */\n    public aliasName: string | ros.IResolvable;\n\n    /**\n     * @Property keyId: Globally unique identifier of the CMK.\n     */\n    public keyId: string | ros.IResolvable;\n\n    /**\n     * Create a new `ALIYUN::KMS::Alias`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: ros.Construct, id: string, props: RosAliasProps, enableResourcePropertyConstraint: boolean) {\n        super(scope, id, { type: RosAlias.ROS_RESOURCE_TYPE_NAME, properties: props });\n\n        this.enableResourcePropertyConstraint = enableResourcePropertyConstraint;\n        this.aliasName = props.aliasName;\n        this.keyId = props.keyId;\n    }\n\n\n    protected get rosProperties(): { [key: string]: any }  {\n        return {\n            aliasName: this.aliasName,\n            keyId: this.keyId,\n        };\n    }\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return rosAliasPropsToRosTemplate(props, this.enableResourcePropertyConstraint);\n    }\n}\n\n/**\n * Properties for defining a `ALIYUN::KMS::Key`\n */\nexport interface RosKeyProps {\n\n    /**\n     * @Property description: The description of the CMK. Length constraints: Minimum length of 0 characters. Maximum length of 8192 characters.\n     */\n    readonly description?: string | ros.IResolvable;\n\n    /**\n     * @Property dkmsInstanceId: The ID of the dedicated KMS instance.\n     */\n    readonly dkmsInstanceId?: string | ros.IResolvable;\n\n    /**\n     * @Property enable: Specifies whether the key is enabled. Defaults to true.\n     */\n    readonly enable?: boolean | ros.IResolvable;\n\n    /**\n     * @Property enableAutomaticRotation: Whether to enable automatic key rotation. Valid value: true/false (default)\n     */\n    readonly enableAutomaticRotation?: boolean | ros.IResolvable;\n\n    /**\n     * @Property keySpec: Key type. Valid value: Aliyun_AES_256/Aliyun_SM4/RSA_2048/EC_P256/EC_P256K/EC_SM2\n     */\n    readonly keySpec?: string | ros.IResolvable;\n\n    /**\n     * @Property keyUsage: The usage of the CMK. Valid values:\n     * ENCRYPT/DECRYPT: encrypts or decrypts data.\n     * SIGN/VERIFY: generates or verifies a digital signature.\n     * If the CMK supports signature verification, the default value is SIGN/VERIFY. If the CMK does not support signature verification, the default value is ENCRYPT/DECRYPT.\n     */\n    readonly keyUsage?: string | ros.IResolvable;\n\n    /**\n     * @Property pendingWindowInDays: The waiting period, specified in number of days. During this period, you can cancel the CMK in PendingDeletion status. After the waiting period expires, you cannot cancel the deletion. The value must be between 7 and 366. Default value is 30.\n     */\n    readonly pendingWindowInDays?: number | ros.IResolvable;\n\n    /**\n     * @Property protectionLevel: The protection level of the CMK to create. Valid value: SOFTWARE and HSM. When this parameter is set to HSM:\n     * If the Origin parameter is set to Aliyun_KMS, the CMK is created in Managed HSM.\n     * If the Origin parameter is set to EXTERNAL, you can import external keys to Managed HSM.\n     */\n    readonly protectionLevel?: string | ros.IResolvable;\n\n    /**\n     * @Property rotationInterval: The time period for automatic rotation. The format is integer[unit], where integer represents the length of time and unit represents the time unit. The legal unit units are: d (day), h (hour), m (minute), s (second). 7d or 604800s both represent a 7-day cycle. Value: 7~730 days.\n     */\n    readonly rotationInterval?: string | ros.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `RosKeyProps`\n *\n * @param properties - the TypeScript properties of a `RosKeyProps`\n *\n * @returns the result of the validation.\n */\nfunction RosKeyPropsValidator(properties: any): ros.ValidationResult {\n    if (!ros.canInspect(properties)) { return ros.VALIDATION_SUCCESS; }\n    const errors = new ros.ValidationResults();\n    errors.collect(ros.propertyValidator('protectionLevel', ros.validateString)(properties.protectionLevel));\n    if(properties.description && (Array.isArray(properties.description) || (typeof properties.description) === 'string')) {\n        errors.collect(ros.propertyValidator('description', ros.validateLength)({\n            data: properties.description.length,\n            min: 0,\n            max: 8192,\n          }));\n    }\n    errors.collect(ros.propertyValidator('description', ros.validateString)(properties.description));\n    errors.collect(ros.propertyValidator('rotationInterval', ros.validateString)(properties.rotationInterval));\n    if(properties.pendingWindowInDays && (typeof properties.pendingWindowInDays) !== 'object') {\n        errors.collect(ros.propertyValidator('pendingWindowInDays', ros.validateRange)({\n            data: properties.pendingWindowInDays,\n            min: 7,\n            max: 366,\n          }));\n    }\n    errors.collect(ros.propertyValidator('pendingWindowInDays', ros.validateNumber)(properties.pendingWindowInDays));\n    errors.collect(ros.propertyValidator('enableAutomaticRotation', ros.validateBoolean)(properties.enableAutomaticRotation));\n    errors.collect(ros.propertyValidator('keySpec', ros.validateString)(properties.keySpec));\n    errors.collect(ros.propertyValidator('enable', ros.validateBoolean)(properties.enable));\n    errors.collect(ros.propertyValidator('keyUsage', ros.validateString)(properties.keyUsage));\n    errors.collect(ros.propertyValidator('dkmsInstanceId', ros.validateString)(properties.dkmsInstanceId));\n    return errors.wrap('supplied properties not correct for \"RosKeyProps\"');\n}\n\n/**\n * Renders the AliCloud ROS Resource properties of an `ALIYUN::KMS::Key` resource\n *\n * @param properties - the TypeScript properties of a `RosKeyProps`\n *\n * @returns the AliCloud ROS Resource properties of an `ALIYUN::KMS::Key` resource.\n */\n// @ts-ignore TS6133\nfunction rosKeyPropsToRosTemplate(properties: any, enableResourcePropertyConstraint: boolean): any {\n    if (!ros.canInspect(properties)) { return properties; }\n    if(enableResourcePropertyConstraint) {\n        RosKeyPropsValidator(properties).assertSuccess();\n    }\n    return {\n      Description: ros.stringToRosTemplate(properties.description),\n      DKMSInstanceId: ros.stringToRosTemplate(properties.dkmsInstanceId),\n      Enable: ros.booleanToRosTemplate(properties.enable),\n      EnableAutomaticRotation: ros.booleanToRosTemplate(properties.enableAutomaticRotation),\n      KeySpec: ros.stringToRosTemplate(properties.keySpec),\n      KeyUsage: ros.stringToRosTemplate(properties.keyUsage),\n      PendingWindowInDays: ros.numberToRosTemplate(properties.pendingWindowInDays),\n      ProtectionLevel: ros.stringToRosTemplate(properties.protectionLevel),\n      RotationInterval: ros.stringToRosTemplate(properties.rotationInterval),\n    };\n}\n\n/**\n * A ROS template type:  `ALIYUN::KMS::Key`\n */\nexport class RosKey extends ros.RosResource {\n    /**\n     * The resource type name for this resource class.\n     */\n    public static readonly ROS_RESOURCE_TYPE_NAME = \"ALIYUN::KMS::Key\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the properties of this ROS resource.\n     */\n\n    /**\n     * @Attribute KeyId: The globally unique identifier for the CMK.\n     */\n    public readonly attrKeyId: ros.IResolvable;\n\n    public enableResourcePropertyConstraint: boolean;\n\n\n    /**\n     * @Property description: The description of the CMK. Length constraints: Minimum length of 0 characters. Maximum length of 8192 characters.\n     */\n    public description: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property dkmsInstanceId: The ID of the dedicated KMS instance.\n     */\n    public dkmsInstanceId: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property enable: Specifies whether the key is enabled. Defaults to true.\n     */\n    public enable: boolean | ros.IResolvable | undefined;\n\n    /**\n     * @Property enableAutomaticRotation: Whether to enable automatic key rotation. Valid value: true/false (default)\n     */\n    public enableAutomaticRotation: boolean | ros.IResolvable | undefined;\n\n    /**\n     * @Property keySpec: Key type. Valid value: Aliyun_AES_256/Aliyun_SM4/RSA_2048/EC_P256/EC_P256K/EC_SM2\n     */\n    public keySpec: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property keyUsage: The usage of the CMK. Valid values:\n     * ENCRYPT/DECRYPT: encrypts or decrypts data.\n     * SIGN/VERIFY: generates or verifies a digital signature.\n     * If the CMK supports signature verification, the default value is SIGN/VERIFY. If the CMK does not support signature verification, the default value is ENCRYPT/DECRYPT.\n     */\n    public keyUsage: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property pendingWindowInDays: The waiting period, specified in number of days. During this period, you can cancel the CMK in PendingDeletion status. After the waiting period expires, you cannot cancel the deletion. The value must be between 7 and 366. Default value is 30.\n     */\n    public pendingWindowInDays: number | ros.IResolvable | undefined;\n\n    /**\n     * @Property protectionLevel: The protection level of the CMK to create. Valid value: SOFTWARE and HSM. When this parameter is set to HSM:\n     * If the Origin parameter is set to Aliyun_KMS, the CMK is created in Managed HSM.\n     * If the Origin parameter is set to EXTERNAL, you can import external keys to Managed HSM.\n     */\n    public protectionLevel: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property rotationInterval: The time period for automatic rotation. The format is integer[unit], where integer represents the length of time and unit represents the time unit. The legal unit units are: d (day), h (hour), m (minute), s (second). 7d or 604800s both represent a 7-day cycle. Value: 7~730 days.\n     */\n    public rotationInterval: string | ros.IResolvable | undefined;\n\n    /**\n     * Create a new `ALIYUN::KMS::Key`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: ros.Construct, id: string, props: RosKeyProps, enableResourcePropertyConstraint: boolean) {\n        super(scope, id, { type: RosKey.ROS_RESOURCE_TYPE_NAME, properties: props });\n        this.attrKeyId = this.getAtt('KeyId');\n\n        this.enableResourcePropertyConstraint = enableResourcePropertyConstraint;\n        this.description = props.description;\n        this.dkmsInstanceId = props.dkmsInstanceId;\n        this.enable = props.enable;\n        this.enableAutomaticRotation = props.enableAutomaticRotation;\n        this.keySpec = props.keySpec;\n        this.keyUsage = props.keyUsage;\n        this.pendingWindowInDays = props.pendingWindowInDays;\n        this.protectionLevel = props.protectionLevel;\n        this.rotationInterval = props.rotationInterval;\n    }\n\n\n    protected get rosProperties(): { [key: string]: any }  {\n        return {\n            description: this.description,\n            dkmsInstanceId: this.dkmsInstanceId,\n            enable: this.enable,\n            enableAutomaticRotation: this.enableAutomaticRotation,\n            keySpec: this.keySpec,\n            keyUsage: this.keyUsage,\n            pendingWindowInDays: this.pendingWindowInDays,\n            protectionLevel: this.protectionLevel,\n            rotationInterval: this.rotationInterval,\n        };\n    }\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return rosKeyPropsToRosTemplate(props, this.enableResourcePropertyConstraint);\n    }\n}\n\n/**\n * Properties for defining a `ALIYUN::KMS::Secret`\n */\nexport interface RosSecretProps {\n\n    /**\n     * @Property secretData: The value of the secret that you want to create. Secrets Manager encrypts the secret\n     * value and stores it in the initial version.\n     */\n    readonly secretData: string | ros.IResolvable;\n\n    /**\n     * @Property secretName: The name of the secret.\n     */\n    readonly secretName: string | ros.IResolvable;\n\n    /**\n     * @Property versionId: The version number of the initial version. Version numbers are unique in each secret\n     * object.\n     */\n    readonly versionId: string | ros.IResolvable;\n\n    /**\n     * @Property description: The description of the secret.\n     */\n    readonly description?: string | ros.IResolvable;\n\n    /**\n     * @Property dkmsInstanceId: The ID of the dedicated KMS instance.\n     */\n    readonly dkmsInstanceId?: string | ros.IResolvable;\n\n    /**\n     * @Property enableAutomaticRotation: Specifies whether to enable automatic rotation. Valid values:\n     * true: specifies to enable automatic rotation.\n     * false: specifies to disable automatic rotation. This is the default value.\n     */\n    readonly enableAutomaticRotation?: boolean | ros.IResolvable;\n\n    /**\n     * @Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.\n     * If you do not specify this parameter, Secrets Manager automatically creates an encryption\n     * key to encrypt the secret.\n     * Note The KMS CMK must be a symmetric key.\n     */\n    readonly encryptionKeyId?: string | ros.IResolvable;\n\n    /**\n     * @Property extendedConfig: The extended configuration of the secret. This parameter specifies the properties of the secret of the specific type.\n     */\n    readonly extendedConfig?: { [key: string]: (any | ros.IResolvable) } | ros.IResolvable;\n\n    /**\n     * @Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:\n     * true\n     * false (default value)\n     */\n    readonly forceDeleteWithoutRecovery?: boolean | ros.IResolvable;\n\n    /**\n     * @Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30\n     */\n    readonly recoveryWindowInDays?: number | ros.IResolvable;\n\n    /**\n     * @Property rotationInterval: The interval for automatic rotation. Valid values: 6 hours to 8,760 hours (365 days).\n     * The value is in the integer[unit] format.\n     * The unit can be d (day), h (hour), m (minute), or s (second). For example, both 7d and 604800s indicate a seven-day interval.\n     */\n    readonly rotationInterval?: string | ros.IResolvable;\n\n    /**\n     * @Property secretDataType: The type of the secret value. Valid values:\n     * text (default value)\n     * binary\n     */\n    readonly secretDataType?: string | ros.IResolvable;\n\n    /**\n     * @Property secretType: The type of the secret. Valid values:\n     * Generic: specifies a generic secret.\n     * Rds: specifies a managed ApsaraDB RDS secret.\n     * RAMCredentials: specifies a managed RAM secret.\n     * ECS: specifies a managed ECS secret.\n     */\n    readonly secretType?: string | ros.IResolvable;\n\n    /**\n     * @Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with \"ACSCurrent\".\n     */\n    readonly versionStages?: Array<string | ros.IResolvable> | ros.IResolvable;\n}\n\n/**\n * Determine whether the given properties match those of a `RosSecretProps`\n *\n * @param properties - the TypeScript properties of a `RosSecretProps`\n *\n * @returns the result of the validation.\n */\nfunction RosSecretPropsValidator(properties: any): ros.ValidationResult {\n    if (!ros.canInspect(properties)) { return ros.VALIDATION_SUCCESS; }\n    const errors = new ros.ValidationResults();\n    errors.collect(ros.propertyValidator('versionId', ros.requiredValidator)(properties.versionId));\n    errors.collect(ros.propertyValidator('versionId', ros.validateString)(properties.versionId));\n    errors.collect(ros.propertyValidator('description', ros.validateString)(properties.description));\n    errors.collect(ros.propertyValidator('rotationInterval', ros.validateString)(properties.rotationInterval));\n    errors.collect(ros.propertyValidator('secretType', ros.validateString)(properties.secretType));\n    if(properties.secretDataType && (typeof properties.secretDataType) !== 'object') {\n        errors.collect(ros.propertyValidator('secretDataType', ros.validateAllowedValues)({\n          data: properties.secretDataType,\n          allowedValues: [\"text\",\"binary\"],\n        }));\n    }\n    errors.collect(ros.propertyValidator('secretDataType', ros.validateString)(properties.secretDataType));\n    errors.collect(ros.propertyValidator('dkmsInstanceId', ros.validateString)(properties.dkmsInstanceId));\n    if(properties.versionStages && (Array.isArray(properties.versionStages) || (typeof properties.versionStages) === 'string')) {\n        errors.collect(ros.propertyValidator('versionStages', ros.validateLength)({\n            data: properties.versionStages.length,\n            min: 1,\n            max: 7,\n          }));\n    }\n    errors.collect(ros.propertyValidator('versionStages', ros.listValidator(ros.validateString))(properties.versionStages));\n    errors.collect(ros.propertyValidator('secretName', ros.requiredValidator)(properties.secretName));\n    errors.collect(ros.propertyValidator('secretName', ros.validateString)(properties.secretName));\n    errors.collect(ros.propertyValidator('enableAutomaticRotation', ros.validateBoolean)(properties.enableAutomaticRotation));\n    errors.collect(ros.propertyValidator('extendedConfig', ros.hashValidator(ros.validateAny))(properties.extendedConfig));\n    errors.collect(ros.propertyValidator('secretData', ros.requiredValidator)(properties.secretData));\n    errors.collect(ros.propertyValidator('secretData', ros.validateString)(properties.secretData));\n    errors.collect(ros.propertyValidator('encryptionKeyId', ros.validateString)(properties.encryptionKeyId));\n    errors.collect(ros.propertyValidator('recoveryWindowInDays', ros.validateNumber)(properties.recoveryWindowInDays));\n    errors.collect(ros.propertyValidator('forceDeleteWithoutRecovery', ros.validateBoolean)(properties.forceDeleteWithoutRecovery));\n    return errors.wrap('supplied properties not correct for \"RosSecretProps\"');\n}\n\n/**\n * Renders the AliCloud ROS Resource properties of an `ALIYUN::KMS::Secret` resource\n *\n * @param properties - the TypeScript properties of a `RosSecretProps`\n *\n * @returns the AliCloud ROS Resource properties of an `ALIYUN::KMS::Secret` resource.\n */\n// @ts-ignore TS6133\nfunction rosSecretPropsToRosTemplate(properties: any, enableResourcePropertyConstraint: boolean): any {\n    if (!ros.canInspect(properties)) { return properties; }\n    if(enableResourcePropertyConstraint) {\n        RosSecretPropsValidator(properties).assertSuccess();\n    }\n    return {\n      SecretData: ros.stringToRosTemplate(properties.secretData),\n      SecretName: ros.stringToRosTemplate(properties.secretName),\n      VersionId: ros.stringToRosTemplate(properties.versionId),\n      Description: ros.stringToRosTemplate(properties.description),\n      DKMSInstanceId: ros.stringToRosTemplate(properties.dkmsInstanceId),\n      EnableAutomaticRotation: ros.booleanToRosTemplate(properties.enableAutomaticRotation),\n      EncryptionKeyId: ros.stringToRosTemplate(properties.encryptionKeyId),\n      ExtendedConfig: ros.hashMapper(ros.objectToRosTemplate)(properties.extendedConfig),\n      ForceDeleteWithoutRecovery: ros.booleanToRosTemplate(properties.forceDeleteWithoutRecovery),\n      RecoveryWindowInDays: ros.numberToRosTemplate(properties.recoveryWindowInDays),\n      RotationInterval: ros.stringToRosTemplate(properties.rotationInterval),\n      SecretDataType: ros.stringToRosTemplate(properties.secretDataType),\n      SecretType: ros.stringToRosTemplate(properties.secretType),\n      VersionStages: ros.listMapper(ros.stringToRosTemplate)(properties.versionStages),\n    };\n}\n\n/**\n * A ROS template type:  `ALIYUN::KMS::Secret`\n */\nexport class RosSecret extends ros.RosResource {\n    /**\n     * The resource type name for this resource class.\n     */\n    public static readonly ROS_RESOURCE_TYPE_NAME = \"ALIYUN::KMS::Secret\";\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the properties of this ROS resource.\n     */\n\n    /**\n     * @Attribute Arn: The Alibaba Cloud Resource Name (ARN).\n     */\n    public readonly attrArn: ros.IResolvable;\n\n    /**\n     * @Attribute SecretName: The name of the secret.\n     */\n    public readonly attrSecretName: ros.IResolvable;\n\n    public enableResourcePropertyConstraint: boolean;\n\n\n    /**\n     * @Property secretData: The value of the secret that you want to create. Secrets Manager encrypts the secret\n     * value and stores it in the initial version.\n     */\n    public secretData: string | ros.IResolvable;\n\n    /**\n     * @Property secretName: The name of the secret.\n     */\n    public secretName: string | ros.IResolvable;\n\n    /**\n     * @Property versionId: The version number of the initial version. Version numbers are unique in each secret\n     * object.\n     */\n    public versionId: string | ros.IResolvable;\n\n    /**\n     * @Property description: The description of the secret.\n     */\n    public description: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property dkmsInstanceId: The ID of the dedicated KMS instance.\n     */\n    public dkmsInstanceId: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property enableAutomaticRotation: Specifies whether to enable automatic rotation. Valid values:\n     * true: specifies to enable automatic rotation.\n     * false: specifies to disable automatic rotation. This is the default value.\n     */\n    public enableAutomaticRotation: boolean | ros.IResolvable | undefined;\n\n    /**\n     * @Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.\n     * If you do not specify this parameter, Secrets Manager automatically creates an encryption\n     * key to encrypt the secret.\n     * Note The KMS CMK must be a symmetric key.\n     */\n    public encryptionKeyId: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property extendedConfig: The extended configuration of the secret. This parameter specifies the properties of the secret of the specific type.\n     */\n    public extendedConfig: { [key: string]: (any | ros.IResolvable) } | ros.IResolvable | undefined;\n\n    /**\n     * @Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:\n     * true\n     * false (default value)\n     */\n    public forceDeleteWithoutRecovery: boolean | ros.IResolvable | undefined;\n\n    /**\n     * @Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30\n     */\n    public recoveryWindowInDays: number | ros.IResolvable | undefined;\n\n    /**\n     * @Property rotationInterval: The interval for automatic rotation. Valid values: 6 hours to 8,760 hours (365 days).\n     * The value is in the integer[unit] format.\n     * The unit can be d (day), h (hour), m (minute), or s (second). For example, both 7d and 604800s indicate a seven-day interval.\n     */\n    public rotationInterval: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property secretDataType: The type of the secret value. Valid values:\n     * text (default value)\n     * binary\n     */\n    public secretDataType: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property secretType: The type of the secret. Valid values:\n     * Generic: specifies a generic secret.\n     * Rds: specifies a managed ApsaraDB RDS secret.\n     * RAMCredentials: specifies a managed RAM secret.\n     * ECS: specifies a managed ECS secret.\n     */\n    public secretType: string | ros.IResolvable | undefined;\n\n    /**\n     * @Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with \"ACSCurrent\".\n     */\n    public versionStages: Array<string | ros.IResolvable> | ros.IResolvable | undefined;\n\n    /**\n     * Create a new `ALIYUN::KMS::Secret`.\n     *\n     * @param scope - scope in which this resource is defined\n     * @param id    - scoped id of the resource\n     * @param props - resource properties\n     */\n    constructor(scope: ros.Construct, id: string, props: RosSecretProps, enableResourcePropertyConstraint: boolean) {\n        super(scope, id, { type: RosSecret.ROS_RESOURCE_TYPE_NAME, properties: props });\n        this.attrArn = this.getAtt('Arn');\n        this.attrSecretName = this.getAtt('SecretName');\n\n        this.enableResourcePropertyConstraint = enableResourcePropertyConstraint;\n        this.secretData = props.secretData;\n        this.secretName = props.secretName;\n        this.versionId = props.versionId;\n        this.description = props.description;\n        this.dkmsInstanceId = props.dkmsInstanceId;\n        this.enableAutomaticRotation = props.enableAutomaticRotation;\n        this.encryptionKeyId = props.encryptionKeyId;\n        this.extendedConfig = props.extendedConfig;\n        this.forceDeleteWithoutRecovery = props.forceDeleteWithoutRecovery;\n        this.recoveryWindowInDays = props.recoveryWindowInDays;\n        this.rotationInterval = props.rotationInterval;\n        this.secretDataType = props.secretDataType;\n        this.secretType = props.secretType;\n        this.versionStages = props.versionStages;\n    }\n\n\n    protected get rosProperties(): { [key: string]: any }  {\n        return {\n            secretData: this.secretData,\n            secretName: this.secretName,\n            versionId: this.versionId,\n            description: this.description,\n            dkmsInstanceId: this.dkmsInstanceId,\n            enableAutomaticRotation: this.enableAutomaticRotation,\n            encryptionKeyId: this.encryptionKeyId,\n            extendedConfig: this.extendedConfig,\n            forceDeleteWithoutRecovery: this.forceDeleteWithoutRecovery,\n            recoveryWindowInDays: this.recoveryWindowInDays,\n            rotationInterval: this.rotationInterval,\n            secretDataType: this.secretDataType,\n            secretType: this.secretType,\n            versionStages: this.versionStages,\n        };\n    }\n    protected renderProperties(props: {[key: string]: any}): { [key: string]: any }  {\n        return rosSecretPropsToRosTemplate(props, this.enableResourcePropertyConstraint);\n    }\n}\n"]}
|
package/lib/secret.d.ts
CHANGED
|
@@ -23,6 +23,16 @@ export interface SecretProps {
|
|
|
23
23
|
* Property description: The description of the secret.
|
|
24
24
|
*/
|
|
25
25
|
readonly description?: string | ros.IResolvable;
|
|
26
|
+
/**
|
|
27
|
+
* Property dkmsInstanceId: The ID of the dedicated KMS instance.
|
|
28
|
+
*/
|
|
29
|
+
readonly dkmsInstanceId?: string | ros.IResolvable;
|
|
30
|
+
/**
|
|
31
|
+
* Property enableAutomaticRotation: Specifies whether to enable automatic rotation. Valid values:
|
|
32
|
+
* true: specifies to enable automatic rotation.
|
|
33
|
+
* false: specifies to disable automatic rotation. This is the default value.
|
|
34
|
+
*/
|
|
35
|
+
readonly enableAutomaticRotation?: boolean | ros.IResolvable;
|
|
26
36
|
/**
|
|
27
37
|
* Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.
|
|
28
38
|
* If you do not specify this parameter, Secrets Manager automatically creates an encryption
|
|
@@ -30,6 +40,12 @@ export interface SecretProps {
|
|
|
30
40
|
* Note The KMS CMK must be a symmetric key.
|
|
31
41
|
*/
|
|
32
42
|
readonly encryptionKeyId?: string | ros.IResolvable;
|
|
43
|
+
/**
|
|
44
|
+
* Property extendedConfig: The extended configuration of the secret. This parameter specifies the properties of the secret of the specific type.
|
|
45
|
+
*/
|
|
46
|
+
readonly extendedConfig?: {
|
|
47
|
+
[key: string]: (any | ros.IResolvable);
|
|
48
|
+
} | ros.IResolvable;
|
|
33
49
|
/**
|
|
34
50
|
* Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:
|
|
35
51
|
* true
|
|
@@ -40,12 +56,26 @@ export interface SecretProps {
|
|
|
40
56
|
* Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30
|
|
41
57
|
*/
|
|
42
58
|
readonly recoveryWindowInDays?: number | ros.IResolvable;
|
|
59
|
+
/**
|
|
60
|
+
* Property rotationInterval: The interval for automatic rotation. Valid values: 6 hours to 8,760 hours (365 days).
|
|
61
|
+
* The value is in the integer[unit] format.
|
|
62
|
+
* The unit can be d (day), h (hour), m (minute), or s (second). For example, both 7d and 604800s indicate a seven-day interval.
|
|
63
|
+
*/
|
|
64
|
+
readonly rotationInterval?: string | ros.IResolvable;
|
|
43
65
|
/**
|
|
44
66
|
* Property secretDataType: The type of the secret value. Valid values:
|
|
45
67
|
* text (default value)
|
|
46
68
|
* binary
|
|
47
69
|
*/
|
|
48
70
|
readonly secretDataType?: string | ros.IResolvable;
|
|
71
|
+
/**
|
|
72
|
+
* Property secretType: The type of the secret. Valid values:
|
|
73
|
+
* Generic: specifies a generic secret.
|
|
74
|
+
* Rds: specifies a managed ApsaraDB RDS secret.
|
|
75
|
+
* RAMCredentials: specifies a managed RAM secret.
|
|
76
|
+
* ECS: specifies a managed ECS secret.
|
|
77
|
+
*/
|
|
78
|
+
readonly secretType?: string | ros.IResolvable;
|
|
49
79
|
/**
|
|
50
80
|
* Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with "ACSCurrent".
|
|
51
81
|
*/
|
package/lib/secret.js
CHANGED
|
@@ -19,11 +19,16 @@ class Secret extends ros.Resource {
|
|
|
19
19
|
super(scope, id);
|
|
20
20
|
const rosSecret = new kms_generated_1.RosSecret(this, id, {
|
|
21
21
|
versionId: props.versionId,
|
|
22
|
-
secretName: props.secretName,
|
|
23
22
|
description: props.description,
|
|
23
|
+
rotationInterval: props.rotationInterval,
|
|
24
|
+
secretType: props.secretType,
|
|
24
25
|
secretDataType: props.secretDataType,
|
|
25
|
-
|
|
26
|
+
dkmsInstanceId: props.dkmsInstanceId,
|
|
26
27
|
versionStages: props.versionStages,
|
|
28
|
+
secretName: props.secretName,
|
|
29
|
+
enableAutomaticRotation: props.enableAutomaticRotation,
|
|
30
|
+
extendedConfig: props.extendedConfig,
|
|
31
|
+
secretData: props.secretData,
|
|
27
32
|
encryptionKeyId: props.encryptionKeyId,
|
|
28
33
|
recoveryWindowInDays: props.recoveryWindowInDays === undefined || props.recoveryWindowInDays === null ? 30 : props.recoveryWindowInDays,
|
|
29
34
|
forceDeleteWithoutRecovery: props.forceDeleteWithoutRecovery === undefined || props.forceDeleteWithoutRecovery === null ? false : props.forceDeleteWithoutRecovery,
|
|
@@ -34,4 +39,4 @@ class Secret extends ros.Resource {
|
|
|
34
39
|
}
|
|
35
40
|
}
|
|
36
41
|
exports.Secret = Secret;
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"secret.js","sourceRoot":"","sources":["secret.ts"],"names":[],"mappings":";;;AAAA,8CAA8C;AAC9C,mDAA4C;AAEtB,+FAFb,yBAAS,OAEkB;AA+FpC;;GAEG;AACH,MAAa,MAAO,SAAQ,GAAG,CAAC,QAAQ;IAiBpC;;;;;;OAMG;IACH,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAkB,EAAE,mCAA2C,IAAI;QAC7G,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,SAAS,GAAG,IAAI,yBAAS,CAAC,IAAI,EAAE,EAAE,EAAG;YACvC,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;YACxC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,uBAAuB,EAAE,KAAK,CAAC,uBAAuB;YACtD,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,eAAe,EAAE,KAAK,CAAC,eAAe;YACtC,oBAAoB,EAAE,KAAK,CAAC,oBAAoB,KAAK,SAAS,IAAI,KAAK,CAAC,oBAAoB,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,oBAAoB;YACvI,0BAA0B,EAAE,KAAK,CAAC,0BAA0B,KAAK,SAAS,IAAI,KAAK,CAAC,0BAA0B,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,0BAA0B;SACrK,EAAE,gCAAgC,IAAI,IAAI,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;QACpF,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC1B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;QACjC,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC,cAAc,CAAC;IACnD,CAAC;CACJ;AA/CD,wBA+CC","sourcesContent":["import * as ros from '@alicloud/ros-cdk-core';\nimport { RosSecret } from './kms.generated';\n// Generated from the AliCloud ROS Resource Specification\nexport { RosSecret as SecretProperty };\n\n/**\n * Properties for defining a `ALIYUN::KMS::Secret`\n */\nexport interface SecretProps {\n\n    /**\n     * Property secretData: The value of the secret that you want to create. Secrets Manager encrypts the secret\n     * value and stores it in the initial version.\n     */\n    readonly secretData: string | ros.IResolvable;\n\n    /**\n     * Property secretName: The name of the secret.\n     */\n    readonly secretName: string | ros.IResolvable;\n\n    /**\n     * Property versionId: The version number of the initial version. Version numbers are unique in each secret\n     * object.\n     */\n    readonly versionId: string | ros.IResolvable;\n\n    /**\n     * Property description: The description of the secret.\n     */\n    readonly description?: string | ros.IResolvable;\n\n    /**\n     * Property dkmsInstanceId: The ID of the dedicated KMS instance.\n     */\n    readonly dkmsInstanceId?: string | ros.IResolvable;\n\n    /**\n     * Property enableAutomaticRotation: Specifies whether to enable automatic rotation. Valid values:\n     * true: specifies to enable automatic rotation.\n     * false: specifies to disable automatic rotation. This is the default value.\n     */\n    readonly enableAutomaticRotation?: boolean | ros.IResolvable;\n\n    /**\n     * Property encryptionKeyId: The ID of the KMS CMK that is used to encrypt the secret value.\n     * If you do not specify this parameter, Secrets Manager automatically creates an encryption\n     * key to encrypt the secret.\n     * Note The KMS CMK must be a symmetric key.\n     */\n    readonly encryptionKeyId?: string | ros.IResolvable;\n\n    /**\n     * Property extendedConfig: The extended configuration of the secret. This parameter specifies the properties of the secret of the specific type.\n     */\n    readonly extendedConfig?: { [key: string]: (any | ros.IResolvable) } | ros.IResolvable;\n\n    /**\n     * Property forceDeleteWithoutRecovery: Specifies whether to forcibly delete the secret. If this parameter is set to true, the secret cannot be recovered. Valid values:\n     * true\n     * false (default value)\n     */\n    readonly forceDeleteWithoutRecovery?: boolean | ros.IResolvable;\n\n    /**\n     * Property recoveryWindowInDays: Specifies the recovery period of the secret if you do not forcibly delete it. Default value: 30\n     */\n    readonly recoveryWindowInDays?: number | ros.IResolvable;\n\n    /**\n     * Property rotationInterval: The interval for automatic rotation. Valid values: 6 hours to 8,760 hours (365 days).\n     * The value is in the integer[unit] format.\n     * The unit can be d (day), h (hour), m (minute), or s (second). For example, both 7d and 604800s indicate a seven-day interval.\n     */\n    readonly rotationInterval?: string | ros.IResolvable;\n\n    /**\n     * Property secretDataType: The type of the secret value. Valid values:\n     * text (default value)\n     * binary\n     */\n    readonly secretDataType?: string | ros.IResolvable;\n\n    /**\n     * Property secretType: The type of the secret. Valid values:\n     * Generic: specifies a generic secret.\n     * Rds: specifies a managed ApsaraDB RDS secret.\n     * RAMCredentials: specifies a managed RAM secret.\n     * ECS: specifies a managed ECS secret.\n     */\n    readonly secretType?: string | ros.IResolvable;\n\n    /**\n     * Property versionStages: The stage labels that mark the secret version. ACSCurrent will be marked as DefaultIf you do not specify it, Secrets Manager marks it with \"ACSCurrent\".\n     */\n    readonly versionStages?: Array<string | ros.IResolvable> | ros.IResolvable;\n}\n\n/**\n * A ROS resource type:  `ALIYUN::KMS::Secret`\n */\nexport class Secret extends ros.Resource {\n\n    /**\n     * A factory method that creates a new instance of this class from an object\n     * containing the properties of this ROS resource, which will be assigned to ROS resource.\n     */\n\n    /**\n     * Attribute Arn: The Alibaba Cloud Resource Name (ARN).\n     */\n    public readonly attrArn: ros.IResolvable;\n\n    /**\n     * Attribute SecretName: The name of the secret.\n     */\n    public readonly attrSecretName: ros.IResolvable;\n\n    /**\n     * Create a new `ALIYUN::KMS::Secret`.\n     *\n     * Param scope - scope in which this resource is defined\n     * Param id    - scoped id of the resource\n     * Param props - resource properties\n     */\n    constructor(scope: ros.Construct, id: string, props: SecretProps, enableResourcePropertyConstraint:boolean = true) {\n        super(scope, id);\n\n        const rosSecret = new RosSecret(this, id,  {\n            versionId: props.versionId,\n            description: props.description,\n            rotationInterval: props.rotationInterval,\n            secretType: props.secretType,\n            secretDataType: props.secretDataType,\n            dkmsInstanceId: props.dkmsInstanceId,\n            versionStages: props.versionStages,\n            secretName: props.secretName,\n            enableAutomaticRotation: props.enableAutomaticRotation,\n            extendedConfig: props.extendedConfig,\n            secretData: props.secretData,\n            encryptionKeyId: props.encryptionKeyId,\n            recoveryWindowInDays: props.recoveryWindowInDays === undefined || props.recoveryWindowInDays === null ? 30 : props.recoveryWindowInDays,\n            forceDeleteWithoutRecovery: props.forceDeleteWithoutRecovery === undefined || props.forceDeleteWithoutRecovery === null ? false : props.forceDeleteWithoutRecovery,\n        }, enableResourcePropertyConstraint && this.stack.enableResourcePropertyConstraint);\n        this.resource = rosSecret;\n        this.attrArn = rosSecret.attrArn;\n        this.attrSecretName = rosSecret.attrSecretName;\n    }\n}\n"]}
|
package/package.json
CHANGED