Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-iam

Package Overview
Dependencies
10
Maintainers
4
Versions
288
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 0.9.2 to 0.10.0

2

lib/group.js

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

exports.Group = Group;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5RjtBQUN6RixtREFBaUQ7QUFDakQscUNBQWlFO0FBRWpFLGlDQUE0RDtBQStCNUQsTUFBYSxLQUFNLFNBQVEsZUFBUztJQW9CaEMsWUFBWSxNQUFpQixFQUFFLElBQVksRUFBRSxRQUFvQixFQUFFO1FBQy9ELEtBQUssQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFKUCxxQkFBZ0IsR0FBRyxJQUFJLHVCQUFnQixFQUFFLENBQUM7UUFNdkQsSUFBSSxDQUFDLGVBQWUsR0FBRyxLQUFLLENBQUMsaUJBQWlCLElBQUksRUFBRSxDQUFDO1FBRXJELE1BQU0sS0FBSyxHQUFHLElBQUksOEJBQWMsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUM3RCxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsaUJBQWlCLEVBQUUsdUJBQWdCLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUMvRCxJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7U0FDbkIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMvQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksa0JBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVEOzs7T0FHRztJQUNJLG1CQUFtQixDQUFDLEdBQVc7UUFDbEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLGtCQUFrQixDQUFDLE1BQWM7UUFDcEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRDs7T0FFRztJQUNJLE9BQU8sQ0FBQyxJQUFVO1FBQ3JCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksV0FBVyxDQUFDLFNBQTBCO1FBQ3pDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3JCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxlQUFNLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBQ3ZELElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzFDO1FBRUQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDL0MsQ0FBQztDQUNKO0FBdkVELHNCQXVFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFyblByaW5jaXBhbCwgQ29uc3RydWN0LCBQb2xpY3lQcmluY2lwYWwsIFBvbGljeVN0YXRlbWVudCB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBjbG91ZGZvcm1hdGlvbiB9IGZyb20gJy4vaWFtLmdlbmVyYXRlZCc7XG5pbXBvcnQgeyBJSWRlbnRpdHlSZXNvdXJjZSwgSVByaW5jaXBhbCwgUG9saWN5IH0gZnJvbSAnLi9wb2xpY3knO1xuaW1wb3J0IHsgVXNlciB9IGZyb20gJy4vdXNlcic7XG5pbXBvcnQgeyBBdHRhY2hlZFBvbGljaWVzLCB1bmRlZmluZWRJZkVtcHR5IH0gZnJvbSAnLi91dGlsJztcblxuZXhwb3J0IGludGVyZmFjZSBHcm91cFByb3BzIHtcbiAgICAvKipcbiAgICAgKiBBIG5hbWUgZm9yIHRoZSBJQU0gZ3JvdXAuIEZvciB2YWxpZCB2YWx1ZXMsIHNlZSB0aGUgR3JvdXBOYW1lIHBhcmFtZXRlclxuICAgICAqIGZvciB0aGUgQ3JlYXRlR3JvdXAgYWN0aW9uIGluIHRoZSBJQU0gQVBJIFJlZmVyZW5jZS4gSWYgeW91IGRvbid0IHNwZWNpZnlcbiAgICAgKiBhIG5hbWUsIEFXUyBDbG91ZEZvcm1hdGlvbiBnZW5lcmF0ZXMgYSB1bmlxdWUgcGh5c2ljYWwgSUQgYW5kIHVzZXMgdGhhdFxuICAgICAqIElEIGZvciB0aGUgZ3JvdXAgbmFtZS5cbiAgICAgKlxuICAgICAqIElmIHlvdSBzcGVjaWZ5IGEgbmFtZSwgeW91IG11c3Qgc3BlY2lmeSB0aGUgQ0FQQUJJTElUWV9OQU1FRF9JQU0gdmFsdWUgdG9cbiAgICAgKiBhY2tub3dsZWRnZSB5b3VyIHRlbXBsYXRlJ3MgY2FwYWJpbGl0aWVzLiBGb3IgbW9yZSBpbmZvcm1hdGlvbiwgc2VlXG4gICAgICogQWNrbm93bGVkZ2luZyBJQU0gUmVzb3VyY2VzIGluIEFXUyBDbG91ZEZvcm1hdGlvbiBUZW1wbGF0ZXMuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCBHZW5lcmF0ZWQgYnkgQ2xvdWRGb3JtYXRpb24gKHJlY29tbWVuZGVkKVxuICAgICAqL1xuICAgIGdyb3VwTmFtZT86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEEgbGlzdCBvZiBBUk5zIGZvciBtYW5hZ2VkIHBvbGljaWVzIGFzc29jaWF0ZWQgd2l0aCBncm91cC5cbiAgICAgKiBAZGVmYXVsdCBObyBtYW5hZ2VkIHBvbGljaWVzLlxuICAgICAqL1xuICAgIG1hbmFnZWRQb2xpY3lBcm5zPzogYW55W107XG5cbiAgICAvKipcbiAgICAgKiBUaGUgcGF0aCB0byB0aGUgZ3JvdXAuIEZvciBtb3JlIGluZm9ybWF0aW9uIGFib3V0IHBhdGhzLCBzZWUgW0lBTVxuICAgICAqIElkZW50aWZpZXJzXShodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9JQU0vbGF0ZXN0L1VzZXJHdWlkZS9pbmRleC5odG1sP1VzaW5nX0lkZW50aWZpZXJzLmh0bWwpXG4gICAgICogaW4gdGhlIElBTSBVc2VyIEd1aWRlLlxuICAgICAqL1xuICAgIHBhdGg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBHcm91cCBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElJZGVudGl0eVJlc291cmNlLCBJUHJpbmNpcGFsIHtcbiAgICAvKipcbiAgICAgKiBUaGUgcnVudGltZSBuYW1lIG9mIHRoaXMgZ3JvdXAuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGdyb3VwTmFtZTogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogVGhlIEFSTiBvZiB0aGlzIGdyb3VwLlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBncm91cEFybjogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQW4gXCJBV1NcIiBwb2xpY3kgcHJpbmNpcGFsIHRoYXQgcmVwcmVzZW50cyB0aGlzIGdyb3VwLlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBwcmluY2lwYWw6IFBvbGljeVByaW5jaXBhbDtcblxuICAgIHByaXZhdGUgcmVhZG9ubHkgbWFuYWdlZFBvbGljaWVzOiBhbnlbXTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGF0dGFjaGVkUG9saWNpZXMgPSBuZXcgQXR0YWNoZWRQb2xpY2llcygpO1xuICAgIHByaXZhdGUgZGVmYXVsdFBvbGljeT86IFBvbGljeTtcblxuICAgIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBHcm91cFByb3BzID0ge30pIHtcbiAgICAgICAgc3VwZXIocGFyZW50LCBuYW1lKTtcblxuICAgICAgICB0aGlzLm1hbmFnZWRQb2xpY2llcyA9IHByb3BzLm1hbmFnZWRQb2xpY3lBcm5zIHx8IFtdO1xuXG4gICAgICAgIGNvbnN0IGdyb3VwID0gbmV3IGNsb3VkZm9ybWF0aW9uLkdyb3VwUmVzb3VyY2UodGhpcywgJ1Jlc291cmNlJywge1xuICAgICAgICAgICAgZ3JvdXBOYW1lOiBwcm9wcy5ncm91cE5hbWUsXG4gICAgICAgICAgICBtYW5hZ2VkUG9saWN5QXJuczogdW5kZWZpbmVkSWZFbXB0eSgoKSA9PiB0aGlzLm1hbmFnZWRQb2xpY2llcyksXG4gICAgICAgICAgICBwYXRoOiBwcm9wcy5wYXRoLFxuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLmdyb3VwTmFtZSA9IGdyb3VwLmdyb3VwTmFtZTtcbiAgICAgICAgdGhpcy5ncm91cEFybiA9IGdyb3VwLmdyb3VwQXJuO1xuICAgICAgICB0aGlzLnByaW5jaXBhbCA9IG5ldyBBcm5QcmluY2lwYWwodGhpcy5ncm91cEFybik7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQXR0YWNoZXMgYSBtYW5hZ2VkIHBvbGljeSB0byB0aGlzIGdyb3VwLlxuICAgICAqIEBwYXJhbSBhcm4gVGhlIEFSTiBvZiB0aGUgbWFuYWdlZCBwb2xpY3kgdG8gYXR0YWNoLlxuICAgICAqL1xuICAgIHB1YmxpYyBhdHRhY2hNYW5hZ2VkUG9saWN5KGFybjogc3RyaW5nKSB7XG4gICAgICAgIHRoaXMubWFuYWdlZFBvbGljaWVzLnB1c2goYXJuKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBBdHRhY2hlcyBhIHBvbGljeSB0byB0aGlzIGdyb3VwLlxuICAgICAqIEBwYXJhbSBwb2xpY3kgVGhlIHBvbGljeSB0byBhdHRhY2guXG4gICAgICovXG4gICAgcHVibGljIGF0dGFjaElubGluZVBvbGljeShwb2xpY3k6IFBvbGljeSkge1xuICAgICAgICB0aGlzLmF0dGFjaGVkUG9saWNpZXMuYXR0YWNoKHBvbGljeSk7XG4gICAgICAgIHBvbGljeS5hdHRhY2hUb0dyb3VwKHRoaXMpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEFkZHMgYSB1c2VyIHRvIHRoaXMgZ3JvdXAuXG4gICAgICovXG4gICAgcHVibGljIGFkZFVzZXIodXNlcjogVXNlcikge1xuICAgICAgICB1c2VyLmFkZFRvR3JvdXAodGhpcyk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQWRkcyBhbiBJQU0gc3RhdGVtZW50IHRvIHRoZSBkZWZhdWx0IHBvbGljeS5cbiAgICAgKi9cbiAgICBwdWJsaWMgYWRkVG9Qb2xpY3koc3RhdGVtZW50OiBQb2xpY3lTdGF0ZW1lbnQpIHtcbiAgICAgICAgaWYgKCF0aGlzLmRlZmF1bHRQb2xpY3kpIHtcbiAgICAgICAgICAgIHRoaXMuZGVmYXVsdFBvbGljeSA9IG5ldyBQb2xpY3kodGhpcywgJ0RlZmF1bHRQb2xpY3knKTtcbiAgICAgICAgICAgIHRoaXMuZGVmYXVsdFBvbGljeS5hdHRhY2hUb0dyb3VwKHRoaXMpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5kZWZhdWx0UG9saWN5LmFkZFN0YXRlbWVudChzdGF0ZW1lbnQpO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5RjtBQUN6RixtREFBaUQ7QUFDakQscUNBQWlFO0FBRWpFLGlDQUE0RDtBQStCNUQsTUFBYSxLQUFNLFNBQVEsZUFBUztJQW9CbEMsWUFBWSxNQUFpQixFQUFFLElBQVksRUFBRSxRQUFvQixFQUFFO1FBQ2pFLEtBQUssQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFKTCxxQkFBZ0IsR0FBRyxJQUFJLHVCQUFnQixFQUFFLENBQUM7UUFNekQsSUFBSSxDQUFDLGVBQWUsR0FBRyxLQUFLLENBQUMsaUJBQWlCLElBQUksRUFBRSxDQUFDO1FBRXJELE1BQU0sS0FBSyxHQUFHLElBQUksOEJBQWMsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUMvRCxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsaUJBQWlCLEVBQUUsdUJBQWdCLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUMvRCxJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7U0FDakIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMvQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksa0JBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVEOzs7T0FHRztJQUNJLG1CQUFtQixDQUFDLEdBQVc7UUFDcEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLGtCQUFrQixDQUFDLE1BQWM7UUFDdEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRDs7T0FFRztJQUNJLE9BQU8sQ0FBQyxJQUFVO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksV0FBVyxDQUFDLFNBQTBCO1FBQzNDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxlQUFNLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBQ3ZELElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3hDO1FBRUQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDN0MsQ0FBQztDQUNGO0FBdkVELHNCQXVFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFyblByaW5jaXBhbCwgQ29uc3RydWN0LCBQb2xpY3lQcmluY2lwYWwsIFBvbGljeVN0YXRlbWVudCB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBjbG91ZGZvcm1hdGlvbiB9IGZyb20gJy4vaWFtLmdlbmVyYXRlZCc7XG5pbXBvcnQgeyBJSWRlbnRpdHlSZXNvdXJjZSwgSVByaW5jaXBhbCwgUG9saWN5IH0gZnJvbSAnLi9wb2xpY3knO1xuaW1wb3J0IHsgVXNlciB9IGZyb20gJy4vdXNlcic7XG5pbXBvcnQgeyBBdHRhY2hlZFBvbGljaWVzLCB1bmRlZmluZWRJZkVtcHR5IH0gZnJvbSAnLi91dGlsJztcblxuZXhwb3J0IGludGVyZmFjZSBHcm91cFByb3BzIHtcbiAgLyoqXG4gICAqIEEgbmFtZSBmb3IgdGhlIElBTSBncm91cC4gRm9yIHZhbGlkIHZhbHVlcywgc2VlIHRoZSBHcm91cE5hbWUgcGFyYW1ldGVyXG4gICAqIGZvciB0aGUgQ3JlYXRlR3JvdXAgYWN0aW9uIGluIHRoZSBJQU0gQVBJIFJlZmVyZW5jZS4gSWYgeW91IGRvbid0IHNwZWNpZnlcbiAgICogYSBuYW1lLCBBV1MgQ2xvdWRGb3JtYXRpb24gZ2VuZXJhdGVzIGEgdW5pcXVlIHBoeXNpY2FsIElEIGFuZCB1c2VzIHRoYXRcbiAgICogSUQgZm9yIHRoZSBncm91cCBuYW1lLlxuICAgKlxuICAgKiBJZiB5b3Ugc3BlY2lmeSBhIG5hbWUsIHlvdSBtdXN0IHNwZWNpZnkgdGhlIENBUEFCSUxJVFlfTkFNRURfSUFNIHZhbHVlIHRvXG4gICAqIGFja25vd2xlZGdlIHlvdXIgdGVtcGxhdGUncyBjYXBhYmlsaXRpZXMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWVcbiAgICogQWNrbm93bGVkZ2luZyBJQU0gUmVzb3VyY2VzIGluIEFXUyBDbG91ZEZvcm1hdGlvbiBUZW1wbGF0ZXMuXG4gICAqXG4gICAqIEBkZWZhdWx0IEdlbmVyYXRlZCBieSBDbG91ZEZvcm1hdGlvbiAocmVjb21tZW5kZWQpXG4gICAqL1xuICBncm91cE5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBBUk5zIGZvciBtYW5hZ2VkIHBvbGljaWVzIGFzc29jaWF0ZWQgd2l0aCBncm91cC5cbiAgICogQGRlZmF1bHQgTm8gbWFuYWdlZCBwb2xpY2llcy5cbiAgICovXG4gIG1hbmFnZWRQb2xpY3lBcm5zPzogYW55W107XG5cbiAgLyoqXG4gICAqIFRoZSBwYXRoIHRvIHRoZSBncm91cC4gRm9yIG1vcmUgaW5mb3JtYXRpb24gYWJvdXQgcGF0aHMsIHNlZSBbSUFNXG4gICAqIElkZW50aWZpZXJzXShodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9JQU0vbGF0ZXN0L1VzZXJHdWlkZS9pbmRleC5odG1sP1VzaW5nX0lkZW50aWZpZXJzLmh0bWwpXG4gICAqIGluIHRoZSBJQU0gVXNlciBHdWlkZS5cbiAgICovXG4gIHBhdGg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBHcm91cCBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElJZGVudGl0eVJlc291cmNlLCBJUHJpbmNpcGFsIHtcbiAgLyoqXG4gICAqIFRoZSBydW50aW1lIG5hbWUgb2YgdGhpcyBncm91cC5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBncm91cE5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIEFSTiBvZiB0aGlzIGdyb3VwLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGdyb3VwQXJuOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEFuIFwiQVdTXCIgcG9saWN5IHByaW5jaXBhbCB0aGF0IHJlcHJlc2VudHMgdGhpcyBncm91cC5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBwcmluY2lwYWw6IFBvbGljeVByaW5jaXBhbDtcblxuICBwcml2YXRlIHJlYWRvbmx5IG1hbmFnZWRQb2xpY2llczogYW55W107XG4gIHByaXZhdGUgcmVhZG9ubHkgYXR0YWNoZWRQb2xpY2llcyA9IG5ldyBBdHRhY2hlZFBvbGljaWVzKCk7XG4gIHByaXZhdGUgZGVmYXVsdFBvbGljeT86IFBvbGljeTtcblxuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogR3JvdXBQcm9wcyA9IHt9KSB7XG4gICAgc3VwZXIocGFyZW50LCBuYW1lKTtcblxuICAgIHRoaXMubWFuYWdlZFBvbGljaWVzID0gcHJvcHMubWFuYWdlZFBvbGljeUFybnMgfHwgW107XG5cbiAgICBjb25zdCBncm91cCA9IG5ldyBjbG91ZGZvcm1hdGlvbi5Hcm91cFJlc291cmNlKHRoaXMsICdSZXNvdXJjZScsIHtcbiAgICAgIGdyb3VwTmFtZTogcHJvcHMuZ3JvdXBOYW1lLFxuICAgICAgbWFuYWdlZFBvbGljeUFybnM6IHVuZGVmaW5lZElmRW1wdHkoKCkgPT4gdGhpcy5tYW5hZ2VkUG9saWNpZXMpLFxuICAgICAgcGF0aDogcHJvcHMucGF0aCxcbiAgICB9KTtcblxuICAgIHRoaXMuZ3JvdXBOYW1lID0gZ3JvdXAuZ3JvdXBOYW1lO1xuICAgIHRoaXMuZ3JvdXBBcm4gPSBncm91cC5ncm91cEFybjtcbiAgICB0aGlzLnByaW5jaXBhbCA9IG5ldyBBcm5QcmluY2lwYWwodGhpcy5ncm91cEFybik7XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBtYW5hZ2VkIHBvbGljeSB0byB0aGlzIGdyb3VwLlxuICAgKiBAcGFyYW0gYXJuIFRoZSBBUk4gb2YgdGhlIG1hbmFnZWQgcG9saWN5IHRvIGF0dGFjaC5cbiAgICovXG4gIHB1YmxpYyBhdHRhY2hNYW5hZ2VkUG9saWN5KGFybjogc3RyaW5nKSB7XG4gICAgdGhpcy5tYW5hZ2VkUG9saWNpZXMucHVzaChhcm4pO1xuICB9XG5cbiAgLyoqXG4gICAqIEF0dGFjaGVzIGEgcG9saWN5IHRvIHRoaXMgZ3JvdXAuXG4gICAqIEBwYXJhbSBwb2xpY3kgVGhlIHBvbGljeSB0byBhdHRhY2guXG4gICAqL1xuICBwdWJsaWMgYXR0YWNoSW5saW5lUG9saWN5KHBvbGljeTogUG9saWN5KSB7XG4gICAgdGhpcy5hdHRhY2hlZFBvbGljaWVzLmF0dGFjaChwb2xpY3kpO1xuICAgIHBvbGljeS5hdHRhY2hUb0dyb3VwKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYSB1c2VyIHRvIHRoaXMgZ3JvdXAuXG4gICAqL1xuICBwdWJsaWMgYWRkVXNlcih1c2VyOiBVc2VyKSB7XG4gICAgdXNlci5hZGRUb0dyb3VwKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYW4gSUFNIHN0YXRlbWVudCB0byB0aGUgZGVmYXVsdCBwb2xpY3kuXG4gICAqL1xuICBwdWJsaWMgYWRkVG9Qb2xpY3koc3RhdGVtZW50OiBQb2xpY3lTdGF0ZW1lbnQpIHtcbiAgICBpZiAoIXRoaXMuZGVmYXVsdFBvbGljeSkge1xuICAgICAgdGhpcy5kZWZhdWx0UG9saWN5ID0gbmV3IFBvbGljeSh0aGlzLCAnRGVmYXVsdFBvbGljeScpO1xuICAgICAgdGhpcy5kZWZhdWx0UG9saWN5LmF0dGFjaFRvR3JvdXAodGhpcyk7XG4gICAgfVxuXG4gICAgdGhpcy5kZWZhdWx0UG9saWN5LmFkZFN0YXRlbWVudChzdGF0ZW1lbnQpO1xuICB9XG59XG4iXX0=

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

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

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

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

@@ -157,8 +159,9 @@ };

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

@@ -221,8 +224,9 @@ };

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

@@ -275,8 +279,9 @@ };

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

@@ -342,8 +347,9 @@ };

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

@@ -402,8 +408,9 @@ };

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

@@ -465,8 +472,9 @@ };

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

@@ -537,8 +545,9 @@ };

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

@@ -545,0 +554,0 @@ };

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

exports.AwsManagedPolicy = AwsManagedPolicy;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFuYWdlZC1wb2xpY3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtYW5hZ2VkLXBvbGljeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUVyQzs7Ozs7Ozs7R0FRRztBQUNILE1BQWEsZ0JBQWdCO0lBQ3pCLFlBQTZCLGlCQUF5QjtRQUF6QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQVE7SUFDdEQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxTQUFTO1FBQ2hCLG1FQUFtRTtRQUNuRSxPQUFPLEdBQUcsQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDO1lBQy9CLE9BQU8sRUFBRSxLQUFLO1lBQ2QsTUFBTSxFQUFFLEVBQUU7WUFDVixPQUFPLEVBQUUsS0FBSztZQUNkLFFBQVEsRUFBRSxRQUFRO1lBQ2xCLFlBQVksRUFBRSxJQUFJLENBQUMsaUJBQWlCO1NBQ3ZDLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDSjtBQWpCRCw0Q0FpQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5cbi8qKlxuICogQSBwb2xpY3kgbWFuYWdlZCBieSBBV1NcbiAqXG4gKiBGb3IgdGhpcyBtYW5hZ2VkIHBvbGljeSwgeW91IG9ubHkgbmVlZCB0byBrbm93IHRoZSBuYW1lIHRvIGJlIGFibGUgdG8gdXNlIGl0LlxuICpcbiAqIFNvbWUgbWFuYWdlZCBwb2xpY3kgbmFtZXMgc3RhcnQgd2l0aCBcInNlcnZpY2Utcm9sZS9cIiwgc29tZSBzdGFydCB3aXRoXG4gKiBcImpvYi1mdW5jdGlvbi9cIiwgYW5kIHNvbWUgZG9uJ3Qgc3RhcnQgd2l0aCBhbnl0aGluZy4gRG8gaW5jbHVkZSB0aGVcbiAqIHByZWZpeCB3aGVuIGNvbnN0cnVjdGluZyB0aGlzIG9iamVjdC5cbiAqL1xuZXhwb3J0IGNsYXNzIEF3c01hbmFnZWRQb2xpY3kge1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgbWFuYWdlZFBvbGljeU5hbWU6IHN0cmluZykge1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFRoZSBBcm4gb2YgdGhpcyBtYW5hZ2VkIHBvbGljeVxuICAgICAqL1xuICAgIHB1YmxpYyBnZXQgcG9saWN5QXJuKCk6IHN0cmluZyB7XG4gICAgICAgIC8vIHRoZSBhcm4gaXMgaW4gdGhlIGZvcm0gb2YgLSBhcm46YXdzOmlhbTo6YXdzOnBvbGljeS88cG9saWN5TmFtZT5cbiAgICAgICAgcmV0dXJuIGNkay5Bcm5VdGlscy5mcm9tQ29tcG9uZW50cyh7XG4gICAgICAgICAgICBzZXJ2aWNlOiBcImlhbVwiLFxuICAgICAgICAgICAgcmVnaW9uOiBcIlwiLCAvLyBubyByZWdpb24gZm9yIG1hbmFnZWQgcG9saWN5XG4gICAgICAgICAgICBhY2NvdW50OiBcImF3c1wiLCAvLyB0aGUgYWNjb3VudCBmb3IgYSBtYW5hZ2VkIHBvbGljeSBpcyAnYXdzJ1xuICAgICAgICAgICAgcmVzb3VyY2U6IFwicG9saWN5XCIsXG4gICAgICAgICAgICByZXNvdXJjZU5hbWU6IHRoaXMubWFuYWdlZFBvbGljeU5hbWVcbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFuYWdlZC1wb2xpY3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJtYW5hZ2VkLXBvbGljeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUVyQzs7Ozs7Ozs7R0FRRztBQUNILE1BQWEsZ0JBQWdCO0lBQzNCLFlBQTZCLGlCQUF5QjtRQUF6QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQVE7SUFDdEQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxTQUFTO1FBQ2xCLG1FQUFtRTtRQUNuRSxPQUFPLEdBQUcsQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDO1lBQ2pDLE9BQU8sRUFBRSxLQUFLO1lBQ2QsTUFBTSxFQUFFLEVBQUU7WUFDVixPQUFPLEVBQUUsS0FBSztZQUNkLFFBQVEsRUFBRSxRQUFRO1lBQ2xCLFlBQVksRUFBRSxJQUFJLENBQUMsaUJBQWlCO1NBQ3JDLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQWpCRCw0Q0FpQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5cbi8qKlxuICogQSBwb2xpY3kgbWFuYWdlZCBieSBBV1NcbiAqXG4gKiBGb3IgdGhpcyBtYW5hZ2VkIHBvbGljeSwgeW91IG9ubHkgbmVlZCB0byBrbm93IHRoZSBuYW1lIHRvIGJlIGFibGUgdG8gdXNlIGl0LlxuICpcbiAqIFNvbWUgbWFuYWdlZCBwb2xpY3kgbmFtZXMgc3RhcnQgd2l0aCBcInNlcnZpY2Utcm9sZS9cIiwgc29tZSBzdGFydCB3aXRoXG4gKiBcImpvYi1mdW5jdGlvbi9cIiwgYW5kIHNvbWUgZG9uJ3Qgc3RhcnQgd2l0aCBhbnl0aGluZy4gRG8gaW5jbHVkZSB0aGVcbiAqIHByZWZpeCB3aGVuIGNvbnN0cnVjdGluZyB0aGlzIG9iamVjdC5cbiAqL1xuZXhwb3J0IGNsYXNzIEF3c01hbmFnZWRQb2xpY3kge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IG1hbmFnZWRQb2xpY3lOYW1lOiBzdHJpbmcpIHtcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgQXJuIG9mIHRoaXMgbWFuYWdlZCBwb2xpY3lcbiAgICovXG4gIHB1YmxpYyBnZXQgcG9saWN5QXJuKCk6IHN0cmluZyB7XG4gICAgLy8gdGhlIGFybiBpcyBpbiB0aGUgZm9ybSBvZiAtIGFybjphd3M6aWFtOjphd3M6cG9saWN5Lzxwb2xpY3lOYW1lPlxuICAgIHJldHVybiBjZGsuQXJuVXRpbHMuZnJvbUNvbXBvbmVudHMoe1xuICAgICAgc2VydmljZTogXCJpYW1cIixcbiAgICAgIHJlZ2lvbjogXCJcIiwgLy8gbm8gcmVnaW9uIGZvciBtYW5hZ2VkIHBvbGljeVxuICAgICAgYWNjb3VudDogXCJhd3NcIiwgLy8gdGhlIGFjY291bnQgZm9yIGEgbWFuYWdlZCBwb2xpY3kgaXMgJ2F3cydcbiAgICAgIHJlc291cmNlOiBcInBvbGljeVwiLFxuICAgICAgcmVzb3VyY2VOYW1lOiB0aGlzLm1hbmFnZWRQb2xpY3lOYW1lXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==

@@ -42,3 +42,3 @@ import { Construct, IDependable, PolicyDocument, PolicyPrincipal, PolicyStatement } from '@aws-cdk/cdk';

* @default Uses the logical ID of the policy resource, which is ensured to
* be unique within the stack.
* be unique within the stack.
*/

@@ -45,0 +45,0 @@ policyName?: string;

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

exports.Policy = Policy;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy.js","sourceRoot":"","sources":["policy.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, IDependable, PolicyDocument, PolicyPrincipal, PolicyStatement, Token } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { cloudformation } from './iam.generated';\nimport { Role } from './role';\nimport { User } from './user';\nimport { generatePolicyName, undefinedIfEmpty } from './util';\n\n/**\n * A construct that represents an IAM principal, such as a user, group or role.\n */\nexport interface IPrincipal {\n    /**\n     * The IAM principal of this identity (i.e. AWS principal, service principal, etc).\n     */\n    readonly principal: PolicyPrincipal;\n\n    /**\n     * Adds an IAM statement to the default inline policy associated with this\n     * principal. If a policy doesn't exist, it is created.\n     */\n    addToPolicy(statement: PolicyStatement): void;\n\n    /**\n     * Attaches an inline policy to this principal.\n     * This is the same as calling `policy.addToXxx(principal)`.\n     * @param policy The policy resource to attach to this principal.\n     */\n    attachInlinePolicy(policy: Policy): void;\n\n    /**\n     * Attaches a managed policy to this principal.\n     * @param arn The ARN of the managed policy\n     */\n    attachManagedPolicy(arn: string): void;\n}\n\n/**\n * @deprecated Use IPrincipal\n */\n// tslint:disable-next-line:no-empty-interface\nexport interface IIdentityResource extends IPrincipal { }\n\nexport interface PolicyProps {\n    /**\n     * The name of the policy. If you specify multiple policies for an entity,\n     * specify unique names. For example, if you specify a list of policies for\n     * an IAM role, each policy must have a unique name.\n     *\n     * @default Uses the logical ID of the policy resource, which is ensured to\n     *          be unique within the stack.\n     */\n    policyName?: string;\n\n    /**\n     * Users to attach this policy to.\n     * You can also use `attachToUser(user)` to attach this policy to a user.\n     */\n    users?: User[];\n\n    /**\n     * Roles to attach this policy to.\n     * You can also use `attachToRole(role)` to attach this policy to a role.\n     */\n    roles?: Role[];\n\n    /**\n     * Groups to attach this policy to.\n     * You can also use `attachToGroup(group)` to attach this policy to a group.\n     */\n    groups?: Group[];\n\n    /**\n     * Initial set of permissions to add to this policy document.\n     * You can also use `addPermission(statement)` to add permissions later.\n     */\n    statements?: PolicyStatement[];\n}\n\n/**\n * The AWS::IAM::Policy resource associates an IAM policy with IAM users, roles,\n * or groups. For more information about IAM policies, see [Overview of IAM\n * Policies](http://docs.aws.amazon.com/IAM/latest/UserGuide/policies_overview.html)\n * in the IAM User Guide guide.\n */\nexport class Policy extends Construct implements IDependable {\n    /**\n     * The policy document.\n     */\n    public readonly document = new PolicyDocument();\n\n    /**\n     * The name of this policy.\n     */\n    public readonly policyName: string;\n\n    /**\n     * Lists all the elements consumers should \"depend-on\".\n     */\n    public readonly dependencyElements: IDependable[];\n\n    private readonly roles = new Array<Role>();\n    private readonly users = new Array<User>();\n    private readonly groups = new Array<Group>();\n\n    constructor(parent: Construct, name: string, props: PolicyProps = {}) {\n        super(parent, name);\n\n        const resource = new cloudformation.PolicyResource(this, 'Resource', {\n            policyDocument: this.document,\n            policyName: new Token(() => this.policyName),\n            roles: undefinedIfEmpty(() => this.roles.map(r => r.roleName)),\n            users: undefinedIfEmpty(() => this.users.map(u => u.userName)),\n            groups: undefinedIfEmpty(() => this.groups.map(g => g.groupName)),\n        });\n\n        // generatePolicyName will take the last 128 characters of the logical id since\n        // policy names are limited to 128. the last 8 chars are a stack-unique hash, so\n        // that shouod be sufficient to ensure uniqueness within a principal.\n        this.policyName = props.policyName || generatePolicyName(resource.logicalId);\n        this.dependencyElements = [ resource ];\n\n        if (props.users) {\n            props.users.forEach(u => this.attachToUser(u));\n        }\n\n        if (props.groups) {\n            props.groups.forEach(g => this.attachToGroup(g));\n        }\n\n        if (props.roles) {\n            props.roles.forEach(r => this.attachToRole(r));\n        }\n\n        if (props.statements) {\n            props.statements.forEach(p => this.addStatement(p));\n        }\n    }\n\n    /**\n     * Adds a statement to the policy document.\n     */\n    public addStatement(statement: PolicyStatement) {\n        this.document.addStatement(statement);\n    }\n\n    /**\n     * Attaches this policy to a user.\n     */\n    public attachToUser(user: User) {\n        if (this.users.find(u => u === user)) { return; }\n        this.users.push(user);\n        user.attachInlinePolicy(this);\n    }\n\n    /**\n     * Attaches this policy to a role.\n     */\n    public attachToRole(role: Role) {\n        if (this.roles.find(r => r === role)) { return; }\n        this.roles.push(role);\n        role.attachInlinePolicy(this);\n    }\n\n    /**\n     * Attaches this policy to a group.\n     */\n    public attachToGroup(group: Group) {\n        if (this.groups.find(g => g === group)) { return; }\n        this.groups.push(group);\n        group.attachInlinePolicy(this);\n    }\n\n    public validate(): string[] {\n        const result = new Array<string>();\n\n        // validate that the policy document is not empty\n        if (this.document.isEmpty) {\n            result.push('Policy is empty. You must add statements to the policy');\n        }\n\n        // validate that the policy is attached to at least one principal (role, user or group).\n        if (this.groups.length + this.users.length + this.roles.length === 0) {\n            result.push(`Policy must be attached to at least one principal: user, group or role`);\n        }\n\n        return result;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy.js","sourceRoot":"","sources":["policy.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, IDependable, PolicyDocument, PolicyPrincipal, PolicyStatement, Token } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { cloudformation } from './iam.generated';\nimport { Role } from './role';\nimport { User } from './user';\nimport { generatePolicyName, undefinedIfEmpty } from './util';\n\n/**\n * A construct that represents an IAM principal, such as a user, group or role.\n */\nexport interface IPrincipal {\n  /**\n   * The IAM principal of this identity (i.e. AWS principal, service principal, etc).\n   */\n  readonly principal: PolicyPrincipal;\n\n  /**\n   * Adds an IAM statement to the default inline policy associated with this\n   * principal. If a policy doesn't exist, it is created.\n   */\n  addToPolicy(statement: PolicyStatement): void;\n\n  /**\n   * Attaches an inline policy to this principal.\n   * This is the same as calling `policy.addToXxx(principal)`.\n   * @param policy The policy resource to attach to this principal.\n   */\n  attachInlinePolicy(policy: Policy): void;\n\n  /**\n   * Attaches a managed policy to this principal.\n   * @param arn The ARN of the managed policy\n   */\n  attachManagedPolicy(arn: string): void;\n}\n\n/**\n * @deprecated Use IPrincipal\n */\n// tslint:disable-next-line:no-empty-interface\nexport interface IIdentityResource extends IPrincipal { }\n\nexport interface PolicyProps {\n  /**\n   * The name of the policy. If you specify multiple policies for an entity,\n   * specify unique names. For example, if you specify a list of policies for\n   * an IAM role, each policy must have a unique name.\n   *\n   * @default Uses the logical ID of the policy resource, which is ensured to\n   *      be unique within the stack.\n   */\n  policyName?: string;\n\n  /**\n   * Users to attach this policy to.\n   * You can also use `attachToUser(user)` to attach this policy to a user.\n   */\n  users?: User[];\n\n  /**\n   * Roles to attach this policy to.\n   * You can also use `attachToRole(role)` to attach this policy to a role.\n   */\n  roles?: Role[];\n\n  /**\n   * Groups to attach this policy to.\n   * You can also use `attachToGroup(group)` to attach this policy to a group.\n   */\n  groups?: Group[];\n\n  /**\n   * Initial set of permissions to add to this policy document.\n   * You can also use `addPermission(statement)` to add permissions later.\n   */\n  statements?: PolicyStatement[];\n}\n\n/**\n * The AWS::IAM::Policy resource associates an IAM policy with IAM users, roles,\n * or groups. For more information about IAM policies, see [Overview of IAM\n * Policies](http://docs.aws.amazon.com/IAM/latest/UserGuide/policies_overview.html)\n * in the IAM User Guide guide.\n */\nexport class Policy extends Construct implements IDependable {\n  /**\n   * The policy document.\n   */\n  public readonly document = new PolicyDocument();\n\n  /**\n   * The name of this policy.\n   */\n  public readonly policyName: string;\n\n  /**\n   * Lists all the elements consumers should \"depend-on\".\n   */\n  public readonly dependencyElements: IDependable[];\n\n  private readonly roles = new Array<Role>();\n  private readonly users = new Array<User>();\n  private readonly groups = new Array<Group>();\n\n  constructor(parent: Construct, name: string, props: PolicyProps = {}) {\n    super(parent, name);\n\n    const resource = new cloudformation.PolicyResource(this, 'Resource', {\n      policyDocument: this.document,\n      policyName: new Token(() => this.policyName),\n      roles: undefinedIfEmpty(() => this.roles.map(r => r.roleName)),\n      users: undefinedIfEmpty(() => this.users.map(u => u.userName)),\n      groups: undefinedIfEmpty(() => this.groups.map(g => g.groupName)),\n    });\n\n    // generatePolicyName will take the last 128 characters of the logical id since\n    // policy names are limited to 128. the last 8 chars are a stack-unique hash, so\n    // that shouod be sufficient to ensure uniqueness within a principal.\n    this.policyName = props.policyName || generatePolicyName(resource.logicalId);\n    this.dependencyElements = [ resource ];\n\n    if (props.users) {\n      props.users.forEach(u => this.attachToUser(u));\n    }\n\n    if (props.groups) {\n      props.groups.forEach(g => this.attachToGroup(g));\n    }\n\n    if (props.roles) {\n      props.roles.forEach(r => this.attachToRole(r));\n    }\n\n    if (props.statements) {\n      props.statements.forEach(p => this.addStatement(p));\n    }\n  }\n\n  /**\n   * Adds a statement to the policy document.\n   */\n  public addStatement(statement: PolicyStatement) {\n    this.document.addStatement(statement);\n  }\n\n  /**\n   * Attaches this policy to a user.\n   */\n  public attachToUser(user: User) {\n    if (this.users.find(u => u === user)) { return; }\n    this.users.push(user);\n    user.attachInlinePolicy(this);\n  }\n\n  /**\n   * Attaches this policy to a role.\n   */\n  public attachToRole(role: Role) {\n    if (this.roles.find(r => r === role)) { return; }\n    this.roles.push(role);\n    role.attachInlinePolicy(this);\n  }\n\n  /**\n   * Attaches this policy to a group.\n   */\n  public attachToGroup(group: Group) {\n    if (this.groups.find(g => g === group)) { return; }\n    this.groups.push(group);\n    group.attachInlinePolicy(this);\n  }\n\n  public validate(): string[] {\n    const result = new Array<string>();\n\n    // validate that the policy document is not empty\n    if (this.document.isEmpty) {\n      result.push('Policy is empty. You must add statements to the policy');\n    }\n\n    // validate that the policy is attached to at least one principal (role, user or group).\n    if (this.groups.length + this.users.length + this.roles.length === 0) {\n      result.push(`Policy must be attached to at least one principal: user, group or role`);\n    }\n\n    return result;\n  }\n}\n"]}

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

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["role.ts"],"names":[],"mappings":";;AAAA,sCAAsH;AACtH,mDAAiD;AACjD,qCAAiE;AACjE,iCAA4D;AA+D5D;;;;;GAKG;AACH,MAAa,IAAK,SAAQ,eAAS;IA8B/B,YAAY,MAAiB,EAAE,IAAY,EAAE,KAAgB;QACzD,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAHP,qBAAgB,GAAG,IAAI,uBAAgB,EAAE,CAAC;QAKvD,IAAI,CAAC,gBAAgB,GAAG,sBAAsB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAChE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB,IAAI,EAAG,CAAC;QAExD,0BAA0B,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAExD,MAAM,IAAI,GAAG,IAAI,8BAAc,CAAC,YAAY,CAAC,IAAI,EAAE,UAAU,EAAE;YAC3D,wBAAwB,EAAE,IAAI,CAAC,gBAAuB;YACtD,iBAAiB,EAAE,uBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC;YACjE,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,kBAAkB,EAAE,KAAK,CAAC,qBAAqB;SAClD,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,kBAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,kBAAkB,GAAG,CAAE,IAAI,CAAE,CAAC;IACvC,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,SAA0B;QACzC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,IAAI,CAAC,aAAa,GAAG,IAAI,eAAM,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;YACvD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC5C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACpD;QACD,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACI,mBAAmB,CAAC,GAAW;QAClC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAED;;;OAGG;IACI,kBAAkB,CAAC,MAAc;QACpC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;CACJ;AAlFD,oBAkFC;AAED,SAAS,sBAAsB,CAAC,SAA0B;IACtD,OAAO,IAAI,oBAAc,EAAE;SACtB,YAAY,CAAC,IAAI,qBAAe,EAAE;SAC9B,YAAY,CAAC,SAAS,CAAC;SACvB,SAAS,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC,CAAC;AACpD,CAAC;AAED,SAAS,0BAA0B,CAAC,QAAiB;IACjD,IAAI,QAAQ,KAAK,SAAS,EAAE;QACxB,OAAO;KACV;IAED,IAAI,QAAQ,GAAG,IAAI,IAAI,QAAQ,GAAG,KAAK,EAAE;QACrC,MAAM,IAAI,KAAK,CAAC,gCAAgC,QAAQ,wDAAwD,CAAC,CAAC;KACrH;AACL,CAAC","sourcesContent":["import { ArnPrincipal, Construct, IDependable, PolicyDocument, PolicyPrincipal, PolicyStatement } from '@aws-cdk/cdk';\nimport { cloudformation } from './iam.generated';\nimport { IIdentityResource, IPrincipal, Policy } from './policy';\nimport { AttachedPolicies, undefinedIfEmpty } from './util';\n\nexport interface RoleProps {\n    /**\n     * The IAM principal (i.e. `new ServicePrincipal('sns.amazonaws.com')`)\n     * which can assume this role.\n     *\n     * You can later modify the assume role policy document by accessing it via\n     * the `assumeRolePolicy` property.\n     */\n    assumedBy: PolicyPrincipal;\n\n    /**\n     * A list of ARNs for managed policies associated with this role.\n     * You can add managed policies later using `attachManagedPolicy(arn)`.\n     * @default No managed policies.\n     */\n    managedPolicyArns?: string[];\n\n    /**\n     * The path associated with this role. For information about IAM paths, see\n     * Friendly Names and Paths in IAM User Guide.\n     */\n    path?: string;\n\n    /**\n     * A name for the IAM role. For valid values, see the RoleName parameter for\n     * the CreateRole action in the IAM API Reference. If you don't specify a\n     * name, AWS CloudFormation generates a unique physical ID and uses that ID\n     * for the group name.\n     *\n     * IMPORTANT: If you specify a name, you cannot perform updates that require\n     * replacement of this resource. You can perform updates that require no or\n     * some interruption. If you must replace the resource, specify a new name.\n     *\n     * If you specify a name, you must specify the CAPABILITY_NAMED_IAM value to\n     * acknowledge your template's capabilities. For more information, see\n     * Acknowledging IAM Resources in AWS CloudFormation Templates.\n     */\n    roleName?: string;\n\n    /**\n     * The maximum session duration (in seconds) that you want to set for the\n     * specified role. If you do not specify a value for this setting, the\n     * default maximum of one hour is applied. This setting can have a value\n     * from 1 hour (3600sec) to 12 (43200sec) hours.\n     *\n     * Anyone who assumes the role from the AWS CLI or API can use the\n     * DurationSeconds API parameter or the duration-seconds CLI parameter to\n     * request a longer session. The MaxSessionDuration setting determines the\n     * maximum duration that can be requested using the DurationSeconds\n     * parameter.\n     *\n     * If users don't specify a value for the DurationSeconds parameter, their\n     * security credentials are valid for one hour by default. This applies when\n     * you use the AssumeRole* API operations or the assume-role* CLI operations\n     * but does not apply when you use those operations to create a console URL.\n     *\n     * @link https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html\n     */\n    maxSessionDurationSec?: number;\n}\n\n/**\n * IAM Role\n *\n * Defines an IAM role. The role is created with an assume policy document associated with\n * the specified AWS service principal defined in `serviceAssumeRole`.\n */\nexport class Role extends Construct implements IIdentityResource, IPrincipal, IDependable {\n    /**\n     * The assume role policy document associated with this role.\n     */\n    public readonly assumeRolePolicy?: PolicyDocument;\n\n    /**\n     * Returns the ARN of this role.\n     */\n    public readonly roleArn: string;\n\n    /**\n     * Returns the name of the role.\n     */\n    public readonly roleName: string;\n\n    /**\n     * Returns the ARN of this role.\n     */\n    public readonly principal: PolicyPrincipal;\n\n    /**\n     * Returns the role.\n     */\n    public readonly dependencyElements: IDependable[];\n\n    private defaultPolicy?: Policy;\n    private readonly managedPolicyArns: string[];\n    private readonly attachedPolicies = new AttachedPolicies();\n\n    constructor(parent: Construct, name: string, props: RoleProps) {\n        super(parent, name);\n\n        this.assumeRolePolicy = createAssumeRolePolicy(props.assumedBy);\n        this.managedPolicyArns = props.managedPolicyArns || [ ];\n\n        validateMaxSessionDuration(props.maxSessionDurationSec);\n\n        const role = new cloudformation.RoleResource(this, 'Resource', {\n            assumeRolePolicyDocument: this.assumeRolePolicy as any,\n            managedPolicyArns: undefinedIfEmpty(() => this.managedPolicyArns),\n            path: props.path,\n            roleName: props.roleName,\n            maxSessionDuration: props.maxSessionDurationSec\n        });\n\n        this.roleArn = role.roleArn;\n        this.principal = new ArnPrincipal(this.roleArn);\n        this.roleName = role.roleName;\n        this.dependencyElements = [ role ];\n    }\n\n    /**\n     * Adds a permission to the role's default policy document.\n     * If there is no default policy attached to this role, it will be created.\n     * @param permission The permission statement to add to the policy document\n     */\n    public addToPolicy(statement: PolicyStatement) {\n        if (!this.defaultPolicy) {\n            this.defaultPolicy = new Policy(this, 'DefaultPolicy');\n            this.attachInlinePolicy(this.defaultPolicy);\n            this.dependencyElements.push(this.defaultPolicy);\n        }\n        this.defaultPolicy.addStatement(statement);\n    }\n\n    /**\n     * Attaches a managed policy to this role.\n     * @param arn The ARN of the managed policy to attach.\n     */\n    public attachManagedPolicy(arn: string) {\n        this.managedPolicyArns.push(arn);\n    }\n\n    /**\n     * Attaches a policy to this role.\n     * @param policy The policy to attach\n     */\n    public attachInlinePolicy(policy: Policy) {\n        this.attachedPolicies.attach(policy);\n        policy.attachToRole(this);\n    }\n}\n\nfunction createAssumeRolePolicy(principal: PolicyPrincipal) {\n    return new PolicyDocument()\n        .addStatement(new PolicyStatement()\n            .addPrincipal(principal)\n            .addAction(principal.assumeRoleAction));\n}\n\nfunction validateMaxSessionDuration(duration?: number) {\n    if (duration === undefined) {\n        return;\n    }\n\n    if (duration < 3600 || duration > 43200) {\n        throw new Error(`maxSessionDuration is set to ${duration}, but must be >= 3600sec (1hr) and <= 43200sec (12hrs)`);\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["role.ts"],"names":[],"mappings":";;AAAA,sCAAsH;AACtH,mDAAiD;AACjD,qCAAiE;AACjE,iCAA4D;AA+D5D;;;;;GAKG;AACH,MAAa,IAAK,SAAQ,eAAS;IA8BjC,YAAY,MAAiB,EAAE,IAAY,EAAE,KAAgB;QAC3D,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAHL,qBAAgB,GAAG,IAAI,uBAAgB,EAAE,CAAC;QAKzD,IAAI,CAAC,gBAAgB,GAAG,sBAAsB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAChE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB,IAAI,EAAG,CAAC;QAExD,0BAA0B,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAExD,MAAM,IAAI,GAAG,IAAI,8BAAc,CAAC,YAAY,CAAC,IAAI,EAAE,UAAU,EAAE;YAC7D,wBAAwB,EAAE,IAAI,CAAC,gBAAuB;YACtD,iBAAiB,EAAE,uBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC;YACjE,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,kBAAkB,EAAE,KAAK,CAAC,qBAAqB;SAChD,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,kBAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,kBAAkB,GAAG,CAAE,IAAI,CAAE,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACI,WAAW,CAAC,SAA0B;QAC3C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,IAAI,eAAM,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;YACvD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC5C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAC7C,CAAC;IAED;;;OAGG;IACI,mBAAmB,CAAC,GAAW;QACpC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnC,CAAC;IAED;;;OAGG;IACI,kBAAkB,CAAC,MAAc;QACtC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;CACF;AAlFD,oBAkFC;AAED,SAAS,sBAAsB,CAAC,SAA0B;IACxD,OAAO,IAAI,oBAAc,EAAE;SACxB,YAAY,CAAC,IAAI,qBAAe,EAAE;SAChC,YAAY,CAAC,SAAS,CAAC;SACvB,SAAS,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC,CAAC;AAC9C,CAAC;AAED,SAAS,0BAA0B,CAAC,QAAiB;IACnD,IAAI,QAAQ,KAAK,SAAS,EAAE;QAC1B,OAAO;KACR;IAED,IAAI,QAAQ,GAAG,IAAI,IAAI,QAAQ,GAAG,KAAK,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,gCAAgC,QAAQ,wDAAwD,CAAC,CAAC;KACnH;AACH,CAAC","sourcesContent":["import { ArnPrincipal, Construct, IDependable, PolicyDocument, PolicyPrincipal, PolicyStatement } from '@aws-cdk/cdk';\nimport { cloudformation } from './iam.generated';\nimport { IIdentityResource, IPrincipal, Policy } from './policy';\nimport { AttachedPolicies, undefinedIfEmpty } from './util';\n\nexport interface RoleProps {\n  /**\n   * The IAM principal (i.e. `new ServicePrincipal('sns.amazonaws.com')`)\n   * which can assume this role.\n   *\n   * You can later modify the assume role policy document by accessing it via\n   * the `assumeRolePolicy` property.\n   */\n  assumedBy: PolicyPrincipal;\n\n  /**\n   * A list of ARNs for managed policies associated with this role.\n   * You can add managed policies later using `attachManagedPolicy(arn)`.\n   * @default No managed policies.\n   */\n  managedPolicyArns?: string[];\n\n  /**\n   * The path associated with this role. For information about IAM paths, see\n   * Friendly Names and Paths in IAM User Guide.\n   */\n  path?: string;\n\n  /**\n   * A name for the IAM role. For valid values, see the RoleName parameter for\n   * the CreateRole action in the IAM API Reference. If you don't specify a\n   * name, AWS CloudFormation generates a unique physical ID and uses that ID\n   * for the group name.\n   *\n   * IMPORTANT: If you specify a name, you cannot perform updates that require\n   * replacement of this resource. You can perform updates that require no or\n   * some interruption. If you must replace the resource, specify a new name.\n   *\n   * If you specify a name, you must specify the CAPABILITY_NAMED_IAM value to\n   * acknowledge your template's capabilities. For more information, see\n   * Acknowledging IAM Resources in AWS CloudFormation Templates.\n   */\n  roleName?: string;\n\n  /**\n   * The maximum session duration (in seconds) that you want to set for the\n   * specified role. If you do not specify a value for this setting, the\n   * default maximum of one hour is applied. This setting can have a value\n   * from 1 hour (3600sec) to 12 (43200sec) hours.\n   *\n   * Anyone who assumes the role from the AWS CLI or API can use the\n   * DurationSeconds API parameter or the duration-seconds CLI parameter to\n   * request a longer session. The MaxSessionDuration setting determines the\n   * maximum duration that can be requested using the DurationSeconds\n   * parameter.\n   *\n   * If users don't specify a value for the DurationSeconds parameter, their\n   * security credentials are valid for one hour by default. This applies when\n   * you use the AssumeRole* API operations or the assume-role* CLI operations\n   * but does not apply when you use those operations to create a console URL.\n   *\n   * @link https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html\n   */\n  maxSessionDurationSec?: number;\n}\n\n/**\n * IAM Role\n *\n * Defines an IAM role. The role is created with an assume policy document associated with\n * the specified AWS service principal defined in `serviceAssumeRole`.\n */\nexport class Role extends Construct implements IIdentityResource, IPrincipal, IDependable {\n  /**\n   * The assume role policy document associated with this role.\n   */\n  public readonly assumeRolePolicy?: PolicyDocument;\n\n  /**\n   * Returns the ARN of this role.\n   */\n  public readonly roleArn: string;\n\n  /**\n   * Returns the name of the role.\n   */\n  public readonly roleName: string;\n\n  /**\n   * Returns the ARN of this role.\n   */\n  public readonly principal: PolicyPrincipal;\n\n  /**\n   * Returns the role.\n   */\n  public readonly dependencyElements: IDependable[];\n\n  private defaultPolicy?: Policy;\n  private readonly managedPolicyArns: string[];\n  private readonly attachedPolicies = new AttachedPolicies();\n\n  constructor(parent: Construct, name: string, props: RoleProps) {\n    super(parent, name);\n\n    this.assumeRolePolicy = createAssumeRolePolicy(props.assumedBy);\n    this.managedPolicyArns = props.managedPolicyArns || [ ];\n\n    validateMaxSessionDuration(props.maxSessionDurationSec);\n\n    const role = new cloudformation.RoleResource(this, 'Resource', {\n      assumeRolePolicyDocument: this.assumeRolePolicy as any,\n      managedPolicyArns: undefinedIfEmpty(() => this.managedPolicyArns),\n      path: props.path,\n      roleName: props.roleName,\n      maxSessionDuration: props.maxSessionDurationSec\n    });\n\n    this.roleArn = role.roleArn;\n    this.principal = new ArnPrincipal(this.roleArn);\n    this.roleName = role.roleName;\n    this.dependencyElements = [ role ];\n  }\n\n  /**\n   * Adds a permission to the role's default policy document.\n   * If there is no default policy attached to this role, it will be created.\n   * @param permission The permission statement to add to the policy document\n   */\n  public addToPolicy(statement: PolicyStatement) {\n    if (!this.defaultPolicy) {\n      this.defaultPolicy = new Policy(this, 'DefaultPolicy');\n      this.attachInlinePolicy(this.defaultPolicy);\n      this.dependencyElements.push(this.defaultPolicy);\n    }\n    this.defaultPolicy.addStatement(statement);\n  }\n\n  /**\n   * Attaches a managed policy to this role.\n   * @param arn The ARN of the managed policy to attach.\n   */\n  public attachManagedPolicy(arn: string) {\n    this.managedPolicyArns.push(arn);\n  }\n\n  /**\n   * Attaches a policy to this role.\n   * @param policy The policy to attach\n   */\n  public attachInlinePolicy(policy: Policy) {\n    this.attachedPolicies.attach(policy);\n    policy.attachToRole(this);\n  }\n}\n\nfunction createAssumeRolePolicy(principal: PolicyPrincipal) {\n  return new PolicyDocument()\n    .addStatement(new PolicyStatement()\n      .addPrincipal(principal)\n      .addAction(principal.assumeRoleAction));\n}\n\nfunction validateMaxSessionDuration(duration?: number) {\n  if (duration === undefined) {\n    return;\n  }\n\n  if (duration < 3600 || duration > 43200) {\n    throw new Error(`maxSessionDuration is set to ${duration}, but must be >= 3600sec (1hr) and <= 43200sec (12hrs)`);\n  }\n}\n"]}

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

exports.User = User;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.js","sourceRoot":"","sources":["user.ts"],"names":[],"mappings":";;AAAA,sCAAyF;AAEzF,mDAAiD;AACjD,qCAAiE;AACjE,iCAA4D;AA2D5D,MAAa,IAAK,SAAQ,eAAS;IAsB/B,YAAY,MAAiB,EAAE,IAAY,EAAE,QAAmB,EAAE;QAC9D,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QANP,WAAM,GAAG,IAAI,KAAK,EAAO,CAAC;QAC1B,sBAAiB,GAAG,IAAI,KAAK,EAAU,CAAC;QACxC,qBAAgB,GAAG,IAAI,uBAAgB,EAAE,CAAC;QAMvD,MAAM,IAAI,GAAG,IAAI,8BAAc,CAAC,YAAY,CAAC,IAAI,EAAE,UAAU,EAAE;YAC3D,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,MAAM,EAAE,uBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;YAC3C,iBAAiB,EAAE,uBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC;YACjE,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,YAAY,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;SAC9C,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,kBAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEhD,IAAI,KAAK,CAAC,MAAM,EAAE;YACd,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;SACjD;IACL,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,KAAY;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED;;;OAGG;IACI,mBAAmB,CAAC,GAAW;QAClC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAED;;OAEG;IACI,kBAAkB,CAAC,MAAc;QACpC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,SAA0B;QACzC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,IAAI,CAAC,aAAa,GAAG,IAAI,eAAM,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;YACvD,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;SACzC;QAED,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IAEO,iBAAiB,CAAC,KAAgB;QACtC,IAAI,KAAK,CAAC,QAAQ,EAAE;YAChB,OAAO;gBACH,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,qBAAqB,EAAE,KAAK,CAAC,qBAAqB;aACrD,CAAC;SACL;QAED,IAAI,KAAK,CAAC,qBAAqB,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,yEAAyE,CAAC,CAAC;SAC9F;QAED,OAAO,SAAS,CAAC,CAAC,oBAAoB;IAC1C,CAAC;CACJ;AA3FD,oBA2FC","sourcesContent":["import { ArnPrincipal, Construct, PolicyPrincipal, PolicyStatement } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { cloudformation } from './iam.generated';\nimport { IIdentityResource, IPrincipal, Policy } from './policy';\nimport { AttachedPolicies, undefinedIfEmpty } from './util';\n\nexport interface UserProps {\n    /**\n     * Groups to add this user to. You can also use `addToGroup` to add this\n     * user to a group.\n     */\n    groups?: Group[];\n\n    /**\n     * A list of ARNs for managed policies attacherd to this user.\n     * You can use `addManagedPolicy(arn)` to attach a managed policy to this user.\n     * @default No managed policies.\n     */\n    managedPolicyArns?: any[];\n\n    /**\n     * The path for the user name. For more information about paths, see IAM\n     * Identifiers in the IAM User Guide.\n     */\n    path?: string;\n\n    /**\n     * A name for the IAM user. For valid values, see the UserName parameter for\n     * the CreateUser action in the IAM API Reference. If you don't specify a\n     * name, AWS CloudFormation generates a unique physical ID and uses that ID\n     * for the user name.\n     *\n     * If you specify a name, you cannot perform updates that require\n     * replacement of this resource. You can perform updates that require no or\n     * some interruption. If you must replace the resource, specify a new name.\n     *\n     * If you specify a name, you must specify the CAPABILITY_NAMED_IAM value to\n     * acknowledge your template's capabilities. For more information, see\n     * Acknowledging IAM Resources in AWS CloudFormation Templates.\n     *\n     * @default Generated by CloudFormation (recommended)\n     */\n    userName?: string;\n\n    /**\n     * The password for the user. This is required so the user can access the\n     * AWS Management Console.\n     *\n     * @default User won't be able to access the management console without a password.\n     */\n    password?: string;\n\n    /**\n     * Specifies whether the user is required to set a new password the next\n     * time the user logs in to the AWS Management Console.\n     *\n     * If this is set to 'true', you must also specify \"initialPassword\".\n     *\n     * @default false\n     */\n    passwordResetRequired?: boolean;\n}\n\nexport class User extends Construct implements IIdentityResource, IPrincipal {\n\n    /**\n     * An attribute that represents the user name.\n     */\n    public readonly userName: string;\n\n    /**\n     * An attribute that represents the user's ARN.\n     */\n    public readonly userArn: string;\n\n    /**\n     * Returns the ARN of this user.\n     */\n    public readonly principal: PolicyPrincipal;\n\n    private readonly groups = new Array<any>();\n    private readonly managedPolicyArns = new Array<string>();\n    private readonly attachedPolicies = new AttachedPolicies();\n    private defaultPolicy?: Policy;\n\n    constructor(parent: Construct, name: string, props: UserProps = {}) {\n        super(parent, name);\n\n        const user = new cloudformation.UserResource(this, 'Resource', {\n            userName: props.userName,\n            groups: undefinedIfEmpty(() => this.groups),\n            managedPolicyArns: undefinedIfEmpty(() => this.managedPolicyArns),\n            path: props.path,\n            loginProfile: this.parseLoginProfile(props)\n        });\n\n        this.userName = user.userName;\n        this.userArn = user.userArn;\n        this.principal = new ArnPrincipal(this.userArn);\n\n        if (props.groups) {\n            props.groups.forEach(g => this.addToGroup(g));\n        }\n    }\n\n    /**\n     * Adds this user to a group.\n     */\n    public addToGroup(group: Group) {\n        this.groups.push(group.groupName);\n    }\n\n    /**\n     * Attaches a managed policy to the user.\n     * @param arn The ARN of the managed policy to attach.\n     */\n    public attachManagedPolicy(arn: string) {\n        this.managedPolicyArns.push(arn);\n    }\n\n    /**\n     * Attaches a policy to this user.\n     */\n    public attachInlinePolicy(policy: Policy) {\n        this.attachedPolicies.attach(policy);\n        policy.attachToUser(this);\n    }\n\n    /**\n     * Adds an IAM statement to the default policy.\n     */\n    public addToPolicy(statement: PolicyStatement) {\n        if (!this.defaultPolicy) {\n            this.defaultPolicy = new Policy(this, 'DefaultPolicy');\n            this.defaultPolicy.attachToUser(this);\n        }\n\n        this.defaultPolicy.addStatement(statement);\n    }\n\n    private parseLoginProfile(props: UserProps): cloudformation.UserResource.LoginProfileProperty | undefined {\n        if (props.password) {\n            return {\n                password: props.password,\n                passwordResetRequired: props.passwordResetRequired\n            };\n        }\n\n        if (props.passwordResetRequired) {\n            throw new Error('Cannot set \"passwordResetRequired\" without specifying \"initialPassword\"');\n        }\n\n        return undefined; // no console access\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.js","sourceRoot":"","sources":["user.ts"],"names":[],"mappings":";;AAAA,sCAAyF;AAEzF,mDAAiD;AACjD,qCAAiE;AACjE,iCAA4D;AA2D5D,MAAa,IAAK,SAAQ,eAAS;IAsBjC,YAAY,MAAiB,EAAE,IAAY,EAAE,QAAmB,EAAE;QAChE,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QANL,WAAM,GAAG,IAAI,KAAK,EAAO,CAAC;QAC1B,sBAAiB,GAAG,IAAI,KAAK,EAAU,CAAC;QACxC,qBAAgB,GAAG,IAAI,uBAAgB,EAAE,CAAC;QAMzD,MAAM,IAAI,GAAG,IAAI,8BAAc,CAAC,YAAY,CAAC,IAAI,EAAE,UAAU,EAAE;YAC7D,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,MAAM,EAAE,uBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC;YAC3C,iBAAiB,EAAE,uBAAgB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC;YACjE,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,YAAY,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;SAC5C,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,kBAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEhD,IAAI,KAAK,CAAC,MAAM,EAAE;YAChB,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;SAC/C;IACH,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,KAAY;QAC5B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC;IAED;;;OAGG;IACI,mBAAmB,CAAC,GAAW;QACpC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnC,CAAC;IAED;;OAEG;IACI,kBAAkB,CAAC,MAAc;QACtC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,SAA0B;QAC3C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,IAAI,eAAM,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;YACvD,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;SACvC;QAED,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAC7C,CAAC;IAEO,iBAAiB,CAAC,KAAgB;QACxC,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,OAAO;gBACL,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,qBAAqB,EAAE,KAAK,CAAC,qBAAqB;aACnD,CAAC;SACH;QAED,IAAI,KAAK,CAAC,qBAAqB,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,yEAAyE,CAAC,CAAC;SAC5F;QAED,OAAO,SAAS,CAAC,CAAC,oBAAoB;IACxC,CAAC;CACF;AA3FD,oBA2FC","sourcesContent":["import { ArnPrincipal, Construct, PolicyPrincipal, PolicyStatement } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { cloudformation } from './iam.generated';\nimport { IIdentityResource, IPrincipal, Policy } from './policy';\nimport { AttachedPolicies, undefinedIfEmpty } from './util';\n\nexport interface UserProps {\n  /**\n   * Groups to add this user to. You can also use `addToGroup` to add this\n   * user to a group.\n   */\n  groups?: Group[];\n\n  /**\n   * A list of ARNs for managed policies attacherd to this user.\n   * You can use `addManagedPolicy(arn)` to attach a managed policy to this user.\n   * @default No managed policies.\n   */\n  managedPolicyArns?: any[];\n\n  /**\n   * The path for the user name. For more information about paths, see IAM\n   * Identifiers in the IAM User Guide.\n   */\n  path?: string;\n\n  /**\n   * A name for the IAM user. For valid values, see the UserName parameter for\n   * the CreateUser action in the IAM API Reference. If you don't specify a\n   * name, AWS CloudFormation generates a unique physical ID and uses that ID\n   * for the user name.\n   *\n   * If you specify a name, you cannot perform updates that require\n   * replacement of this resource. You can perform updates that require no or\n   * some interruption. If you must replace the resource, specify a new name.\n   *\n   * If you specify a name, you must specify the CAPABILITY_NAMED_IAM value to\n   * acknowledge your template's capabilities. For more information, see\n   * Acknowledging IAM Resources in AWS CloudFormation Templates.\n   *\n   * @default Generated by CloudFormation (recommended)\n   */\n  userName?: string;\n\n  /**\n   * The password for the user. This is required so the user can access the\n   * AWS Management Console.\n   *\n   * @default User won't be able to access the management console without a password.\n   */\n  password?: string;\n\n  /**\n   * Specifies whether the user is required to set a new password the next\n   * time the user logs in to the AWS Management Console.\n   *\n   * If this is set to 'true', you must also specify \"initialPassword\".\n   *\n   * @default false\n   */\n  passwordResetRequired?: boolean;\n}\n\nexport class User extends Construct implements IIdentityResource, IPrincipal {\n\n  /**\n   * An attribute that represents the user name.\n   */\n  public readonly userName: string;\n\n  /**\n   * An attribute that represents the user's ARN.\n   */\n  public readonly userArn: string;\n\n  /**\n   * Returns the ARN of this user.\n   */\n  public readonly principal: PolicyPrincipal;\n\n  private readonly groups = new Array<any>();\n  private readonly managedPolicyArns = new Array<string>();\n  private readonly attachedPolicies = new AttachedPolicies();\n  private defaultPolicy?: Policy;\n\n  constructor(parent: Construct, name: string, props: UserProps = {}) {\n    super(parent, name);\n\n    const user = new cloudformation.UserResource(this, 'Resource', {\n      userName: props.userName,\n      groups: undefinedIfEmpty(() => this.groups),\n      managedPolicyArns: undefinedIfEmpty(() => this.managedPolicyArns),\n      path: props.path,\n      loginProfile: this.parseLoginProfile(props)\n    });\n\n    this.userName = user.userName;\n    this.userArn = user.userArn;\n    this.principal = new ArnPrincipal(this.userArn);\n\n    if (props.groups) {\n      props.groups.forEach(g => this.addToGroup(g));\n    }\n  }\n\n  /**\n   * Adds this user to a group.\n   */\n  public addToGroup(group: Group) {\n    this.groups.push(group.groupName);\n  }\n\n  /**\n   * Attaches a managed policy to the user.\n   * @param arn The ARN of the managed policy to attach.\n   */\n  public attachManagedPolicy(arn: string) {\n    this.managedPolicyArns.push(arn);\n  }\n\n  /**\n   * Attaches a policy to this user.\n   */\n  public attachInlinePolicy(policy: Policy) {\n    this.attachedPolicies.attach(policy);\n    policy.attachToUser(this);\n  }\n\n  /**\n   * Adds an IAM statement to the default policy.\n   */\n  public addToPolicy(statement: PolicyStatement) {\n    if (!this.defaultPolicy) {\n      this.defaultPolicy = new Policy(this, 'DefaultPolicy');\n      this.defaultPolicy.attachToUser(this);\n    }\n\n    this.defaultPolicy.addStatement(statement);\n  }\n\n  private parseLoginProfile(props: UserProps): cloudformation.UserResource.LoginProfileProperty | undefined {\n    if (props.password) {\n      return {\n        password: props.password,\n        passwordResetRequired: props.passwordResetRequired\n      };\n    }\n\n    if (props.passwordResetRequired) {\n      throw new Error('Cannot set \"passwordResetRequired\" without specifying \"initialPassword\"');\n    }\n\n    return undefined; // no console access\n  }\n}\n"]}

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

exports.AttachedPolicies = AttachedPolicies;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxzQ0FBbUQ7QUFHbkQsTUFBTSxtQkFBbUIsR0FBRyxHQUFHLENBQUM7QUFFaEMsU0FBZ0IsZ0JBQWdCLENBQUksQ0FBWTtJQUM1QyxPQUFPLElBQUkseUJBQW1CLENBQUMsR0FBRyxFQUFFO1FBQ2hDLE1BQU0sS0FBSyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ2xCLE9BQU8sQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDM0QsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDO0FBTEQsNENBS0M7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLGtCQUFrQixDQUFDLFNBQWlCO0lBQ2hELE9BQU8sU0FBUyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDLEVBQUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ3RHLENBQUM7QUFGRCxnREFFQztBQUVEOztHQUVHO0FBQ0gsTUFBYSxnQkFBZ0I7SUFBN0I7UUFDWSxhQUFRLEdBQUcsSUFBSSxLQUFLLEVBQVUsQ0FBQztJQW1CM0MsQ0FBQztJQWpCRzs7Ozs7T0FLRztJQUNJLE1BQU0sQ0FBQyxNQUFjO1FBQ3hCLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssTUFBTSxDQUFDLEVBQUU7WUFDdkMsT0FBTyxDQUFDLG1CQUFtQjtTQUM5QjtRQUVELElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLE1BQU0sQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUM3RCxNQUFNLElBQUksS0FBSyxDQUFDLG1CQUFtQixNQUFNLENBQUMsVUFBVSx1QkFBdUIsQ0FBQyxDQUFDO1NBQ2hGO1FBRUQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDL0IsQ0FBQztDQUNKO0FBcEJELDRDQW9CQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsb3VkRm9ybWF0aW9uVG9rZW4gfSBmcm9tICdAYXdzLWNkay9jZGsnO1xuaW1wb3J0IHsgUG9saWN5IH0gZnJvbSAnLi9wb2xpY3knO1xuXG5jb25zdCBNQVhfUE9MSUNZX05BTUVfTEVOID0gMTI4O1xuXG5leHBvcnQgZnVuY3Rpb24gdW5kZWZpbmVkSWZFbXB0eTxUPihmOiAoKSA9PiBUW10pOiBDbG91ZEZvcm1hdGlvblRva2VuIHtcbiAgICByZXR1cm4gbmV3IENsb3VkRm9ybWF0aW9uVG9rZW4oKCkgPT4ge1xuICAgICAgICBjb25zdCBhcnJheSA9IGYoKTtcbiAgICAgICAgcmV0dXJuIChhcnJheSAmJiBhcnJheS5sZW5ndGggPiAwKSA/IGFycmF5IDogdW5kZWZpbmVkO1xuICAgIH0pO1xufVxuXG4vKipcbiAqIFVzZWQgdG8gZ2VuZXJhdGUgYSB1bmlxdWUgcG9saWN5IG5hbWUgYmFzZWQgb24gdGhlIHBvbGljeSByZXNvdXJjZSBjb25zdHJ1Y3QuXG4gKiBUaGUgbG9naWNhbCBJRCBvZiB0aGUgcmVzb3VyY2UgaXMgYSBncmVhdCBjYW5kaWRhdGUgYXMgbG9uZyBhcyBpdCBkb2Vzbid0IGV4Y2VlZFxuICogMTI4IGNoYXJhY3RlcnMsIHNvIHdlIHRha2UgdGhlIGxhc3QgMTI4IGNoYXJhY3RlcnMgKGluIG9yZGVyIHRvIG1ha2Ugc3VyZSB0aGUgaGFzaFxuICogaXMgdGhlcmUpLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVQb2xpY3lOYW1lKGxvZ2ljYWxJZDogc3RyaW5nKSB7XG4gICAgcmV0dXJuIGxvZ2ljYWxJZC5zdWJzdHJpbmcoTWF0aC5tYXgobG9naWNhbElkLmxlbmd0aCAtIE1BWF9QT0xJQ1lfTkFNRV9MRU4sIDApLCBsb2dpY2FsSWQubGVuZ3RoKTtcbn1cblxuLyoqXG4gKiBIZWxwZXIgY2xhc3MgdGhhdCBtYWludGFpbnMgdGhlIHNldCBvZiBhdHRhY2hlZCBwb2xpY2llcyBmb3IgYSBwcmluY2lwYWwuXG4gKi9cbmV4cG9ydCBjbGFzcyBBdHRhY2hlZFBvbGljaWVzIHtcbiAgICBwcml2YXRlIHBvbGljaWVzID0gbmV3IEFycmF5PFBvbGljeT4oKTtcblxuICAgIC8qKlxuICAgICAqIEFkZHMgYSBwb2xpY3kgdG8gdGhlIGxpc3Qgb2YgYXR0YWNoZWQgcG9saWNpZXMuXG4gICAgICpcbiAgICAgKiBJZiB0aGlzIHBvbGljeSBpcyBhbHJlYWR5LCBhdHRhY2hlZCwgcmV0dXJucyBmYWxzZS5cbiAgICAgKiBJZiB0aGVyZSBpcyBhbm90aGVyIHBvbGljeSBhdHRhY2hlZCB3aXRoIHRoZSBzYW1lIG5hbWUsIHRocm93cyBhbiBleGNlcHRpb24uXG4gICAgICovXG4gICAgcHVibGljIGF0dGFjaChwb2xpY3k6IFBvbGljeSkge1xuICAgICAgICBpZiAodGhpcy5wb2xpY2llcy5maW5kKHAgPT4gcCA9PT0gcG9saWN5KSkge1xuICAgICAgICAgICAgcmV0dXJuOyAvLyBhbHJlYWR5IGF0dGFjaGVkXG4gICAgICAgIH1cblxuICAgICAgICBpZiAodGhpcy5wb2xpY2llcy5maW5kKHAgPT4gcC5wb2xpY3lOYW1lID09PSBwb2xpY3kucG9saWN5TmFtZSkpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgQSBwb2xpY3kgbmFtZWQgXCIke3BvbGljeS5wb2xpY3lOYW1lfVwiIGlzIGFscmVhZHkgYXR0YWNoZWRgKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMucG9saWNpZXMucHVzaChwb2xpY3kpO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxzQ0FBbUQ7QUFHbkQsTUFBTSxtQkFBbUIsR0FBRyxHQUFHLENBQUM7QUFFaEMsU0FBZ0IsZ0JBQWdCLENBQUksQ0FBWTtJQUM5QyxPQUFPLElBQUkseUJBQW1CLENBQUMsR0FBRyxFQUFFO1FBQ2xDLE1BQU0sS0FBSyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ2xCLE9BQU8sQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDekQsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBTEQsNENBS0M7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLGtCQUFrQixDQUFDLFNBQWlCO0lBQ2xELE9BQU8sU0FBUyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDLEVBQUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ3BHLENBQUM7QUFGRCxnREFFQztBQUVEOztHQUVHO0FBQ0gsTUFBYSxnQkFBZ0I7SUFBN0I7UUFDVSxhQUFRLEdBQUcsSUFBSSxLQUFLLEVBQVUsQ0FBQztJQW1CekMsQ0FBQztJQWpCQzs7Ozs7T0FLRztJQUNJLE1BQU0sQ0FBQyxNQUFjO1FBQzFCLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssTUFBTSxDQUFDLEVBQUU7WUFDekMsT0FBTyxDQUFDLG1CQUFtQjtTQUM1QjtRQUVELElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLE1BQU0sQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUMvRCxNQUFNLElBQUksS0FBSyxDQUFDLG1CQUFtQixNQUFNLENBQUMsVUFBVSx1QkFBdUIsQ0FBQyxDQUFDO1NBQzlFO1FBRUQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0IsQ0FBQztDQUNGO0FBcEJELDRDQW9CQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsb3VkRm9ybWF0aW9uVG9rZW4gfSBmcm9tICdAYXdzLWNkay9jZGsnO1xuaW1wb3J0IHsgUG9saWN5IH0gZnJvbSAnLi9wb2xpY3knO1xuXG5jb25zdCBNQVhfUE9MSUNZX05BTUVfTEVOID0gMTI4O1xuXG5leHBvcnQgZnVuY3Rpb24gdW5kZWZpbmVkSWZFbXB0eTxUPihmOiAoKSA9PiBUW10pOiBDbG91ZEZvcm1hdGlvblRva2VuIHtcbiAgcmV0dXJuIG5ldyBDbG91ZEZvcm1hdGlvblRva2VuKCgpID0+IHtcbiAgICBjb25zdCBhcnJheSA9IGYoKTtcbiAgICByZXR1cm4gKGFycmF5ICYmIGFycmF5Lmxlbmd0aCA+IDApID8gYXJyYXkgOiB1bmRlZmluZWQ7XG4gIH0pO1xufVxuXG4vKipcbiAqIFVzZWQgdG8gZ2VuZXJhdGUgYSB1bmlxdWUgcG9saWN5IG5hbWUgYmFzZWQgb24gdGhlIHBvbGljeSByZXNvdXJjZSBjb25zdHJ1Y3QuXG4gKiBUaGUgbG9naWNhbCBJRCBvZiB0aGUgcmVzb3VyY2UgaXMgYSBncmVhdCBjYW5kaWRhdGUgYXMgbG9uZyBhcyBpdCBkb2Vzbid0IGV4Y2VlZFxuICogMTI4IGNoYXJhY3RlcnMsIHNvIHdlIHRha2UgdGhlIGxhc3QgMTI4IGNoYXJhY3RlcnMgKGluIG9yZGVyIHRvIG1ha2Ugc3VyZSB0aGUgaGFzaFxuICogaXMgdGhlcmUpLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVQb2xpY3lOYW1lKGxvZ2ljYWxJZDogc3RyaW5nKSB7XG4gIHJldHVybiBsb2dpY2FsSWQuc3Vic3RyaW5nKE1hdGgubWF4KGxvZ2ljYWxJZC5sZW5ndGggLSBNQVhfUE9MSUNZX05BTUVfTEVOLCAwKSwgbG9naWNhbElkLmxlbmd0aCk7XG59XG5cbi8qKlxuICogSGVscGVyIGNsYXNzIHRoYXQgbWFpbnRhaW5zIHRoZSBzZXQgb2YgYXR0YWNoZWQgcG9saWNpZXMgZm9yIGEgcHJpbmNpcGFsLlxuICovXG5leHBvcnQgY2xhc3MgQXR0YWNoZWRQb2xpY2llcyB7XG4gIHByaXZhdGUgcG9saWNpZXMgPSBuZXcgQXJyYXk8UG9saWN5PigpO1xuXG4gIC8qKlxuICAgKiBBZGRzIGEgcG9saWN5IHRvIHRoZSBsaXN0IG9mIGF0dGFjaGVkIHBvbGljaWVzLlxuICAgKlxuICAgKiBJZiB0aGlzIHBvbGljeSBpcyBhbHJlYWR5LCBhdHRhY2hlZCwgcmV0dXJucyBmYWxzZS5cbiAgICogSWYgdGhlcmUgaXMgYW5vdGhlciBwb2xpY3kgYXR0YWNoZWQgd2l0aCB0aGUgc2FtZSBuYW1lLCB0aHJvd3MgYW4gZXhjZXB0aW9uLlxuICAgKi9cbiAgcHVibGljIGF0dGFjaChwb2xpY3k6IFBvbGljeSkge1xuICAgIGlmICh0aGlzLnBvbGljaWVzLmZpbmQocCA9PiBwID09PSBwb2xpY3kpKSB7XG4gICAgICByZXR1cm47IC8vIGFscmVhZHkgYXR0YWNoZWRcbiAgICB9XG5cbiAgICBpZiAodGhpcy5wb2xpY2llcy5maW5kKHAgPT4gcC5wb2xpY3lOYW1lID09PSBwb2xpY3kucG9saWN5TmFtZSkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgQSBwb2xpY3kgbmFtZWQgXCIke3BvbGljeS5wb2xpY3lOYW1lfVwiIGlzIGFscmVhZHkgYXR0YWNoZWRgKTtcbiAgICB9XG5cbiAgICB0aGlzLnBvbGljaWVzLnB1c2gocG9saWN5KTtcbiAgfVxufVxuIl19
{
"name": "@aws-cdk/aws-iam",
"version": "0.9.2",
"version": "0.10.0",
"description": "CDK routines for easily assigning correct and minimal IAM permissions",

@@ -57,12 +57,12 @@ "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/cdk": "^0.9.2"
"@aws-cdk/cdk": "^0.10.0"
},
"homepage": "https://github.com/awslabs/aws-cdk"
}

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

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

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

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

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

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

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5ncm91cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZ3JvdXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHNDQUEwQztBQUUxQyxnQ0FBcUM7QUFFckMsaUJBQVM7SUFDTCxlQUFlLENBQUMsSUFBVTtRQUN0QixNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsRUFBRSxDQUFDO1FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4QyxJQUFJLFdBQUssQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDNUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUU7WUFDckQsU0FBUyxFQUFFLEVBQUUsZUFBZSxFQUFFLEVBQUUsSUFBSSxFQUFFLGlCQUFpQixFQUFFLEVBQUU7U0FDOUQsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hCLENBQUM7SUFFRCxpRkFBaUYsQ0FBQyxJQUFVO1FBQ3hGLE1BQU0sR0FBRyxHQUFHLElBQUksU0FBRyxFQUFFLENBQUM7UUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3hDLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxDQUFDLEtBQUssRUFBRSxTQUFTLENBQUMsQ0FBQztRQUMxQyxNQUFNLEtBQUssR0FBRyxJQUFJLFVBQUksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDdkMsTUFBTSxLQUFLLEdBQUcsSUFBSSxVQUFJLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQ3ZDLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVyQixJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFLFNBQVMsRUFDaEUsRUFBRSxlQUFlLEVBQUUsRUFBRSxJQUFJLEVBQUUsaUJBQWlCLEVBQUU7Z0JBQzVDLGFBQWEsRUFDWixFQUFFLElBQUksRUFBRSxnQkFBZ0I7b0JBQ3RCLFVBQVUsRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFFLEVBQUUsR0FBRyxFQUFFLGlCQUFpQixFQUFFLENBQUUsRUFBRSxFQUFFO2dCQUMzRCxhQUFhLEVBQ1osRUFBRSxJQUFJLEVBQUUsZ0JBQWdCO29CQUN0QixVQUFVLEVBQUUsRUFBRSxNQUFNLEVBQUUsQ0FBRSxFQUFFLEdBQUcsRUFBRSxpQkFBaUIsRUFBRSxDQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZFLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFwcCwgU3RhY2sgfSBmcm9tICdAYXdzLWNkay9jZGsnO1xuaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEdyb3VwLCBVc2VyIH0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0ID0ge1xuICAgICdkZWZhdWx0IGdyb3VwJyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbiAgICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCAnTXlTdGFjaycpO1xuICAgICAgICBuZXcgR3JvdXAoc3RhY2ssICdNeUdyb3VwJyk7XG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKGFwcC5zeW50aGVzaXplU3RhY2soc3RhY2submFtZSkudGVtcGxhdGUsIHtcbiAgICAgICAgICAgIFJlc291cmNlczogeyBNeUdyb3VwQ0JBNTRCMUI6IHsgVHlwZTogJ0FXUzo6SUFNOjpHcm91cCcgfSB9XG4gICAgICAgIH0pO1xuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxuXG4gICAgJ3VzZXJzIGNhbiBiZSBhZGRlZCB0byB0aGUgZ3JvdXAgZWl0aGVyIHZpYSBgdXNlci5hZGRUb0dyb3VwYCBvciBgZ3JvdXAuYWRkVXNlcmAnKHRlc3Q6IFRlc3QpIHtcbiAgICAgICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgICAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdNeVN0YWNrJyk7XG4gICAgICAgIGNvbnN0IGdyb3VwID0gbmV3IEdyb3VwKHN0YWNrLCAnTXlHcm91cCcpO1xuICAgICAgICBjb25zdCB1c2VyMSA9IG5ldyBVc2VyKHN0YWNrLCAnVXNlcjEnKTtcbiAgICAgICAgY29uc3QgdXNlcjIgPSBuZXcgVXNlcihzdGFjaywgJ1VzZXIyJyk7XG4gICAgICAgIHVzZXIxLmFkZFRvR3JvdXAoZ3JvdXApO1xuICAgICAgICBncm91cC5hZGRVc2VyKHVzZXIyKTtcblxuICAgICAgICB0ZXN0LmRlZXBFcXVhbChhcHAuc3ludGhlc2l6ZVN0YWNrKHN0YWNrLm5hbWUpLnRlbXBsYXRlLCB7IFJlc291cmNlczpcbiAgICAgICAgICAgIHsgTXlHcm91cENCQTU0QjFCOiB7IFR5cGU6ICdBV1M6OklBTTo6R3JvdXAnIH0sXG4gICAgICAgICAgICAgIFVzZXIxRTI3OEE3MzY6XG4gICAgICAgICAgICAgICB7IFR5cGU6ICdBV1M6OklBTTo6VXNlcicsXG4gICAgICAgICAgICAgICAgIFByb3BlcnRpZXM6IHsgR3JvdXBzOiBbIHsgUmVmOiAnTXlHcm91cENCQTU0QjFCJyB9IF0gfSB9LFxuICAgICAgICAgICAgICBVc2VyMjFGMTQ4NkQxOlxuICAgICAgICAgICAgICAgeyBUeXBlOiAnQVdTOjpJQU06OlVzZXInLFxuICAgICAgICAgICAgICAgICBQcm9wZXJ0aWVzOiB7IEdyb3VwczogWyB7IFJlZjogJ015R3JvdXBDQkE1NEIxQicgfSBdIH0gfSB9IH0pO1xuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5ncm91cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QuZ3JvdXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHNDQUEwQztBQUUxQyxnQ0FBcUM7QUFFckMsaUJBQVM7SUFDUCxlQUFlLENBQUMsSUFBVTtRQUN4QixNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsRUFBRSxDQUFDO1FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4QyxJQUFJLFdBQUssQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDNUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUU7WUFDdkQsU0FBUyxFQUFFLEVBQUUsZUFBZSxFQUFFLEVBQUUsSUFBSSxFQUFFLGlCQUFpQixFQUFFLEVBQUU7U0FDNUQsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVELGlGQUFpRixDQUFDLElBQVU7UUFDMUYsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDeEMsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQzFDLE1BQU0sS0FBSyxHQUFHLElBQUksVUFBSSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN2QyxNQUFNLEtBQUssR0FBRyxJQUFJLFVBQUksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDdkMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4QixLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRXJCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsU0FBUyxFQUNsRSxFQUFFLGVBQWUsRUFBRSxFQUFFLElBQUksRUFBRSxpQkFBaUIsRUFBRTtnQkFDNUMsYUFBYSxFQUNaLEVBQUUsSUFBSSxFQUFFLGdCQUFnQjtvQkFDeEIsVUFBVSxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUUsRUFBRSxHQUFHLEVBQUUsaUJBQWlCLEVBQUUsQ0FBRSxFQUFFLEVBQUU7Z0JBQ3pELGFBQWEsRUFDWixFQUFFLElBQUksRUFBRSxnQkFBZ0I7b0JBQ3hCLFVBQVUsRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFFLEVBQUUsR0FBRyxFQUFFLGlCQUFpQixFQUFFLENBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDbkUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIFN0YWNrIH0gZnJvbSAnQGF3cy1jZGsvY2RrJztcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBHcm91cCwgVXNlciB9IGZyb20gJy4uL2xpYic7XG5cbmV4cG9ydCA9IHtcbiAgJ2RlZmF1bHQgZ3JvdXAnKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBhcHAgPSBuZXcgQXBwKCk7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCAnTXlTdGFjaycpO1xuICAgIG5ldyBHcm91cChzdGFjaywgJ015R3JvdXAnKTtcbiAgICB0ZXN0LmRlZXBFcXVhbChhcHAuc3ludGhlc2l6ZVN0YWNrKHN0YWNrLm5hbWUpLnRlbXBsYXRlLCB7XG4gICAgICBSZXNvdXJjZXM6IHsgTXlHcm91cENCQTU0QjFCOiB7IFR5cGU6ICdBV1M6OklBTTo6R3JvdXAnIH0gfVxuICAgIH0pO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICd1c2VycyBjYW4gYmUgYWRkZWQgdG8gdGhlIGdyb3VwIGVpdGhlciB2aWEgYHVzZXIuYWRkVG9Hcm91cGAgb3IgYGdyb3VwLmFkZFVzZXJgJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ015U3RhY2snKTtcbiAgICBjb25zdCBncm91cCA9IG5ldyBHcm91cChzdGFjaywgJ015R3JvdXAnKTtcbiAgICBjb25zdCB1c2VyMSA9IG5ldyBVc2VyKHN0YWNrLCAnVXNlcjEnKTtcbiAgICBjb25zdCB1c2VyMiA9IG5ldyBVc2VyKHN0YWNrLCAnVXNlcjInKTtcbiAgICB1c2VyMS5hZGRUb0dyb3VwKGdyb3VwKTtcbiAgICBncm91cC5hZGRVc2VyKHVzZXIyKTtcblxuICAgIHRlc3QuZGVlcEVxdWFsKGFwcC5zeW50aGVzaXplU3RhY2soc3RhY2submFtZSkudGVtcGxhdGUsIHsgUmVzb3VyY2VzOlxuICAgICAgeyBNeUdyb3VwQ0JBNTRCMUI6IHsgVHlwZTogJ0FXUzo6SUFNOjpHcm91cCcgfSxcbiAgICAgICAgVXNlcjFFMjc4QTczNjpcbiAgICAgICAgIHsgVHlwZTogJ0FXUzo6SUFNOjpVc2VyJyxcbiAgICAgICAgIFByb3BlcnRpZXM6IHsgR3JvdXBzOiBbIHsgUmVmOiAnTXlHcm91cENCQTU0QjFCJyB9IF0gfSB9LFxuICAgICAgICBVc2VyMjFGMTQ4NkQxOlxuICAgICAgICAgeyBUeXBlOiAnQVdTOjpJQU06OlVzZXInLFxuICAgICAgICAgUHJvcGVydGllczogeyBHcm91cHM6IFsgeyBSZWY6ICdNeUdyb3VwQ0JBNTRCMUInIH0gXSB9IH0gfSB9KTtcbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcbn07XG4iXX0=

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5tYW5hZ2VkLXBvbGljeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QubWFuYWdlZC1wb2xpY3kudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLG9DQUFxQztBQUVyQyxnQ0FBMEM7QUFFMUMsaUJBQVM7SUFDTCx1QkFBdUIsQ0FBQyxJQUFVO1FBQzlCLE1BQU0sRUFBRSxHQUFHLElBQUksc0JBQWdCLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUUzRCxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3RDLFVBQVUsRUFBRSxDQUFDLEVBQUUsRUFBRTtvQkFDYixLQUFLO29CQUNMLEdBQUc7b0JBQ0gsRUFBRSxHQUFHLEVBQUUsZ0JBQWdCLEVBQUU7b0JBQ3pCLEdBQUc7b0JBQ0gsS0FBSztvQkFDTCxHQUFHO29CQUNILEVBQUU7b0JBQ0YsR0FBRztvQkFDSCxLQUFLO29CQUNMLEdBQUc7b0JBQ0gsUUFBUTtvQkFDUixHQUFHO29CQUNILHlCQUF5QjtpQkFDNUIsQ0FBQztTQUNMLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBBd3NNYW5hZ2VkUG9saWN5IH0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0ID0ge1xuICAgICdzaW1wbGUgbWFuYWdlZCBwb2xpY3knKHRlc3Q6IFRlc3QpIHtcbiAgICAgICAgY29uc3QgbXAgPSBuZXcgQXdzTWFuYWdlZFBvbGljeShcInNlcnZpY2Utcm9sZS9Tb21lUG9saWN5XCIpO1xuXG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKGNkay5yZXNvbHZlKG1wLnBvbGljeUFybiksIHtcbiAgICAgICAgICAgIFwiRm46OkpvaW5cIjogWycnLCBbXG4gICAgICAgICAgICAgICAgJ2FybicsXG4gICAgICAgICAgICAgICAgJzonLFxuICAgICAgICAgICAgICAgIHsgUmVmOiAnQVdTOjpQYXJ0aXRpb24nIH0sXG4gICAgICAgICAgICAgICAgJzonLFxuICAgICAgICAgICAgICAgICdpYW0nLFxuICAgICAgICAgICAgICAgICc6JyxcbiAgICAgICAgICAgICAgICAnJyxcbiAgICAgICAgICAgICAgICAnOicsXG4gICAgICAgICAgICAgICAgJ2F3cycsXG4gICAgICAgICAgICAgICAgJzonLFxuICAgICAgICAgICAgICAgICdwb2xpY3knLFxuICAgICAgICAgICAgICAgICcvJyxcbiAgICAgICAgICAgICAgICAnc2VydmljZS1yb2xlL1NvbWVQb2xpY3knXG4gICAgICAgICAgICBdXVxuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0LmRvbmUoKTtcbiAgICB9LFxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5tYW5hZ2VkLXBvbGljeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QubWFuYWdlZC1wb2xpY3kudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLG9DQUFxQztBQUVyQyxnQ0FBMEM7QUFFMUMsaUJBQVM7SUFDUCx1QkFBdUIsQ0FBQyxJQUFVO1FBQ2hDLE1BQU0sRUFBRSxHQUFHLElBQUksc0JBQWdCLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUUzRCxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3hDLFVBQVUsRUFBRSxDQUFDLEVBQUUsRUFBRTtvQkFDZixLQUFLO29CQUNMLEdBQUc7b0JBQ0gsRUFBRSxHQUFHLEVBQUUsZ0JBQWdCLEVBQUU7b0JBQ3pCLEdBQUc7b0JBQ0gsS0FBSztvQkFDTCxHQUFHO29CQUNILEVBQUU7b0JBQ0YsR0FBRztvQkFDSCxLQUFLO29CQUNMLEdBQUc7b0JBQ0gsUUFBUTtvQkFDUixHQUFHO29CQUNILHlCQUF5QjtpQkFDMUIsQ0FBQztTQUNILENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEF3c01hbmFnZWRQb2xpY3kgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICdzaW1wbGUgbWFuYWdlZCBwb2xpY3knKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBtcCA9IG5ldyBBd3NNYW5hZ2VkUG9saWN5KFwic2VydmljZS1yb2xlL1NvbWVQb2xpY3lcIik7XG5cbiAgICB0ZXN0LmRlZXBFcXVhbChjZGsucmVzb2x2ZShtcC5wb2xpY3lBcm4pLCB7XG4gICAgICBcIkZuOjpKb2luXCI6IFsnJywgW1xuICAgICAgICAnYXJuJyxcbiAgICAgICAgJzonLFxuICAgICAgICB7IFJlZjogJ0FXUzo6UGFydGl0aW9uJyB9LFxuICAgICAgICAnOicsXG4gICAgICAgICdpYW0nLFxuICAgICAgICAnOicsXG4gICAgICAgICcnLFxuICAgICAgICAnOicsXG4gICAgICAgICdhd3MnLFxuICAgICAgICAnOicsXG4gICAgICAgICdwb2xpY3knLFxuICAgICAgICAnLycsXG4gICAgICAgICdzZXJ2aWNlLXJvbGUvU29tZVBvbGljeSdcbiAgICAgIF1dXG4gICAgfSk7XG5cbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcbn07XG4iXX0=

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.policy.js","sourceRoot":"","sources":["test.policy.ts"],"names":[],"mappings":"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","sourcesContent":["import { App, PolicyStatement, ServicePrincipal, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Role } from '../lib';\nimport { Group } from '../lib/group';\nimport { Policy } from '../lib/policy';\nimport { User } from '../lib/user';\nimport { generatePolicyName } from '../lib/util';\n\nexport = {\n    'fails when policy is empty'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'MyStack');\n        new Policy(stack, 'MyPolicy');\n\n        test.throws(() => app.synthesizeStack(stack.name), /Policy is empty/);\n        test.done();\n    },\n\n    'policy with statements'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'MyStack');\n\n        const policy = new Policy(stack, 'MyPolicy', { policyName: 'MyPolicyName' });\n        policy.addStatement(new PolicyStatement().addResource('*').addAction('sqs:SendMessage'));\n        policy.addStatement(new PolicyStatement().addResource('arn').addAction('sns:Subscribe'));\n\n        const group = new Group(stack, 'MyGroup');\n        group.attachInlinePolicy(policy);\n\n        test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n            { MyPolicy39D66CF6:\n               { Type: 'AWS::IAM::Policy',\n                 Properties:\n                  { Groups: [ { Ref: 'MyGroupCBA54B1B' } ],\n                    PolicyDocument:\n                     { Statement:\n                        [ { Action: 'sqs:SendMessage', Effect: 'Allow', Resource: '*' },\n                          { Action: 'sns:Subscribe', Effect: 'Allow', Resource: 'arn' } ],\n                       Version: '2012-10-17' },\n                    PolicyName: 'MyPolicyName' } },\n              MyGroupCBA54B1B: { Type: 'AWS::IAM::Group' } } });\n        test.done();\n    },\n\n    'policy name can be omitted, in which case the logical id will be used'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'MyStack');\n\n        const policy = new Policy(stack, 'MyPolicy');\n        policy.addStatement(new PolicyStatement().addResource('*').addAction('sqs:SendMessage'));\n        policy.addStatement(new PolicyStatement().addResource('arn').addAction('sns:Subscribe'));\n\n        const user = new User(stack, 'MyUser');\n        user.attachInlinePolicy(policy);\n\n        test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n            { MyPolicy39D66CF6:\n               { Type: 'AWS::IAM::Policy',\n                 Properties:\n                  { PolicyDocument:\n                     { Statement:\n                        [ { Action: 'sqs:SendMessage', Effect: 'Allow', Resource: '*' },\n                          { Action: 'sns:Subscribe', Effect: 'Allow', Resource: 'arn' } ],\n                       Version: '2012-10-17' },\n                    PolicyName: 'MyPolicy39D66CF6',\n                    Users: [ { Ref: 'MyUserDC45028B' } ] } },\n              MyUserDC45028B: { Type: 'AWS::IAM::User' } } });\n        test.done();\n    },\n\n    'policy can be attached users, groups and roles and added permissions via props'(test: Test) {\n        const app = new App();\n\n        const stack = new Stack(app, 'MyStack');\n\n        const user1 = new User(stack, 'User1');\n        const group1 = new Group(stack, 'Group1');\n        const role1 = new Role(stack, 'Role1', {\n            assumedBy: new ServicePrincipal('lambda.amazonaws.com')\n        });\n\n        new Policy(stack, 'MyTestPolicy', {\n            policyName: 'Foo',\n            users: [ user1 ],\n            groups: [ group1 ],\n            roles: [ role1 ],\n            statements: [ new PolicyStatement().addResource('*').addAction('dynamodb:PutItem') ],\n        });\n\n        test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n            { User1E278A736: { Type: 'AWS::IAM::User' },\n              Group1BEBD4686: { Type: 'AWS::IAM::Group' },\n              Role13A5C70C1:\n               { Type: 'AWS::IAM::Role',\n                 Properties:\n                  { AssumeRolePolicyDocument:\n                     { Statement:\n                        [ { Action: 'sts:AssumeRole',\n                            Effect: 'Allow',\n                            Principal: { Service: 'lambda.amazonaws.com' } } ],\n                       Version: '2012-10-17' } } },\n              MyTestPolicy316BDB50:\n               { Type: 'AWS::IAM::Policy',\n                 Properties:\n                  { Groups: [ { Ref: 'Group1BEBD4686' } ],\n                    PolicyDocument:\n                     { Statement:\n                        [ { Action: 'dynamodb:PutItem', Effect: 'Allow', Resource: '*' } ],\n                       Version: '2012-10-17' },\n                    PolicyName: 'Foo',\n                    Roles: [ { Ref: 'Role13A5C70C1' } ],\n                    Users: [ { Ref: 'User1E278A736' } ] } } } });\n\n        test.done();\n    },\n\n    'idempotent if a principal (user/group/role) is attached twice'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'MyStack');\n        const p = new Policy(stack, 'MyPolicy');\n        p.addStatement(new PolicyStatement().addAction('*').addResource('*'));\n\n        const user = new User(stack, 'MyUser');\n        p.attachToUser(user);\n        p.attachToUser(user);\n\n        test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n            { MyPolicy39D66CF6:\n               { Type: 'AWS::IAM::Policy',\n                 Properties:\n                  { PolicyDocument:\n                     { Statement: [ { Action: '*', Effect: 'Allow', Resource: '*' } ],\n                       Version: '2012-10-17' },\n                    PolicyName: 'MyPolicy39D66CF6',\n                    Users: [ { Ref: 'MyUserDC45028B' } ] } },\n              MyUserDC45028B: { Type: 'AWS::IAM::User' } } });\n        test.done();\n    },\n\n    'users, groups, roles and permissions can be added using methods'(test: Test) {\n        const app = new App();\n\n        const stack = new Stack(app, 'MyStack');\n\n        const p = new Policy(stack, 'MyTestPolicy', {\n            policyName: 'Foo',\n        });\n\n        p.attachToUser(new User(stack, 'User1'));\n        p.attachToUser(new User(stack, 'User2'));\n        p.attachToGroup(new Group(stack, 'Group1'));\n        p.attachToRole(new Role(stack, 'Role1', { assumedBy: new ServicePrincipal('lambda.amazonaws.com') }));\n        p.addStatement(new PolicyStatement().addResource('*').addAction('dynamodb:GetItem'));\n\n        test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n            { MyTestPolicy316BDB50:\n               { Type: 'AWS::IAM::Policy',\n                 Properties:\n                  { Groups: [ { Ref: 'Group1BEBD4686' } ],\n                    PolicyDocument:\n                     { Statement:\n                        [ { Action: 'dynamodb:GetItem', Effect: 'Allow', Resource: '*' } ],\n                       Version: '2012-10-17' },\n                    PolicyName: 'Foo',\n                    Roles: [ { Ref: 'Role13A5C70C1' } ],\n                    Users: [ { Ref: 'User1E278A736' }, { Ref: 'User21F1486D1' } ] } },\n              User1E278A736: { Type: 'AWS::IAM::User' },\n              User21F1486D1: { Type: 'AWS::IAM::User' },\n              Group1BEBD4686: { Type: 'AWS::IAM::Group' },\n              Role13A5C70C1:\n               { Type: 'AWS::IAM::Role',\n                 Properties:\n                  { AssumeRolePolicyDocument:\n                     { Statement:\n                        [ { Action: 'sts:AssumeRole',\n                            Effect: 'Allow',\n                            Principal: { Service: 'lambda.amazonaws.com' } } ],\n                       Version: '2012-10-17' } } } } });\n        test.done();\n    },\n\n    'policy can be attached to users, groups or role via methods on the principal'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'MyStack');\n\n        const policy = new Policy(stack, 'MyPolicy');\n        const user = new User(stack, 'MyUser');\n        const group = new Group(stack, 'MyGroup');\n        const role = new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('foo') });\n\n        user.attachInlinePolicy(policy);\n        group.attachInlinePolicy(policy);\n        role.attachInlinePolicy(policy);\n\n        policy.addStatement(new PolicyStatement().addResource('*').addAction('*'));\n\n        test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n            { MyPolicy39D66CF6:\n               { Type: 'AWS::IAM::Policy',\n                 Properties:\n                  { Groups: [ { Ref: 'MyGroupCBA54B1B' } ],\n                    PolicyDocument:\n                     { Statement: [ { Action: '*', Effect: 'Allow', Resource: '*' } ],\n                       Version: '2012-10-17' },\n                    PolicyName: 'MyPolicy39D66CF6',\n                    Roles: [ { Ref: 'MyRoleF48FFE04' } ],\n                    Users: [ { Ref: 'MyUserDC45028B' } ] } },\n              MyUserDC45028B: { Type: 'AWS::IAM::User' },\n              MyGroupCBA54B1B: { Type: 'AWS::IAM::Group' },\n              MyRoleF48FFE04:\n               { Type: 'AWS::IAM::Role',\n                 Properties:\n                  { AssumeRolePolicyDocument:\n                     { Statement:\n                        [ { Action: 'sts:AssumeRole',\n                            Effect: 'Allow',\n                            Principal: { Service: 'foo' } } ],\n                       Version: '2012-10-17' } } } } });\n        test.done();\n    },\n\n    'fails if policy name is not unique within a user/group/role'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'MyStack');\n\n        // create two policies named Foo and attach them both to the same user/group/role\n        const p1 = new Policy(stack, 'P1', { policyName: 'Foo' });\n        const p2 = new Policy(stack, 'P2', { policyName: 'Foo' });\n        const p3 = new Policy(stack, 'P3'); // uses logicalID as name\n\n        const user = new User(stack, 'MyUser');\n        const group = new Group(stack, 'MyGroup');\n        const role = new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('sns.amazonaws.com') });\n\n        p1.attachToUser(user);\n        p1.attachToGroup(group);\n        p1.attachToRole(role);\n\n        // try to attach p2 to all of these and expect to fail\n        test.throws(() => p2.attachToUser(user), /A policy named \"Foo\" is already attached/);\n        test.throws(() => p2.attachToGroup(group), /A policy named \"Foo\" is already attached/);\n        test.throws(() => p2.attachToRole(role), /A policy named \"Foo\" is already attached/);\n\n        p3.attachToUser(user);\n        p3.attachToGroup(group);\n        p3.attachToRole(role);\n\n        test.done();\n    },\n\n    'fails if policy is not attached to a principal'(test: Test) {\n        const app = new App();\n        const stack = new Stack(app, 'MyStack');\n        new Policy(stack, 'MyPolicy');\n        test.throws(() => app.synthesizeStack(stack.name), /Policy must be attached to at least one principal: user, group or role/);\n        test.done();\n    },\n\n    'generated policy name only uses the last 128 characters of the logical id'(test: Test) {\n        test.equal(generatePolicyName('Foo'), 'Foo');\n\n        const logicalId50 = '[' + dup(50 - 2) + ']';\n        test.equal(generatePolicyName(logicalId50), logicalId50);\n\n        const logicalId128 = '[' + dup(128 - 2) + ']';\n        test.equal(generatePolicyName(logicalId128), logicalId128);\n\n        const withPrefix = 'PREFIX' + logicalId128;\n        test.equal(generatePolicyName(withPrefix), logicalId128, 'ensure prefix is omitted');\n\n        test.done();\n\n        function dup(count: number) {\n            let r = '';\n            for (let i = 0; i < count; ++i) {\n                r += 'x';\n            }\n            return r;\n        }\n    }\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.policy.js","sourceRoot":"","sources":["test.policy.ts"],"names":[],"mappings":"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","sourcesContent":["import { App, PolicyStatement, ServicePrincipal, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Role } from '../lib';\nimport { Group } from '../lib/group';\nimport { Policy } from '../lib/policy';\nimport { User } from '../lib/user';\nimport { generatePolicyName } from '../lib/util';\n\nexport = {\n  'fails when policy is empty'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n    new Policy(stack, 'MyPolicy');\n\n    test.throws(() => app.synthesizeStack(stack.name), /Policy is empty/);\n    test.done();\n  },\n\n  'policy with statements'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n\n    const policy = new Policy(stack, 'MyPolicy', { policyName: 'MyPolicyName' });\n    policy.addStatement(new PolicyStatement().addResource('*').addAction('sqs:SendMessage'));\n    policy.addStatement(new PolicyStatement().addResource('arn').addAction('sns:Subscribe'));\n\n    const group = new Group(stack, 'MyGroup');\n    group.attachInlinePolicy(policy);\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n      { MyPolicy39D66CF6:\n         { Type: 'AWS::IAM::Policy',\n         Properties:\n          { Groups: [ { Ref: 'MyGroupCBA54B1B' } ],\n          PolicyDocument:\n           { Statement:\n            [ { Action: 'sqs:SendMessage', Effect: 'Allow', Resource: '*' },\n              { Action: 'sns:Subscribe', Effect: 'Allow', Resource: 'arn' } ],\n             Version: '2012-10-17' },\n          PolicyName: 'MyPolicyName' } },\n        MyGroupCBA54B1B: { Type: 'AWS::IAM::Group' } } });\n    test.done();\n  },\n\n  'policy name can be omitted, in which case the logical id will be used'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n\n    const policy = new Policy(stack, 'MyPolicy');\n    policy.addStatement(new PolicyStatement().addResource('*').addAction('sqs:SendMessage'));\n    policy.addStatement(new PolicyStatement().addResource('arn').addAction('sns:Subscribe'));\n\n    const user = new User(stack, 'MyUser');\n    user.attachInlinePolicy(policy);\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n      { MyPolicy39D66CF6:\n         { Type: 'AWS::IAM::Policy',\n         Properties:\n          { PolicyDocument:\n           { Statement:\n            [ { Action: 'sqs:SendMessage', Effect: 'Allow', Resource: '*' },\n              { Action: 'sns:Subscribe', Effect: 'Allow', Resource: 'arn' } ],\n             Version: '2012-10-17' },\n          PolicyName: 'MyPolicy39D66CF6',\n          Users: [ { Ref: 'MyUserDC45028B' } ] } },\n        MyUserDC45028B: { Type: 'AWS::IAM::User' } } });\n    test.done();\n  },\n\n  'policy can be attached users, groups and roles and added permissions via props'(test: Test) {\n    const app = new App();\n\n    const stack = new Stack(app, 'MyStack');\n\n    const user1 = new User(stack, 'User1');\n    const group1 = new Group(stack, 'Group1');\n    const role1 = new Role(stack, 'Role1', {\n      assumedBy: new ServicePrincipal('lambda.amazonaws.com')\n    });\n\n    new Policy(stack, 'MyTestPolicy', {\n      policyName: 'Foo',\n      users: [ user1 ],\n      groups: [ group1 ],\n      roles: [ role1 ],\n      statements: [ new PolicyStatement().addResource('*').addAction('dynamodb:PutItem') ],\n    });\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n      { User1E278A736: { Type: 'AWS::IAM::User' },\n        Group1BEBD4686: { Type: 'AWS::IAM::Group' },\n        Role13A5C70C1:\n         { Type: 'AWS::IAM::Role',\n         Properties:\n          { AssumeRolePolicyDocument:\n           { Statement:\n            [ { Action: 'sts:AssumeRole',\n              Effect: 'Allow',\n              Principal: { Service: 'lambda.amazonaws.com' } } ],\n             Version: '2012-10-17' } } },\n        MyTestPolicy316BDB50:\n         { Type: 'AWS::IAM::Policy',\n         Properties:\n          { Groups: [ { Ref: 'Group1BEBD4686' } ],\n          PolicyDocument:\n           { Statement:\n            [ { Action: 'dynamodb:PutItem', Effect: 'Allow', Resource: '*' } ],\n             Version: '2012-10-17' },\n          PolicyName: 'Foo',\n          Roles: [ { Ref: 'Role13A5C70C1' } ],\n          Users: [ { Ref: 'User1E278A736' } ] } } } });\n\n    test.done();\n  },\n\n  'idempotent if a principal (user/group/role) is attached twice'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n    const p = new Policy(stack, 'MyPolicy');\n    p.addStatement(new PolicyStatement().addAction('*').addResource('*'));\n\n    const user = new User(stack, 'MyUser');\n    p.attachToUser(user);\n    p.attachToUser(user);\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n      { MyPolicy39D66CF6:\n         { Type: 'AWS::IAM::Policy',\n         Properties:\n          { PolicyDocument:\n           { Statement: [ { Action: '*', Effect: 'Allow', Resource: '*' } ],\n             Version: '2012-10-17' },\n          PolicyName: 'MyPolicy39D66CF6',\n          Users: [ { Ref: 'MyUserDC45028B' } ] } },\n        MyUserDC45028B: { Type: 'AWS::IAM::User' } } });\n    test.done();\n  },\n\n  'users, groups, roles and permissions can be added using methods'(test: Test) {\n    const app = new App();\n\n    const stack = new Stack(app, 'MyStack');\n\n    const p = new Policy(stack, 'MyTestPolicy', {\n      policyName: 'Foo',\n    });\n\n    p.attachToUser(new User(stack, 'User1'));\n    p.attachToUser(new User(stack, 'User2'));\n    p.attachToGroup(new Group(stack, 'Group1'));\n    p.attachToRole(new Role(stack, 'Role1', { assumedBy: new ServicePrincipal('lambda.amazonaws.com') }));\n    p.addStatement(new PolicyStatement().addResource('*').addAction('dynamodb:GetItem'));\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n      { MyTestPolicy316BDB50:\n         { Type: 'AWS::IAM::Policy',\n         Properties:\n          { Groups: [ { Ref: 'Group1BEBD4686' } ],\n          PolicyDocument:\n           { Statement:\n            [ { Action: 'dynamodb:GetItem', Effect: 'Allow', Resource: '*' } ],\n             Version: '2012-10-17' },\n          PolicyName: 'Foo',\n          Roles: [ { Ref: 'Role13A5C70C1' } ],\n          Users: [ { Ref: 'User1E278A736' }, { Ref: 'User21F1486D1' } ] } },\n        User1E278A736: { Type: 'AWS::IAM::User' },\n        User21F1486D1: { Type: 'AWS::IAM::User' },\n        Group1BEBD4686: { Type: 'AWS::IAM::Group' },\n        Role13A5C70C1:\n         { Type: 'AWS::IAM::Role',\n         Properties:\n          { AssumeRolePolicyDocument:\n           { Statement:\n            [ { Action: 'sts:AssumeRole',\n              Effect: 'Allow',\n              Principal: { Service: 'lambda.amazonaws.com' } } ],\n             Version: '2012-10-17' } } } } });\n    test.done();\n  },\n\n  'policy can be attached to users, groups or role via methods on the principal'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n\n    const policy = new Policy(stack, 'MyPolicy');\n    const user = new User(stack, 'MyUser');\n    const group = new Group(stack, 'MyGroup');\n    const role = new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('foo') });\n\n    user.attachInlinePolicy(policy);\n    group.attachInlinePolicy(policy);\n    role.attachInlinePolicy(policy);\n\n    policy.addStatement(new PolicyStatement().addResource('*').addAction('*'));\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, { Resources:\n      { MyPolicy39D66CF6:\n         { Type: 'AWS::IAM::Policy',\n         Properties:\n          { Groups: [ { Ref: 'MyGroupCBA54B1B' } ],\n          PolicyDocument:\n           { Statement: [ { Action: '*', Effect: 'Allow', Resource: '*' } ],\n             Version: '2012-10-17' },\n          PolicyName: 'MyPolicy39D66CF6',\n          Roles: [ { Ref: 'MyRoleF48FFE04' } ],\n          Users: [ { Ref: 'MyUserDC45028B' } ] } },\n        MyUserDC45028B: { Type: 'AWS::IAM::User' },\n        MyGroupCBA54B1B: { Type: 'AWS::IAM::Group' },\n        MyRoleF48FFE04:\n         { Type: 'AWS::IAM::Role',\n         Properties:\n          { AssumeRolePolicyDocument:\n           { Statement:\n            [ { Action: 'sts:AssumeRole',\n              Effect: 'Allow',\n              Principal: { Service: 'foo' } } ],\n             Version: '2012-10-17' } } } } });\n    test.done();\n  },\n\n  'fails if policy name is not unique within a user/group/role'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n\n    // create two policies named Foo and attach them both to the same user/group/role\n    const p1 = new Policy(stack, 'P1', { policyName: 'Foo' });\n    const p2 = new Policy(stack, 'P2', { policyName: 'Foo' });\n    const p3 = new Policy(stack, 'P3'); // uses logicalID as name\n\n    const user = new User(stack, 'MyUser');\n    const group = new Group(stack, 'MyGroup');\n    const role = new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('sns.amazonaws.com') });\n\n    p1.attachToUser(user);\n    p1.attachToGroup(group);\n    p1.attachToRole(role);\n\n    // try to attach p2 to all of these and expect to fail\n    test.throws(() => p2.attachToUser(user), /A policy named \"Foo\" is already attached/);\n    test.throws(() => p2.attachToGroup(group), /A policy named \"Foo\" is already attached/);\n    test.throws(() => p2.attachToRole(role), /A policy named \"Foo\" is already attached/);\n\n    p3.attachToUser(user);\n    p3.attachToGroup(group);\n    p3.attachToRole(role);\n\n    test.done();\n  },\n\n  'fails if policy is not attached to a principal'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n    new Policy(stack, 'MyPolicy');\n    test.throws(() => app.synthesizeStack(stack.name), /Policy must be attached to at least one principal: user, group or role/);\n    test.done();\n  },\n\n  'generated policy name only uses the last 128 characters of the logical id'(test: Test) {\n    test.equal(generatePolicyName('Foo'), 'Foo');\n\n    const logicalId50 = '[' + dup(50 - 2) + ']';\n    test.equal(generatePolicyName(logicalId50), logicalId50);\n\n    const logicalId128 = '[' + dup(128 - 2) + ']';\n    test.equal(generatePolicyName(logicalId128), logicalId128);\n\n    const withPrefix = 'PREFIX' + logicalId128;\n    test.equal(generatePolicyName(withPrefix), logicalId128, 'ensure prefix is omitted');\n\n    test.done();\n\n    function dup(count: number) {\n      let r = '';\n      for (let i = 0; i < count; ++i) {\n        r += 'x';\n      }\n      return r;\n    }\n  }\n};\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.role.js","sourceRoot":"","sources":["test.role.ts"],"names":[],"mappings":";AAAA,4CAAuD;AACvD,sCAAsG;AAEtG,gCAA8B;AAE9B,iBAAS;IACL,cAAc,CAAC,IAAU;QACrB,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAE1B,IAAI,UAAI,CAAC,KAAK,EAAE,QAAQ,EAAE;YACtB,SAAS,EAAE,IAAI,sBAAgB,CAAC,mBAAmB,CAAC;SACvD,CAAC,CAAC;QAEH,eAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAC7B,EAAE,cAAc,EACb,EAAE,IAAI,EAAE,gBAAgB;oBACtB,UAAU,EACT,EAAE,wBAAwB,EACvB,EAAE,SAAS,EACR,CAAE,EAAE,MAAM,EAAE,gBAAgB;oCACxB,MAAM,EAAE,OAAO;oCACf,SAAS,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,EAAE,CAAE;4BACpD,OAAO,EAAE,YAAY,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,4DAA4D,CAAC,IAAU;QACnE,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAE1B,MAAM,IAAI,GAAG,IAAI,UAAI,CAAC,KAAK,EAAE,QAAQ,EAAE;YACnC,SAAS,EAAE,IAAI,sBAAgB,CAAC,mBAAmB,CAAC;SACvD,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,6BAA6B,IAAI,KAAK,CAAC,gBAAgB,EAAE,CAAC,SAAS,CAAC,EAAE,oCAAoC,CAAC,CAAC;QAEtH,IAAI,CAAC,WAAW,CAAC,IAAI,qBAAe,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC;QACxF,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,SAAS,CAAC,2BAA2B,EAAE,yBAAyB,CAAC,CAAC;QAEnG,eAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAC7B,EAAE,cAAc,EACb,EAAE,IAAI,EAAE,gBAAgB;oBACtB,UAAU,EACT,EAAE,wBAAwB,EACvB,EAAE,SAAS,EACR,CAAE,EAAE,MAAM,EAAE,gBAAgB;oCACxB,MAAM,EAAE,OAAO;oCACf,SAAS,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,EAAE,CAAE;4BACpD,OAAO,EAAE,YAAY,EAAE,EAAE,EAAE;gBACpC,2BAA2B,EAC1B,EAAE,IAAI,EAAE,kBAAkB;oBACxB,UAAU,EACT,EAAE,cAAc,EACb,EAAE,SAAS,EACR,CAAE,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAE;4BACpE,OAAO,EAAE,YAAY,EAAE;wBAC1B,UAAU,EAAE,6BAA6B;wBACzC,KAAK,EAAE,CAAE,EAAE,GAAG,EAAE,gBAAgB,EAAE,CAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAC1D,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,8EAA8E,CAAC,IAAU;QACrF,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAE1B,MAAM,IAAI,GAAG,IAAI,UAAI,CAAC,KAAK,EAAE,QAAQ,EAAE;YACnC,SAAS,EAAE,IAAI,sBAAgB,CAAC,SAAS,CAAC;YAC1C,iBAAiB,EAAE,CAAE,UAAU,EAAE,UAAU,CAAE;SAChD,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;QACrC,eAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAC7B,EAAE,cAAc,EACb,EAAE,IAAI,EAAE,gBAAgB;oBACtB,UAAU,EACT,EAAE,wBAAwB,EACvB,EAAE,SAAS,EACR,CAAE,EAAE,MAAM,EAAE,gBAAgB;oCACxB,MAAM,EAAE,OAAO;oCACf,SAAS,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAE;4BAC1C,OAAO,EAAE,YAAY,EAAE;wBAC1B,iBAAiB,EAAE,CAAE,UAAU,EAAE,UAAU,EAAE,UAAU,CAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAC/E,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,gEAAgE,CAAC,IAAU;QACvE,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAC1B,MAAM,IAAI,GAAG,IAAI,UAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,sBAAgB,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAEnF,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAE9C,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAa,CAAC;QAC5D,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;QACxD,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,iDAAiD,CAAC,IAAU;QACxD,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;QAC1B,MAAM,gBAAgB,GAAG,IAAI,wBAAkB,CAC3C,KAAK,EACL,EAAE,YAAY,EAAE,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE,EAClC,qBAAqB,CAAC,CAAC;QAE3B,IAAI,UAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAE3D,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,gBAAgB,EAAE;YAC5C,wBAAwB,EAAE;gBACtB,SAAS,EAAE;oBACP;wBACI,SAAS,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;wBAC/B,SAAS,EAAE;4BACP,YAAY,EAAE,EAAE,GAAG,EAAE,OAAO,EAAE;yBACjC;wBACD,MAAM,EAAE,qBAAqB;wBAC7B,MAAM,EAAE,OAAO;qBAClB;iBACJ;aACJ;SACJ,CAAC,CAAC,CAAC;QAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,oBAAoB,EAAE;QAElB,6BAA6B,CAAC,IAAU;YACpC,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;YAC1B,IAAI,UAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,sBAAgB,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC;YACpF,eAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;gBAClB,SAAS,EAAE;oBACT,cAAc,EAAE;wBACd,IAAI,EAAE,gBAAgB;wBACtB,UAAU,EAAE;4BACV,wBAAwB,EAAE;gCACxB,SAAS,EAAE;oCACT;wCACE,MAAM,EAAE,gBAAgB;wCACxB,MAAM,EAAE,OAAO;wCACf,SAAS,EAAE;4CACT,OAAO,EAAE,mBAAmB;yCAC7B;qCACF;iCACF;gCACD,OAAO,EAAE,YAAY;6BACtB;yBACF;qBACF;iBACF;aACJ,CAAC,CAAC;YACH,IAAI,CAAC,IAAI,EAAE,CAAC;QAChB,CAAC;QAED,2EAA2E,CAAC,IAAU;YAClF,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;YAE1B,IAAI,UAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,qBAAqB,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,sBAAgB,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC;YAEjH,eAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,qBAAY,CAAC,gBAAgB,EAAE;gBAC5C,kBAAkB,EAAE,IAAI;aAC3B,CAAC,CAAC,CAAC;YAEJ,IAAI,CAAC,IAAI,EAAE,CAAC;QAChB,CAAC;QAED,gCAAgC,CAAC,IAAU;YACvC,MAAM,KAAK,GAAG,IAAI,WAAK,EAAE,CAAC;YAE1B,MAAM,SAAS,GAAG,IAAI,sBAAgB,CAAC,KAAK,CAAC,CAAC;YAE9C,IAAI,UAAI,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,qBAAqB,EAAE,IAAI,EAAE,CAAC,CAAC;YACvE,IAAI,UAAI,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,qBAAqB,EAAE,KAAK,EAAE,CAAC,CAAC;YAExE,MAAM,QAAQ,GAAG,CAAC,GAAQ,EAAE,EAAE,CAAC,gCAAgC,GAAG,wDAAwD,CAAC;YAC3H,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,UAAI,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,qBAAqB,EAAE,EAAE,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;YACtG,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,UAAI,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,qBAAqB,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;YAC1G,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,UAAI,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,qBAAqB,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;YAE5G,IAAI,CAAC,IAAI,EAAE,CAAC;QAChB,CAAC;KACJ;CAEJ,CAAC","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport { FederatedPrincipal, PolicyStatement, Resource, ServicePrincipal, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Role } from '../lib';\n\nexport = {\n    'default role'(test: Test) {\n        const stack = new Stack();\n\n        new Role(stack, 'MyRole', {\n            assumedBy: new ServicePrincipal('sns.amazonaws.com')\n        });\n\n        expect(stack).toMatch({ Resources:\n            { MyRoleF48FFE04:\n               { Type: 'AWS::IAM::Role',\n                 Properties:\n                  { AssumeRolePolicyDocument:\n                     { Statement:\n                        [ { Action: 'sts:AssumeRole',\n                            Effect: 'Allow',\n                            Principal: { Service: 'sns.amazonaws.com' } } ],\n                       Version: '2012-10-17' } } } } });\n        test.done();\n    },\n\n    'policy is created automatically when permissions are added'(test: Test) {\n        const stack = new Stack();\n\n        const role = new Role(stack, 'MyRole', {\n            assumedBy: new ServicePrincipal('sns.amazonaws.com')\n        });\n\n        test.ok(!('MyRoleDefaultPolicyA36BE1DD' in stack.toCloudFormation().Resources), 'initially created without a policy');\n\n        role.addToPolicy(new PolicyStatement().addResource('myresource').addAction('myaction'));\n        test.ok(stack.toCloudFormation().Resources.MyRoleDefaultPolicyA36BE1DD, 'policy resource created');\n\n        expect(stack).toMatch({ Resources:\n            { MyRoleF48FFE04:\n               { Type: 'AWS::IAM::Role',\n                 Properties:\n                  { AssumeRolePolicyDocument:\n                     { Statement:\n                        [ { Action: 'sts:AssumeRole',\n                            Effect: 'Allow',\n                            Principal: { Service: 'sns.amazonaws.com' } } ],\n                       Version: '2012-10-17' } } },\n              MyRoleDefaultPolicyA36BE1DD:\n               { Type: 'AWS::IAM::Policy',\n                 Properties:\n                  { PolicyDocument:\n                     { Statement:\n                        [ { Action: 'myaction', Effect: 'Allow', Resource: 'myresource' } ],\n                       Version: '2012-10-17' },\n                    PolicyName: 'MyRoleDefaultPolicyA36BE1DD',\n                    Roles: [ { Ref: 'MyRoleF48FFE04' } ] } } } });\n        test.done();\n    },\n\n    'managed policy arns can be supplied upon initialization and also added later'(test: Test) {\n        const stack = new Stack();\n\n        const role = new Role(stack, 'MyRole', {\n            assumedBy: new ServicePrincipal('service'),\n            managedPolicyArns: [ 'managed1', 'managed2' ]\n        });\n\n        role.attachManagedPolicy('managed3');\n        expect(stack).toMatch({ Resources:\n            { MyRoleF48FFE04:\n               { Type: 'AWS::IAM::Role',\n                 Properties:\n                  { AssumeRolePolicyDocument:\n                     { Statement:\n                        [ { Action: 'sts:AssumeRole',\n                            Effect: 'Allow',\n                            Principal: { Service: 'service' } } ],\n                       Version: '2012-10-17' },\n                    ManagedPolicyArns: [ 'managed1', 'managed2', 'managed3' ] } } } });\n        test.done();\n    },\n\n    'role implements IDependable to allow resources to depend on it'(test: Test) {\n        const stack = new Stack();\n        const role = new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('foo') });\n\n        test.equal(role.dependencyElements.length, 1);\n\n        const roleResource = role.dependencyElements[0] as Resource;\n        test.equal(roleResource.resourceType, 'AWS::IAM::Role');\n        test.done();\n    },\n\n    'federated principal can change AssumeRoleAction'(test: Test) {\n        const stack = new Stack();\n        const cognitoPrincipal = new FederatedPrincipal(\n            'foo',\n            { StringEquals: { key: 'value' } },\n            'sts:AssumeSomething');\n\n        new Role(stack, 'MyRole', { assumedBy: cognitoPrincipal });\n\n        expect(stack).to(haveResource('AWS::IAM::Role', {\n            AssumeRolePolicyDocument: {\n                Statement: [\n                    {\n                        Principal: { Federated: \"foo\" },\n                        Condition: {\n                            StringEquals: { key: \"value\" }\n                        },\n                        Action: \"sts:AssumeSomething\",\n                        Effect: \"Allow\",\n                    }\n                ],\n            }\n        }));\n\n        test.done();\n    },\n\n    'maxSessionDuration': {\n\n        'is not specified by default'(test: Test) {\n            const stack = new Stack();\n            new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('sns.amazonaws.com') });\n            expect(stack).toMatch({\n                Resources: {\n                  MyRoleF48FFE04: {\n                    Type: \"AWS::IAM::Role\",\n                    Properties: {\n                      AssumeRolePolicyDocument: {\n                        Statement: [\n                          {\n                            Action: \"sts:AssumeRole\",\n                            Effect: \"Allow\",\n                            Principal: {\n                              Service: \"sns.amazonaws.com\"\n                            }\n                          }\n                        ],\n                        Version: \"2012-10-17\"\n                      }\n                    }\n                  }\n                }\n            });\n            test.done();\n        },\n\n        'can be used to specify the maximum session duration for assuming the role'(test: Test) {\n            const stack = new Stack();\n\n            new Role(stack, 'MyRole', { maxSessionDurationSec: 3700, assumedBy: new ServicePrincipal('sns.amazonaws.com') });\n\n            expect(stack).to(haveResource('AWS::IAM::Role', {\n                MaxSessionDuration: 3700\n            }));\n\n            test.done();\n        },\n\n        'must be between 3600 and 43200'(test: Test) {\n            const stack = new Stack();\n\n            const assumedBy = new ServicePrincipal('bla');\n\n            new Role(stack, 'MyRole1', { assumedBy, maxSessionDurationSec: 3600 });\n            new Role(stack, 'MyRole2', { assumedBy, maxSessionDurationSec: 43200 });\n\n            const expected = (val: any) => `maxSessionDuration is set to ${val}, but must be >= 3600sec (1hr) and <= 43200sec (12hrs)`;\n            test.throws(() => new Role(stack, 'MyRole3', { assumedBy, maxSessionDurationSec: 60 }), expected(60));\n            test.throws(() => new Role(stack, 'MyRole4', { assumedBy, maxSessionDurationSec: 3599 }), expected(3599));\n            test.throws(() => new Role(stack, 'MyRole5', { assumedBy, maxSessionDurationSec: 43201 }), expected(43201));\n\n            test.done();\n        }\n    }\n\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.role.js","sourceRoot":"","sources":["test.role.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource } from '@aws-cdk/assert';\nimport { FederatedPrincipal, PolicyStatement, Resource, ServicePrincipal, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Role } from '../lib';\n\nexport = {\n  'default role'(test: Test) {\n    const stack = new Stack();\n\n    new Role(stack, 'MyRole', {\n      assumedBy: new ServicePrincipal('sns.amazonaws.com')\n    });\n\n    expect(stack).toMatch({ Resources:\n      { MyRoleF48FFE04:\n         { Type: 'AWS::IAM::Role',\n         Properties:\n          { AssumeRolePolicyDocument:\n           { Statement:\n            [ { Action: 'sts:AssumeRole',\n              Effect: 'Allow',\n              Principal: { Service: 'sns.amazonaws.com' } } ],\n             Version: '2012-10-17' } } } } });\n    test.done();\n  },\n\n  'policy is created automatically when permissions are added'(test: Test) {\n    const stack = new Stack();\n\n    const role = new Role(stack, 'MyRole', {\n      assumedBy: new ServicePrincipal('sns.amazonaws.com')\n    });\n\n    test.ok(!('MyRoleDefaultPolicyA36BE1DD' in stack.toCloudFormation().Resources), 'initially created without a policy');\n\n    role.addToPolicy(new PolicyStatement().addResource('myresource').addAction('myaction'));\n    test.ok(stack.toCloudFormation().Resources.MyRoleDefaultPolicyA36BE1DD, 'policy resource created');\n\n    expect(stack).toMatch({ Resources:\n      { MyRoleF48FFE04:\n         { Type: 'AWS::IAM::Role',\n         Properties:\n          { AssumeRolePolicyDocument:\n           { Statement:\n            [ { Action: 'sts:AssumeRole',\n              Effect: 'Allow',\n              Principal: { Service: 'sns.amazonaws.com' } } ],\n             Version: '2012-10-17' } } },\n        MyRoleDefaultPolicyA36BE1DD:\n         { Type: 'AWS::IAM::Policy',\n         Properties:\n          { PolicyDocument:\n           { Statement:\n            [ { Action: 'myaction', Effect: 'Allow', Resource: 'myresource' } ],\n             Version: '2012-10-17' },\n          PolicyName: 'MyRoleDefaultPolicyA36BE1DD',\n          Roles: [ { Ref: 'MyRoleF48FFE04' } ] } } } });\n    test.done();\n  },\n\n  'managed policy arns can be supplied upon initialization and also added later'(test: Test) {\n    const stack = new Stack();\n\n    const role = new Role(stack, 'MyRole', {\n      assumedBy: new ServicePrincipal('service'),\n      managedPolicyArns: [ 'managed1', 'managed2' ]\n    });\n\n    role.attachManagedPolicy('managed3');\n    expect(stack).toMatch({ Resources:\n      { MyRoleF48FFE04:\n         { Type: 'AWS::IAM::Role',\n         Properties:\n          { AssumeRolePolicyDocument:\n           { Statement:\n            [ { Action: 'sts:AssumeRole',\n              Effect: 'Allow',\n              Principal: { Service: 'service' } } ],\n             Version: '2012-10-17' },\n          ManagedPolicyArns: [ 'managed1', 'managed2', 'managed3' ] } } } });\n    test.done();\n  },\n\n  'role implements IDependable to allow resources to depend on it'(test: Test) {\n    const stack = new Stack();\n    const role = new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('foo') });\n\n    test.equal(role.dependencyElements.length, 1);\n\n    const roleResource = role.dependencyElements[0] as Resource;\n    test.equal(roleResource.resourceType, 'AWS::IAM::Role');\n    test.done();\n  },\n\n  'federated principal can change AssumeRoleAction'(test: Test) {\n    const stack = new Stack();\n    const cognitoPrincipal = new FederatedPrincipal(\n      'foo',\n      { StringEquals: { key: 'value' } },\n      'sts:AssumeSomething');\n\n    new Role(stack, 'MyRole', { assumedBy: cognitoPrincipal });\n\n    expect(stack).to(haveResource('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Principal: { Federated: \"foo\" },\n            Condition: {\n              StringEquals: { key: \"value\" }\n            },\n            Action: \"sts:AssumeSomething\",\n            Effect: \"Allow\",\n          }\n        ],\n      }\n    }));\n\n    test.done();\n  },\n\n  'maxSessionDuration': {\n\n    'is not specified by default'(test: Test) {\n      const stack = new Stack();\n      new Role(stack, 'MyRole', { assumedBy: new ServicePrincipal('sns.amazonaws.com') });\n      expect(stack).toMatch({\n        Resources: {\n          MyRoleF48FFE04: {\n          Type: \"AWS::IAM::Role\",\n          Properties: {\n            AssumeRolePolicyDocument: {\n            Statement: [\n              {\n              Action: \"sts:AssumeRole\",\n              Effect: \"Allow\",\n              Principal: {\n                Service: \"sns.amazonaws.com\"\n              }\n              }\n            ],\n            Version: \"2012-10-17\"\n            }\n          }\n          }\n        }\n      });\n      test.done();\n    },\n\n    'can be used to specify the maximum session duration for assuming the role'(test: Test) {\n      const stack = new Stack();\n\n      new Role(stack, 'MyRole', { maxSessionDurationSec: 3700, assumedBy: new ServicePrincipal('sns.amazonaws.com') });\n\n      expect(stack).to(haveResource('AWS::IAM::Role', {\n        MaxSessionDuration: 3700\n      }));\n\n      test.done();\n    },\n\n    'must be between 3600 and 43200'(test: Test) {\n      const stack = new Stack();\n\n      const assumedBy = new ServicePrincipal('bla');\n\n      new Role(stack, 'MyRole1', { assumedBy, maxSessionDurationSec: 3600 });\n      new Role(stack, 'MyRole2', { assumedBy, maxSessionDurationSec: 43200 });\n\n      const expected = (val: any) => `maxSessionDuration is set to ${val}, but must be >= 3600sec (1hr) and <= 43200sec (12hrs)`;\n      test.throws(() => new Role(stack, 'MyRole3', { assumedBy, maxSessionDurationSec: 60 }), expected(60));\n      test.throws(() => new Role(stack, 'MyRole4', { assumedBy, maxSessionDurationSec: 3599 }), expected(3599));\n      test.throws(() => new Role(stack, 'MyRole5', { assumedBy, maxSessionDurationSec: 43201 }), expected(43201));\n\n      test.done();\n    }\n  }\n\n};\n"]}

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

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC51c2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC51c2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxzQ0FBMEM7QUFFMUMsZ0NBQThCO0FBRTlCLGlCQUFTO0lBQ0wsY0FBYyxDQUFDLElBQVU7UUFDckIsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDeEMsSUFBSSxVQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQzFCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFO1lBQ3JELFNBQVMsRUFBRSxFQUFFLGNBQWMsRUFBRSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxFQUFFO1NBQzVELENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNoQixDQUFDO0lBRUQsNEJBQTRCLENBQUMsSUFBVTtRQUNuQyxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsRUFBRSxDQUFDO1FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4QyxJQUFJLFVBQUksQ0FBQyxLQUFLLEVBQUUsUUFBUSxFQUFFO1lBQ3RCLFFBQVEsRUFBRSxNQUFNO1NBQ25CLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsU0FBUyxFQUNoRSxFQUFFLGNBQWMsRUFDYixFQUFFLElBQUksRUFBRSxnQkFBZ0I7b0JBQ3RCLFVBQVUsRUFBRSxFQUFFLFlBQVksRUFBRSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDbkUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hCLENBQUM7SUFFRCw0REFBNEQsQ0FBQyxJQUFVO1FBQ25FLE1BQU0sR0FBRyxHQUFHLElBQUksU0FBRyxFQUFFLENBQUM7UUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxVQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRSxFQUFFLHFCQUFxQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM5RSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEIsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIFN0YWNrIH0gZnJvbSAnQGF3cy1jZGsvY2RrJztcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBVc2VyIH0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0ID0ge1xuICAgICdkZWZhdWx0IHVzZXInKHRlc3Q6IFRlc3QpIHtcbiAgICAgICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgICAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdNeVN0YWNrJyk7XG4gICAgICAgIG5ldyBVc2VyKHN0YWNrLCAnTXlVc2VyJyk7XG4gICAgICAgIHRlc3QuZGVlcEVxdWFsKGFwcC5zeW50aGVzaXplU3RhY2soc3RhY2submFtZSkudGVtcGxhdGUsIHtcbiAgICAgICAgICAgIFJlc291cmNlczogeyBNeVVzZXJEQzQ1MDI4QjogeyBUeXBlOiAnQVdTOjpJQU06OlVzZXInIH0gfVxuICAgICAgICB9KTtcbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdkZWZhdWx0IHVzZXIgd2l0aCBwYXNzd29yZCcodGVzdDogVGVzdCkge1xuICAgICAgICBjb25zdCBhcHAgPSBuZXcgQXBwKCk7XG4gICAgICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ015U3RhY2snKTtcbiAgICAgICAgbmV3IFVzZXIoc3RhY2ssICdNeVVzZXInLCB7XG4gICAgICAgICAgICBwYXNzd29yZDogJzEyMzQnXG4gICAgICAgIH0pO1xuICAgICAgICB0ZXN0LmRlZXBFcXVhbChhcHAuc3ludGhlc2l6ZVN0YWNrKHN0YWNrLm5hbWUpLnRlbXBsYXRlLCB7IFJlc291cmNlczpcbiAgICAgICAgICAgIHsgTXlVc2VyREM0NTAyOEI6XG4gICAgICAgICAgICAgICB7IFR5cGU6ICdBV1M6OklBTTo6VXNlcicsXG4gICAgICAgICAgICAgICAgIFByb3BlcnRpZXM6IHsgTG9naW5Qcm9maWxlOiB7IFBhc3N3b3JkOiAnMTIzNCcgfSB9IH0gfSB9KTtcbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfSxcblxuICAgICdmYWlscyBpZiByZXNldCBwYXNzd29yZCBpcyByZXF1aXJlZCBidXQgbm8gcGFzc3dvcmQgaXMgc2V0Jyh0ZXN0OiBUZXN0KSB7XG4gICAgICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbiAgICAgICAgY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCAnTXlTdGFjaycpO1xuICAgICAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgVXNlcihzdGFjaywgJ015VXNlcicsIHsgcGFzc3dvcmRSZXNldFJlcXVpcmVkOiB0cnVlIH0pKTtcbiAgICAgICAgdGVzdC5kb25lKCk7XG4gICAgfVxufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC51c2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGVzdC51c2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxzQ0FBMEM7QUFFMUMsZ0NBQThCO0FBRTlCLGlCQUFTO0lBQ1AsY0FBYyxDQUFDLElBQVU7UUFDdkIsTUFBTSxHQUFHLEdBQUcsSUFBSSxTQUFHLEVBQUUsQ0FBQztRQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDeEMsSUFBSSxVQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQzFCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFO1lBQ3ZELFNBQVMsRUFBRSxFQUFFLGNBQWMsRUFBRSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxFQUFFO1NBQzFELENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCw0QkFBNEIsQ0FBQyxJQUFVO1FBQ3JDLE1BQU0sR0FBRyxHQUFHLElBQUksU0FBRyxFQUFFLENBQUM7UUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3hDLElBQUksVUFBSSxDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUU7WUFDeEIsUUFBUSxFQUFFLE1BQU07U0FDakIsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxTQUFTLEVBQ2xFLEVBQUUsY0FBYyxFQUNiLEVBQUUsSUFBSSxFQUFFLGdCQUFnQjtvQkFDeEIsVUFBVSxFQUFFLEVBQUUsWUFBWSxFQUFFLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMvRCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0lBRUQsNERBQTRELENBQUMsSUFBVTtRQUNyRSxNQUFNLEdBQUcsR0FBRyxJQUFJLFNBQUcsRUFBRSxDQUFDO1FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksVUFBSSxDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUUsRUFBRSxxQkFBcUIsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDOUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2QsQ0FBQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBcHAsIFN0YWNrIH0gZnJvbSAnQGF3cy1jZGsvY2RrJztcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBVc2VyIH0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0ID0ge1xuICAnZGVmYXVsdCB1c2VyJyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ015U3RhY2snKTtcbiAgICBuZXcgVXNlcihzdGFjaywgJ015VXNlcicpO1xuICAgIHRlc3QuZGVlcEVxdWFsKGFwcC5zeW50aGVzaXplU3RhY2soc3RhY2submFtZSkudGVtcGxhdGUsIHtcbiAgICAgIFJlc291cmNlczogeyBNeVVzZXJEQzQ1MDI4QjogeyBUeXBlOiAnQVdTOjpJQU06OlVzZXInIH0gfVxuICAgIH0pO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdkZWZhdWx0IHVzZXIgd2l0aCBwYXNzd29yZCcodGVzdDogVGVzdCkge1xuICAgIGNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBTdGFjayhhcHAsICdNeVN0YWNrJyk7XG4gICAgbmV3IFVzZXIoc3RhY2ssICdNeVVzZXInLCB7XG4gICAgICBwYXNzd29yZDogJzEyMzQnXG4gICAgfSk7XG4gICAgdGVzdC5kZWVwRXF1YWwoYXBwLnN5bnRoZXNpemVTdGFjayhzdGFjay5uYW1lKS50ZW1wbGF0ZSwgeyBSZXNvdXJjZXM6XG4gICAgICB7IE15VXNlckRDNDUwMjhCOlxuICAgICAgICAgeyBUeXBlOiAnQVdTOjpJQU06OlVzZXInLFxuICAgICAgICAgUHJvcGVydGllczogeyBMb2dpblByb2ZpbGU6IHsgUGFzc3dvcmQ6ICcxMjM0JyB9IH0gfSB9IH0pO1xuICAgIHRlc3QuZG9uZSgpO1xuICB9LFxuXG4gICdmYWlscyBpZiByZXNldCBwYXNzd29yZCBpcyByZXF1aXJlZCBidXQgbm8gcGFzc3dvcmQgaXMgc2V0Jyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgJ015U3RhY2snKTtcbiAgICB0ZXN0LnRocm93cygoKSA9PiBuZXcgVXNlcihzdGFjaywgJ015VXNlcicsIHsgcGFzc3dvcmRSZXNldFJlcXVpcmVkOiB0cnVlIH0pKTtcbiAgICB0ZXN0LmRvbmUoKTtcbiAgfVxufTtcbiJdfQ==

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc