Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-kms

Package Overview
Dependencies
Maintainers
4
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-kms - npm Package Compare versions

Comparing version 0.9.2 to 0.10.0

2

lib/alias.js

@@ -36,2 +36,2 @@ "use strict";

exports.EncryptionKeyAlias = EncryptionKeyAlias;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxpYXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhbGlhcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5QztBQUV6QyxtREFBaUQ7QUFFakQsTUFBTSxxQkFBcUIsR0FBRyxRQUFRLENBQUM7QUFDdkMsTUFBTSxpQkFBaUIsR0FBRyxxQkFBcUIsR0FBRyxLQUFLLENBQUM7QUFrQnhEOzs7Ozs7OztHQVFHO0FBQ0gsTUFBYSxrQkFBbUIsU0FBUSxlQUFTO0lBTTdDLFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBOEI7UUFDdkUsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVwQixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMscUJBQXFCLENBQUMsRUFBRTtZQUNoRCxNQUFNLElBQUksS0FBSyxDQUFDLHFDQUFxQyxxQkFBcUIsTUFBTSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztTQUNsRztRQUVELElBQUksS0FBSyxDQUFDLEtBQUssS0FBSyxxQkFBcUIsRUFBRTtZQUN2QyxNQUFNLElBQUksS0FBSyxDQUFDLHFDQUFxQyxxQkFBcUIsTUFBTSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztTQUNsRztRQUVELElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsRUFBRTtZQUMzQyxNQUFNLElBQUksS0FBSyxDQUFDLDJCQUEyQixpQkFBaUIsS0FBSyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztTQUNuRjtRQUVELE1BQU0sUUFBUSxHQUFHLElBQUksOEJBQWMsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUNoRSxTQUFTLEVBQUUsS0FBSyxDQUFDLEtBQUs7WUFDdEIsV0FBVyxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsTUFBTTtTQUNoQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUM7SUFDeEMsQ0FBQztDQUNKO0FBNUJELGdEQTRCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBFbmNyeXB0aW9uS2V5UmVmIH0gZnJvbSAnLi9rZXknO1xuaW1wb3J0IHsgY2xvdWRmb3JtYXRpb24gfSBmcm9tICcuL2ttcy5nZW5lcmF0ZWQnO1xuXG5jb25zdCBSRVFVSVJFRF9BTElBU19QUkVGSVggPSAnYWxpYXMvJztcbmNvbnN0IERJU0FMTE9XRURfUFJFRklYID0gUkVRVUlSRURfQUxJQVNfUFJFRklYICsgJ0FXUyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5jcnlwdGlvbktleUFsaWFzUHJvcHMge1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBhbGlhcy4gVGhlIG5hbWUgbXVzdCBzdGFydCB3aXRoIGFsaWFzIGZvbGxvd2VkIGJ5IGFcbiAgICAgKiBmb3J3YXJkIHNsYXNoLCBzdWNoIGFzIGFsaWFzLy4gWW91IGNhbid0IHNwZWNpZnkgYWxpYXNlcyB0aGF0IGJlZ2luIHdpdGhcbiAgICAgKiBhbGlhcy9BV1MuIFRoZXNlIGFsaWFzZXMgYXJlIHJlc2VydmVkLlxuICAgICAqL1xuICAgIGFsaWFzOiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgSUQgb2YgdGhlIGtleSBmb3Igd2hpY2ggeW91IGFyZSBjcmVhdGluZyB0aGUgYWxpYXMuIFNwZWNpZnkgdGhlIGtleSdzXG4gICAgICogZ2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgb3IgQW1hem9uIFJlc291cmNlIE5hbWUgKEFSTikuIFlvdSBjYW4ndFxuICAgICAqIHNwZWNpZnkgYW5vdGhlciBhbGlhcy5cbiAgICAgKi9cbiAgICBrZXk6IEVuY3J5cHRpb25LZXlSZWY7XG59XG5cbi8qKlxuICogRGVmaW5lcyBhIGRpc3BsYXkgbmFtZSBmb3IgYSBjdXN0b21lciBtYXN0ZXIga2V5IChDTUspIGluIEFXUyBLZXkgTWFuYWdlbWVudFxuICogU2VydmljZSAoQVdTIEtNUykuIFVzaW5nIGFuIGFsaWFzIHRvIHJlZmVyIHRvIGEga2V5IGNhbiBoZWxwIHlvdSBzaW1wbGlmeSBrZXlcbiAqIG1hbmFnZW1lbnQuIEZvciBleGFtcGxlLCB3aGVuIHJvdGF0aW5nIGtleXMsIHlvdSBjYW4ganVzdCB1cGRhdGUgdGhlIGFsaWFzXG4gKiBtYXBwaW5nIGluc3RlYWQgb2YgdHJhY2tpbmcgYW5kIGNoYW5naW5nIGtleSBJRHMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWVcbiAqIFdvcmtpbmcgd2l0aCBBbGlhc2VzIGluIHRoZSBBV1MgS2V5IE1hbmFnZW1lbnQgU2VydmljZSBEZXZlbG9wZXIgR3VpZGUuXG4gKlxuICogWW91IGNhbiBhbHNvIGFkZCBhbiBhbGlhcyBmb3IgYSBrZXkgYnkgY2FsbGluZyBga2V5LmFkZEFsaWFzKGFsaWFzKWAuXG4gKi9cbmV4cG9ydCBjbGFzcyBFbmNyeXB0aW9uS2V5QWxpYXMgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBhbGlhcy5cbiAgICAgKi9cbiAgICBwdWJsaWMgYWxpYXNOYW1lOiBzdHJpbmc7XG5cbiAgICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogRW5jcnlwdGlvbktleUFsaWFzUHJvcHMpIHtcbiAgICAgICAgc3VwZXIocGFyZW50LCBuYW1lKTtcblxuICAgICAgICBpZiAoIXByb3BzLmFsaWFzLnN0YXJ0c1dpdGgoUkVRVUlSRURfQUxJQVNfUFJFRklYKSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBBbGlhcyBtdXN0IHN0YXJ0IHdpdGggdGhlIHByZWZpeCBcIiR7UkVRVUlSRURfQUxJQVNfUFJFRklYfVwiOiAke3Byb3BzLmFsaWFzfWApO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHByb3BzLmFsaWFzID09PSBSRVFVSVJFRF9BTElBU19QUkVGSVgpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgQWxpYXMgbXVzdCBpbmNsdWRlIGEgdmFsdWUgYWZ0ZXIgXCIke1JFUVVJUkVEX0FMSUFTX1BSRUZJWH1cIjogJHtwcm9wcy5hbGlhc31gKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChwcm9wcy5hbGlhcy5zdGFydHNXaXRoKERJU0FMTE9XRURfUFJFRklYKSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBBbGlhcyBjYW5ub3Qgc3RhcnQgd2l0aCAke0RJU0FMTE9XRURfUFJFRklYfTogJHtwcm9wcy5hbGlhc31gKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHJlc291cmNlID0gbmV3IGNsb3VkZm9ybWF0aW9uLkFsaWFzUmVzb3VyY2UodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgICAgICAgYWxpYXNOYW1lOiBwcm9wcy5hbGlhcyxcbiAgICAgICAgICAgIHRhcmdldEtleUlkOiBwcm9wcy5rZXkua2V5QXJuXG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRoaXMuYWxpYXNOYW1lID0gcmVzb3VyY2UuYWxpYXNOYW1lO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxpYXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJhbGlhcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5QztBQUV6QyxtREFBaUQ7QUFFakQsTUFBTSxxQkFBcUIsR0FBRyxRQUFRLENBQUM7QUFDdkMsTUFBTSxpQkFBaUIsR0FBRyxxQkFBcUIsR0FBRyxLQUFLLENBQUM7QUFrQnhEOzs7Ozs7OztHQVFHO0FBQ0gsTUFBYSxrQkFBbUIsU0FBUSxlQUFTO0lBTS9DLFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBOEI7UUFDekUsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVwQixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMscUJBQXFCLENBQUMsRUFBRTtZQUNsRCxNQUFNLElBQUksS0FBSyxDQUFDLHFDQUFxQyxxQkFBcUIsTUFBTSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztTQUNoRztRQUVELElBQUksS0FBSyxDQUFDLEtBQUssS0FBSyxxQkFBcUIsRUFBRTtZQUN6QyxNQUFNLElBQUksS0FBSyxDQUFDLHFDQUFxQyxxQkFBcUIsTUFBTSxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztTQUNoRztRQUVELElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsRUFBRTtZQUM3QyxNQUFNLElBQUksS0FBSyxDQUFDLDJCQUEyQixpQkFBaUIsS0FBSyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztTQUNqRjtRQUVELE1BQU0sUUFBUSxHQUFHLElBQUksOEJBQWMsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUNsRSxTQUFTLEVBQUUsS0FBSyxDQUFDLEtBQUs7WUFDdEIsV0FBVyxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsTUFBTTtTQUM5QixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUM7SUFDdEMsQ0FBQztDQUNGO0FBNUJELGdEQTRCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBFbmNyeXB0aW9uS2V5UmVmIH0gZnJvbSAnLi9rZXknO1xuaW1wb3J0IHsgY2xvdWRmb3JtYXRpb24gfSBmcm9tICcuL2ttcy5nZW5lcmF0ZWQnO1xuXG5jb25zdCBSRVFVSVJFRF9BTElBU19QUkVGSVggPSAnYWxpYXMvJztcbmNvbnN0IERJU0FMTE9XRURfUFJFRklYID0gUkVRVUlSRURfQUxJQVNfUFJFRklYICsgJ0FXUyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5jcnlwdGlvbktleUFsaWFzUHJvcHMge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIGFsaWFzLiBUaGUgbmFtZSBtdXN0IHN0YXJ0IHdpdGggYWxpYXMgZm9sbG93ZWQgYnkgYVxuICAgKiBmb3J3YXJkIHNsYXNoLCBzdWNoIGFzIGFsaWFzLy4gWW91IGNhbid0IHNwZWNpZnkgYWxpYXNlcyB0aGF0IGJlZ2luIHdpdGhcbiAgICogYWxpYXMvQVdTLiBUaGVzZSBhbGlhc2VzIGFyZSByZXNlcnZlZC5cbiAgICovXG4gIGFsaWFzOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBJRCBvZiB0aGUga2V5IGZvciB3aGljaCB5b3UgYXJlIGNyZWF0aW5nIHRoZSBhbGlhcy4gU3BlY2lmeSB0aGUga2V5J3NcbiAgICogZ2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgb3IgQW1hem9uIFJlc291cmNlIE5hbWUgKEFSTikuIFlvdSBjYW4ndFxuICAgKiBzcGVjaWZ5IGFub3RoZXIgYWxpYXMuXG4gICAqL1xuICBrZXk6IEVuY3J5cHRpb25LZXlSZWY7XG59XG5cbi8qKlxuICogRGVmaW5lcyBhIGRpc3BsYXkgbmFtZSBmb3IgYSBjdXN0b21lciBtYXN0ZXIga2V5IChDTUspIGluIEFXUyBLZXkgTWFuYWdlbWVudFxuICogU2VydmljZSAoQVdTIEtNUykuIFVzaW5nIGFuIGFsaWFzIHRvIHJlZmVyIHRvIGEga2V5IGNhbiBoZWxwIHlvdSBzaW1wbGlmeSBrZXlcbiAqIG1hbmFnZW1lbnQuIEZvciBleGFtcGxlLCB3aGVuIHJvdGF0aW5nIGtleXMsIHlvdSBjYW4ganVzdCB1cGRhdGUgdGhlIGFsaWFzXG4gKiBtYXBwaW5nIGluc3RlYWQgb2YgdHJhY2tpbmcgYW5kIGNoYW5naW5nIGtleSBJRHMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWVcbiAqIFdvcmtpbmcgd2l0aCBBbGlhc2VzIGluIHRoZSBBV1MgS2V5IE1hbmFnZW1lbnQgU2VydmljZSBEZXZlbG9wZXIgR3VpZGUuXG4gKlxuICogWW91IGNhbiBhbHNvIGFkZCBhbiBhbGlhcyBmb3IgYSBrZXkgYnkgY2FsbGluZyBga2V5LmFkZEFsaWFzKGFsaWFzKWAuXG4gKi9cbmV4cG9ydCBjbGFzcyBFbmNyeXB0aW9uS2V5QWxpYXMgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIGFsaWFzLlxuICAgKi9cbiAgcHVibGljIGFsaWFzTmFtZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBFbmNyeXB0aW9uS2V5QWxpYXNQcm9wcykge1xuICAgIHN1cGVyKHBhcmVudCwgbmFtZSk7XG5cbiAgICBpZiAoIXByb3BzLmFsaWFzLnN0YXJ0c1dpdGgoUkVRVUlSRURfQUxJQVNfUFJFRklYKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBBbGlhcyBtdXN0IHN0YXJ0IHdpdGggdGhlIHByZWZpeCBcIiR7UkVRVUlSRURfQUxJQVNfUFJFRklYfVwiOiAke3Byb3BzLmFsaWFzfWApO1xuICAgIH1cblxuICAgIGlmIChwcm9wcy5hbGlhcyA9PT0gUkVRVUlSRURfQUxJQVNfUFJFRklYKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEFsaWFzIG11c3QgaW5jbHVkZSBhIHZhbHVlIGFmdGVyIFwiJHtSRVFVSVJFRF9BTElBU19QUkVGSVh9XCI6ICR7cHJvcHMuYWxpYXN9YCk7XG4gICAgfVxuXG4gICAgaWYgKHByb3BzLmFsaWFzLnN0YXJ0c1dpdGgoRElTQUxMT1dFRF9QUkVGSVgpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEFsaWFzIGNhbm5vdCBzdGFydCB3aXRoICR7RElTQUxMT1dFRF9QUkVGSVh9OiAke3Byb3BzLmFsaWFzfWApO1xuICAgIH1cblxuICAgIGNvbnN0IHJlc291cmNlID0gbmV3IGNsb3VkZm9ybWF0aW9uLkFsaWFzUmVzb3VyY2UodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgYWxpYXNOYW1lOiBwcm9wcy5hbGlhcyxcbiAgICAgIHRhcmdldEtleUlkOiBwcm9wcy5rZXkua2V5QXJuXG4gICAgfSk7XG5cbiAgICB0aGlzLmFsaWFzTmFtZSA9IHJlc291cmNlLmFsaWFzTmFtZTtcbiAgfVxufVxuIl19

