@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 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 intended use of the CMK. Default value: ENCRYPT/DECRYPT.
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 === undefined || props.keyUsage === null ? 'ENCRYPT/DECRYPT' : 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsia2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDhDQUE4QztBQUM5QyxtREFBeUM7QUFFdEIsNEZBRlYsc0JBQU0sT0FFZTtBQWtEOUI7O0dBRUc7QUFDSCxNQUFhLEdBQUksU0FBUSxHQUFHLENBQUMsUUFBUTtJQVlqQzs7Ozs7O09BTUc7SUFDSCxZQUFZLEtBQW9CLEVBQUUsRUFBVSxFQUFFLFFBQWtCLEVBQUUsRUFBRSxtQ0FBMkMsSUFBSTtRQUMvRyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sTUFBTSxHQUFHLElBQUksc0JBQU0sQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFHO1lBQ2pDLGVBQWUsRUFBRSxLQUFLLENBQUMsZUFBZTtZQUN0QyxXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQjtZQUN4Qyx1QkFBdUIsRUFBRSxLQUFLLENBQUMsdUJBQXVCO1lBQ3RELG1CQUFtQixFQUFFLEtBQUssQ0FBQyxtQkFBbUIsS0FBSyxTQUFTLElBQUksS0FBSyxDQUFDLG1CQUFtQixLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsbUJBQW1CO1lBQ25JLE9BQU8sRUFBRSxLQUFLLENBQUMsT0FBTztZQUN0QixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sS0FBSyxTQUFTLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU07WUFDakYsUUFBUSxFQUFFLEtBQUssQ0FBQyxRQUFRLEtBQUssU0FBUyxJQUFJLEtBQUssQ0FBQyxRQUFRLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVE7U0FDekcsRUFBRSxnQ0FBZ0MsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7UUFDcEYsSUFBSSxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUM7UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDO0lBQ3RDLENBQUM7Q0FDSjtBQW5DRCxrQkFtQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyByb3MgZnJvbSAnQGFsaWNsb3VkL3Jvcy1jZGstY29yZSc7XG5pbXBvcnQgeyBSb3NLZXkgfSBmcm9tICcuL2ttcy5nZW5lcmF0ZWQnO1xuLy8gR2VuZXJhdGVkIGZyb20gdGhlIEFsaUNsb3VkIFJPUyBSZXNvdXJjZSBTcGVjaWZpY2F0aW9uXG5leHBvcnQgeyBSb3NLZXkgYXMgS2V5UHJvcGVydHkgfTtcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhIGBBTElZVU46OktNUzo6S2V5YFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEtleVByb3BzIHtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IGRlc2NyaXB0aW9uOiBUaGUgZGVzY3JpcHRpb24gb2YgdGhlIENNSy4gTGVuZ3RoIGNvbnN0cmFpbnRzOiBNaW5pbXVtIGxlbmd0aCBvZiAwIGNoYXJhY3RlcnMuIE1heGltdW0gbGVuZ3RoIG9mIDgxOTIgY2hhcmFjdGVycy5cbiAgICAgKi9cbiAgICByZWFkb25seSBkZXNjcmlwdGlvbj86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IGVuYWJsZTogU3BlY2lmaWVzIHdoZXRoZXIgdGhlIGtleSBpcyBlbmFibGVkLiBEZWZhdWx0cyB0byB0cnVlLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IGVuYWJsZT86IGJvb2xlYW4gfCByb3MuSVJlc29sdmFibGU7XG5cbiAgICAvKipcbiAgICAgKiBQcm9wZXJ0eSBlbmFibGVBdXRvbWF0aWNSb3RhdGlvbjogV2hldGhlciB0byBlbmFibGUgYXV0b21hdGljIGtleSByb3RhdGlvbi4gVmFsaWQgdmFsdWU6IHRydWUvZmFsc2UgKGRlZmF1bHQpXG4gICAgICovXG4gICAgcmVhZG9ubHkgZW5hYmxlQXV0b21hdGljUm90YXRpb24/OiBib29sZWFuIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkga2V5U3BlYzogS2V5IHR5cGUuIFZhbGlkIHZhbHVlOiBBbGl5dW5fQUVTXzI1Ni9BbGl5dW5fU000L1JTQV8yMDQ4L0VDX1AyNTYvRUNfUDI1NksvRUNfU00yXG4gICAgICovXG4gICAgcmVhZG9ubHkga2V5U3BlYz86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IGtleVVzYWdlOiBUaGUgaW50ZW5kZWQgdXNlIG9mIHRoZSBDTUsuIERlZmF1bHQgdmFsdWU6IEVOQ1JZUFQvREVDUllQVC5cbiAgICAgKi9cbiAgICByZWFkb25seSBrZXlVc2FnZT86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHBlbmRpbmdXaW5kb3dJbkRheXM6IFRoZSB3YWl0aW5nIHBlcmlvZCwgc3BlY2lmaWVkIGluIG51bWJlciBvZiBkYXlzLiBEdXJpbmcgdGhpcyBwZXJpb2QsIHlvdSBjYW4gY2FuY2VsIHRoZSBDTUsgaW4gUGVuZGluZ0RlbGV0aW9uIHN0YXR1cy4gQWZ0ZXIgdGhlIHdhaXRpbmcgcGVyaW9kIGV4cGlyZXMsIHlvdSBjYW5ub3QgY2FuY2VsIHRoZSBkZWxldGlvbi4gVGhlIHZhbHVlIG11c3QgYmUgYmV0d2VlbiA3IGFuZCAzNjYuIERlZmF1bHQgdmFsdWUgaXMgMzAuXG4gICAgICovXG4gICAgcmVhZG9ubHkgcGVuZGluZ1dpbmRvd0luRGF5cz86IG51bWJlciB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHByb3RlY3Rpb25MZXZlbDogVGhlIHByb3RlY3Rpb24gbGV2ZWwgb2YgdGhlIENNSyB0byBjcmVhdGUuIFZhbGlkIHZhbHVlOiBTT0ZUV0FSRSBhbmQgSFNNLiBXaGVuIHRoaXMgcGFyYW1ldGVyIGlzIHNldCB0byBIU006XG4gICAgICogSWYgdGhlIE9yaWdpbiBwYXJhbWV0ZXIgaXMgc2V0IHRvIEFsaXl1bl9LTVMsIHRoZSBDTUsgaXMgY3JlYXRlZCBpbiBNYW5hZ2VkIEhTTS5cbiAgICAgKiBJZiB0aGUgT3JpZ2luIHBhcmFtZXRlciBpcyBzZXQgdG8gRVhURVJOQUwsIHlvdSBjYW4gaW1wb3J0IGV4dGVybmFsIGtleXMgdG8gTWFuYWdlZCBIU00uXG4gICAgICovXG4gICAgcmVhZG9ubHkgcHJvdGVjdGlvbkxldmVsPzogc3RyaW5nIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgcm90YXRpb25JbnRlcnZhbDogVGhlIHRpbWUgcGVyaW9kIGZvciBhdXRvbWF0aWMgcm90YXRpb24uIFRoZSBmb3JtYXQgaXMgaW50ZWdlclt1bml0XSwgd2hlcmUgaW50ZWdlciByZXByZXNlbnRzIHRoZSBsZW5ndGggb2YgdGltZSBhbmQgdW5pdCByZXByZXNlbnRzIHRoZSB0aW1lIHVuaXQuIFRoZSBsZWdhbCB1bml0IHVuaXRzIGFyZTogZCAoZGF5KSwgaCAoaG91ciksIG0gKG1pbnV0ZSksIHMgKHNlY29uZCkuIDdkIG9yIDYwNDgwMHMgYm90aCByZXByZXNlbnQgYSA3LWRheSBjeWNsZS4gVmFsdWU6IDd+NzMwIGRheXMuXG4gICAgICovXG4gICAgcmVhZG9ubHkgcm90YXRpb25JbnRlcnZhbD86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcbn1cblxuLyoqXG4gKiBBIFJPUyByZXNvdXJjZSB0eXBlOiAgYEFMSVlVTjo6S01TOjpLZXlgXG4gKi9cbmV4cG9ydCBjbGFzcyBLZXkgZXh0ZW5kcyByb3MuUmVzb3VyY2Uge1xuXG4gICAgLyoqXG4gICAgICogQSBmYWN0b3J5IG1ldGhvZCB0aGF0IGNyZWF0ZXMgYSBuZXcgaW5zdGFuY2Ugb2YgdGhpcyBjbGFzcyBmcm9tIGFuIG9iamVjdFxuICAgICAqIGNvbnRhaW5pbmcgdGhlIHByb3BlcnRpZXMgb2YgdGhpcyBST1MgcmVzb3VyY2UsIHdoaWNoIHdpbGwgYmUgYXNzaWduZWQgdG8gUk9TIHJlc291cmNlLlxuICAgICAqL1xuXG4gICAgLyoqXG4gICAgICogQXR0cmlidXRlIEtleUlkOiBUaGUgZ2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBDTUsuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGF0dHJLZXlJZDogcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgbmV3IGBBTElZVU46OktNUzo6S2V5YC5cbiAgICAgKlxuICAgICAqIFBhcmFtIHNjb3BlIC0gc2NvcGUgaW4gd2hpY2ggdGhpcyByZXNvdXJjZSBpcyBkZWZpbmVkXG4gICAgICogUGFyYW0gaWQgICAgLSBzY29wZWQgaWQgb2YgdGhlIHJlc291cmNlXG4gICAgICogUGFyYW0gcHJvcHMgLSByZXNvdXJjZSBwcm9wZXJ0aWVzXG4gICAgICovXG4gICAgY29uc3RydWN0b3Ioc2NvcGU6IHJvcy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBLZXlQcm9wcyA9IHt9LCBlbmFibGVSZXNvdXJjZVByb3BlcnR5Q29uc3RyYWludDpib29sZWFuID0gdHJ1ZSkge1xuICAgICAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgICAgIGNvbnN0IHJvc0tleSA9IG5ldyBSb3NLZXkodGhpcywgaWQsICB7XG4gICAgICAgICAgICBwcm90ZWN0aW9uTGV2ZWw6IHByb3BzLnByb3RlY3Rpb25MZXZlbCxcbiAgICAgICAgICAgIGRlc2NyaXB0aW9uOiBwcm9wcy5kZXNjcmlwdGlvbixcbiAgICAgICAgICAgIHJvdGF0aW9uSW50ZXJ2YWw6IHByb3BzLnJvdGF0aW9uSW50ZXJ2YWwsXG4gICAgICAgICAgICBlbmFibGVBdXRvbWF0aWNSb3RhdGlvbjogcHJvcHMuZW5hYmxlQXV0b21hdGljUm90YXRpb24sXG4gICAgICAgICAgICBwZW5kaW5nV2luZG93SW5EYXlzOiBwcm9wcy5wZW5kaW5nV2luZG93SW5EYXlzID09PSB1bmRlZmluZWQgfHwgcHJvcHMucGVuZGluZ1dpbmRvd0luRGF5cyA9PT0gbnVsbCA/IDMwIDogcHJvcHMucGVuZGluZ1dpbmRvd0luRGF5cyxcbiAgICAgICAgICAgIGtleVNwZWM6IHByb3BzLmtleVNwZWMsXG4gICAgICAgICAgICBlbmFibGU6IHByb3BzLmVuYWJsZSA9PT0gdW5kZWZpbmVkIHx8IHByb3BzLmVuYWJsZSA9PT0gbnVsbCA/IHRydWUgOiBwcm9wcy5lbmFibGUsXG4gICAgICAgICAgICBrZXlVc2FnZTogcHJvcHMua2V5VXNhZ2UgPT09IHVuZGVmaW5lZCB8fCBwcm9wcy5rZXlVc2FnZSA9PT0gbnVsbCA/ICdFTkNSWVBUL0RFQ1JZUFQnIDogcHJvcHMua2V5VXNhZ2UsXG4gICAgICAgIH0sIGVuYWJsZVJlc291cmNlUHJvcGVydHlDb25zdHJhaW50ICYmIHRoaXMuc3RhY2suZW5hYmxlUmVzb3VyY2VQcm9wZXJ0eUNvbnN0cmFpbnQpO1xuICAgICAgICB0aGlzLnJlc291cmNlID0gcm9zS2V5O1xuICAgICAgICB0aGlzLmF0dHJLZXlJZCA9IHJvc0tleS5hdHRyS2V5SWQ7XG4gICAgfVxufVxuIl19
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsia2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDhDQUE4QztBQUM5QyxtREFBeUM7QUFFdEIsNEZBRlYsc0JBQU0sT0FFZTtBQTBEOUI7O0dBRUc7QUFDSCxNQUFhLEdBQUksU0FBUSxHQUFHLENBQUMsUUFBUTtJQVlqQzs7Ozs7O09BTUc7SUFDSCxZQUFZLEtBQW9CLEVBQUUsRUFBVSxFQUFFLFFBQWtCLEVBQUUsRUFBRSxtQ0FBMkMsSUFBSTtRQUMvRyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sTUFBTSxHQUFHLElBQUksc0JBQU0sQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFHO1lBQ2pDLGVBQWUsRUFBRSxLQUFLLENBQUMsZUFBZTtZQUN0QyxXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLGdCQUFnQjtZQUN4QyxtQkFBbUIsRUFBRSxLQUFLLENBQUMsbUJBQW1CLEtBQUssU0FBUyxJQUFJLEtBQUssQ0FBQyxtQkFBbUIsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLG1CQUFtQjtZQUNuSSx1QkFBdUIsRUFBRSxLQUFLLENBQUMsdUJBQXVCO1lBQ3RELE9BQU8sRUFBRSxLQUFLLENBQUMsT0FBTztZQUN0QixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU0sS0FBSyxTQUFTLElBQUksS0FBSyxDQUFDLE1BQU0sS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU07WUFDakYsUUFBUSxFQUFFLEtBQUssQ0FBQyxRQUFRO1lBQ3hCLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYztTQUN2QyxFQUFFLGdDQUFnQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztRQUNwRixJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQztRQUN2QixJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7SUFDdEMsQ0FBQztDQUNKO0FBcENELGtCQW9DQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHJvcyBmcm9tICdAYWxpY2xvdWQvcm9zLWNkay1jb3JlJztcbmltcG9ydCB7IFJvc0tleSB9IGZyb20gJy4va21zLmdlbmVyYXRlZCc7XG4vLyBHZW5lcmF0ZWQgZnJvbSB0aGUgQWxpQ2xvdWQgUk9TIFJlc291cmNlIFNwZWNpZmljYXRpb25cbmV4cG9ydCB7IFJvc0tleSBhcyBLZXlQcm9wZXJ0eSB9O1xuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIGRlZmluaW5nIGEgYEFMSVlVTjo6S01TOjpLZXlgXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgS2V5UHJvcHMge1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgZGVzY3JpcHRpb246IFRoZSBkZXNjcmlwdGlvbiBvZiB0aGUgQ01LLiBMZW5ndGggY29uc3RyYWludHM6IE1pbmltdW0gbGVuZ3RoIG9mIDAgY2hhcmFjdGVycy4gTWF4aW11bSBsZW5ndGggb2YgODE5MiBjaGFyYWN0ZXJzLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IGRlc2NyaXB0aW9uPzogc3RyaW5nIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgZGttc0luc3RhbmNlSWQ6IFRoZSBJRCBvZiB0aGUgZGVkaWNhdGVkIEtNUyBpbnN0YW5jZS5cbiAgICAgKi9cbiAgICByZWFkb25seSBka21zSW5zdGFuY2VJZD86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IGVuYWJsZTogU3BlY2lmaWVzIHdoZXRoZXIgdGhlIGtleSBpcyBlbmFibGVkLiBEZWZhdWx0cyB0byB0cnVlLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IGVuYWJsZT86IGJvb2xlYW4gfCByb3MuSVJlc29sdmFibGU7XG5cbiAgICAvKipcbiAgICAgKiBQcm9wZXJ0eSBlbmFibGVBdXRvbWF0aWNSb3RhdGlvbjogV2hldGhlciB0byBlbmFibGUgYXV0b21hdGljIGtleSByb3RhdGlvbi4gVmFsaWQgdmFsdWU6IHRydWUvZmFsc2UgKGRlZmF1bHQpXG4gICAgICovXG4gICAgcmVhZG9ubHkgZW5hYmxlQXV0b21hdGljUm90YXRpb24/OiBib29sZWFuIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkga2V5U3BlYzogS2V5IHR5cGUuIFZhbGlkIHZhbHVlOiBBbGl5dW5fQUVTXzI1Ni9BbGl5dW5fU000L1JTQV8yMDQ4L0VDX1AyNTYvRUNfUDI1NksvRUNfU00yXG4gICAgICovXG4gICAgcmVhZG9ubHkga2V5U3BlYz86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IGtleVVzYWdlOiBUaGUgdXNhZ2Ugb2YgdGhlIENNSy4gVmFsaWQgdmFsdWVzOlxuICAgICAqIEVOQ1JZUFQvREVDUllQVDogZW5jcnlwdHMgb3IgZGVjcnlwdHMgZGF0YS5cbiAgICAgKiBTSUdOL1ZFUklGWTogZ2VuZXJhdGVzIG9yIHZlcmlmaWVzIGEgZGlnaXRhbCBzaWduYXR1cmUuXG4gICAgICogSWYgdGhlIENNSyBzdXBwb3J0cyBzaWduYXR1cmUgdmVyaWZpY2F0aW9uLCB0aGUgZGVmYXVsdCB2YWx1ZSBpcyBTSUdOL1ZFUklGWS4gSWYgdGhlIENNSyBkb2VzIG5vdCBzdXBwb3J0IHNpZ25hdHVyZSB2ZXJpZmljYXRpb24sIHRoZSBkZWZhdWx0IHZhbHVlIGlzIEVOQ1JZUFQvREVDUllQVC5cbiAgICAgKi9cbiAgICByZWFkb25seSBrZXlVc2FnZT86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHBlbmRpbmdXaW5kb3dJbkRheXM6IFRoZSB3YWl0aW5nIHBlcmlvZCwgc3BlY2lmaWVkIGluIG51bWJlciBvZiBkYXlzLiBEdXJpbmcgdGhpcyBwZXJpb2QsIHlvdSBjYW4gY2FuY2VsIHRoZSBDTUsgaW4gUGVuZGluZ0RlbGV0aW9uIHN0YXR1cy4gQWZ0ZXIgdGhlIHdhaXRpbmcgcGVyaW9kIGV4cGlyZXMsIHlvdSBjYW5ub3QgY2FuY2VsIHRoZSBkZWxldGlvbi4gVGhlIHZhbHVlIG11c3QgYmUgYmV0d2VlbiA3IGFuZCAzNjYuIERlZmF1bHQgdmFsdWUgaXMgMzAuXG4gICAgICovXG4gICAgcmVhZG9ubHkgcGVuZGluZ1dpbmRvd0luRGF5cz86IG51bWJlciB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHByb3RlY3Rpb25MZXZlbDogVGhlIHByb3RlY3Rpb24gbGV2ZWwgb2YgdGhlIENNSyB0byBjcmVhdGUuIFZhbGlkIHZhbHVlOiBTT0ZUV0FSRSBhbmQgSFNNLiBXaGVuIHRoaXMgcGFyYW1ldGVyIGlzIHNldCB0byBIU006XG4gICAgICogSWYgdGhlIE9yaWdpbiBwYXJhbWV0ZXIgaXMgc2V0IHRvIEFsaXl1bl9LTVMsIHRoZSBDTUsgaXMgY3JlYXRlZCBpbiBNYW5hZ2VkIEhTTS5cbiAgICAgKiBJZiB0aGUgT3JpZ2luIHBhcmFtZXRlciBpcyBzZXQgdG8gRVhURVJOQUwsIHlvdSBjYW4gaW1wb3J0IGV4dGVybmFsIGtleXMgdG8gTWFuYWdlZCBIU00uXG4gICAgICovXG4gICAgcmVhZG9ubHkgcHJvdGVjdGlvbkxldmVsPzogc3RyaW5nIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgcm90YXRpb25JbnRlcnZhbDogVGhlIHRpbWUgcGVyaW9kIGZvciBhdXRvbWF0aWMgcm90YXRpb24uIFRoZSBmb3JtYXQgaXMgaW50ZWdlclt1bml0XSwgd2hlcmUgaW50ZWdlciByZXByZXNlbnRzIHRoZSBsZW5ndGggb2YgdGltZSBhbmQgdW5pdCByZXByZXNlbnRzIHRoZSB0aW1lIHVuaXQuIFRoZSBsZWdhbCB1bml0IHVuaXRzIGFyZTogZCAoZGF5KSwgaCAoaG91ciksIG0gKG1pbnV0ZSksIHMgKHNlY29uZCkuIDdkIG9yIDYwNDgwMHMgYm90aCByZXByZXNlbnQgYSA3LWRheSBjeWNsZS4gVmFsdWU6IDd+NzMwIGRheXMuXG4gICAgICovXG4gICAgcmVhZG9ubHkgcm90YXRpb25JbnRlcnZhbD86IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcbn1cblxuLyoqXG4gKiBBIFJPUyByZXNvdXJjZSB0eXBlOiAgYEFMSVlVTjo6S01TOjpLZXlgXG4gKi9cbmV4cG9ydCBjbGFzcyBLZXkgZXh0ZW5kcyByb3MuUmVzb3VyY2Uge1xuXG4gICAgLyoqXG4gICAgICogQSBmYWN0b3J5IG1ldGhvZCB0aGF0IGNyZWF0ZXMgYSBuZXcgaW5zdGFuY2Ugb2YgdGhpcyBjbGFzcyBmcm9tIGFuIG9iamVjdFxuICAgICAqIGNvbnRhaW5pbmcgdGhlIHByb3BlcnRpZXMgb2YgdGhpcyBST1MgcmVzb3VyY2UsIHdoaWNoIHdpbGwgYmUgYXNzaWduZWQgdG8gUk9TIHJlc291cmNlLlxuICAgICAqL1xuXG4gICAgLyoqXG4gICAgICogQXR0cmlidXRlIEtleUlkOiBUaGUgZ2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBDTUsuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGF0dHJLZXlJZDogcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgbmV3IGBBTElZVU46OktNUzo6S2V5YC5cbiAgICAgKlxuICAgICAqIFBhcmFtIHNjb3BlIC0gc2NvcGUgaW4gd2hpY2ggdGhpcyByZXNvdXJjZSBpcyBkZWZpbmVkXG4gICAgICogUGFyYW0gaWQgICAgLSBzY29wZWQgaWQgb2YgdGhlIHJlc291cmNlXG4gICAgICogUGFyYW0gcHJvcHMgLSByZXNvdXJjZSBwcm9wZXJ0aWVzXG4gICAgICovXG4gICAgY29uc3RydWN0b3Ioc2NvcGU6IHJvcy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBLZXlQcm9wcyA9IHt9LCBlbmFibGVSZXNvdXJjZVByb3BlcnR5Q29uc3RyYWludDpib29sZWFuID0gdHJ1ZSkge1xuICAgICAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgICAgIGNvbnN0IHJvc0tleSA9IG5ldyBSb3NLZXkodGhpcywgaWQsICB7XG4gICAgICAgICAgICBwcm90ZWN0aW9uTGV2ZWw6IHByb3BzLnByb3RlY3Rpb25MZXZlbCxcbiAgICAgICAgICAgIGRlc2NyaXB0aW9uOiBwcm9wcy5kZXNjcmlwdGlvbixcbiAgICAgICAgICAgIHJvdGF0aW9uSW50ZXJ2YWw6IHByb3BzLnJvdGF0aW9uSW50ZXJ2YWwsXG4gICAgICAgICAgICBwZW5kaW5nV2luZG93SW5EYXlzOiBwcm9wcy5wZW5kaW5nV2luZG93SW5EYXlzID09PSB1bmRlZmluZWQgfHwgcHJvcHMucGVuZGluZ1dpbmRvd0luRGF5cyA9PT0gbnVsbCA/IDMwIDogcHJvcHMucGVuZGluZ1dpbmRvd0luRGF5cyxcbiAgICAgICAgICAgIGVuYWJsZUF1dG9tYXRpY1JvdGF0aW9uOiBwcm9wcy5lbmFibGVBdXRvbWF0aWNSb3RhdGlvbixcbiAgICAgICAgICAgIGtleVNwZWM6IHByb3BzLmtleVNwZWMsXG4gICAgICAgICAgICBlbmFibGU6IHByb3BzLmVuYWJsZSA9PT0gdW5kZWZpbmVkIHx8IHByb3BzLmVuYWJsZSA9PT0gbnVsbCA/IHRydWUgOiBwcm9wcy5lbmFibGUsXG4gICAgICAgICAgICBrZXlVc2FnZTogcHJvcHMua2V5VXNhZ2UsXG4gICAgICAgICAgICBka21zSW5zdGFuY2VJZDogcHJvcHMuZGttc0luc3RhbmNlSWQsXG4gICAgICAgIH0sIGVuYWJsZVJlc291cmNlUHJvcGVydHlDb25zdHJhaW50ICYmIHRoaXMuc3RhY2suZW5hYmxlUmVzb3VyY2VQcm9wZXJ0eUNvbnN0cmFpbnQpO1xuICAgICAgICB0aGlzLnJlc291cmNlID0gcm9zS2V5O1xuICAgICAgICB0aGlzLmF0dHJLZXlJZCA9IHJvc0tleS5hdHRyS2V5SWQ7XG4gICAgfVxufVxuIl19
@@ -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 intended use of the CMK. Default value: ENCRYPT/DECRYPT.
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 intended use of the CMK. Default value: ENCRYPT/DECRYPT.
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
  */
@@ -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('secretData', ros.requiredValidator)(properties.secretData));
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
- secretData: props.secretData,
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2VjcmV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDhDQUE4QztBQUM5QyxtREFBNEM7QUFFdEIsK0ZBRmIseUJBQVMsT0FFa0I7QUE4RHBDOztHQUVHO0FBQ0gsTUFBYSxNQUFPLFNBQVEsR0FBRyxDQUFDLFFBQVE7SUFpQnBDOzs7Ozs7T0FNRztJQUNILFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQUUsS0FBa0IsRUFBRSxtQ0FBMkMsSUFBSTtRQUM3RyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sU0FBUyxHQUFHLElBQUkseUJBQVMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFHO1lBQ3ZDLFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztZQUMxQixVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7WUFDNUIsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1lBQzlCLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYztZQUNwQyxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVU7WUFDNUIsYUFBYSxFQUFFLEtBQUssQ0FBQyxhQUFhO1lBQ2xDLGVBQWUsRUFBRSxLQUFLLENBQUMsZUFBZTtZQUN0QyxvQkFBb0IsRUFBRSxLQUFLLENBQUMsb0JBQW9CLEtBQUssU0FBUyxJQUFJLEtBQUssQ0FBQyxvQkFBb0IsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLG9CQUFvQjtZQUN2SSwwQkFBMEIsRUFBRSxLQUFLLENBQUMsMEJBQTBCLEtBQUssU0FBUyxJQUFJLEtBQUssQ0FBQywwQkFBMEIsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLDBCQUEwQjtTQUNySyxFQUFFLGdDQUFnQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztRQUNwRixJQUFJLENBQUMsUUFBUSxHQUFHLFNBQVMsQ0FBQztRQUMxQixJQUFJLENBQUMsT0FBTyxHQUFHLFNBQVMsQ0FBQyxPQUFPLENBQUM7UUFDakMsSUFBSSxDQUFDLGNBQWMsR0FBRyxTQUFTLENBQUMsY0FBYyxDQUFDO0lBQ25ELENBQUM7Q0FDSjtBQTFDRCx3QkEwQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyByb3MgZnJvbSAnQGFsaWNsb3VkL3Jvcy1jZGstY29yZSc7XG5pbXBvcnQgeyBSb3NTZWNyZXQgfSBmcm9tICcuL2ttcy5nZW5lcmF0ZWQnO1xuLy8gR2VuZXJhdGVkIGZyb20gdGhlIEFsaUNsb3VkIFJPUyBSZXNvdXJjZSBTcGVjaWZpY2F0aW9uXG5leHBvcnQgeyBSb3NTZWNyZXQgYXMgU2VjcmV0UHJvcGVydHkgfTtcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhIGBBTElZVU46OktNUzo6U2VjcmV0YFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNlY3JldFByb3BzIHtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHNlY3JldERhdGE6IFRoZSB2YWx1ZSBvZiB0aGUgc2VjcmV0IHRoYXQgeW91IHdhbnQgdG8gY3JlYXRlLiBTZWNyZXRzIE1hbmFnZXIgZW5jcnlwdHMgdGhlIHNlY3JldFxuICAgICAqIHZhbHVlIGFuZCBzdG9yZXMgaXQgaW4gdGhlIGluaXRpYWwgdmVyc2lvbi5cbiAgICAgKi9cbiAgICByZWFkb25seSBzZWNyZXREYXRhOiBzdHJpbmcgfCByb3MuSVJlc29sdmFibGU7XG5cbiAgICAvKipcbiAgICAgKiBQcm9wZXJ0eSBzZWNyZXROYW1lOiBUaGUgbmFtZSBvZiB0aGUgc2VjcmV0LlxuICAgICAqL1xuICAgIHJlYWRvbmx5IHNlY3JldE5hbWU6IHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIFByb3BlcnR5IHZlcnNpb25JZDogVGhlIHZlcnNpb24gbnVtYmVyIG9mIHRoZSBpbml0aWFsIHZlcnNpb24uIFZlcnNpb24gbnVtYmVycyBhcmUgdW5pcXVlIGluIGVhY2ggc2VjcmV0XG4gICAgICogb2JqZWN0LlxuICAgICAqL1xuICAgIHJlYWRvbmx5IHZlcnNpb25JZDogc3RyaW5nIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgZGVzY3JpcHRpb246IFRoZSBkZXNjcmlwdGlvbiBvZiB0aGUgc2VjcmV0LlxuICAgICAqL1xuICAgIHJlYWRvbmx5IGRlc2NyaXB0aW9uPzogc3RyaW5nIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgZW5jcnlwdGlvbktleUlkOiBUaGUgSUQgb2YgdGhlIEtNUyBDTUsgdGhhdCBpcyB1c2VkIHRvIGVuY3J5cHQgdGhlIHNlY3JldCB2YWx1ZS5cbiAgICAgKiBJZiB5b3UgZG8gbm90IHNwZWNpZnkgdGhpcyBwYXJhbWV0ZXIsIFNlY3JldHMgTWFuYWdlciBhdXRvbWF0aWNhbGx5IGNyZWF0ZXMgYW4gZW5jcnlwdGlvblxuICAgICAqIGtleSB0byBlbmNyeXB0IHRoZSBzZWNyZXQuXG4gICAgICogTm90ZSBUaGUgS01TIENNSyBtdXN0IGJlIGEgc3ltbWV0cmljIGtleS5cbiAgICAgKi9cbiAgICByZWFkb25seSBlbmNyeXB0aW9uS2V5SWQ/OiBzdHJpbmcgfCByb3MuSVJlc29sdmFibGU7XG5cbiAgICAvKipcbiAgICAgKiBQcm9wZXJ0eSBmb3JjZURlbGV0ZVdpdGhvdXRSZWNvdmVyeTogU3BlY2lmaWVzIHdoZXRoZXIgdG8gZm9yY2libHkgZGVsZXRlIHRoZSBzZWNyZXQuIElmIHRoaXMgcGFyYW1ldGVyIGlzIHNldCB0byB0cnVlLCB0aGUgc2VjcmV0IGNhbm5vdCBiZSByZWNvdmVyZWQuIFZhbGlkIHZhbHVlczpcbiAgICAgKiB0cnVlXG4gICAgICogZmFsc2UgKGRlZmF1bHQgdmFsdWUpXG4gICAgICovXG4gICAgcmVhZG9ubHkgZm9yY2VEZWxldGVXaXRob3V0UmVjb3Zlcnk/OiBib29sZWFuIHwgcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogUHJvcGVydHkgcmVjb3ZlcnlXaW5kb3dJbkRheXM6IFNwZWNpZmllcyB0aGUgcmVjb3ZlcnkgcGVyaW9kIG9mIHRoZSBzZWNyZXQgaWYgeW91IGRvIG5vdCBmb3JjaWJseSBkZWxldGUgaXQuIERlZmF1bHQgdmFsdWU6IDMwXG4gICAgICovXG4gICAgcmVhZG9ubHkgcmVjb3ZlcnlXaW5kb3dJbkRheXM/OiBudW1iZXIgfCByb3MuSVJlc29sdmFibGU7XG5cbiAgICAvKipcbiAgICAgKiBQcm9wZXJ0eSBzZWNyZXREYXRhVHlwZTogVGhlIHR5cGUgb2YgdGhlIHNlY3JldCB2YWx1ZS4gVmFsaWQgdmFsdWVzOlxuICAgICAqIHRleHQgKGRlZmF1bHQgdmFsdWUpXG4gICAgICogYmluYXJ5XG4gICAgICovXG4gICAgcmVhZG9ubHkgc2VjcmV0RGF0YVR5cGU/OiBzdHJpbmcgfCByb3MuSVJlc29sdmFibGU7XG5cbiAgICAvKipcbiAgICAgKiBQcm9wZXJ0eSB2ZXJzaW9uU3RhZ2VzOiBUaGUgc3RhZ2UgbGFiZWxzIHRoYXQgbWFyayB0aGUgc2VjcmV0IHZlcnNpb24uIEFDU0N1cnJlbnQgd2lsbCBiZSBtYXJrZWQgYXMgRGVmYXVsdElmIHlvdSBkbyBub3Qgc3BlY2lmeSBpdCwgU2VjcmV0cyBNYW5hZ2VyIG1hcmtzIGl0IHdpdGggXCJBQ1NDdXJyZW50XCIuXG4gICAgICovXG4gICAgcmVhZG9ubHkgdmVyc2lvblN0YWdlcz86IEFycmF5PHN0cmluZyB8IHJvcy5JUmVzb2x2YWJsZT4gfCByb3MuSVJlc29sdmFibGU7XG59XG5cbi8qKlxuICogQSBST1MgcmVzb3VyY2UgdHlwZTogIGBBTElZVU46OktNUzo6U2VjcmV0YFxuICovXG5leHBvcnQgY2xhc3MgU2VjcmV0IGV4dGVuZHMgcm9zLlJlc291cmNlIHtcblxuICAgIC8qKlxuICAgICAqIEEgZmFjdG9yeSBtZXRob2QgdGhhdCBjcmVhdGVzIGEgbmV3IGluc3RhbmNlIG9mIHRoaXMgY2xhc3MgZnJvbSBhbiBvYmplY3RcbiAgICAgKiBjb250YWluaW5nIHRoZSBwcm9wZXJ0aWVzIG9mIHRoaXMgUk9TIHJlc291cmNlLCB3aGljaCB3aWxsIGJlIGFzc2lnbmVkIHRvIFJPUyByZXNvdXJjZS5cbiAgICAgKi9cblxuICAgIC8qKlxuICAgICAqIEF0dHJpYnV0ZSBBcm46IFRoZSBBbGliYWJhIENsb3VkIFJlc291cmNlIE5hbWUgKEFSTikuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGF0dHJBcm46IHJvcy5JUmVzb2x2YWJsZTtcblxuICAgIC8qKlxuICAgICAqIEF0dHJpYnV0ZSBTZWNyZXROYW1lOiBUaGUgbmFtZSBvZiB0aGUgc2VjcmV0LlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBhdHRyU2VjcmV0TmFtZTogcm9zLklSZXNvbHZhYmxlO1xuXG4gICAgLyoqXG4gICAgICogQ3JlYXRlIGEgbmV3IGBBTElZVU46OktNUzo6U2VjcmV0YC5cbiAgICAgKlxuICAgICAqIFBhcmFtIHNjb3BlIC0gc2NvcGUgaW4gd2hpY2ggdGhpcyByZXNvdXJjZSBpcyBkZWZpbmVkXG4gICAgICogUGFyYW0gaWQgICAgLSBzY29wZWQgaWQgb2YgdGhlIHJlc291cmNlXG4gICAgICogUGFyYW0gcHJvcHMgLSByZXNvdXJjZSBwcm9wZXJ0aWVzXG4gICAgICovXG4gICAgY29uc3RydWN0b3Ioc2NvcGU6IHJvcy5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBTZWNyZXRQcm9wcywgZW5hYmxlUmVzb3VyY2VQcm9wZXJ0eUNvbnN0cmFpbnQ6Ym9vbGVhbiA9IHRydWUpIHtcbiAgICAgICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgICAgICBjb25zdCByb3NTZWNyZXQgPSBuZXcgUm9zU2VjcmV0KHRoaXMsIGlkLCAge1xuICAgICAgICAgICAgdmVyc2lvbklkOiBwcm9wcy52ZXJzaW9uSWQsXG4gICAgICAgICAgICBzZWNyZXROYW1lOiBwcm9wcy5zZWNyZXROYW1lLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246IHByb3BzLmRlc2NyaXB0aW9uLFxuICAgICAgICAgICAgc2VjcmV0RGF0YVR5cGU6IHByb3BzLnNlY3JldERhdGFUeXBlLFxuICAgICAgICAgICAgc2VjcmV0RGF0YTogcHJvcHMuc2VjcmV0RGF0YSxcbiAgICAgICAgICAgIHZlcnNpb25TdGFnZXM6IHByb3BzLnZlcnNpb25TdGFnZXMsXG4gICAgICAgICAgICBlbmNyeXB0aW9uS2V5SWQ6IHByb3BzLmVuY3J5cHRpb25LZXlJZCxcbiAgICAgICAgICAgIHJlY292ZXJ5V2luZG93SW5EYXlzOiBwcm9wcy5yZWNvdmVyeVdpbmRvd0luRGF5cyA9PT0gdW5kZWZpbmVkIHx8IHByb3BzLnJlY292ZXJ5V2luZG93SW5EYXlzID09PSBudWxsID8gMzAgOiBwcm9wcy5yZWNvdmVyeVdpbmRvd0luRGF5cyxcbiAgICAgICAgICAgIGZvcmNlRGVsZXRlV2l0aG91dFJlY292ZXJ5OiBwcm9wcy5mb3JjZURlbGV0ZVdpdGhvdXRSZWNvdmVyeSA9PT0gdW5kZWZpbmVkIHx8IHByb3BzLmZvcmNlRGVsZXRlV2l0aG91dFJlY292ZXJ5ID09PSBudWxsID8gZmFsc2UgOiBwcm9wcy5mb3JjZURlbGV0ZVdpdGhvdXRSZWNvdmVyeSxcbiAgICAgICAgfSwgZW5hYmxlUmVzb3VyY2VQcm9wZXJ0eUNvbnN0cmFpbnQgJiYgdGhpcy5zdGFjay5lbmFibGVSZXNvdXJjZVByb3BlcnR5Q29uc3RyYWludCk7XG4gICAgICAgIHRoaXMucmVzb3VyY2UgPSByb3NTZWNyZXQ7XG4gICAgICAgIHRoaXMuYXR0ckFybiA9IHJvc1NlY3JldC5hdHRyQXJuO1xuICAgICAgICB0aGlzLmF0dHJTZWNyZXROYW1lID0gcm9zU2VjcmV0LmF0dHJTZWNyZXROYW1lO1xuICAgIH1cbn1cbiJdfQ==
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alicloud/ros-cdk-kms",
3
- "version": "1.0.12",
3
+ "version": "1.0.13",
4
4
  "description": "Aliyun SDK Copyright (C) Alibaba Cloud Computing All rights reserved. http://www.aliyun.com",
5
5
  "author": "ROS Development Team",
6
6
  "license": "Apache-2.0",