@@ -18,7 +18,7 @@ import { Construct, PolicyDocument, PolicyStatement } from '@aws-cdk/cdk';

*
* const keyRefProps = key.export();
* const keyRef1 = EncryptionKeyRef.import(this, 'MyImportedKey1', keyRefProps);
* const keyRef2 = EncryptionKeyRef.import(this, 'MyImportedKey2', {
* keyArn: new KeyArn('arn:aws:kms:...')
* });
* const keyRefProps = key.export();
* const keyRef1 = EncryptionKeyRef.import(this, 'MyImportedKey1', keyRefProps);
* const keyRef2 = EncryptionKeyRef.import(this, 'MyImportedKey2', {
* keyArn: new KeyArn('arn:aws:kms:...')
* });
*

@@ -25,0 +25,0 @@ * @param parent The parent construct.

@@ -15,7 +15,7 @@ "use strict";

*
* const keyRefProps = key.export();
* const keyRef1 = EncryptionKeyRef.import(this, 'MyImportedKey1', keyRefProps);
* const keyRef2 = EncryptionKeyRef.import(this, 'MyImportedKey2', {
* keyArn: new KeyArn('arn:aws:kms:...')
* });
* const keyRefProps = key.export();
* const keyRef1 = EncryptionKeyRef.import(this, 'MyImportedKey1', keyRefProps);
* const keyRef2 = EncryptionKeyRef.import(this, 'MyImportedKey2', {
* keyArn: new KeyArn('arn:aws:kms:...')
* });
*

@@ -117,2 +117,2 @@ * @param parent The parent construct.

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["key.ts"],"names":[],"mappings":";;AAAA,sCAA2G;AAC3G,mCAA6C;AAC7C,mDAAiD;AASjD,MAAsB,gBAAiB,SAAQ,eAAS;IACpD;;;;;;;;;;;;;;;;;OAiBG;IACI,MAAM,CAAC,MAAM,CAAC,MAAiB,EAAE,IAAY,EAAE,KAA4B;QAC9E,OAAO,IAAI,sBAAsB,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IAC3D,CAAC;IAeD;;OAEG;IACI,QAAQ,CAAC,KAAa;QACzB,OAAO,IAAI,0BAAkB,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;IACvE,CAAC;IAED;;;;;;OAMG;IACI,mBAAmB,CAAC,SAA0B,EAAE,SAAS,GAAG,IAAI;QACnE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,IAAI,SAAS,EAAE;gBAAE,OAAO;aAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,+DAA+D,IAAI,CAAC,SAAS,CAAC,aAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC;SAC1H;QAED,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IACxC,CAAC;IAED;;;OAGG;IACI,MAAM;QACT,OAAO;YACH,MAAM,EAAE,IAAI,YAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,eAAe,EAAE,CAAC,QAAQ,EAAE;SAClE,CAAC;IACN,CAAC;CACJ;AApED,4CAoEC;AAiCD;;GAEG;AACH,MAAa,aAAc,SAAQ,gBAAgB;IAI/C,YAAY,MAAiB,EAAE,IAAY,EAAE,QAA4B,EAAE;QACvE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAEpB,IAAI,KAAK,CAAC,MAAM,EAAE;YACd,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;SAC9B;aAAM;YACH,IAAI,CAAC,MAAM,GAAG,IAAI,oBAAc,EAAE,CAAC;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9B;QAED,MAAM,QAAQ,GAAG,IAAI,8BAAc,CAAC,WAAW,CAAC,IAAI,EAAE,UAAU,EAAE;YAC9D,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;YAC1C,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,SAAS,EAAE,IAAI,CAAC,MAAM;SACzB,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC;QAC9B,QAAQ,CAAC,OAAO,CAAC,cAAc,GAAG,oBAAc,CAAC,MAAM,CAAC;IAC5D,CAAC;IAED;;;OAGG;IACK,mBAAmB;QACvB,MAAM,OAAO,GAAG;YACZ,aAAa;YACb,eAAe;YACf,aAAa;YACb,WAAW;YACX,UAAU;YACV,aAAa;YACb,aAAa;YACb,cAAc;YACd,UAAU;YACV,aAAa;YACb,yBAAyB;YACzB,uBAAuB;SAC1B,CAAC;QAEF,IAAI,CAAC,mBAAmB,CAAC,IAAI,qBAAe,EAAE;aACzC,eAAe,EAAE;aACjB,UAAU,CAAC,GAAG,OAAO,CAAC;aACtB,uBAAuB,EAAE,CAAC,CAAC;IACpC,CAAC;CACJ;AAlDD,sCAkDC;AAED,MAAM,sBAAuB,SAAQ,gBAAgB;IAIjD,YAAY,MAAiB,EAAE,IAAY,EAAE,KAA4B;QACrE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAHL,WAAM,GAAG,SAAS,CAAC,CAAC,4CAA4C;QAK/E,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAC/B,CAAC;CACJ","sourcesContent":["import { Construct, DeletionPolicy, Output, PolicyDocument, PolicyStatement, resolve } from '@aws-cdk/cdk';\nimport { EncryptionKeyAlias } from './alias';\nimport { cloudformation } from './kms.generated';\n\nexport interface EncryptionKeyRefProps {\n    /**\n     * The ARN of the external KMS key.\n     */\n    keyArn: string;\n}\n\nexport abstract class EncryptionKeyRef extends Construct {\n    /**\n     * Defines an imported encryption key.\n     *\n     * `ref` can be obtained either via a call to `key.export()` or using\n     * literals.\n     *\n     * For example:\n     *\n     *     const keyRefProps = key.export();\n     *     const keyRef1 = EncryptionKeyRef.import(this, 'MyImportedKey1', keyRefProps);\n     *     const keyRef2 = EncryptionKeyRef.import(this, 'MyImportedKey2', {\n     *         keyArn: new KeyArn('arn:aws:kms:...')\n     *     });\n     *\n     * @param parent The parent construct.\n     * @param name The name of the construct.\n     * @param props The key reference.\n     */\n    public static import(parent: Construct, name: string, props: EncryptionKeyRefProps): EncryptionKeyRef {\n        return new EncryptionKeyRefImport(parent, name, props);\n    }\n\n    /**\n     * The ARN of the key.\n     */\n    public abstract readonly keyArn: string;\n\n    /**\n     * Optional policy document that represents the resource policy of this key.\n     *\n     * If specified, addToResourcePolicy can be used to edit this policy.\n     * Otherwise this method will no-op.\n     */\n    protected abstract readonly policy?: PolicyDocument;\n\n    /**\n     * Defines a new alias for the key.\n     */\n    public addAlias(alias: string): EncryptionKeyAlias {\n        return new EncryptionKeyAlias(this, 'Alias', { alias, key: this });\n    }\n\n    /**\n     * Adds a statement to the KMS key resource policy.\n     * @param statement The policy statement to add\n     * @param allowNoOp If this is set to `false` and there is no policy\n     * defined (i.e. external key), the operation will fail. Otherwise, it will\n     * no-op.\n     */\n    public addToResourcePolicy(statement: PolicyStatement, allowNoOp = true) {\n        if (!this.policy) {\n            if (allowNoOp) { return; }\n            throw new Error(`Unable to add statement to IAM resource policy for KMS key: ${JSON.stringify(resolve(this.keyArn))}`);\n        }\n\n        this.policy.addStatement(statement);\n    }\n\n    /**\n     * Exports this key from the current stack.\n     * @returns a key ref which can be used in a call to `EncryptionKey.import(ref)`.\n     */\n    public export(): EncryptionKeyRefProps {\n        return {\n            keyArn: new Output(this, 'KeyArn').makeImportValue().toString()\n        };\n    }\n}\n\n/**\n * Construction properties for a KMS Key object\n */\nexport interface EncryptionKeyProps {\n    /**\n     * A description of the key. Use a description that helps your users decide\n     * whether the key is appropriate for a particular task.\n     */\n    description?: string;\n\n    /**\n     * Indicates whether AWS KMS rotates the key.\n     * @default false\n     */\n    enableKeyRotation?: boolean;\n\n    /**\n     * Indicates whether the key is available for use.\n     * @default Key is enabled\n     */\n    enabled?: boolean;\n\n    /**\n     * Custom policy document to attach to the KMS key.\n     *\n     * @default A policy document with permissions for the account root to\n     * administer the key will be created.\n     */\n    policy?: PolicyDocument;\n}\n\n/**\n * Definews a KMS key.\n */\nexport class EncryptionKey extends EncryptionKeyRef {\n    public readonly keyArn: string;\n    protected readonly policy?: PolicyDocument;\n\n    constructor(parent: Construct, name: string, props: EncryptionKeyProps = {}) {\n        super(parent, name);\n\n        if (props.policy) {\n            this.policy = props.policy;\n        } else {\n            this.policy = new PolicyDocument();\n            this.allowAccountToAdmin();\n        }\n\n        const resource = new cloudformation.KeyResource(this, 'Resource', {\n            description: props.description,\n            enableKeyRotation: props.enableKeyRotation,\n            enabled: props.enabled,\n            keyPolicy: this.policy\n        });\n\n        this.keyArn = resource.keyArn;\n        resource.options.deletionPolicy = DeletionPolicy.Retain;\n    }\n\n    /**\n     * Let users from this account admin this key.\n     * @link https://aws.amazon.com/premiumsupport/knowledge-center/update-key-policy-future/\n     */\n    private allowAccountToAdmin() {\n        const actions = [\n            \"kms:Create*\",\n            \"kms:Describe*\",\n            \"kms:Enable*\",\n            \"kms:List*\",\n            \"kms:Put*\",\n            \"kms:Update*\",\n            \"kms:Revoke*\",\n            \"kms:Disable*\",\n            \"kms:Get*\",\n            \"kms:Delete*\",\n            \"kms:ScheduleKeyDeletion\",\n            \"kms:CancelKeyDeletion\"\n        ];\n\n        this.addToResourcePolicy(new PolicyStatement()\n            .addAllResources()\n            .addActions(...actions)\n            .addAccountRootPrincipal());\n    }\n}\n\nclass EncryptionKeyRefImport extends EncryptionKeyRef {\n    public readonly keyArn: string;\n    protected readonly policy = undefined; // no policy associated with an imported key\n\n    constructor(parent: Construct, name: string, props: EncryptionKeyRefProps) {\n        super(parent, name);\n\n        this.keyArn = props.keyArn;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["key.ts"],"names":[],"mappings":";;AAAA,sCAA2G;AAC3G,mCAA6C;AAC7C,mDAAiD;AASjD,MAAsB,gBAAiB,SAAQ,eAAS;IACtD;;;;;;;;;;;;;;;;;OAiBG;IACI,MAAM,CAAC,MAAM,CAAC,MAAiB,EAAE,IAAY,EAAE,KAA4B;QAChF,OAAO,IAAI,sBAAsB,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACzD,CAAC;IAeD;;OAEG;IACI,QAAQ,CAAC,KAAa;QAC3B,OAAO,IAAI,0BAAkB,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;IACrE,CAAC;IAED;;;;;;OAMG;IACI,mBAAmB,CAAC,SAA0B,EAAE,SAAS,GAAG,IAAI;QACrE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,SAAS,EAAE;gBAAE,OAAO;aAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,+DAA+D,IAAI,CAAC,SAAS,CAAC,aAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC;SACxH;QAED,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED;;;OAGG;IACI,MAAM;QACX,OAAO;YACL,MAAM,EAAE,IAAI,YAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,eAAe,EAAE,CAAC,QAAQ,EAAE;SAChE,CAAC;IACJ,CAAC;CACF;AApED,4CAoEC;AAiCD;;GAEG;AACH,MAAa,aAAc,SAAQ,gBAAgB;IAIjD,YAAY,MAAiB,EAAE,IAAY,EAAE,QAA4B,EAAE;QACzE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAEpB,IAAI,KAAK,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;SAC5B;aAAM;YACL,IAAI,CAAC,MAAM,GAAG,IAAI,oBAAc,EAAE,CAAC;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;QAED,MAAM,QAAQ,GAAG,IAAI,8BAAc,CAAC,WAAW,CAAC,IAAI,EAAE,UAAU,EAAE;YAChE,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;YAC1C,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,SAAS,EAAE,IAAI,CAAC,MAAM;SACvB,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC;QAC9B,QAAQ,CAAC,OAAO,CAAC,cAAc,GAAG,oBAAc,CAAC,MAAM,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACK,mBAAmB;QACzB,MAAM,OAAO,GAAG;YACd,aAAa;YACb,eAAe;YACf,aAAa;YACb,WAAW;YACX,UAAU;YACV,aAAa;YACb,aAAa;YACb,cAAc;YACd,UAAU;YACV,aAAa;YACb,yBAAyB;YACzB,uBAAuB;SACxB,CAAC;QAEF,IAAI,CAAC,mBAAmB,CAAC,IAAI,qBAAe,EAAE;aAC3C,eAAe,EAAE;aACjB,UAAU,CAAC,GAAG,OAAO,CAAC;aACtB,uBAAuB,EAAE,CAAC,CAAC;IAChC,CAAC;CACF;AAlDD,sCAkDC;AAED,MAAM,sBAAuB,SAAQ,gBAAgB;IAInD,YAAY,MAAiB,EAAE,IAAY,EAAE,KAA4B;QACvE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAHH,WAAM,GAAG,SAAS,CAAC,CAAC,4CAA4C;QAKjF,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAC7B,CAAC;CACF","sourcesContent":["import { Construct, DeletionPolicy, Output, PolicyDocument, PolicyStatement, resolve } from '@aws-cdk/cdk';\nimport { EncryptionKeyAlias } from './alias';\nimport { cloudformation } from './kms.generated';\n\nexport interface EncryptionKeyRefProps {\n  /**\n   * The ARN of the external KMS key.\n   */\n  keyArn: string;\n}\n\nexport abstract class EncryptionKeyRef extends Construct {\n  /**\n   * Defines an imported encryption key.\n   *\n   * `ref` can be obtained either via a call to `key.export()` or using\n   * literals.\n   *\n   * For example:\n   *\n   *   const keyRefProps = key.export();\n   *   const keyRef1 = EncryptionKeyRef.import(this, 'MyImportedKey1', keyRefProps);\n   *   const keyRef2 = EncryptionKeyRef.import(this, 'MyImportedKey2', {\n   *     keyArn: new KeyArn('arn:aws:kms:...')\n   *   });\n   *\n   * @param parent The parent construct.\n   * @param name The name of the construct.\n   * @param props The key reference.\n   */\n  public static import(parent: Construct, name: string, props: EncryptionKeyRefProps): EncryptionKeyRef {\n    return new EncryptionKeyRefImport(parent, name, props);\n  }\n\n  /**\n   * The ARN of the key.\n   */\n  public abstract readonly keyArn: string;\n\n  /**\n   * Optional policy document that represents the resource policy of this key.\n   *\n   * If specified, addToResourcePolicy can be used to edit this policy.\n   * Otherwise this method will no-op.\n   */\n  protected abstract readonly policy?: PolicyDocument;\n\n  /**\n   * Defines a new alias for the key.\n   */\n  public addAlias(alias: string): EncryptionKeyAlias {\n    return new EncryptionKeyAlias(this, 'Alias', { alias, key: this });\n  }\n\n  /**\n   * Adds a statement to the KMS key resource policy.\n   * @param statement The policy statement to add\n   * @param allowNoOp If this is set to `false` and there is no policy\n   * defined (i.e. external key), the operation will fail. Otherwise, it will\n   * no-op.\n   */\n  public addToResourcePolicy(statement: PolicyStatement, allowNoOp = true) {\n    if (!this.policy) {\n      if (allowNoOp) { return; }\n      throw new Error(`Unable to add statement to IAM resource policy for KMS key: ${JSON.stringify(resolve(this.keyArn))}`);\n    }\n\n    this.policy.addStatement(statement);\n  }\n\n  /**\n   * Exports this key from the current stack.\n   * @returns a key ref which can be used in a call to `EncryptionKey.import(ref)`.\n   */\n  public export(): EncryptionKeyRefProps {\n    return {\n      keyArn: new Output(this, 'KeyArn').makeImportValue().toString()\n    };\n  }\n}\n\n/**\n * Construction properties for a KMS Key object\n */\nexport interface EncryptionKeyProps {\n  /**\n   * A description of the key. Use a description that helps your users decide\n   * whether the key is appropriate for a particular task.\n   */\n  description?: string;\n\n  /**\n   * Indicates whether AWS KMS rotates the key.\n   * @default false\n   */\n  enableKeyRotation?: boolean;\n\n  /**\n   * Indicates whether the key is available for use.\n   * @default Key is enabled\n   */\n  enabled?: boolean;\n\n  /**\n   * Custom policy document to attach to the KMS key.\n   *\n   * @default A policy document with permissions for the account root to\n   * administer the key will be created.\n   */\n  policy?: PolicyDocument;\n}\n\n/**\n * Definews a KMS key.\n */\nexport class EncryptionKey extends EncryptionKeyRef {\n  public readonly keyArn: string;\n  protected readonly policy?: PolicyDocument;\n\n  constructor(parent: Construct, name: string, props: EncryptionKeyProps = {}) {\n    super(parent, name);\n\n    if (props.policy) {\n      this.policy = props.policy;\n    } else {\n      this.policy = new PolicyDocument();\n      this.allowAccountToAdmin();\n    }\n\n    const resource = new cloudformation.KeyResource(this, 'Resource', {\n      description: props.description,\n      enableKeyRotation: props.enableKeyRotation,\n      enabled: props.enabled,\n      keyPolicy: this.policy\n    });\n\n    this.keyArn = resource.keyArn;\n    resource.options.deletionPolicy = DeletionPolicy.Retain;\n  }\n\n  /**\n   * Let users from this account admin this key.\n   * @link https://aws.amazon.com/premiumsupport/knowledge-center/update-key-policy-future/\n   */\n  private allowAccountToAdmin() {\n    const actions = [\n      \"kms:Create*\",\n      \"kms:Describe*\",\n      \"kms:Enable*\",\n      \"kms:List*\",\n      \"kms:Put*\",\n      \"kms:Update*\",\n      \"kms:Revoke*\",\n      \"kms:Disable*\",\n      \"kms:Get*\",\n      \"kms:Delete*\",\n      \"kms:ScheduleKeyDeletion\",\n      \"kms:CancelKeyDeletion\"\n    ];\n\n    this.addToResourcePolicy(new PolicyStatement()\n      .addAllResources()\n      .addActions(...actions)\n      .addAccountRootPrincipal());\n  }\n}\n\nclass EncryptionKeyRefImport extends EncryptionKeyRef {\n  public readonly keyArn: string;\n  protected readonly policy = undefined; // no policy associated with an imported key\n\n  constructor(parent: Construct, name: string, props: EncryptionKeyRefProps) {\n    super(parent, name);\n\n    this.keyArn = props.keyArn;\n  }\n}\n"]}

@@ -30,8 +30,9 @@ import cdk = require('@aws-cdk/cdk');

*
* @param parent the ``cdk.Construct`` this ``AliasResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param parent the ``cdk.Construct`` this ``AliasResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``AliasResource``
*/
constructor(parent: cdk.Construct, name: string, properties: AliasResourceProps);
protected renderProperties(): {
readonly propertyOverrides: AliasResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;

@@ -93,8 +94,9 @@ };

*
* @param parent the ``cdk.Construct`` this ``KeyResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param parent the ``cdk.Construct`` this ``KeyResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``KeyResource``
*/
constructor(parent: cdk.Construct, name: string, properties: KeyResourceProps);
protected renderProperties(): {
readonly propertyOverrides: KeyResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;

@@ -101,0 +103,0 @@ };

@@ -5,3 +5,3 @@ "use strict";

// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html
// @cfn2ts:meta@ {"generated":"2018-09-20T12:54:36.806Z","fingerprint":"xALVHBhCJQSIPdnEzR8bXolWnntu0I8Q/5VZzHGWSdE="}
// @cfn2ts:meta@ {"generated":"2018-09-27T21:36:05.106Z","fingerprint":"oa/5byAO6rorqfsFNruZynLOyuw546901vXLRaE/XWI="}
Object.defineProperty(exports, "__esModule", { value: true });

@@ -54,4 +54,4 @@ // tslint:disable:max-line-length | This is generated code - line lengths are difficult to control

*
* @param parent the ``cdk.Construct`` this ``AliasResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param parent the ``cdk.Construct`` this ``AliasResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``AliasResource``

@@ -65,5 +65,8 @@ */

}
renderProperties() {
return aliasResourcePropsToCloudFormation(cdk.resolve(this.properties));
get propertyOverrides() {
return this.untypedPropertyOverrides;
}
renderProperties(properties) {
return aliasResourcePropsToCloudFormation(cdk.resolve(properties));
}
}

@@ -126,4 +129,4 @@ /**

*
* @param parent the ``cdk.Construct`` this ``KeyResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param parent the ``cdk.Construct`` this ``KeyResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``KeyResource``

@@ -137,5 +140,8 @@ */

}
renderProperties() {
return keyResourcePropsToCloudFormation(cdk.resolve(this.properties));
get propertyOverrides() {
return this.untypedPropertyOverrides;
}
renderProperties(properties) {
return keyResourcePropsToCloudFormation(cdk.resolve(properties));
}
}

@@ -148,2 +154,2 @@ /**

})(cloudformation = exports.cloudformation || (exports.cloudformation = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kms.generated.js","sourceRoot":"","sources":["kms.generated.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2012-2018 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// Generated from the AWS CloudFormation Resource Specification\n// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html\n// @cfn2ts:meta@ {\"generated\":\"2018-09-20T12:54:36.806Z\",\"fingerprint\":\"xALVHBhCJQSIPdnEzR8bXolWnntu0I8Q/5VZzHGWSdE=\"}\n\n// tslint:disable:max-line-length | This is generated code - line lengths are difficult to control\n\nimport cdk = require('@aws-cdk/cdk');\n\nexport namespace cloudformation {\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n     */\n    export interface AliasResourceProps {\n        /**\n         * ``AWS::KMS::Alias.AliasName``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-aliasname\n         */\n        aliasName: string | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Alias.TargetKeyId``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-targetkeyid\n         */\n        targetKeyId: string | cdk.CloudFormationToken;\n    }\n\n    /**\n     * Determine whether the given properties match those of a ``AliasResourceProps``\n     *\n     * @param properties the TypeScript properties of a ``AliasResourceProps``\n     *\n     * @returns the result of the validation.\n     */\n    function AliasResourcePropsValidator(properties: any): cdk.ValidationResult {\n        if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n        const errors = new cdk.ValidationResults();\n        errors.collect(cdk.propertyValidator('aliasName', cdk.requiredValidator)(properties.aliasName));\n        errors.collect(cdk.propertyValidator('aliasName', cdk.validateString)(properties.aliasName));\n        errors.collect(cdk.propertyValidator('targetKeyId', cdk.requiredValidator)(properties.targetKeyId));\n        errors.collect(cdk.propertyValidator('targetKeyId', cdk.validateString)(properties.targetKeyId));\n        return errors.wrap('supplied properties not correct for \"AliasResourceProps\"');\n    }\n\n    /**\n     * Renders the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource\n     *\n     * @param properties the TypeScript properties of a ``AliasResourceProps``\n     *\n     * @returns the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource.\n     */\n    function aliasResourcePropsToCloudFormation(properties: any): any {\n        if (!cdk.canInspect(properties)) { return properties; }\n        AliasResourcePropsValidator(properties).assertSuccess();\n        return {\n            AliasName: cdk.stringToCloudFormation(properties.aliasName),\n            TargetKeyId: cdk.stringToCloudFormation(properties.targetKeyId),\n        };\n    }\n\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n     */\n    export class AliasResource extends cdk.Resource {\n        /**\n         * The CloudFormation resource type name for this resource class.\n         */\n        public static readonly resourceTypeName = \"AWS::KMS::Alias\";\n        public readonly aliasName: string;\n\n        /**\n         * Creates a new ``AWS::KMS::Alias``.\n         *\n         * @param parent     the ``cdk.Construct`` this ``AliasResource`` is a part of\n         * @param name       the name of the resource in the ``cdk.Construct`` tree\n         * @param properties the properties of this ``AliasResource``\n         */\n        constructor(parent: cdk.Construct, name: string, properties: AliasResourceProps) {\n            super(parent, name, { type: AliasResource.resourceTypeName, properties });\n            cdk.requireProperty(properties, 'aliasName', this);\n            cdk.requireProperty(properties, 'targetKeyId', this);\n            this.aliasName = this.ref.toString();\n        }\n\n        protected renderProperties(): { [key: string]: any }  {\n            return aliasResourcePropsToCloudFormation(cdk.resolve(this.properties));\n        }\n    }\n}\n\nexport namespace cloudformation {\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n     */\n    export interface KeyResourceProps {\n        /**\n         * ``AWS::KMS::Key.KeyPolicy``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keypolicy\n         */\n        keyPolicy: object | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.Description``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-description\n         */\n        description?: string | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.Enabled``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enabled\n         */\n        enabled?: boolean | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.EnableKeyRotation``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enablekeyrotation\n         */\n        enableKeyRotation?: boolean | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.KeyUsage``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keyusage\n         */\n        keyUsage?: string | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.Tags``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-tags\n         */\n        tags?: Array<cdk.Tag | cdk.CloudFormationToken> | cdk.CloudFormationToken;\n    }\n\n    /**\n     * Determine whether the given properties match those of a ``KeyResourceProps``\n     *\n     * @param properties the TypeScript properties of a ``KeyResourceProps``\n     *\n     * @returns the result of the validation.\n     */\n    function KeyResourcePropsValidator(properties: any): cdk.ValidationResult {\n        if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n        const errors = new cdk.ValidationResults();\n        errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));\n        errors.collect(cdk.propertyValidator('enableKeyRotation', cdk.validateBoolean)(properties.enableKeyRotation));\n        errors.collect(cdk.propertyValidator('enabled', cdk.validateBoolean)(properties.enabled));\n        errors.collect(cdk.propertyValidator('keyPolicy', cdk.requiredValidator)(properties.keyPolicy));\n        errors.collect(cdk.propertyValidator('keyPolicy', cdk.validateObject)(properties.keyPolicy));\n        errors.collect(cdk.propertyValidator('keyUsage', cdk.validateString)(properties.keyUsage));\n        errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateTag))(properties.tags));\n        return errors.wrap('supplied properties not correct for \"KeyResourceProps\"');\n    }\n\n    /**\n     * Renders the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource\n     *\n     * @param properties the TypeScript properties of a ``KeyResourceProps``\n     *\n     * @returns the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource.\n     */\n    function keyResourcePropsToCloudFormation(properties: any): any {\n        if (!cdk.canInspect(properties)) { return properties; }\n        KeyResourcePropsValidator(properties).assertSuccess();\n        return {\n            KeyPolicy: cdk.objectToCloudFormation(properties.keyPolicy),\n            Description: cdk.stringToCloudFormation(properties.description),\n            Enabled: cdk.booleanToCloudFormation(properties.enabled),\n            EnableKeyRotation: cdk.booleanToCloudFormation(properties.enableKeyRotation),\n            KeyUsage: cdk.stringToCloudFormation(properties.keyUsage),\n            Tags: cdk.listMapper(cdk.tagToCloudFormation)(properties.tags),\n        };\n    }\n\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n     */\n    export class KeyResource extends cdk.Resource {\n        /**\n         * The CloudFormation resource type name for this resource class.\n         */\n        public static readonly resourceTypeName = \"AWS::KMS::Key\";\n\n        /**\n         * @cloudformation_attribute Arn\n         */\n        public readonly keyArn: string;\n        public readonly keyId: string;\n\n        /**\n         * Creates a new ``AWS::KMS::Key``.\n         *\n         * @param parent     the ``cdk.Construct`` this ``KeyResource`` is a part of\n         * @param name       the name of the resource in the ``cdk.Construct`` tree\n         * @param properties the properties of this ``KeyResource``\n         */\n        constructor(parent: cdk.Construct, name: string, properties: KeyResourceProps) {\n            super(parent, name, { type: KeyResource.resourceTypeName, properties });\n            cdk.requireProperty(properties, 'keyPolicy', this);\n            this.keyArn = this.getAtt('Arn').toString();\n            this.keyId = this.ref.toString();\n        }\n\n        protected renderProperties(): { [key: string]: any }  {\n            return keyResourcePropsToCloudFormation(cdk.resolve(this.properties));\n        }\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kms.generated.js","sourceRoot":"","sources":["kms.generated.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2012-2018 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// Generated from the AWS CloudFormation Resource Specification\n// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html\n// @cfn2ts:meta@ {\"generated\":\"2018-09-27T21:36:05.106Z\",\"fingerprint\":\"oa/5byAO6rorqfsFNruZynLOyuw546901vXLRaE/XWI=\"}\n\n// tslint:disable:max-line-length | This is generated code - line lengths are difficult to control\n\nimport cdk = require('@aws-cdk/cdk');\n\nexport namespace cloudformation {\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n     */\n    export interface AliasResourceProps {\n        /**\n         * ``AWS::KMS::Alias.AliasName``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-aliasname\n         */\n        aliasName: string | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Alias.TargetKeyId``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-targetkeyid\n         */\n        targetKeyId: string | cdk.CloudFormationToken;\n    }\n\n    /**\n     * Determine whether the given properties match those of a ``AliasResourceProps``\n     *\n     * @param properties the TypeScript properties of a ``AliasResourceProps``\n     *\n     * @returns the result of the validation.\n     */\n    function AliasResourcePropsValidator(properties: any): cdk.ValidationResult {\n        if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n        const errors = new cdk.ValidationResults();\n        errors.collect(cdk.propertyValidator('aliasName', cdk.requiredValidator)(properties.aliasName));\n        errors.collect(cdk.propertyValidator('aliasName', cdk.validateString)(properties.aliasName));\n        errors.collect(cdk.propertyValidator('targetKeyId', cdk.requiredValidator)(properties.targetKeyId));\n        errors.collect(cdk.propertyValidator('targetKeyId', cdk.validateString)(properties.targetKeyId));\n        return errors.wrap('supplied properties not correct for \"AliasResourceProps\"');\n    }\n\n    /**\n     * Renders the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource\n     *\n     * @param properties the TypeScript properties of a ``AliasResourceProps``\n     *\n     * @returns the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource.\n     */\n    function aliasResourcePropsToCloudFormation(properties: any): any {\n        if (!cdk.canInspect(properties)) { return properties; }\n        AliasResourcePropsValidator(properties).assertSuccess();\n        return {\n          AliasName: cdk.stringToCloudFormation(properties.aliasName),\n          TargetKeyId: cdk.stringToCloudFormation(properties.targetKeyId),\n        };\n    }\n\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n     */\n    export class AliasResource extends cdk.Resource {\n        /**\n         * The CloudFormation resource type name for this resource class.\n         */\n        public static readonly resourceTypeName = \"AWS::KMS::Alias\";\n        public readonly aliasName: string;\n\n        /**\n         * Creates a new ``AWS::KMS::Alias``.\n         *\n         * @param parent   the ``cdk.Construct`` this ``AliasResource`` is a part of\n         * @param name     the name of the resource in the ``cdk.Construct`` tree\n         * @param properties the properties of this ``AliasResource``\n         */\n        constructor(parent: cdk.Construct, name: string, properties: AliasResourceProps) {\n            super(parent, name, { type: AliasResource.resourceTypeName, properties });\n            cdk.requireProperty(properties, 'aliasName', this);\n            cdk.requireProperty(properties, 'targetKeyId', this);\n            this.aliasName = this.ref.toString();\n        }\n\n        public get propertyOverrides(): AliasResourceProps {\n            return this.untypedPropertyOverrides;\n        }\n        protected renderProperties(properties: any): { [key: string]: any }  {\n            return aliasResourcePropsToCloudFormation(cdk.resolve(properties));\n        }\n    }\n}\n\nexport namespace cloudformation {\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n     */\n    export interface KeyResourceProps {\n        /**\n         * ``AWS::KMS::Key.KeyPolicy``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keypolicy\n         */\n        keyPolicy: object | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.Description``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-description\n         */\n        description?: string | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.Enabled``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enabled\n         */\n        enabled?: boolean | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.EnableKeyRotation``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enablekeyrotation\n         */\n        enableKeyRotation?: boolean | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.KeyUsage``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keyusage\n         */\n        keyUsage?: string | cdk.CloudFormationToken;\n        /**\n         * ``AWS::KMS::Key.Tags``\n         * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-tags\n         */\n        tags?: Array<cdk.Tag | cdk.CloudFormationToken> | cdk.CloudFormationToken;\n    }\n\n    /**\n     * Determine whether the given properties match those of a ``KeyResourceProps``\n     *\n     * @param properties the TypeScript properties of a ``KeyResourceProps``\n     *\n     * @returns the result of the validation.\n     */\n    function KeyResourcePropsValidator(properties: any): cdk.ValidationResult {\n        if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n        const errors = new cdk.ValidationResults();\n        errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));\n        errors.collect(cdk.propertyValidator('enableKeyRotation', cdk.validateBoolean)(properties.enableKeyRotation));\n        errors.collect(cdk.propertyValidator('enabled', cdk.validateBoolean)(properties.enabled));\n        errors.collect(cdk.propertyValidator('keyPolicy', cdk.requiredValidator)(properties.keyPolicy));\n        errors.collect(cdk.propertyValidator('keyPolicy', cdk.validateObject)(properties.keyPolicy));\n        errors.collect(cdk.propertyValidator('keyUsage', cdk.validateString)(properties.keyUsage));\n        errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateTag))(properties.tags));\n        return errors.wrap('supplied properties not correct for \"KeyResourceProps\"');\n    }\n\n    /**\n     * Renders the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource\n     *\n     * @param properties the TypeScript properties of a ``KeyResourceProps``\n     *\n     * @returns the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource.\n     */\n    function keyResourcePropsToCloudFormation(properties: any): any {\n        if (!cdk.canInspect(properties)) { return properties; }\n        KeyResourcePropsValidator(properties).assertSuccess();\n        return {\n          KeyPolicy: cdk.objectToCloudFormation(properties.keyPolicy),\n          Description: cdk.stringToCloudFormation(properties.description),\n          Enabled: cdk.booleanToCloudFormation(properties.enabled),\n          EnableKeyRotation: cdk.booleanToCloudFormation(properties.enableKeyRotation),\n          KeyUsage: cdk.stringToCloudFormation(properties.keyUsage),\n          Tags: cdk.listMapper(cdk.tagToCloudFormation)(properties.tags),\n        };\n    }\n\n    /**\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n     */\n    export class KeyResource extends cdk.Resource {\n        /**\n         * The CloudFormation resource type name for this resource class.\n         */\n        public static readonly resourceTypeName = \"AWS::KMS::Key\";\n\n        /**\n         * @cloudformation_attribute Arn\n         */\n        public readonly keyArn: string;\n        public readonly keyId: string;\n\n        /**\n         * Creates a new ``AWS::KMS::Key``.\n         *\n         * @param parent   the ``cdk.Construct`` this ``KeyResource`` is a part of\n         * @param name     the name of the resource in the ``cdk.Construct`` tree\n         * @param properties the properties of this ``KeyResource``\n         */\n        constructor(parent: cdk.Construct, name: string, properties: KeyResourceProps) {\n            super(parent, name, { type: KeyResource.resourceTypeName, properties });\n            cdk.requireProperty(properties, 'keyPolicy', this);\n            this.keyArn = this.getAtt('Arn').toString();\n            this.keyId = this.ref.toString();\n        }\n\n        public get propertyOverrides(): KeyResourceProps {\n            return this.untypedPropertyOverrides;\n        }\n        protected renderProperties(properties: any): { [key: string]: any }  {\n            return keyResourcePropsToCloudFormation(cdk.resolve(properties));\n        }\n    }\n}\n"]}
{
"name": "@aws-cdk/aws-kms",
"version": "0.9.2",
"version": "0.10.0",
"description": "CDK Constructs for AWS KMS",

@@ -55,13 +55,13 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^0.9.2",
"cdk-build-tools": "^0.9.2",
"cdk-integ-tools": "^0.9.2",
"cfn2ts": "^0.9.2",
"pkglint": "^0.9.2"
"@aws-cdk/assert": "^0.10.0",
"cdk-build-tools": "^0.10.0",
"cdk-integ-tools": "^0.10.0",
"cfn2ts": "^0.10.0",
"pkglint": "^0.10.0"
},
"dependencies": {
"@aws-cdk/aws-iam": "^0.9.2",
"@aws-cdk/cdk": "^0.9.2"
"@aws-cdk/aws-iam": "^0.10.0",
"@aws-cdk/cdk": "^0.10.0"
},
"homepage": "https://github.com/awslabs/aws-cdk"
}

@@ -14,2 +14,2 @@ "use strict";

process.stdout.write(app.run());
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcua2V5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcua2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQXlFO0FBQ3pFLGdDQUF1QztBQUV2QyxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7QUFFbEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsR0FBRyxFQUFFLGVBQWUsQ0FBQyxDQUFDO0FBRTlDLE1BQU0sR0FBRyxHQUFHLElBQUksbUJBQWEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFFOUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLElBQUkscUJBQWUsRUFBRTtLQUN4QyxlQUFlLEVBQUU7S0FDakIsU0FBUyxDQUFDLGFBQWEsQ0FBQztLQUN4QixlQUFlLENBQUMsSUFBSSxrQkFBWSxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBRXJELEdBQUcsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7QUFFMUIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIEF3c0FjY291bnRJZCwgUG9saWN5U3RhdGVtZW50LCBTdGFjayB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBFbmNyeXB0aW9uS2V5IH0gZnJvbSAnLi4vbGliJztcblxuY29uc3QgYXBwID0gbmV3IEFwcChwcm9jZXNzLmFyZ3YpO1xuXG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsIGBhd3MtY2RrLWttcy0xYCk7XG5cbmNvbnN0IGtleSA9IG5ldyBFbmNyeXB0aW9uS2V5KHN0YWNrLCAnTXlLZXknKTtcblxua2V5LmFkZFRvUmVzb3VyY2VQb2xpY3kobmV3IFBvbGljeVN0YXRlbWVudCgpXG4gICAgLmFkZEFsbFJlc291cmNlcygpXG4gICAgLmFkZEFjdGlvbigna21zOmVuY3J5cHQnKVxuICAgIC5hZGRBd3NQcmluY2lwYWwobmV3IEF3c0FjY291bnRJZCgpLnRvU3RyaW5nKCkpKTtcblxua2V5LmFkZEFsaWFzKCdhbGlhcy9iYXInKTtcblxucHJvY2Vzcy5zdGRvdXQud3JpdGUoYXBwLnJ1bigpKTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcua2V5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcua2V5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQXlFO0FBQ3pFLGdDQUF1QztBQUV2QyxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7QUFFbEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsR0FBRyxFQUFFLGVBQWUsQ0FBQyxDQUFDO0FBRTlDLE1BQU0sR0FBRyxHQUFHLElBQUksbUJBQWEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFFOUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLElBQUkscUJBQWUsRUFBRTtLQUMxQyxlQUFlLEVBQUU7S0FDakIsU0FBUyxDQUFDLGFBQWEsQ0FBQztLQUN4QixlQUFlLENBQUMsSUFBSSxrQkFBWSxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBRW5ELEdBQUcsQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7QUFFMUIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIEF3c0FjY291bnRJZCwgUG9saWN5U3RhdGVtZW50LCBTdGFjayB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBFbmNyeXB0aW9uS2V5IH0gZnJvbSAnLi4vbGliJztcblxuY29uc3QgYXBwID0gbmV3IEFwcChwcm9jZXNzLmFyZ3YpO1xuXG5jb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsIGBhd3MtY2RrLWttcy0xYCk7XG5cbmNvbnN0IGtleSA9IG5ldyBFbmNyeXB0aW9uS2V5KHN0YWNrLCAnTXlLZXknKTtcblxua2V5LmFkZFRvUmVzb3VyY2VQb2xpY3kobmV3IFBvbGljeVN0YXRlbWVudCgpXG4gIC5hZGRBbGxSZXNvdXJjZXMoKVxuICAuYWRkQWN0aW9uKCdrbXM6ZW5jcnlwdCcpXG4gIC5hZGRBd3NQcmluY2lwYWwobmV3IEF3c0FjY291bnRJZCgpLnRvU3RyaW5nKCkpKTtcblxua2V5LmFkZEFsaWFzKCdhbGlhcy9iYXInKTtcblxucHJvY2Vzcy5zdGRvdXQud3JpdGUoYXBwLnJ1bigpKTtcbiJdfQ==

@@ -68,2 +68,2 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5hbGlhcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuYWxpYXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHNDQUEwQztBQUUxQyxnQ0FBdUM7QUFDdkMsd0NBQWtEO0FBRWxELGlCQUFTO0lBQ0wsZUFBZSxDQUFDLElBQVU7UUFDdEIsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDckMsTUFBTSxHQUFHLEdBQUcsSUFBSSxtQkFBYSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztRQUU1QyxJQUFJLDBCQUFrQixDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxHQUFHLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFFcEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRTtZQUM3RSxJQUFJLEVBQUUsaUJBQWlCO1lBQ3ZCLFVBQVUsRUFBRTtnQkFDUixTQUFTLEVBQUUsV0FBVztnQkFDdEIsV0FBVyxFQUFFLEVBQUUsWUFBWSxFQUFFLENBQUUsYUFBYSxFQUFFLEtBQUssQ0FBRSxFQUFFO2FBQzFEO1NBQ0osQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hCLENBQUM7SUFFRCxpREFBaUQsQ0FBQyxJQUFVO1FBQ3hELE1BQU0sR0FBRyxHQUFHLElBQUksU0FBRyxFQUFFLENBQUM7UUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRXJDLE1BQU0sR0FBRyxHQUFHLElBQUksbUJBQWEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQzFDLGlCQUFpQixFQUFFLElBQUk7WUFDdkIsT0FBTyxFQUFFLEtBQUs7U0FDakIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLDBCQUFrQixDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDckQsS0FBSyxFQUFFLEtBQUs7WUFDWixHQUFHO1NBQ04sQ0FBQyxDQUFDLENBQUM7UUFFSixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVELCtDQUErQyxDQUFDLElBQVU7UUFDdEQsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFckMsTUFBTSxHQUFHLEdBQUcsSUFBSSxtQkFBYSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDMUMsaUJBQWlCLEVBQUUsSUFBSTtZQUN2QixPQUFPLEVBQUUsS0FBSztTQUNqQixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksMEJBQWtCLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRTtZQUNyRCxLQUFLLEVBQUUsUUFBUTtZQUNmLEdBQUc7U0FDTixDQUFDLENBQUMsQ0FBQztRQUVKLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQsd0NBQXdDLENBQUMsSUFBVTtRQUMvQyxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsRUFBRSxDQUFDO1FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUVyQyxNQUFNLEdBQUcsR0FBRyxJQUFJLG1CQUFhLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRTtZQUMxQyxpQkFBaUIsRUFBRSxJQUFJO1lBQ3ZCLE9BQU8sRUFBRSxLQUFLO1NBQ2pCLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSwwQkFBa0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQ3JELEtBQUssRUFBRSxXQUFXO1lBQ2xCLEdBQUc7U0FDTixDQUFDLENBQUMsQ0FBQztRQUVKLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSwwQkFBa0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQ3JELEtBQUssRUFBRSxrQkFBa0I7WUFDekIsR0FBRztTQUNOLENBQUMsQ0FBQyxDQUFDO1FBRUosSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLDBCQUFrQixDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDckQsS0FBSyxFQUFFLG1CQUFtQjtZQUMxQixHQUFHO1NBQ04sQ0FBQyxDQUFDLENBQUM7UUFFSixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIFN0YWNrIH0gZnJvbSAnQGF3cy1jZGsvY2RrJztcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBFbmNyeXB0aW9uS2V5IH0gZnJvbSAnLi4vbGliJztcbmltcG9ydCB7IEVuY3J5cHRpb25LZXlBbGlhcyB9IGZyb20gJy4uL2xpYi9hbGlhcyc7XG5cbmV4cG9ydCA9IHtcbiAgICAnZGVmYXVsdCBhbGlhcycodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBhcHAgPSBuZXcgQXBwKCk7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ1Rlc3QnKTtcbiAgICAgICAgY29uc3Qga2V5ID0gbmV3IEVuY3J5cHRpb25LZXkoc3RhY2ssICdLZXknKTtcblxuICAgICAgICBuZXcgRW5jcnlwdGlvbktleUFsaWFzKHN0YWNrLCAnQWxpYXMnLCB7IGtleSwgYWxpYXM6ICdhbGlhcy9mb28nIH0pO1xuXG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKGFwcC5zeW50aGVzaXplU3RhY2soc3RhY2submFtZSkudGVtcGxhdGUuUmVzb3VyY2VzLkFsaWFzMzI1QzU3MjcsIHtcbiAgICAgICAgICAgIFR5cGU6ICdBV1M6OktNUzo6QWxpYXMnLFxuICAgICAgICAgICAgUHJvcGVydGllczoge1xuICAgICAgICAgICAgICAgIEFsaWFzTmFtZTogJ2FsaWFzL2ZvbycsXG4gICAgICAgICAgICAgICAgVGFyZ2V0S2V5SWQ6IHsgJ0ZuOjpHZXRBdHQnOiBbICdLZXk5NjFCNzNGRCcsICdBcm4nIF0gfVxuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ2ZhaWxzIGlmIGFsaWFzIG5hbWUgZG9lc1xcJ3Qgc3RhcnQgd2l0aCBcImFsaWFzL1wiJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbiAgICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCAnVGVzdCcpO1xuXG4gICAgICAgIGNvbnN0IGtleSA9IG5ldyBFbmNyeXB0aW9uS2V5KHN0YWNrLCAnTXlLZXknLCB7XG4gICAgICAgICAgICBlbmFibGVLZXlSb3RhdGlvbjogdHJ1ZSxcbiAgICAgICAgICAgIGVuYWJsZWQ6IGZhbHNlXG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QudGhyb3dzKCgpID0+IG5ldyBFbmNyeXB0aW9uS2V5QWxpYXMoc3RhY2ssICdBbGlhcycsIHtcbiAgICAgICAgICAgIGFsaWFzOiAnZm9vJyxcbiAgICAgICAgICAgIGtleVxuICAgICAgICB9KSk7XG5cbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdmYWlscyBpZiBhbGlhcyBpcyBcImFsaWFzL1wiIChhbmQgbm90aGluZyBtb3JlKScodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBhcHAgPSBuZXcgQXBwKCk7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ1Rlc3QnKTtcblxuICAgICAgICBjb25zdCBrZXkgPSBuZXcgRW5jcnlwdGlvbktleShzdGFjaywgJ015S2V5Jywge1xuICAgICAgICAgICAgZW5hYmxlS2V5Um90YXRpb246IHRydWUsXG4gICAgICAgICAgICBlbmFibGVkOiBmYWxzZVxuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgRW5jcnlwdGlvbktleUFsaWFzKHN0YWNrLCAnQWxpYXMnLCB7XG4gICAgICAgICAgICBhbGlhczogJ2FsaWFzLycsXG4gICAgICAgICAgICBrZXlcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHRlc3QuZG9uZSgpO1xuICAgIH0sXG5cbiAgICAnZmFpbHMgaWYgYWxpYXMgc3RhcnRzIHdpdGggXCJhbGlhcy9BV1NcIicodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBhcHAgPSBuZXcgQXBwKCk7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ1Rlc3QnKTtcblxuICAgICAgICBjb25zdCBrZXkgPSBuZXcgRW5jcnlwdGlvbktleShzdGFjaywgJ015S2V5Jywge1xuICAgICAgICAgICAgZW5hYmxlS2V5Um90YXRpb246IHRydWUsXG4gICAgICAgICAgICBlbmFibGVkOiBmYWxzZVxuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgRW5jcnlwdGlvbktleUFsaWFzKHN0YWNrLCAnQWxpYXMnLCB7XG4gICAgICAgICAgICBhbGlhczogJ2FsaWFzL0FXUycsXG4gICAgICAgICAgICBrZXlcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHRlc3QudGhyb3dzKCgpID0+IG5ldyBFbmNyeXB0aW9uS2V5QWxpYXMoc3RhY2ssICdBbGlhcycsIHtcbiAgICAgICAgICAgIGFsaWFzOiAnYWxpYXMvQVdTQXdlc29tZScsXG4gICAgICAgICAgICBrZXlcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHRlc3QudGhyb3dzKCgpID0+IG5ldyBFbmNyeXB0aW9uS2V5QWxpYXMoc3RhY2ssICdBbGlhcycsIHtcbiAgICAgICAgICAgIGFsaWFzOiAnYWxpYXMvQVdTL2F3ZXNvbWUnLFxuICAgICAgICAgICAga2V5XG4gICAgICAgIH0pKTtcblxuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9XG59O1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5hbGlhcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuYWxpYXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHNDQUEwQztBQUUxQyxnQ0FBdUM7QUFDdkMsd0NBQWtEO0FBRWxELGlCQUFTO0lBQ1AsZUFBZSxDQUFDLElBQVU7UUFDeEIsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDckMsTUFBTSxHQUFHLEdBQUcsSUFBSSxtQkFBYSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztRQUU1QyxJQUFJLDBCQUFrQixDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxHQUFHLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFFcEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRTtZQUMvRSxJQUFJLEVBQUUsaUJBQWlCO1lBQ3ZCLFVBQVUsRUFBRTtnQkFDVixTQUFTLEVBQUUsV0FBVztnQkFDdEIsV0FBVyxFQUFFLEVBQUUsWUFBWSxFQUFFLENBQUUsYUFBYSxFQUFFLEtBQUssQ0FBRSxFQUFFO2FBQ3hEO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVELGlEQUFpRCxDQUFDLElBQVU7UUFDMUQsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFckMsTUFBTSxHQUFHLEdBQUcsSUFBSSxtQkFBYSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDNUMsaUJBQWlCLEVBQUUsSUFBSTtZQUN2QixPQUFPLEVBQUUsS0FBSztTQUNmLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSwwQkFBa0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQ3ZELEtBQUssRUFBRSxLQUFLO1lBQ1osR0FBRztTQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUosSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVELCtDQUErQyxDQUFDLElBQVU7UUFDeEQsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFckMsTUFBTSxHQUFHLEdBQUcsSUFBSSxtQkFBYSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDNUMsaUJBQWlCLEVBQUUsSUFBSTtZQUN2QixPQUFPLEVBQUUsS0FBSztTQUNmLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSwwQkFBa0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQ3ZELEtBQUssRUFBRSxRQUFRO1lBQ2YsR0FBRztTQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUosSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVELHdDQUF3QyxDQUFDLElBQVU7UUFDakQsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFckMsTUFBTSxHQUFHLEdBQUcsSUFBSSxtQkFBYSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDNUMsaUJBQWlCLEVBQUUsSUFBSTtZQUN2QixPQUFPLEVBQUUsS0FBSztTQUNmLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSwwQkFBa0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQ3ZELEtBQUssRUFBRSxXQUFXO1lBQ2xCLEdBQUc7U0FDSixDQUFDLENBQUMsQ0FBQztRQUVKLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSwwQkFBa0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO1lBQ3ZELEtBQUssRUFBRSxrQkFBa0I7WUFDekIsR0FBRztTQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUosSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLDBCQUFrQixDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7WUFDdkQsS0FBSyxFQUFFLG1CQUFtQjtZQUMxQixHQUFHO1NBQ0osQ0FBQyxDQUFDLENBQUM7UUFFSixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcCwgU3RhY2sgfSBmcm9tICdAYXdzLWNkay9jZGsnO1xuaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEVuY3J5cHRpb25LZXkgfSBmcm9tICcuLi9saWInO1xuaW1wb3J0IHsgRW5jcnlwdGlvbktleUFsaWFzIH0gZnJvbSAnLi4vbGliL2FsaWFzJztcblxuZXhwb3J0ID0ge1xuICAnZGVmYXVsdCBhbGlhcycodGVzdDogVGVzdCkge1xuICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdUZXN0Jyk7XG4gICAgY29uc3Qga2V5ID0gbmV3IEVuY3J5cHRpb25LZXkoc3RhY2ssICdLZXknKTtcblxuICAgIG5ldyBFbmNyeXB0aW9uS2V5QWxpYXMoc3RhY2ssICdBbGlhcycsIHsga2V5LCBhbGlhczogJ2FsaWFzL2ZvbycgfSk7XG5cbiAgICB0ZXN0LmRlZXBFcXVhbChhcHAuc3ludGhlc2l6ZVN0YWNrKHN0YWNrLm5hbWUpLnRlbXBsYXRlLlJlc291cmNlcy5BbGlhczMyNUM1NzI3LCB7XG4gICAgICBUeXBlOiAnQVdTOjpLTVM6OkFsaWFzJyxcbiAgICAgIFByb3BlcnRpZXM6IHtcbiAgICAgICAgQWxpYXNOYW1lOiAnYWxpYXMvZm9vJyxcbiAgICAgICAgVGFyZ2V0S2V5SWQ6IHsgJ0ZuOjpHZXRBdHQnOiBbICdLZXk5NjFCNzNGRCcsICdBcm4nIF0gfVxuICAgICAgfVxuICAgIH0pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG5cbiAgJ2ZhaWxzIGlmIGFsaWFzIG5hbWUgZG9lc1xcJ3Qgc3RhcnQgd2l0aCBcImFsaWFzL1wiJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ1Rlc3QnKTtcblxuICAgIGNvbnN0IGtleSA9IG5ldyBFbmNyeXB0aW9uS2V5KHN0YWNrLCAnTXlLZXknLCB7XG4gICAgICBlbmFibGVLZXlSb3RhdGlvbjogdHJ1ZSxcbiAgICAgIGVuYWJsZWQ6IGZhbHNlXG4gICAgfSk7XG5cbiAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgRW5jcnlwdGlvbktleUFsaWFzKHN0YWNrLCAnQWxpYXMnLCB7XG4gICAgICBhbGlhczogJ2ZvbycsXG4gICAgICBrZXlcbiAgICB9KSk7XG5cbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcblxuICAnZmFpbHMgaWYgYWxpYXMgaXMgXCJhbGlhcy9cIiAoYW5kIG5vdGhpbmcgbW9yZSknKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBhcHAgPSBuZXcgQXBwKCk7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCAnVGVzdCcpO1xuXG4gICAgY29uc3Qga2V5ID0gbmV3IEVuY3J5cHRpb25LZXkoc3RhY2ssICdNeUtleScsIHtcbiAgICAgIGVuYWJsZUtleVJvdGF0aW9uOiB0cnVlLFxuICAgICAgZW5hYmxlZDogZmFsc2VcbiAgICB9KTtcblxuICAgIHRlc3QudGhyb3dzKCgpID0+IG5ldyBFbmNyeXB0aW9uS2V5QWxpYXMoc3RhY2ssICdBbGlhcycsIHtcbiAgICAgIGFsaWFzOiAnYWxpYXMvJyxcbiAgICAgIGtleVxuICAgIH0pKTtcblxuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdmYWlscyBpZiBhbGlhcyBzdGFydHMgd2l0aCBcImFsaWFzL0FXU1wiJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ1Rlc3QnKTtcblxuICAgIGNvbnN0IGtleSA9IG5ldyBFbmNyeXB0aW9uS2V5KHN0YWNrLCAnTXlLZXknLCB7XG4gICAgICBlbmFibGVLZXlSb3RhdGlvbjogdHJ1ZSxcbiAgICAgIGVuYWJsZWQ6IGZhbHNlXG4gICAgfSk7XG5cbiAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgRW5jcnlwdGlvbktleUFsaWFzKHN0YWNrLCAnQWxpYXMnLCB7XG4gICAgICBhbGlhczogJ2FsaWFzL0FXUycsXG4gICAgICBrZXlcbiAgICB9KSk7XG5cbiAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgRW5jcnlwdGlvbktleUFsaWFzKHN0YWNrLCAnQWxpYXMnLCB7XG4gICAgICBhbGlhczogJ2FsaWFzL0FXU0F3ZXNvbWUnLFxuICAgICAga2V5XG4gICAgfSkpO1xuXG4gICAgdGVzdC50aHJvd3MoKCkgPT4gbmV3IEVuY3J5cHRpb25LZXlBbGlhcyhzdGFjaywgJ0FsaWFzJywge1xuICAgICAgYWxpYXM6ICdhbGlhcy9BV1MvYXdlc29tZScsXG4gICAgICBrZXlcbiAgICB9KSk7XG5cbiAgICB0ZXN0LmRvbmUoKTtcbiAgfVxufTtcbiJdfQ==

@@ -346,2 +346,2 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.key.js","sourceRoot":"","sources":["test.key.ts"],"names":[],"mappings":"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","sourcesContent":["import { exactlyMatchTemplate, expect } from '@aws-cdk/assert';\nimport { App, PolicyDocument, PolicyStatement, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { EncryptionKey } from '../lib';\n\nexport = {\n    'default key'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'TestStack');\n\n        new EncryptionKey(stack, 'MyKey');\n\n        expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n          Resources: {\n            MyKey6AB29FA6: {\n              Type: \"AWS::KMS::Key\",\n              Properties: {\n                KeyPolicy: {\n                  Statement: [\n                    {\n                      Action: [\n                        \"kms:Create*\",\n                        \"kms:Describe*\",\n                        \"kms:Enable*\",\n                        \"kms:List*\",\n                        \"kms:Put*\",\n                        \"kms:Update*\",\n                        \"kms:Revoke*\",\n                        \"kms:Disable*\",\n                        \"kms:Get*\",\n                        \"kms:Delete*\",\n                        \"kms:ScheduleKeyDeletion\",\n                        \"kms:CancelKeyDeletion\"\n                      ],\n                      Effect: \"Allow\",\n                      Principal: {\n                        AWS: {\n                          \"Fn::Join\": [\n                            \"\",\n                            [\n                              \"arn:\",\n                              {\n                                Ref: \"AWS::Partition\"\n                              },\n                              \":iam::\",\n                              {\n                                Ref: \"AWS::AccountId\"\n                              },\n                              \":root\"\n                            ]\n                          ]\n                        }\n                      },\n                      Resource: \"*\"\n                    }\n                  ],\n                  Version: \"2012-10-17\"\n                }\n              },\n              DeletionPolicy: \"Retain\"\n            }\n          }\n        }));\n        test.done();\n    },\n\n    'default with some permission'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'Test');\n\n        const key = new EncryptionKey(stack, 'MyKey');\n        const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n        p.addAwsPrincipal('arn');\n        key.addToResourcePolicy(p);\n\n        expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n            Resources: {\n              MyKey6AB29FA6: {\n                Type: \"AWS::KMS::Key\",\n                Properties: {\n                  KeyPolicy: {\n                    Statement: [\n                      {\n                        Action: [\n                          \"kms:Create*\",\n                          \"kms:Describe*\",\n                          \"kms:Enable*\",\n                          \"kms:List*\",\n                          \"kms:Put*\",\n                          \"kms:Update*\",\n                          \"kms:Revoke*\",\n                          \"kms:Disable*\",\n                          \"kms:Get*\",\n                          \"kms:Delete*\",\n                          \"kms:ScheduleKeyDeletion\",\n                          \"kms:CancelKeyDeletion\"\n                        ],\n                        Effect: \"Allow\",\n                        Principal: {\n                          AWS: {\n                            \"Fn::Join\": [\n                              \"\",\n                              [\n                                \"arn:\",\n                                {\n                                  Ref: \"AWS::Partition\"\n                                },\n                                \":iam::\",\n                                {\n                                  Ref: \"AWS::AccountId\"\n                                },\n                                \":root\"\n                              ]\n                            ]\n                          }\n                        },\n                        Resource: '*'\n                      },\n                      {\n                        Action: \"kms:encrypt\",\n                        Effect: \"Allow\",\n                        Principal: {\n                          AWS: \"arn\"\n                        },\n                        Resource: \"*\"\n                      }\n                    ],\n                    Version: \"2012-10-17\"\n                  }\n                },\n                DeletionPolicy: \"Retain\"\n              }\n            }\n          }));\n\n        test.done();\n    },\n\n    'key with some options'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'Test');\n\n        const key = new EncryptionKey(stack, 'MyKey', {\n            enableKeyRotation: true,\n            enabled: false\n        });\n        const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n        p.addAwsPrincipal('arn');\n        key.addToResourcePolicy(p);\n\n        expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n            Resources: {\n              MyKey6AB29FA6: {\n                Type: \"AWS::KMS::Key\",\n                Properties: {\n                  Enabled: false,\n                  EnableKeyRotation: true,\n                  KeyPolicy: {\n                    Statement: [\n                      {\n                        Action: [\n                          \"kms:Create*\",\n                          \"kms:Describe*\",\n                          \"kms:Enable*\",\n                          \"kms:List*\",\n                          \"kms:Put*\",\n                          \"kms:Update*\",\n                          \"kms:Revoke*\",\n                          \"kms:Disable*\",\n                          \"kms:Get*\",\n                          \"kms:Delete*\",\n                          \"kms:ScheduleKeyDeletion\",\n                          \"kms:CancelKeyDeletion\"\n                        ],\n                        Effect: \"Allow\",\n                        Principal: {\n                          AWS: {\n                            \"Fn::Join\": [\n                              \"\",\n                              [\n                                \"arn:\",\n                                {\n                                  Ref: \"AWS::Partition\"\n                                },\n                                \":iam::\",\n                                {\n                                  Ref: \"AWS::AccountId\"\n                                },\n                                \":root\"\n                              ]\n                            ]\n                          }\n                        },\n                        Resource: '*'\n                      },\n                      {\n                        Action: \"kms:encrypt\",\n                        Effect: \"Allow\",\n                        Principal: {\n                          AWS: \"arn\"\n                        },\n                        Resource: \"*\"\n                      }\n                    ],\n                    Version: \"2012-10-17\"\n                  }\n                },\n                DeletionPolicy: \"Retain\"\n              }\n            }\n          }));\n\n        test.done();\n    },\n\n    'addAlias creates an alias'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'Test');\n\n        const key = new EncryptionKey(stack, 'MyKey', {\n            enableKeyRotation: true,\n            enabled: false\n        });\n\n        const alias = key.addAlias('alias/xoo');\n        test.ok(alias.aliasName);\n\n        test.deepEqual(app.synthesizeStack(stack.name).template, {\n          Resources: {\n            MyKey6AB29FA6: {\n              Type: \"AWS::KMS::Key\",\n              Properties: {\n                EnableKeyRotation: true,\n                Enabled: false,\n                KeyPolicy: {\n                  Statement: [\n                    {\n                      Action: [\n                        \"kms:Create*\",\n                        \"kms:Describe*\",\n                        \"kms:Enable*\",\n                        \"kms:List*\",\n                        \"kms:Put*\",\n                        \"kms:Update*\",\n                        \"kms:Revoke*\",\n                        \"kms:Disable*\",\n                        \"kms:Get*\",\n                        \"kms:Delete*\",\n                        \"kms:ScheduleKeyDeletion\",\n                        \"kms:CancelKeyDeletion\"\n                      ],\n                      Effect: \"Allow\",\n                      Principal: {\n                        AWS: {\n                          \"Fn::Join\": [\n                            \"\",\n                            [\n                              \"arn:\",\n                              {\n                                Ref: \"AWS::Partition\"\n                              },\n                              \":iam::\",\n                              {\n                                Ref: \"AWS::AccountId\"\n                              },\n                              \":root\"\n                            ]\n                          ]\n                        }\n                      },\n                      Resource: \"*\"\n                    }\n                  ],\n                  Version: \"2012-10-17\"\n                }\n              },\n              DeletionPolicy: \"Retain\"\n            },\n            MyKeyAlias1B45D9DA: {\n              Type: \"AWS::KMS::Alias\",\n              Properties: {\n                AliasName: \"alias/xoo\",\n                TargetKeyId: {\n                  \"Fn::GetAtt\": [\n                    \"MyKey6AB29FA6\",\n                    \"Arn\"\n                  ]\n                }\n              }\n            }\n          }\n        });\n\n        test.done();\n    },\n\n    'import/export can be used to bring in an existing key'(test: Test) {\n        const stack1 = new Stack();\n        const policy = new PolicyDocument();\n        policy.addStatement(new PolicyStatement().addAllResources());\n        const myKey = new EncryptionKey(stack1, 'MyKey', { policy });\n        const exportedKeyRef = myKey.export();\n\n        expect(stack1).toMatch({\n          Resources: {\n            MyKey6AB29FA6: {\n              Type: \"AWS::KMS::Key\",\n              Properties: {\n                KeyPolicy: {\n                  Statement: [\n                    {\n                      Effect: \"Allow\",\n                      Resource: \"*\"\n                    }\n                  ],\n                  Version: \"2012-10-17\"\n                }\n              },\n              DeletionPolicy: \"Retain\"\n            }\n          },\n          Outputs: {\n            MyKeyKeyArn317F1332: {\n              Export: {\n                Name: \"MyKeyKeyArn317F1332\"\n              }\n            }\n          }\n        });\n\n        const stack2 = new Stack();\n        const myKeyImported = EncryptionKey.import(stack2, 'MyKeyImported', exportedKeyRef);\n\n        // addAlias can be called on imported keys.\n        myKeyImported.addAlias('alias/hello');\n\n        expect(stack2).toMatch({\n          Resources: {\n            MyKeyImportedAliasB1C5269F: {\n              Type: \"AWS::KMS::Alias\",\n              Properties: {\n                AliasName: \"alias/hello\",\n                TargetKeyId: {\n                  \"Fn::ImportValue\": \"MyKeyKeyArn317F1332\"\n                }\n              }\n            }\n          }\n        });\n\n        test.done();\n    },\n\n    'addToResourcePolicy allowNoOp and there is no policy': {\n        'succeed if set to true (default)'(test: Test) {\n            const stack = new Stack();\n\n            const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n            key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'));\n\n            test.done();\n        },\n\n        'fails if set to false'(test: Test) {\n\n            const stack = new Stack();\n\n            const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n            test.throws(() =>\n              key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'), /* allowNoOp */ false),\n              'Unable to add statement to IAM resource policy for KMS key: \"foo/bar\"');\n\n            test.done();\n\n        }\n    }\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.key.js","sourceRoot":"","sources":["test.key.ts"],"names":[],"mappings":"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","sourcesContent":["import { exactlyMatchTemplate, expect } from '@aws-cdk/assert';\nimport { App, PolicyDocument, PolicyStatement, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { EncryptionKey } from '../lib';\n\nexport = {\n  'default key'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'TestStack');\n\n    new EncryptionKey(stack, 'MyKey');\n\n    expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n      Resources: {\n      MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n        KeyPolicy: {\n          Statement: [\n          {\n            Action: [\n            \"kms:Create*\",\n            \"kms:Describe*\",\n            \"kms:Enable*\",\n            \"kms:List*\",\n            \"kms:Put*\",\n            \"kms:Update*\",\n            \"kms:Revoke*\",\n            \"kms:Disable*\",\n            \"kms:Get*\",\n            \"kms:Delete*\",\n            \"kms:ScheduleKeyDeletion\",\n            \"kms:CancelKeyDeletion\"\n            ],\n            Effect: \"Allow\",\n            Principal: {\n            AWS: {\n              \"Fn::Join\": [\n              \"\",\n              [\n                \"arn:\",\n                {\n                Ref: \"AWS::Partition\"\n                },\n                \":iam::\",\n                {\n                Ref: \"AWS::AccountId\"\n                },\n                \":root\"\n              ]\n              ]\n            }\n            },\n            Resource: \"*\"\n          }\n          ],\n          Version: \"2012-10-17\"\n        }\n        },\n        DeletionPolicy: \"Retain\"\n      }\n      }\n    }));\n    test.done();\n  },\n\n  'default with some permission'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey');\n    const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n    p.addAwsPrincipal('arn');\n    key.addToResourcePolicy(p);\n\n    expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n      Resources: {\n        MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n          KeyPolicy: {\n          Statement: [\n            {\n            Action: [\n              \"kms:Create*\",\n              \"kms:Describe*\",\n              \"kms:Enable*\",\n              \"kms:List*\",\n              \"kms:Put*\",\n              \"kms:Update*\",\n              \"kms:Revoke*\",\n              \"kms:Disable*\",\n              \"kms:Get*\",\n              \"kms:Delete*\",\n              \"kms:ScheduleKeyDeletion\",\n              \"kms:CancelKeyDeletion\"\n            ],\n            Effect: \"Allow\",\n            Principal: {\n              AWS: {\n              \"Fn::Join\": [\n                \"\",\n                [\n                \"arn:\",\n                {\n                  Ref: \"AWS::Partition\"\n                },\n                \":iam::\",\n                {\n                  Ref: \"AWS::AccountId\"\n                },\n                \":root\"\n                ]\n              ]\n              }\n            },\n            Resource: '*'\n            },\n            {\n            Action: \"kms:encrypt\",\n            Effect: \"Allow\",\n            Principal: {\n              AWS: \"arn\"\n            },\n            Resource: \"*\"\n            }\n          ],\n          Version: \"2012-10-17\"\n          }\n        },\n        DeletionPolicy: \"Retain\"\n        }\n      }\n      }));\n\n    test.done();\n  },\n\n  'key with some options'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey', {\n      enableKeyRotation: true,\n      enabled: false\n    });\n    const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n    p.addAwsPrincipal('arn');\n    key.addToResourcePolicy(p);\n\n    expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n      Resources: {\n        MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n          Enabled: false,\n          EnableKeyRotation: true,\n          KeyPolicy: {\n          Statement: [\n            {\n            Action: [\n              \"kms:Create*\",\n              \"kms:Describe*\",\n              \"kms:Enable*\",\n              \"kms:List*\",\n              \"kms:Put*\",\n              \"kms:Update*\",\n              \"kms:Revoke*\",\n              \"kms:Disable*\",\n              \"kms:Get*\",\n              \"kms:Delete*\",\n              \"kms:ScheduleKeyDeletion\",\n              \"kms:CancelKeyDeletion\"\n            ],\n            Effect: \"Allow\",\n            Principal: {\n              AWS: {\n              \"Fn::Join\": [\n                \"\",\n                [\n                \"arn:\",\n                {\n                  Ref: \"AWS::Partition\"\n                },\n                \":iam::\",\n                {\n                  Ref: \"AWS::AccountId\"\n                },\n                \":root\"\n                ]\n              ]\n              }\n            },\n            Resource: '*'\n            },\n            {\n            Action: \"kms:encrypt\",\n            Effect: \"Allow\",\n            Principal: {\n              AWS: \"arn\"\n            },\n            Resource: \"*\"\n            }\n          ],\n          Version: \"2012-10-17\"\n          }\n        },\n        DeletionPolicy: \"Retain\"\n        }\n      }\n      }));\n\n    test.done();\n  },\n\n  'addAlias creates an alias'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey', {\n      enableKeyRotation: true,\n      enabled: false\n    });\n\n    const alias = key.addAlias('alias/xoo');\n    test.ok(alias.aliasName);\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, {\n      Resources: {\n      MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n        EnableKeyRotation: true,\n        Enabled: false,\n        KeyPolicy: {\n          Statement: [\n          {\n            Action: [\n            \"kms:Create*\",\n            \"kms:Describe*\",\n            \"kms:Enable*\",\n            \"kms:List*\",\n            \"kms:Put*\",\n            \"kms:Update*\",\n            \"kms:Revoke*\",\n            \"kms:Disable*\",\n            \"kms:Get*\",\n            \"kms:Delete*\",\n            \"kms:ScheduleKeyDeletion\",\n            \"kms:CancelKeyDeletion\"\n            ],\n            Effect: \"Allow\",\n            Principal: {\n            AWS: {\n              \"Fn::Join\": [\n              \"\",\n              [\n                \"arn:\",\n                {\n                Ref: \"AWS::Partition\"\n                },\n                \":iam::\",\n                {\n                Ref: \"AWS::AccountId\"\n                },\n                \":root\"\n              ]\n              ]\n            }\n            },\n            Resource: \"*\"\n          }\n          ],\n          Version: \"2012-10-17\"\n        }\n        },\n        DeletionPolicy: \"Retain\"\n      },\n      MyKeyAlias1B45D9DA: {\n        Type: \"AWS::KMS::Alias\",\n        Properties: {\n        AliasName: \"alias/xoo\",\n        TargetKeyId: {\n          \"Fn::GetAtt\": [\n          \"MyKey6AB29FA6\",\n          \"Arn\"\n          ]\n        }\n        }\n      }\n      }\n    });\n\n    test.done();\n  },\n\n  'import/export can be used to bring in an existing key'(test: Test) {\n    const stack1 = new Stack();\n    const policy = new PolicyDocument();\n    policy.addStatement(new PolicyStatement().addAllResources());\n    const myKey = new EncryptionKey(stack1, 'MyKey', { policy });\n    const exportedKeyRef = myKey.export();\n\n    expect(stack1).toMatch({\n      Resources: {\n      MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n        KeyPolicy: {\n          Statement: [\n          {\n            Effect: \"Allow\",\n            Resource: \"*\"\n          }\n          ],\n          Version: \"2012-10-17\"\n        }\n        },\n        DeletionPolicy: \"Retain\"\n      }\n      },\n      Outputs: {\n      MyKeyKeyArn317F1332: {\n        Export: {\n        Name: \"MyKeyKeyArn317F1332\"\n        }\n      }\n      }\n    });\n\n    const stack2 = new Stack();\n    const myKeyImported = EncryptionKey.import(stack2, 'MyKeyImported', exportedKeyRef);\n\n    // addAlias can be called on imported keys.\n    myKeyImported.addAlias('alias/hello');\n\n    expect(stack2).toMatch({\n      Resources: {\n      MyKeyImportedAliasB1C5269F: {\n        Type: \"AWS::KMS::Alias\",\n        Properties: {\n        AliasName: \"alias/hello\",\n        TargetKeyId: {\n          \"Fn::ImportValue\": \"MyKeyKeyArn317F1332\"\n        }\n        }\n      }\n      }\n    });\n\n    test.done();\n  },\n\n  'addToResourcePolicy allowNoOp and there is no policy': {\n    'succeed if set to true (default)'(test: Test) {\n      const stack = new Stack();\n\n      const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n      key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'));\n\n      test.done();\n    },\n\n    'fails if set to false'(test: Test) {\n\n      const stack = new Stack();\n\n      const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n      test.throws(() =>\n        key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'), /* allowNoOp */ false),\n        'Unable to add statement to IAM resource policy for KMS key: \"foo/bar\"');\n\n      test.done();\n\n    }\n  }\n};\n"]}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc