Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-iam

Package Overview
Dependencies
Maintainers
4
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

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

Comparing version 0.21.0 to 0.22.0

test/test.auto-cross-stack-refs.d.ts

2

lib/group.d.ts

@@ -47,3 +47,3 @@ import { Construct } from '@aws-cdk/cdk';

private defaultPolicy?;
constructor(parent: Construct, name: string, props?: GroupProps);
constructor(scope: Construct, id: string, props?: GroupProps);
/**

@@ -50,0 +50,0 @@ * Attaches a managed policy to this group.

@@ -9,4 +9,4 @@ "use strict";

class Group extends cdk_1.Construct {
constructor(parent, name, props = {}) {
super(parent, name);
constructor(scope, id, props = {}) {
super(scope, id);
this.attachedPolicies = new util_1.AttachedPolicies();

@@ -56,2 +56,2 @@ this.managedPolicies = props.managedPolicyArns || [];

exports.Group = Group;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5QztBQUN6QyxtREFBMkM7QUFDM0MscUNBQThDO0FBQzlDLHVEQUFtRjtBQUVuRixpQ0FBNEQ7QUErQjVELE1BQWEsS0FBTSxTQUFRLGVBQVM7SUFvQmxDLFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsUUFBb0IsRUFBRTtRQUNqRSxLQUFLLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBSkwscUJBQWdCLEdBQUcsSUFBSSx1QkFBZ0IsRUFBRSxDQUFDO1FBTXpELElBQUksQ0FBQyxlQUFlLEdBQUcsS0FBSyxDQUFDLGlCQUFpQixJQUFJLEVBQUUsQ0FBQztRQUVyRCxNQUFNLEtBQUssR0FBRyxJQUFJLHdCQUFRLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUMzQyxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsaUJBQWlCLEVBQUUsdUJBQWdCLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUMvRCxJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7U0FDakIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMvQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksOEJBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVEOzs7T0FHRztJQUNJLG1CQUFtQixDQUFDLEdBQVc7UUFDcEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLGtCQUFrQixDQUFDLE1BQWM7UUFDdEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRDs7T0FFRztJQUNJLE9BQU8sQ0FBQyxJQUFVO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksV0FBVyxDQUFDLFNBQTBCO1FBQzNDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxlQUFNLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBQ3ZELElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3hDO1FBRUQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDN0MsQ0FBQztDQUNGO0FBdkVELHNCQXVFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBDZm5Hcm91cCB9IGZyb20gJy4vaWFtLmdlbmVyYXRlZCc7XG5pbXBvcnQgeyBJUHJpbmNpcGFsLCBQb2xpY3kgfSBmcm9tICcuL3BvbGljeSc7XG5pbXBvcnQgeyBBcm5QcmluY2lwYWwsIFBvbGljeVByaW5jaXBhbCwgUG9saWN5U3RhdGVtZW50IH0gZnJvbSAnLi9wb2xpY3ktZG9jdW1lbnQnO1xuaW1wb3J0IHsgVXNlciB9IGZyb20gJy4vdXNlcic7XG5pbXBvcnQgeyBBdHRhY2hlZFBvbGljaWVzLCB1bmRlZmluZWRJZkVtcHR5IH0gZnJvbSAnLi91dGlsJztcblxuZXhwb3J0IGludGVyZmFjZSBHcm91cFByb3BzIHtcbiAgLyoqXG4gICAqIEEgbmFtZSBmb3IgdGhlIElBTSBncm91cC4gRm9yIHZhbGlkIHZhbHVlcywgc2VlIHRoZSBHcm91cE5hbWUgcGFyYW1ldGVyXG4gICAqIGZvciB0aGUgQ3JlYXRlR3JvdXAgYWN0aW9uIGluIHRoZSBJQU0gQVBJIFJlZmVyZW5jZS4gSWYgeW91IGRvbid0IHNwZWNpZnlcbiAgICogYSBuYW1lLCBBV1MgQ2xvdWRGb3JtYXRpb24gZ2VuZXJhdGVzIGEgdW5pcXVlIHBoeXNpY2FsIElEIGFuZCB1c2VzIHRoYXRcbiAgICogSUQgZm9yIHRoZSBncm91cCBuYW1lLlxuICAgKlxuICAgKiBJZiB5b3Ugc3BlY2lmeSBhIG5hbWUsIHlvdSBtdXN0IHNwZWNpZnkgdGhlIENBUEFCSUxJVFlfTkFNRURfSUFNIHZhbHVlIHRvXG4gICAqIGFja25vd2xlZGdlIHlvdXIgdGVtcGxhdGUncyBjYXBhYmlsaXRpZXMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWVcbiAgICogQWNrbm93bGVkZ2luZyBJQU0gUmVzb3VyY2VzIGluIEFXUyBDbG91ZEZvcm1hdGlvbiBUZW1wbGF0ZXMuXG4gICAqXG4gICAqIEBkZWZhdWx0IEdlbmVyYXRlZCBieSBDbG91ZEZvcm1hdGlvbiAocmVjb21tZW5kZWQpXG4gICAqL1xuICBncm91cE5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBBUk5zIGZvciBtYW5hZ2VkIHBvbGljaWVzIGFzc29jaWF0ZWQgd2l0aCBncm91cC5cbiAgICogQGRlZmF1bHQgTm8gbWFuYWdlZCBwb2xpY2llcy5cbiAgICovXG4gIG1hbmFnZWRQb2xpY3lBcm5zPzogYW55W107XG5cbiAgLyoqXG4gICAqIFRoZSBwYXRoIHRvIHRoZSBncm91cC4gRm9yIG1vcmUgaW5mb3JtYXRpb24gYWJvdXQgcGF0aHMsIHNlZSBbSUFNXG4gICAqIElkZW50aWZpZXJzXShodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9JQU0vbGF0ZXN0L1VzZXJHdWlkZS9pbmRleC5odG1sP1VzaW5nX0lkZW50aWZpZXJzLmh0bWwpXG4gICAqIGluIHRoZSBJQU0gVXNlciBHdWlkZS5cbiAgICovXG4gIHBhdGg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBHcm91cCBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElQcmluY2lwYWwge1xuICAvKipcbiAgICogVGhlIHJ1bnRpbWUgbmFtZSBvZiB0aGlzIGdyb3VwLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGdyb3VwTmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQVJOIG9mIHRoaXMgZ3JvdXAuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZ3JvdXBBcm46IHN0cmluZztcblxuICAvKipcbiAgICogQW4gXCJBV1NcIiBwb2xpY3kgcHJpbmNpcGFsIHRoYXQgcmVwcmVzZW50cyB0aGlzIGdyb3VwLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHByaW5jaXBhbDogUG9saWN5UHJpbmNpcGFsO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgbWFuYWdlZFBvbGljaWVzOiBhbnlbXTtcbiAgcHJpdmF0ZSByZWFkb25seSBhdHRhY2hlZFBvbGljaWVzID0gbmV3IEF0dGFjaGVkUG9saWNpZXMoKTtcbiAgcHJpdmF0ZSBkZWZhdWx0UG9saWN5PzogUG9saWN5O1xuXG4gIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBHcm91cFByb3BzID0ge30pIHtcbiAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuXG4gICAgdGhpcy5tYW5hZ2VkUG9saWNpZXMgPSBwcm9wcy5tYW5hZ2VkUG9saWN5QXJucyB8fCBbXTtcblxuICAgIGNvbnN0IGdyb3VwID0gbmV3IENmbkdyb3VwKHRoaXMsICdSZXNvdXJjZScsIHtcbiAgICAgIGdyb3VwTmFtZTogcHJvcHMuZ3JvdXBOYW1lLFxuICAgICAgbWFuYWdlZFBvbGljeUFybnM6IHVuZGVmaW5lZElmRW1wdHkoKCkgPT4gdGhpcy5tYW5hZ2VkUG9saWNpZXMpLFxuICAgICAgcGF0aDogcHJvcHMucGF0aCxcbiAgICB9KTtcblxuICAgIHRoaXMuZ3JvdXBOYW1lID0gZ3JvdXAuZ3JvdXBOYW1lO1xuICAgIHRoaXMuZ3JvdXBBcm4gPSBncm91cC5ncm91cEFybjtcbiAgICB0aGlzLnByaW5jaXBhbCA9IG5ldyBBcm5QcmluY2lwYWwodGhpcy5ncm91cEFybik7XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBtYW5hZ2VkIHBvbGljeSB0byB0aGlzIGdyb3VwLlxuICAgKiBAcGFyYW0gYXJuIFRoZSBBUk4gb2YgdGhlIG1hbmFnZWQgcG9saWN5IHRvIGF0dGFjaC5cbiAgICovXG4gIHB1YmxpYyBhdHRhY2hNYW5hZ2VkUG9saWN5KGFybjogc3RyaW5nKSB7XG4gICAgdGhpcy5tYW5hZ2VkUG9saWNpZXMucHVzaChhcm4pO1xuICB9XG5cbiAgLyoqXG4gICAqIEF0dGFjaGVzIGEgcG9saWN5IHRvIHRoaXMgZ3JvdXAuXG4gICAqIEBwYXJhbSBwb2xpY3kgVGhlIHBvbGljeSB0byBhdHRhY2guXG4gICAqL1xuICBwdWJsaWMgYXR0YWNoSW5saW5lUG9saWN5KHBvbGljeTogUG9saWN5KSB7XG4gICAgdGhpcy5hdHRhY2hlZFBvbGljaWVzLmF0dGFjaChwb2xpY3kpO1xuICAgIHBvbGljeS5hdHRhY2hUb0dyb3VwKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYSB1c2VyIHRvIHRoaXMgZ3JvdXAuXG4gICAqL1xuICBwdWJsaWMgYWRkVXNlcih1c2VyOiBVc2VyKSB7XG4gICAgdXNlci5hZGRUb0dyb3VwKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYW4gSUFNIHN0YXRlbWVudCB0byB0aGUgZGVmYXVsdCBwb2xpY3kuXG4gICAqL1xuICBwdWJsaWMgYWRkVG9Qb2xpY3koc3RhdGVtZW50OiBQb2xpY3lTdGF0ZW1lbnQpIHtcbiAgICBpZiAoIXRoaXMuZGVmYXVsdFBvbGljeSkge1xuICAgICAgdGhpcy5kZWZhdWx0UG9saWN5ID0gbmV3IFBvbGljeSh0aGlzLCAnRGVmYXVsdFBvbGljeScpO1xuICAgICAgdGhpcy5kZWZhdWx0UG9saWN5LmF0dGFjaFRvR3JvdXAodGhpcyk7XG4gICAgfVxuXG4gICAgdGhpcy5kZWZhdWx0UG9saWN5LmFkZFN0YXRlbWVudChzdGF0ZW1lbnQpO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJncm91cC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHNDQUF5QztBQUN6QyxtREFBMkM7QUFDM0MscUNBQThDO0FBQzlDLHVEQUFtRjtBQUVuRixpQ0FBNEQ7QUErQjVELE1BQWEsS0FBTSxTQUFRLGVBQVM7SUFvQmxDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsUUFBb0IsRUFBRTtRQUM5RCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBSkYscUJBQWdCLEdBQUcsSUFBSSx1QkFBZ0IsRUFBRSxDQUFDO1FBTXpELElBQUksQ0FBQyxlQUFlLEdBQUcsS0FBSyxDQUFDLGlCQUFpQixJQUFJLEVBQUUsQ0FBQztRQUVyRCxNQUFNLEtBQUssR0FBRyxJQUFJLHdCQUFRLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUMzQyxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsaUJBQWlCLEVBQUUsdUJBQWdCLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUMvRCxJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7U0FDakIsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMvQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksOEJBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVEOzs7T0FHRztJQUNJLG1CQUFtQixDQUFDLEdBQVc7UUFDcEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVEOzs7T0FHRztJQUNJLGtCQUFrQixDQUFDLE1BQWM7UUFDdEMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQyxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRDs7T0FFRztJQUNJLE9BQU8sQ0FBQyxJQUFVO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksV0FBVyxDQUFDLFNBQTBCO1FBQzNDLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxlQUFNLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxDQUFDO1lBQ3ZELElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3hDO1FBRUQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDN0MsQ0FBQztDQUNGO0FBdkVELHNCQXVFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBDZm5Hcm91cCB9IGZyb20gJy4vaWFtLmdlbmVyYXRlZCc7XG5pbXBvcnQgeyBJUHJpbmNpcGFsLCBQb2xpY3kgfSBmcm9tICcuL3BvbGljeSc7XG5pbXBvcnQgeyBBcm5QcmluY2lwYWwsIFBvbGljeVByaW5jaXBhbCwgUG9saWN5U3RhdGVtZW50IH0gZnJvbSAnLi9wb2xpY3ktZG9jdW1lbnQnO1xuaW1wb3J0IHsgVXNlciB9IGZyb20gJy4vdXNlcic7XG5pbXBvcnQgeyBBdHRhY2hlZFBvbGljaWVzLCB1bmRlZmluZWRJZkVtcHR5IH0gZnJvbSAnLi91dGlsJztcblxuZXhwb3J0IGludGVyZmFjZSBHcm91cFByb3BzIHtcbiAgLyoqXG4gICAqIEEgbmFtZSBmb3IgdGhlIElBTSBncm91cC4gRm9yIHZhbGlkIHZhbHVlcywgc2VlIHRoZSBHcm91cE5hbWUgcGFyYW1ldGVyXG4gICAqIGZvciB0aGUgQ3JlYXRlR3JvdXAgYWN0aW9uIGluIHRoZSBJQU0gQVBJIFJlZmVyZW5jZS4gSWYgeW91IGRvbid0IHNwZWNpZnlcbiAgICogYSBuYW1lLCBBV1MgQ2xvdWRGb3JtYXRpb24gZ2VuZXJhdGVzIGEgdW5pcXVlIHBoeXNpY2FsIElEIGFuZCB1c2VzIHRoYXRcbiAgICogSUQgZm9yIHRoZSBncm91cCBuYW1lLlxuICAgKlxuICAgKiBJZiB5b3Ugc3BlY2lmeSBhIG5hbWUsIHlvdSBtdXN0IHNwZWNpZnkgdGhlIENBUEFCSUxJVFlfTkFNRURfSUFNIHZhbHVlIHRvXG4gICAqIGFja25vd2xlZGdlIHlvdXIgdGVtcGxhdGUncyBjYXBhYmlsaXRpZXMuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBzZWVcbiAgICogQWNrbm93bGVkZ2luZyBJQU0gUmVzb3VyY2VzIGluIEFXUyBDbG91ZEZvcm1hdGlvbiBUZW1wbGF0ZXMuXG4gICAqXG4gICAqIEBkZWZhdWx0IEdlbmVyYXRlZCBieSBDbG91ZEZvcm1hdGlvbiAocmVjb21tZW5kZWQpXG4gICAqL1xuICBncm91cE5hbWU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBBUk5zIGZvciBtYW5hZ2VkIHBvbGljaWVzIGFzc29jaWF0ZWQgd2l0aCBncm91cC5cbiAgICogQGRlZmF1bHQgTm8gbWFuYWdlZCBwb2xpY2llcy5cbiAgICovXG4gIG1hbmFnZWRQb2xpY3lBcm5zPzogYW55W107XG5cbiAgLyoqXG4gICAqIFRoZSBwYXRoIHRvIHRoZSBncm91cC4gRm9yIG1vcmUgaW5mb3JtYXRpb24gYWJvdXQgcGF0aHMsIHNlZSBbSUFNXG4gICAqIElkZW50aWZpZXJzXShodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9JQU0vbGF0ZXN0L1VzZXJHdWlkZS9pbmRleC5odG1sP1VzaW5nX0lkZW50aWZpZXJzLmh0bWwpXG4gICAqIGluIHRoZSBJQU0gVXNlciBHdWlkZS5cbiAgICovXG4gIHBhdGg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBHcm91cCBleHRlbmRzIENvbnN0cnVjdCBpbXBsZW1lbnRzIElQcmluY2lwYWwge1xuICAvKipcbiAgICogVGhlIHJ1bnRpbWUgbmFtZSBvZiB0aGlzIGdyb3VwLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IGdyb3VwTmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgQVJOIG9mIHRoaXMgZ3JvdXAuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgZ3JvdXBBcm46IHN0cmluZztcblxuICAvKipcbiAgICogQW4gXCJBV1NcIiBwb2xpY3kgcHJpbmNpcGFsIHRoYXQgcmVwcmVzZW50cyB0aGlzIGdyb3VwLlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IHByaW5jaXBhbDogUG9saWN5UHJpbmNpcGFsO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgbWFuYWdlZFBvbGljaWVzOiBhbnlbXTtcbiAgcHJpdmF0ZSByZWFkb25seSBhdHRhY2hlZFBvbGljaWVzID0gbmV3IEF0dGFjaGVkUG9saWNpZXMoKTtcbiAgcHJpdmF0ZSBkZWZhdWx0UG9saWN5PzogUG9saWN5O1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBHcm91cFByb3BzID0ge30pIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy5tYW5hZ2VkUG9saWNpZXMgPSBwcm9wcy5tYW5hZ2VkUG9saWN5QXJucyB8fCBbXTtcblxuICAgIGNvbnN0IGdyb3VwID0gbmV3IENmbkdyb3VwKHRoaXMsICdSZXNvdXJjZScsIHtcbiAgICAgIGdyb3VwTmFtZTogcHJvcHMuZ3JvdXBOYW1lLFxuICAgICAgbWFuYWdlZFBvbGljeUFybnM6IHVuZGVmaW5lZElmRW1wdHkoKCkgPT4gdGhpcy5tYW5hZ2VkUG9saWNpZXMpLFxuICAgICAgcGF0aDogcHJvcHMucGF0aCxcbiAgICB9KTtcblxuICAgIHRoaXMuZ3JvdXBOYW1lID0gZ3JvdXAuZ3JvdXBOYW1lO1xuICAgIHRoaXMuZ3JvdXBBcm4gPSBncm91cC5ncm91cEFybjtcbiAgICB0aGlzLnByaW5jaXBhbCA9IG5ldyBBcm5QcmluY2lwYWwodGhpcy5ncm91cEFybik7XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBtYW5hZ2VkIHBvbGljeSB0byB0aGlzIGdyb3VwLlxuICAgKiBAcGFyYW0gYXJuIFRoZSBBUk4gb2YgdGhlIG1hbmFnZWQgcG9saWN5IHRvIGF0dGFjaC5cbiAgICovXG4gIHB1YmxpYyBhdHRhY2hNYW5hZ2VkUG9saWN5KGFybjogc3RyaW5nKSB7XG4gICAgdGhpcy5tYW5hZ2VkUG9saWNpZXMucHVzaChhcm4pO1xuICB9XG5cbiAgLyoqXG4gICAqIEF0dGFjaGVzIGEgcG9saWN5IHRvIHRoaXMgZ3JvdXAuXG4gICAqIEBwYXJhbSBwb2xpY3kgVGhlIHBvbGljeSB0byBhdHRhY2guXG4gICAqL1xuICBwdWJsaWMgYXR0YWNoSW5saW5lUG9saWN5KHBvbGljeTogUG9saWN5KSB7XG4gICAgdGhpcy5hdHRhY2hlZFBvbGljaWVzLmF0dGFjaChwb2xpY3kpO1xuICAgIHBvbGljeS5hdHRhY2hUb0dyb3VwKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYSB1c2VyIHRvIHRoaXMgZ3JvdXAuXG4gICAqL1xuICBwdWJsaWMgYWRkVXNlcih1c2VyOiBVc2VyKSB7XG4gICAgdXNlci5hZGRUb0dyb3VwKHRoaXMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYW4gSUFNIHN0YXRlbWVudCB0byB0aGUgZGVmYXVsdCBwb2xpY3kuXG4gICAqL1xuICBwdWJsaWMgYWRkVG9Qb2xpY3koc3RhdGVtZW50OiBQb2xpY3lTdGF0ZW1lbnQpIHtcbiAgICBpZiAoIXRoaXMuZGVmYXVsdFBvbGljeSkge1xuICAgICAgdGhpcy5kZWZhdWx0UG9saWN5ID0gbmV3IFBvbGljeSh0aGlzLCAnRGVmYXVsdFBvbGljeScpO1xuICAgICAgdGhpcy5kZWZhdWx0UG9saWN5LmF0dGFjaFRvR3JvdXAodGhpcyk7XG4gICAgfVxuXG4gICAgdGhpcy5kZWZhdWx0UG9saWN5LmFkZFN0YXRlbWVudChzdGF0ZW1lbnQpO1xuICB9XG59XG4iXX0=

@@ -10,3 +10,3 @@ import cdk = require('@aws-cdk/cdk');

*/
userName: string | cdk.Token;
userName: string;
/**

@@ -21,3 +21,3 @@ * ``AWS::IAM::AccessKey.Serial``

*/
status?: string | cdk.Token;
status?: string;
}

@@ -40,7 +40,7 @@ /**

*
* @param parent the ``cdk.Construct`` this ``CfnAccessKey`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnAccessKey``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties: CfnAccessKeyProps);
constructor(scope: cdk.Construct, id: string, props: CfnAccessKeyProps);
readonly propertyOverrides: CfnAccessKeyProps;

@@ -51,51 +51,2 @@ protected renderProperties(properties: any): {

}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-accesskey.html
*/
interface AccessKeyResourceProps {
/**
* ``AWS::IAM::AccessKey.UserName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-accesskey.html#cfn-iam-accesskey-username
*/
userName: string | cdk.Token;
/**
* ``AWS::IAM::AccessKey.Serial``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-accesskey.html#cfn-iam-accesskey-serial
*/
serial?: number | cdk.Token;
/**
* ``AWS::IAM::AccessKey.Status``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-accesskey.html#cfn-iam-accesskey-status
*/
status?: string | cdk.Token;
}
/**
* @deprecated "cloudformation.AccessKeyResource" will be deprecated in a future release in favor of "CfnAccessKey" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-accesskey.html
*/
class AccessKeyResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::AccessKey";
/**
* @cloudformation_attribute SecretAccessKey
*/
readonly accessKeySecretAccessKey: string;
readonly accessKeyId: string;
/**
* Creates a new ``AWS::IAM::AccessKey``.
*
* @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);
readonly propertyOverrides: AccessKeyResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
}
/**

@@ -109,3 +60,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-group.html

*/
groupName?: string | cdk.Token;
groupName?: string;
/**

@@ -120,3 +71,3 @@ * ``AWS::IAM::Group.ManagedPolicyArns``

*/
path?: string | cdk.Token;
path?: string;
/**

@@ -144,7 +95,7 @@ * ``AWS::IAM::Group.Policies``

*
* @param parent the ``cdk.Construct`` this ``CfnGroup`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnGroup``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties?: CfnGroupProps);
constructor(scope: cdk.Construct, id: string, props?: CfnGroupProps);
readonly propertyOverrides: CfnGroupProps;

@@ -169,76 +120,5 @@ protected renderProperties(properties: any): {

*/
policyName: string | cdk.Token;
policyName: string;
}
}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-group.html
*/
interface GroupResourceProps {
/**
* ``AWS::IAM::Group.GroupName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-group.html#cfn-iam-group-groupname
*/
groupName?: string | cdk.Token;
/**
* ``AWS::IAM::Group.ManagedPolicyArns``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-group.html#cfn-iam-group-managepolicyarns
*/
managedPolicyArns?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::Group.Path``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-group.html#cfn-iam-group-path
*/
path?: string | cdk.Token;
/**
* ``AWS::IAM::Group.Policies``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-group.html#cfn-iam-group-policies
*/
policies?: Array<GroupResource.PolicyProperty | cdk.Token> | cdk.Token;
}
/**
* @deprecated "cloudformation.GroupResource" will be deprecated in a future release in favor of "CfnGroup" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-group.html
*/
class GroupResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::Group";
/**
* @cloudformation_attribute Arn
*/
readonly groupArn: string;
readonly groupName: string;
/**
* Creates a new ``AWS::IAM::Group``.
*
* @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);
readonly propertyOverrides: GroupResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
namespace GroupResource {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html
*/
interface PolicyProperty {
/**
* ``GroupResource.PolicyProperty.PolicyDocument``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html#cfn-iam-policies-policydocument
*/
policyDocument: object | cdk.Token;
/**
* ``GroupResource.PolicyProperty.PolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html#cfn-iam-policies-policyname
*/
policyName: string | cdk.Token;
}
}
}
/**

@@ -257,3 +137,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-instanceprofile.html

*/
instanceProfileName?: string | cdk.Token;
instanceProfileName?: string;
/**

@@ -263,3 +143,3 @@ * ``AWS::IAM::InstanceProfile.Path``

*/
path?: string | cdk.Token;
path?: string;
}

@@ -282,7 +162,7 @@ /**

*
* @param parent the ``cdk.Construct`` this ``CfnInstanceProfile`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnInstanceProfile``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties: CfnInstanceProfileProps);
constructor(scope: cdk.Construct, id: string, props: CfnInstanceProfileProps);
readonly propertyOverrides: CfnInstanceProfileProps;

@@ -293,51 +173,2 @@ protected renderProperties(properties: any): {

}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-instanceprofile.html
*/
interface InstanceProfileResourceProps {
/**
* ``AWS::IAM::InstanceProfile.Roles``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-instanceprofile.html#cfn-iam-instanceprofile-roles
*/
roles: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::InstanceProfile.InstanceProfileName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-instanceprofile.html#cfn-iam-instanceprofile-instanceprofilename
*/
instanceProfileName?: string | cdk.Token;
/**
* ``AWS::IAM::InstanceProfile.Path``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-instanceprofile.html#cfn-iam-instanceprofile-path
*/
path?: string | cdk.Token;
}
/**
* @deprecated "cloudformation.InstanceProfileResource" will be deprecated in a future release in favor of "CfnInstanceProfile" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-instanceprofile.html
*/
class InstanceProfileResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::InstanceProfile";
/**
* @cloudformation_attribute Arn
*/
readonly instanceProfileArn: string;
readonly instanceProfileName: string;
/**
* Creates a new ``AWS::IAM::InstanceProfile``.
*
* @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);
readonly propertyOverrides: InstanceProfileResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
}
/**

@@ -356,3 +187,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html

*/
description?: string | cdk.Token;
description?: string;
/**

@@ -367,3 +198,3 @@ * ``AWS::IAM::ManagedPolicy.Groups``

*/
managedPolicyName?: string | cdk.Token;
managedPolicyName?: string;
/**

@@ -373,3 +204,3 @@ * ``AWS::IAM::ManagedPolicy.Path``

*/
path?: string | cdk.Token;
path?: string;
/**

@@ -398,7 +229,7 @@ * ``AWS::IAM::ManagedPolicy.Roles``

*
* @param parent the ``cdk.Construct`` this ``CfnManagedPolicy`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnManagedPolicy``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties: CfnManagedPolicyProps);
constructor(scope: cdk.Construct, id: string, props: CfnManagedPolicyProps);
readonly propertyOverrides: CfnManagedPolicyProps;

@@ -409,67 +240,2 @@ protected renderProperties(properties: any): {

}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html
*/
interface ManagedPolicyResourceProps {
/**
* ``AWS::IAM::ManagedPolicy.PolicyDocument``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html#cfn-iam-managedpolicy-policydocument
*/
policyDocument: object | cdk.Token;
/**
* ``AWS::IAM::ManagedPolicy.Description``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html#cfn-iam-managedpolicy-description
*/
description?: string | cdk.Token;
/**
* ``AWS::IAM::ManagedPolicy.Groups``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html#cfn-iam-managedpolicy-groups
*/
groups?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::ManagedPolicy.ManagedPolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html#cfn-iam-managedpolicy-managedpolicyname
*/
managedPolicyName?: string | cdk.Token;
/**
* ``AWS::IAM::ManagedPolicy.Path``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html#cfn-ec2-dhcpoptions-path
*/
path?: string | cdk.Token;
/**
* ``AWS::IAM::ManagedPolicy.Roles``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html#cfn-iam-managedpolicy-roles
*/
roles?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::ManagedPolicy.Users``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html#cfn-iam-managedpolicy-users
*/
users?: Array<string | cdk.Token> | cdk.Token;
}
/**
* @deprecated "cloudformation.ManagedPolicyResource" will be deprecated in a future release in favor of "CfnManagedPolicy" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-managedpolicy.html
*/
class ManagedPolicyResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::ManagedPolicy";
readonly managedPolicyArn: string;
/**
* Creates a new ``AWS::IAM::ManagedPolicy``.
*
* @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);
readonly propertyOverrides: ManagedPolicyResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
}
/**

@@ -488,3 +254,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html

*/
policyName: string | cdk.Token;
policyName: string;
/**

@@ -518,7 +284,7 @@ * ``AWS::IAM::Policy.Groups``

*
* @param parent the ``cdk.Construct`` this ``CfnPolicy`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnPolicy``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties: CfnPolicyProps);
constructor(scope: cdk.Construct, id: string, props: CfnPolicyProps);
readonly propertyOverrides: CfnPolicyProps;

@@ -529,57 +295,2 @@ protected renderProperties(properties: any): {

}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html
*/
interface PolicyResourceProps {
/**
* ``AWS::IAM::Policy.PolicyDocument``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html#cfn-iam-policy-policydocument
*/
policyDocument: object | cdk.Token;
/**
* ``AWS::IAM::Policy.PolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html#cfn-iam-policy-policyname
*/
policyName: string | cdk.Token;
/**
* ``AWS::IAM::Policy.Groups``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html#cfn-iam-policy-groups
*/
groups?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::Policy.Roles``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html#cfn-iam-policy-roles
*/
roles?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::Policy.Users``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html#cfn-iam-policy-users
*/
users?: Array<string | cdk.Token> | cdk.Token;
}
/**
* @deprecated "cloudformation.PolicyResource" will be deprecated in a future release in favor of "CfnPolicy" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-policy.html
*/
class PolicyResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::Policy";
readonly policyName: string;
/**
* Creates a new ``AWS::IAM::Policy``.
*
* @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);
readonly propertyOverrides: PolicyResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
}
/**

@@ -608,3 +319,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html

*/
path?: string | cdk.Token;
path?: string;
/**

@@ -614,3 +325,3 @@ * ``AWS::IAM::Role.PermissionsBoundary``

*/
permissionsBoundary?: string | cdk.Token;
permissionsBoundary?: string;
/**

@@ -625,3 +336,3 @@ * ``AWS::IAM::Role.Policies``

*/
roleName?: string | cdk.Token;
roleName?: string;
}

@@ -648,7 +359,7 @@ /**

*
* @param parent the ``cdk.Construct`` this ``CfnRole`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnRole``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties: CfnRoleProps);
constructor(scope: cdk.Construct, id: string, props: CfnRoleProps);
readonly propertyOverrides: CfnRoleProps;

@@ -673,95 +384,5 @@ protected renderProperties(properties: any): {

*/
policyName: string | cdk.Token;
policyName: string;
}
}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html
*/
interface RoleResourceProps {
/**
* ``AWS::IAM::Role.AssumeRolePolicyDocument``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html#cfn-iam-role-assumerolepolicydocument
*/
assumeRolePolicyDocument: object | cdk.Token;
/**
* ``AWS::IAM::Role.ManagedPolicyArns``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html#cfn-iam-role-managepolicyarns
*/
managedPolicyArns?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::Role.MaxSessionDuration``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html#cfn-iam-role-maxsessionduration
*/
maxSessionDuration?: number | cdk.Token;
/**
* ``AWS::IAM::Role.Path``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html#cfn-iam-role-path
*/
path?: string | cdk.Token;
/**
* ``AWS::IAM::Role.PermissionsBoundary``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html#cfn-iam-role-permissionsboundary
*/
permissionsBoundary?: string | cdk.Token;
/**
* ``AWS::IAM::Role.Policies``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html#cfn-iam-role-policies
*/
policies?: Array<RoleResource.PolicyProperty | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::Role.RoleName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html#cfn-iam-role-rolename
*/
roleName?: string | cdk.Token;
}
/**
* @deprecated "cloudformation.RoleResource" will be deprecated in a future release in favor of "CfnRole" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-role.html
*/
class RoleResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::Role";
/**
* @cloudformation_attribute Arn
*/
readonly roleArn: string;
/**
* @cloudformation_attribute RoleId
*/
readonly roleId: string;
readonly roleName: string;
/**
* Creates a new ``AWS::IAM::Role``.
*
* @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);
readonly propertyOverrides: RoleResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
namespace RoleResource {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html
*/
interface PolicyProperty {
/**
* ``RoleResource.PolicyProperty.PolicyDocument``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html#cfn-iam-policies-policydocument
*/
policyDocument: object | cdk.Token;
/**
* ``RoleResource.PolicyProperty.PolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html#cfn-iam-policies-policyname
*/
policyName: string | cdk.Token;
}
}
}
/**

@@ -775,3 +396,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-servicelinkedrole.html

*/
awsServiceName: string | cdk.Token;
awsServiceName: string;
/**

@@ -781,3 +402,3 @@ * ``AWS::IAM::ServiceLinkedRole.CustomSuffix``

*/
customSuffix?: string | cdk.Token;
customSuffix?: string;
/**

@@ -787,3 +408,3 @@ * ``AWS::IAM::ServiceLinkedRole.Description``

*/
description?: string | cdk.Token;
description?: string;
}

@@ -801,7 +422,7 @@ /**

*
* @param parent the ``cdk.Construct`` this ``CfnServiceLinkedRole`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnServiceLinkedRole``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties: CfnServiceLinkedRoleProps);
constructor(scope: cdk.Construct, id: string, props: CfnServiceLinkedRoleProps);
readonly propertyOverrides: CfnServiceLinkedRoleProps;

@@ -812,46 +433,2 @@ protected renderProperties(properties: any): {

}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-servicelinkedrole.html
*/
interface ServiceLinkedRoleResourceProps {
/**
* ``AWS::IAM::ServiceLinkedRole.AWSServiceName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-servicelinkedrole.html#cfn-iam-servicelinkedrole-awsservicename
*/
awsServiceName: string | cdk.Token;
/**
* ``AWS::IAM::ServiceLinkedRole.CustomSuffix``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-servicelinkedrole.html#cfn-iam-servicelinkedrole-customsuffix
*/
customSuffix?: string | cdk.Token;
/**
* ``AWS::IAM::ServiceLinkedRole.Description``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-servicelinkedrole.html#cfn-iam-servicelinkedrole-description
*/
description?: string | cdk.Token;
}
/**
* @deprecated "cloudformation.ServiceLinkedRoleResource" will be deprecated in a future release in favor of "CfnServiceLinkedRole" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-iam-servicelinkedrole.html
*/
class ServiceLinkedRoleResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::ServiceLinkedRole";
/**
* Creates a new ``AWS::IAM::ServiceLinkedRole``.
*
* @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);
readonly propertyOverrides: ServiceLinkedRoleResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
}
/**

@@ -880,3 +457,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html

*/
path?: string | cdk.Token;
path?: string;
/**

@@ -886,3 +463,3 @@ * ``AWS::IAM::User.PermissionsBoundary``

*/
permissionsBoundary?: string | cdk.Token;
permissionsBoundary?: string;
/**

@@ -897,3 +474,3 @@ * ``AWS::IAM::User.Policies``

*/
userName?: string | cdk.Token;
userName?: string;
}

@@ -916,7 +493,7 @@ /**

*
* @param parent the ``cdk.Construct`` this ``CfnUser`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnUser``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties?: CfnUserProps);
constructor(scope: cdk.Construct, id: string, props?: CfnUserProps);
readonly propertyOverrides: CfnUserProps;

@@ -936,3 +513,3 @@ protected renderProperties(properties: any): {

*/
password: string | cdk.Token;
password: string;
/**

@@ -959,108 +536,5 @@ * ``CfnUser.LoginProfileProperty.PasswordResetRequired``

*/
policyName: string | cdk.Token;
policyName: string;
}
}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html
*/
interface UserResourceProps {
/**
* ``AWS::IAM::User.Groups``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html#cfn-iam-user-groups
*/
groups?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::User.LoginProfile``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html#cfn-iam-user-loginprofile
*/
loginProfile?: UserResource.LoginProfileProperty | cdk.Token;
/**
* ``AWS::IAM::User.ManagedPolicyArns``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html#cfn-iam-user-managepolicyarns
*/
managedPolicyArns?: Array<string | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::User.Path``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html#cfn-iam-user-path
*/
path?: string | cdk.Token;
/**
* ``AWS::IAM::User.PermissionsBoundary``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html#cfn-iam-user-permissionsboundary
*/
permissionsBoundary?: string | cdk.Token;
/**
* ``AWS::IAM::User.Policies``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html#cfn-iam-user-policies
*/
policies?: Array<UserResource.PolicyProperty | cdk.Token> | cdk.Token;
/**
* ``AWS::IAM::User.UserName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html#cfn-iam-user-username
*/
userName?: string | cdk.Token;
}
/**
* @deprecated "cloudformation.UserResource" will be deprecated in a future release in favor of "CfnUser" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user.html
*/
class UserResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::User";
/**
* @cloudformation_attribute Arn
*/
readonly userArn: string;
readonly userName: string;
/**
* Creates a new ``AWS::IAM::User``.
*
* @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);
readonly propertyOverrides: UserResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
namespace UserResource {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user-loginprofile.html
*/
interface LoginProfileProperty {
/**
* ``UserResource.LoginProfileProperty.Password``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user-loginprofile.html#cfn-iam-user-loginprofile-password
*/
password: string | cdk.Token;
/**
* ``UserResource.LoginProfileProperty.PasswordResetRequired``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-user-loginprofile.html#cfn-iam-user-loginprofile-passwordresetrequired
*/
passwordResetRequired?: boolean | cdk.Token;
}
}
namespace UserResource {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html
*/
interface PolicyProperty {
/**
* ``UserResource.PolicyProperty.PolicyDocument``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html#cfn-iam-policies-policydocument
*/
policyDocument: object | cdk.Token;
/**
* ``UserResource.PolicyProperty.PolicyName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-policy.html#cfn-iam-policies-policyname
*/
policyName: string | cdk.Token;
}
}
}
/**

@@ -1074,3 +548,3 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-addusertogroup.html

*/
groupName: string | cdk.Token;
groupName: string;
/**

@@ -1093,7 +567,7 @@ * ``AWS::IAM::UserToGroupAddition.Users``

*
* @param parent the ``cdk.Construct`` this ``CfnUserToGroupAddition`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CfnUserToGroupAddition``
* @param scope scope in which this resource is defined
* @param id scoped id of the resource
* @param props resource properties
*/
constructor(parent: cdk.Construct, name: string, properties: CfnUserToGroupAdditionProps);
constructor(scope: cdk.Construct, id: string, props: CfnUserToGroupAdditionProps);
readonly propertyOverrides: CfnUserToGroupAdditionProps;

@@ -1104,40 +578,1 @@ protected renderProperties(properties: any): {

}
export declare namespace cloudformation {
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-addusertogroup.html
*/
interface UserToGroupAdditionResourceProps {
/**
* ``AWS::IAM::UserToGroupAddition.GroupName``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-addusertogroup.html#cfn-iam-addusertogroup-groupname
*/
groupName: string | cdk.Token;
/**
* ``AWS::IAM::UserToGroupAddition.Users``
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-addusertogroup.html#cfn-iam-addusertogroup-users
*/
users: Array<string | cdk.Token> | cdk.Token;
}
/**
* @deprecated "cloudformation.UserToGroupAdditionResource" will be deprecated in a future release in favor of "CfnUserToGroupAddition" (see https://github.com/awslabs/aws-cdk/issues/878)
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-iam-addusertogroup.html
*/
class UserToGroupAdditionResource extends cdk.Resource {
/**
* The CloudFormation resource type name for this resource class.
*/
static readonly resourceTypeName = "AWS::IAM::UserToGroupAddition";
/**
* Creates a new ``AWS::IAM::UserToGroupAddition``.
*
* @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);
readonly propertyOverrides: UserToGroupAdditionResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;
};
}
}
import cdk = require('@aws-cdk/cdk');
import { Policy } from './policy';
import { PolicyPrincipal, PolicyStatement } from './policy-document';
import { IRole, RoleProps } from './role';
import { IRole, RoleImportProps, RoleProps } from './role';
/**

@@ -20,3 +20,4 @@ * An IAM role that only gets attached to the construct tree once it gets used, not before

private readonly managedPolicies;
constructor(parent: cdk.Construct, id: string, props: RoleProps);
constructor(scope: cdk.Construct, id: string, props: RoleProps);
export(): RoleImportProps;
/**

@@ -46,2 +47,3 @@ * Adds a permission to the role's default policy document.

readonly roleArn: string;
readonly roleId: string;
/**

@@ -48,0 +50,0 @@ * Returns a Principal object representing the ARN of this role.

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

class LazyRole extends cdk.Construct {
constructor(parent, id, props) {
super(parent, id);
constructor(scope, id, props) {
super(scope, id);
this.props = props;

@@ -23,2 +23,5 @@ this.statements = new Array();

}
export() {
return this.instantiate().export();
}
/**

@@ -73,2 +76,5 @@ * Adds a permission to the role's default policy document.

}
get roleId() {
return this.instantiate().roleId;
}
/**

@@ -92,2 +98,2 @@ * Returns a Principal object representing the ARN of this role.

exports.LazyRole = LazyRole;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1yb2xlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGF6eS1yb2xlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsb0NBQXFDO0FBR3JDLGlDQUFnRDtBQUVoRDs7Ozs7Ozs7R0FRRztBQUNILE1BQWEsUUFBUyxTQUFRLEdBQUcsQ0FBQyxTQUFTO0lBTXpDLFlBQVksTUFBcUIsRUFBRSxFQUFVLEVBQW1CLEtBQWdCO1FBQzlFLEtBQUssQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFENEMsVUFBSyxHQUFMLEtBQUssQ0FBVztRQUovRCxlQUFVLEdBQUcsSUFBSSxLQUFLLEVBQW1CLENBQUM7UUFDMUMsYUFBUSxHQUFHLElBQUksS0FBSyxFQUFVLENBQUM7UUFDL0Isb0JBQWUsR0FBRyxJQUFJLEtBQUssRUFBVSxDQUFDO0lBSXZELENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksV0FBVyxDQUFDLFNBQTBCO1FBQzNDLElBQUksSUFBSSxDQUFDLElBQUksRUFBRTtZQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ2xDO2FBQU07WUFDTCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUNqQztJQUNILENBQUM7SUFFRDs7O09BR0c7SUFDSSxrQkFBa0IsQ0FBQyxNQUFjO1FBQ3RDLElBQUksSUFBSSxDQUFDLElBQUksRUFBRTtZQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDdEM7YUFBTTtZQUNMLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQzVCO0lBQ0gsQ0FBQztJQUVEOzs7T0FHRztJQUNJLG1CQUFtQixDQUFDLEdBQVc7UUFDcEMsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNwQzthQUFNO1lBQ0wsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDaEM7SUFDSCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLGtCQUFrQjtRQUMzQixPQUFPLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztJQUMvQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsT0FBTyxDQUFDO0lBQ3BDLENBQUM7SUFFRDs7T0FFRztJQUNILElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUM7SUFDdEMsQ0FBQztJQUVPLFdBQVc7UUFDakIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDZCxNQUFNLElBQUksR0FBRyxJQUFJLFdBQUksQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNuRCxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBQ3JELElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUMxRCxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDbEUsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7U0FDbEI7UUFDRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQztDQUNGO0FBOUVELDRCQThFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IFBvbGljeSB9IGZyb20gJy4vcG9saWN5JztcbmltcG9ydCB7IFBvbGljeVByaW5jaXBhbCwgUG9saWN5U3RhdGVtZW50IH0gZnJvbSAnLi9wb2xpY3ktZG9jdW1lbnQnO1xuaW1wb3J0IHsgSVJvbGUsIFJvbGUsIFJvbGVQcm9wcyB9IGZyb20gJy4vcm9sZSc7XG5cbi8qKlxuICogQW4gSUFNIHJvbGUgdGhhdCBvbmx5IGdldHMgYXR0YWNoZWQgdG8gdGhlIGNvbnN0cnVjdCB0cmVlIG9uY2UgaXQgZ2V0cyB1c2VkLCBub3QgYmVmb3JlXG4gKlxuICogVGhpcyBjb25zdHJ1Y3QgY2FuIGJlIHVzZWQgdG8gc2ltcGxpZnkgbG9naWMgaW4gb3RoZXIgY29uc3RydWN0c1xuICogd2hpY2ggbmVlZCB0byBjcmVhdGUgYSByb2xlIGJ1dCBvbmx5IGlmIGNlcnRhaW4gY29uZmlndXJhdGlvbnMgb2NjdXJcbiAqIChzdWNoIGFzIHdoZW4gQXV0b1NjYWxpbmcgaXMgY29uZmlndXJlZCkuIFRoZSByb2xlIGNhbiBiZSBjb25maWd1cmVkIGluIG9uZVxuICogcGxhY2UsIGJ1dCBpZiBpdCBuZXZlciBnZXRzIHVzZWQgaXQgZG9lc24ndCBnZXQgaW5zdGFudGlhdGVkIGFuZCB3aWxsXG4gKiBub3QgYmUgc3ludGhlc2l6ZWQgb3IgZGVwbG95ZWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBMYXp5Um9sZSBleHRlbmRzIGNkay5Db25zdHJ1Y3QgaW1wbGVtZW50cyBJUm9sZSB7XG4gIHByaXZhdGUgcm9sZT86IFJvbGU7XG4gIHByaXZhdGUgcmVhZG9ubHkgc3RhdGVtZW50cyA9IG5ldyBBcnJheTxQb2xpY3lTdGF0ZW1lbnQ+KCk7XG4gIHByaXZhdGUgcmVhZG9ubHkgcG9saWNpZXMgPSBuZXcgQXJyYXk8UG9saWN5PigpO1xuICBwcml2YXRlIHJlYWRvbmx5IG1hbmFnZWRQb2xpY2llcyA9IG5ldyBBcnJheTxzdHJpbmc+KCk7XG5cbiAgY29uc3RydWN0b3IocGFyZW50OiBjZGsuQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcml2YXRlIHJlYWRvbmx5IHByb3BzOiBSb2xlUHJvcHMpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGEgcGVybWlzc2lvbiB0byB0aGUgcm9sZSdzIGRlZmF1bHQgcG9saWN5IGRvY3VtZW50LlxuICAgKiBJZiB0aGVyZSBpcyBubyBkZWZhdWx0IHBvbGljeSBhdHRhY2hlZCB0byB0aGlzIHJvbGUsIGl0IHdpbGwgYmUgY3JlYXRlZC5cbiAgICogQHBhcmFtIHBlcm1pc3Npb24gVGhlIHBlcm1pc3Npb24gc3RhdGVtZW50IHRvIGFkZCB0byB0aGUgcG9saWN5IGRvY3VtZW50XG4gICAqL1xuICBwdWJsaWMgYWRkVG9Qb2xpY3koc3RhdGVtZW50OiBQb2xpY3lTdGF0ZW1lbnQpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5yb2xlKSB7XG4gICAgICB0aGlzLnJvbGUuYWRkVG9Qb2xpY3koc3RhdGVtZW50KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zdGF0ZW1lbnRzLnB1c2goc3RhdGVtZW50KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBwb2xpY3kgdG8gdGhpcyByb2xlLlxuICAgKiBAcGFyYW0gcG9saWN5IFRoZSBwb2xpY3kgdG8gYXR0YWNoXG4gICAqL1xuICBwdWJsaWMgYXR0YWNoSW5saW5lUG9saWN5KHBvbGljeTogUG9saWN5KTogdm9pZCB7XG4gICAgaWYgKHRoaXMucm9sZSkge1xuICAgICAgdGhpcy5yb2xlLmF0dGFjaElubGluZVBvbGljeShwb2xpY3kpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnBvbGljaWVzLnB1c2gocG9saWN5KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBtYW5hZ2VkIHBvbGljeSB0byB0aGlzIHJvbGUuXG4gICAqIEBwYXJhbSBhcm4gVGhlIEFSTiBvZiB0aGUgbWFuYWdlZCBwb2xpY3kgdG8gYXR0YWNoLlxuICAgKi9cbiAgcHVibGljIGF0dGFjaE1hbmFnZWRQb2xpY3koYXJuOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5yb2xlKSB7XG4gICAgICB0aGlzLnJvbGUuYXR0YWNoTWFuYWdlZFBvbGljeShhcm4pO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1hbmFnZWRQb2xpY2llcy5wdXNoKGFybik7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHJvbGUuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGRlcGVuZGVuY3lFbGVtZW50cygpOiBjZGsuSURlcGVuZGFibGVbXSB7XG4gICAgcmV0dXJuIHRoaXMuaW5zdGFudGlhdGUoKS5kZXBlbmRlbmN5RWxlbWVudHM7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgQVJOIG9mIHRoaXMgcm9sZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgcm9sZUFybigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmluc3RhbnRpYXRlKCkucm9sZUFybjtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGEgUHJpbmNpcGFsIG9iamVjdCByZXByZXNlbnRpbmcgdGhlIEFSTiBvZiB0aGlzIHJvbGUuXG4gICAqL1xuICBwdWJsaWMgZ2V0IHByaW5jaXBhbCgpOiBQb2xpY3lQcmluY2lwYWwge1xuICAgIHJldHVybiB0aGlzLmluc3RhbnRpYXRlKCkucHJpbmNpcGFsO1xuICB9XG5cbiAgcHJpdmF0ZSBpbnN0YW50aWF0ZSgpOiBSb2xlIHtcbiAgICBpZiAoIXRoaXMucm9sZSkge1xuICAgICAgY29uc3Qgcm9sZSA9IG5ldyBSb2xlKHRoaXMsICdEZWZhdWx0JywgdGhpcy5wcm9wcyk7XG4gICAgICB0aGlzLnN0YXRlbWVudHMuZm9yRWFjaChyb2xlLmFkZFRvUG9saWN5LmJpbmQocm9sZSkpO1xuICAgICAgdGhpcy5wb2xpY2llcy5mb3JFYWNoKHJvbGUuYXR0YWNoSW5saW5lUG9saWN5LmJpbmQocm9sZSkpO1xuICAgICAgdGhpcy5tYW5hZ2VkUG9saWNpZXMuZm9yRWFjaChyb2xlLmF0dGFjaE1hbmFnZWRQb2xpY3kuYmluZChyb2xlKSk7XG4gICAgICB0aGlzLnJvbGUgPSByb2xlO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5yb2xlO1xuICB9XG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1yb2xlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibGF6eS1yb2xlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsb0NBQXFDO0FBR3JDLGlDQUFpRTtBQUVqRTs7Ozs7Ozs7R0FRRztBQUNILE1BQWEsUUFBUyxTQUFRLEdBQUcsQ0FBQyxTQUFTO0lBTXpDLFlBQVksS0FBb0IsRUFBRSxFQUFVLEVBQW1CLEtBQWdCO1FBQzdFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFENEMsVUFBSyxHQUFMLEtBQUssQ0FBVztRQUo5RCxlQUFVLEdBQUcsSUFBSSxLQUFLLEVBQW1CLENBQUM7UUFDMUMsYUFBUSxHQUFHLElBQUksS0FBSyxFQUFVLENBQUM7UUFDL0Isb0JBQWUsR0FBRyxJQUFJLEtBQUssRUFBVSxDQUFDO0lBSXZELENBQUM7SUFFTSxNQUFNO1FBQ1gsT0FBTyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDckMsQ0FBQztJQUVEOzs7O09BSUc7SUFDSSxXQUFXLENBQUMsU0FBMEI7UUFDM0MsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDbEM7YUFBTTtZQUNMLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1NBQ2pDO0lBQ0gsQ0FBQztJQUVEOzs7T0FHRztJQUNJLGtCQUFrQixDQUFDLE1BQWM7UUFDdEMsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUN0QzthQUFNO1lBQ0wsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDNUI7SUFDSCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksbUJBQW1CLENBQUMsR0FBVztRQUNwQyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDYixJQUFJLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQ3BDO2FBQU07WUFDTCxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNoQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNILElBQVcsa0JBQWtCO1FBQzNCLE9BQU8sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLGtCQUFrQixDQUFDO0lBQy9DLENBQUM7SUFFRDs7T0FFRztJQUNILElBQVcsT0FBTztRQUNoQixPQUFPLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxPQUFPLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQVcsTUFBTTtRQUNmLE9BQU8sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLE1BQU0sQ0FBQztJQUNuQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFNBQVM7UUFDbEIsT0FBTyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsU0FBUyxDQUFDO0lBQ3RDLENBQUM7SUFFTyxXQUFXO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ2QsTUFBTSxJQUFJLEdBQUcsSUFBSSxXQUFJLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbkQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUNyRCxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDMUQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBQ2xFLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1NBQ2xCO1FBQ0QsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7Q0FDRjtBQXRGRCw0QkFzRkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBQb2xpY3kgfSBmcm9tICcuL3BvbGljeSc7XG5pbXBvcnQgeyBQb2xpY3lQcmluY2lwYWwsIFBvbGljeVN0YXRlbWVudCB9IGZyb20gJy4vcG9saWN5LWRvY3VtZW50JztcbmltcG9ydCB7IElSb2xlLCBSb2xlLCBSb2xlSW1wb3J0UHJvcHMsIFJvbGVQcm9wcyB9IGZyb20gJy4vcm9sZSc7XG5cbi8qKlxuICogQW4gSUFNIHJvbGUgdGhhdCBvbmx5IGdldHMgYXR0YWNoZWQgdG8gdGhlIGNvbnN0cnVjdCB0cmVlIG9uY2UgaXQgZ2V0cyB1c2VkLCBub3QgYmVmb3JlXG4gKlxuICogVGhpcyBjb25zdHJ1Y3QgY2FuIGJlIHVzZWQgdG8gc2ltcGxpZnkgbG9naWMgaW4gb3RoZXIgY29uc3RydWN0c1xuICogd2hpY2ggbmVlZCB0byBjcmVhdGUgYSByb2xlIGJ1dCBvbmx5IGlmIGNlcnRhaW4gY29uZmlndXJhdGlvbnMgb2NjdXJcbiAqIChzdWNoIGFzIHdoZW4gQXV0b1NjYWxpbmcgaXMgY29uZmlndXJlZCkuIFRoZSByb2xlIGNhbiBiZSBjb25maWd1cmVkIGluIG9uZVxuICogcGxhY2UsIGJ1dCBpZiBpdCBuZXZlciBnZXRzIHVzZWQgaXQgZG9lc24ndCBnZXQgaW5zdGFudGlhdGVkIGFuZCB3aWxsXG4gKiBub3QgYmUgc3ludGhlc2l6ZWQgb3IgZGVwbG95ZWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBMYXp5Um9sZSBleHRlbmRzIGNkay5Db25zdHJ1Y3QgaW1wbGVtZW50cyBJUm9sZSB7XG4gIHByaXZhdGUgcm9sZT86IFJvbGU7XG4gIHByaXZhdGUgcmVhZG9ubHkgc3RhdGVtZW50cyA9IG5ldyBBcnJheTxQb2xpY3lTdGF0ZW1lbnQ+KCk7XG4gIHByaXZhdGUgcmVhZG9ubHkgcG9saWNpZXMgPSBuZXcgQXJyYXk8UG9saWN5PigpO1xuICBwcml2YXRlIHJlYWRvbmx5IG1hbmFnZWRQb2xpY2llcyA9IG5ldyBBcnJheTxzdHJpbmc+KCk7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByaXZhdGUgcmVhZG9ubHkgcHJvcHM6IFJvbGVQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG4gIH1cblxuICBwdWJsaWMgZXhwb3J0KCk6IFJvbGVJbXBvcnRQcm9wcyB7XG4gICAgcmV0dXJuIHRoaXMuaW5zdGFudGlhdGUoKS5leHBvcnQoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGEgcGVybWlzc2lvbiB0byB0aGUgcm9sZSdzIGRlZmF1bHQgcG9saWN5IGRvY3VtZW50LlxuICAgKiBJZiB0aGVyZSBpcyBubyBkZWZhdWx0IHBvbGljeSBhdHRhY2hlZCB0byB0aGlzIHJvbGUsIGl0IHdpbGwgYmUgY3JlYXRlZC5cbiAgICogQHBhcmFtIHBlcm1pc3Npb24gVGhlIHBlcm1pc3Npb24gc3RhdGVtZW50IHRvIGFkZCB0byB0aGUgcG9saWN5IGRvY3VtZW50XG4gICAqL1xuICBwdWJsaWMgYWRkVG9Qb2xpY3koc3RhdGVtZW50OiBQb2xpY3lTdGF0ZW1lbnQpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5yb2xlKSB7XG4gICAgICB0aGlzLnJvbGUuYWRkVG9Qb2xpY3koc3RhdGVtZW50KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zdGF0ZW1lbnRzLnB1c2goc3RhdGVtZW50KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBwb2xpY3kgdG8gdGhpcyByb2xlLlxuICAgKiBAcGFyYW0gcG9saWN5IFRoZSBwb2xpY3kgdG8gYXR0YWNoXG4gICAqL1xuICBwdWJsaWMgYXR0YWNoSW5saW5lUG9saWN5KHBvbGljeTogUG9saWN5KTogdm9pZCB7XG4gICAgaWYgKHRoaXMucm9sZSkge1xuICAgICAgdGhpcy5yb2xlLmF0dGFjaElubGluZVBvbGljeShwb2xpY3kpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnBvbGljaWVzLnB1c2gocG9saWN5KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQXR0YWNoZXMgYSBtYW5hZ2VkIHBvbGljeSB0byB0aGlzIHJvbGUuXG4gICAqIEBwYXJhbSBhcm4gVGhlIEFSTiBvZiB0aGUgbWFuYWdlZCBwb2xpY3kgdG8gYXR0YWNoLlxuICAgKi9cbiAgcHVibGljIGF0dGFjaE1hbmFnZWRQb2xpY3koYXJuOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5yb2xlKSB7XG4gICAgICB0aGlzLnJvbGUuYXR0YWNoTWFuYWdlZFBvbGljeShhcm4pO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1hbmFnZWRQb2xpY2llcy5wdXNoKGFybik7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHJvbGUuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGRlcGVuZGVuY3lFbGVtZW50cygpOiBjZGsuSURlcGVuZGFibGVbXSB7XG4gICAgcmV0dXJuIHRoaXMuaW5zdGFudGlhdGUoKS5kZXBlbmRlbmN5RWxlbWVudHM7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgQVJOIG9mIHRoaXMgcm9sZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgcm9sZUFybigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmluc3RhbnRpYXRlKCkucm9sZUFybjtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgcm9sZUlkKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuaW5zdGFudGlhdGUoKS5yb2xlSWQ7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyBhIFByaW5jaXBhbCBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSBBUk4gb2YgdGhpcyByb2xlLlxuICAgKi9cbiAgcHVibGljIGdldCBwcmluY2lwYWwoKTogUG9saWN5UHJpbmNpcGFsIHtcbiAgICByZXR1cm4gdGhpcy5pbnN0YW50aWF0ZSgpLnByaW5jaXBhbDtcbiAgfVxuXG4gIHByaXZhdGUgaW5zdGFudGlhdGUoKTogUm9sZSB7XG4gICAgaWYgKCF0aGlzLnJvbGUpIHtcbiAgICAgIGNvbnN0IHJvbGUgPSBuZXcgUm9sZSh0aGlzLCAnRGVmYXVsdCcsIHRoaXMucHJvcHMpO1xuICAgICAgdGhpcy5zdGF0ZW1lbnRzLmZvckVhY2gocm9sZS5hZGRUb1BvbGljeS5iaW5kKHJvbGUpKTtcbiAgICAgIHRoaXMucG9saWNpZXMuZm9yRWFjaChyb2xlLmF0dGFjaElubGluZVBvbGljeS5iaW5kKHJvbGUpKTtcbiAgICAgIHRoaXMubWFuYWdlZFBvbGljaWVzLmZvckVhY2gocm9sZS5hdHRhY2hNYW5hZ2VkUG9saWN5LmJpbmQocm9sZSkpO1xuICAgICAgdGhpcy5yb2xlID0gcm9sZTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMucm9sZTtcbiAgfVxufSJdfQ==

@@ -0,1 +1,2 @@

import cdk = require('@aws-cdk/cdk');
/**

@@ -12,3 +13,4 @@ * A policy managed by AWS

private readonly managedPolicyName;
constructor(managedPolicyName: string);
private readonly scope;
constructor(managedPolicyName: string, scope: cdk.IConstruct);
/**

@@ -15,0 +17,0 @@ * The Arn of this managed policy

@@ -14,4 +14,5 @@ "use strict";

class AwsManagedPolicy {
constructor(managedPolicyName) {
constructor(managedPolicyName, scope) {
this.managedPolicyName = managedPolicyName;
this.scope = scope;
}

@@ -23,3 +24,3 @@ /**

// the arn is in the form of - arn:aws:iam::aws:policy/<policyName>
return cdk.ArnUtils.fromComponents({
return cdk.Stack.find(this.scope).formatArn({
service: "iam",

@@ -34,2 +35,2 @@ region: "",

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

@@ -1,3 +0,3 @@

import { Token } from '@aws-cdk/cdk';
export declare class PolicyDocument extends Token {
import cdk = require('@aws-cdk/cdk');
export declare class PolicyDocument extends cdk.Token {
private readonly baseDocument?;

@@ -11,3 +11,3 @@ private statements;

constructor(baseDocument?: any);
resolve(): any;
resolve(_context: cdk.ResolveContext): any;
readonly isEmpty: boolean;

@@ -123,3 +123,3 @@ /**

*/
export declare class PolicyStatement extends Token {
export declare class PolicyStatement extends cdk.Token {
private action;

@@ -140,4 +140,4 @@ private principal;

addAwsPrincipal(arn: string): this;
addAwsAccountPrincipal(accountId: string): this;
addArnPrincipal(arn: string): this;
addAwsAccountPrincipal(accountId: string): this;
addServicePrincipal(service: string): this;

@@ -186,3 +186,3 @@ addFederatedPrincipal(federated: any, conditions: {

limitToAccount(accountId: string): PolicyStatement;
resolve(): any;
resolve(_context: cdk.ResolveContext): any;
toJson(): any;

@@ -189,0 +189,0 @@ }

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const cdk_1 = require("@aws-cdk/cdk");
class PolicyDocument extends cdk_1.Token {
const cdk = require("@aws-cdk/cdk");
class PolicyDocument extends cdk.Token {
/**

@@ -15,3 +15,3 @@ * Creates a new IAM policy document.

}
resolve() {
resolve(_context) {
if (this.isEmpty) {

@@ -79,3 +79,3 @@ return undefined;

constructor(accountId) {
super(`arn:${new cdk_1.AwsPartition()}:iam::${accountId}:root`);
super(new StackDependentToken(stack => `arn:${stack.partition}:iam::${accountId}:root`).toString());
this.accountId = accountId;

@@ -135,3 +135,3 @@ }

constructor() {
super(new cdk_1.AwsAccountId());
super(new StackDependentToken(stack => stack.accountId).toString());
}

@@ -191,3 +191,3 @@ }

*/
class PolicyStatement extends cdk_1.Token {
class PolicyStatement extends cdk.Token {
constructor(effect = PolicyStatementEffect.Allow) {

@@ -230,8 +230,8 @@ super();

}
addAwsAccountPrincipal(accountId) {
return this.addPrincipal(new AccountPrincipal(accountId));
}
addArnPrincipal(arn) {
return this.addAwsPrincipal(arn);
}
addAwsAccountPrincipal(accountId) {
return this.addPrincipal(new AccountPrincipal(accountId));
}
addServicePrincipal(service) {

@@ -324,3 +324,3 @@ return this.addPrincipal(new ServicePrincipal(service));

limitToAccount(accountId) {
return this.addCondition('StringEquals', new cdk_1.Token(() => {
return this.addCondition('StringEquals', new cdk.Token(() => {
return { 'sts:ExternalId': accountId };

@@ -332,3 +332,3 @@ }));

//
resolve() {
resolve(_context) {
return this.toJson();

@@ -401,2 +401,15 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-document.js","sourceRoot":"","sources":["policy-document.ts"],"names":[],"mappings":"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","sourcesContent":["import { AwsAccountId, AwsPartition, Token } from '@aws-cdk/cdk';\n\nexport class PolicyDocument extends Token {\n  private statements = new Array<PolicyStatement>();\n\n  /**\n   * Creates a new IAM policy document.\n   * @param defaultDocument An IAM policy document to use as an initial\n   * policy. All statements of this document will be copied in.\n   */\n  constructor(private readonly baseDocument?: any) {\n    super();\n  }\n\n  public resolve(): any {\n    if (this.isEmpty) {\n      return undefined;\n    }\n\n    const doc = this.baseDocument || { };\n    doc.Statement = doc.Statement || [ ];\n    doc.Version = doc.Version || '2012-10-17';\n    doc.Statement = doc.Statement.concat(this.statements);\n    return doc;\n  }\n\n  get isEmpty(): boolean {\n    return this.statements.length === 0;\n  }\n\n  /**\n   * The number of statements already added to this policy.\n   * Can be used, for example, to generate uniuqe \"sid\"s within the policy.\n   */\n  get statementCount(): number {\n    return this.statements.length;\n  }\n\n  public addStatement(statement: PolicyStatement): PolicyDocument {\n    this.statements.push(statement);\n    return this;\n  }\n}\n\n/**\n * Represents an IAM principal.\n */\nexport abstract class PolicyPrincipal {\n  /**\n   * When this Principal is used in an AssumeRole policy, the action to use.\n   */\n  public assumeRoleAction: string = 'sts:AssumeRole';\n\n  /**\n   * Return the policy fragment that identifies this principal in a Policy.\n   */\n  public abstract policyFragment(): PrincipalPolicyFragment;\n}\n\n/**\n * A collection of the fields in a PolicyStatement that can be used to identify a principal.\n *\n * This consists of the JSON used in the \"Principal\" field, and optionally a\n * set of \"Condition\"s that need to be applied to the policy.\n */\nexport class PrincipalPolicyFragment {\n  constructor(\n    public readonly principalJson: { [key: string]: string[] },\n    public readonly conditions: { [key: string]: any } = { }) {\n  }\n}\n\nexport class ArnPrincipal extends PolicyPrincipal {\n  constructor(public readonly arn: string) {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ AWS: [ this.arn ] });\n  }\n}\n\nexport class AccountPrincipal extends ArnPrincipal {\n  constructor(public readonly accountId: any) {\n    super(`arn:${new AwsPartition()}:iam::${accountId}:root`);\n  }\n}\n\n/**\n * An IAM principal that represents an AWS service (i.e. sqs.amazonaws.com).\n */\nexport class ServicePrincipal extends PolicyPrincipal {\n  constructor(public readonly service: string) {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ Service: [ this.service ] });\n  }\n}\n\n/**\n * A policy prinicipal for canonicalUserIds - useful for S3 bucket policies that use\n * Origin Access identities.\n *\n * See https://docs.aws.amazon.com/general/latest/gr/acct-identifiers.html\n *\n * and\n *\n * https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-restricting-access-to-s3.html\n *\n * for more details.\n *\n */\nexport class CanonicalUserPrincipal extends PolicyPrincipal {\n  constructor(public readonly canonicalUserId: string) {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ CanonicalUser: [ this.canonicalUserId ] });\n  }\n}\n\nexport class FederatedPrincipal extends PolicyPrincipal {\n  constructor(\n    public readonly federated: string,\n    public readonly conditions: {[key: string]: any},\n    public assumeRoleAction: string = 'sts:AssumeRole') {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ Federated: [ this.federated ] }, this.conditions);\n  }\n}\n\nexport class AccountRootPrincipal extends AccountPrincipal {\n  constructor() {\n    super(new AwsAccountId());\n  }\n}\n\n/**\n * A principal representing all identities in all accounts\n */\nexport class AnyPrincipal extends ArnPrincipal {\n  constructor() {\n    super('*');\n  }\n}\n\n/**\n * A principal representing all identities in all accounts\n * @deprecated use `AnyPrincipal`\n */\nexport class Anyone extends AnyPrincipal { }\n\nexport class CompositePrincipal extends PolicyPrincipal {\n  private readonly principals = new Array<PolicyPrincipal>();\n\n  constructor(principal: PolicyPrincipal, ...additionalPrincipals: PolicyPrincipal[]) {\n    super();\n    this.assumeRoleAction = principal.assumeRoleAction;\n    this.addPrincipals(principal);\n    this.addPrincipals(...additionalPrincipals);\n  }\n\n  public addPrincipals(...principals: PolicyPrincipal[]): this {\n    for (const p of principals) {\n      if (p.assumeRoleAction !== this.assumeRoleAction) {\n        throw new Error(\n          `Cannot add multiple principals with different \"assumeRoleAction\". ` +\n          `Expecting \"${this.assumeRoleAction}\", got \"${p.assumeRoleAction}\"`);\n      }\n\n      const fragment = p.policyFragment();\n      if (fragment.conditions && Object.keys(fragment.conditions).length > 0) {\n        throw new Error(\n          `Components of a CompositePrincipal must not have conditions. ` +\n          `Tried to add the following fragment: ${JSON.stringify(fragment)}`);\n      }\n\n      this.principals.push(p);\n    }\n\n    return this;\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    const principalJson: { [key: string]: string[] } = { };\n\n    for (const p of this.principals) {\n      mergePrincipal(principalJson, p.policyFragment().principalJson);\n    }\n\n    return new PrincipalPolicyFragment(principalJson);\n  }\n}\n\n/**\n * Represents a statement in an IAM policy document.\n */\nexport class PolicyStatement extends Token {\n  private action = new Array<any>();\n  private principal: { [key: string]: any[] } = {};\n  private resource = new Array<any>();\n  private condition: { [key: string]: any } = { };\n  private effect?: PolicyStatementEffect;\n  private sid?: any;\n\n  constructor(effect: PolicyStatementEffect = PolicyStatementEffect.Allow) {\n    super();\n    this.effect = effect;\n  }\n\n  //\n  // Actions\n  //\n\n  public addAction(action: string): PolicyStatement {\n    this.action.push(action);\n    return this;\n  }\n\n  public addActions(...actions: string[]): PolicyStatement {\n    actions.forEach(action => this.addAction(action));\n    return this;\n  }\n\n  //\n  // Principal\n  //\n\n  /**\n   * Indicates if this permission has a \"Principal\" section.\n   */\n  public get hasPrincipal() {\n    return Object.keys(this.principal).length > 0;\n  }\n\n  public addPrincipal(principal: PolicyPrincipal): this {\n    const fragment = principal.policyFragment();\n    mergePrincipal(this.principal, fragment.principalJson);\n    this.addConditions(fragment.conditions);\n    return this;\n  }\n\n  public addAwsPrincipal(arn: string): this {\n    return this.addPrincipal(new ArnPrincipal(arn));\n  }\n\n  public addArnPrincipal(arn: string): this {\n    return this.addAwsPrincipal(arn);\n  }\n\n  public addAwsAccountPrincipal(accountId: string): this {\n    return this.addPrincipal(new AccountPrincipal(accountId));\n  }\n\n  public addServicePrincipal(service: string): this {\n    return this.addPrincipal(new ServicePrincipal(service));\n  }\n\n  public addFederatedPrincipal(federated: any, conditions: {[key: string]: any}): this {\n    return this.addPrincipal(new FederatedPrincipal(federated, conditions));\n  }\n\n  public addAccountRootPrincipal(): this {\n    return this.addPrincipal(new AccountRootPrincipal());\n  }\n\n  public addCanonicalUserPrincipal(canonicalUserId: string): this {\n    return this.addPrincipal(new CanonicalUserPrincipal(canonicalUserId));\n  }\n\n  public addAnyPrincipal(): this {\n    return this.addPrincipal(new Anyone());\n  }\n\n  //\n  // Resources\n  //\n\n  public addResource(arn: string): PolicyStatement {\n    this.resource.push(arn);\n    return this;\n  }\n\n  /**\n   * Adds a ``\"*\"`` resource to this statement.\n   */\n  public addAllResources(): PolicyStatement {\n    return this.addResource('*');\n  }\n\n  public addResources(...arns: string[]): PolicyStatement {\n    arns.forEach(r => this.addResource(r));\n    return this;\n  }\n\n  /**\n   * Indicates if this permission as at least one resource associated with it.\n   */\n  public get hasResource() {\n    return this.resource && this.resource.length > 0;\n  }\n\n  public describe(sid: string): PolicyStatement {\n    this.sid = sid;\n    return this;\n  }\n\n  //\n  // Effect\n  //\n\n  /**\n   * Sets the permission effect to allow access to resources.\n   */\n  public allow(): PolicyStatement {\n    this.effect = PolicyStatementEffect.Allow;\n    return this;\n  }\n\n  /**\n   * Sets the permission effect to deny access to resources.\n   */\n  public deny(): PolicyStatement {\n    this.effect = PolicyStatementEffect.Deny;\n    return this;\n  }\n\n  //\n  // Condition\n  //\n\n  /**\n   * Add a condition to the Policy\n   */\n  public addCondition(key: string, value: any): PolicyStatement {\n    this.condition[key] = value;\n    return this;\n  }\n\n  /**\n   * Add multiple conditions to the Policy\n   */\n  public addConditions(conditions: {[key: string]: any}): PolicyStatement {\n    Object.keys(conditions).map(key => {\n      this.addCondition(key, conditions[key]);\n    });\n    return this;\n  }\n\n  /**\n   * Add a condition to the Policy.\n   *\n   * @deprecated For backwards compatibility. Use addCondition() instead.\n   */\n  public setCondition(key: string, value: any): PolicyStatement {\n    return this.addCondition(key, value);\n  }\n\n  public limitToAccount(accountId: string): PolicyStatement {\n    return this.addCondition('StringEquals', new Token(() => {\n      return { 'sts:ExternalId': accountId };\n    }));\n  }\n\n  //\n  // Serialization\n  //\n\n  public resolve(): any {\n    return this.toJson();\n  }\n\n  public toJson(): any {\n    return {\n      Action: _norm(this.action),\n      Condition: _norm(this.condition),\n      Effect: _norm(this.effect),\n      Principal: _normPrincipal(this.principal),\n      Resource: _norm(this.resource),\n      Sid: _norm(this.sid),\n    };\n\n    function _norm(values: any) {\n\n      if (typeof(values) === 'undefined') {\n        return undefined;\n      }\n\n      if (Array.isArray(values)) {\n        if (!values || values.length === 0) {\n          return undefined;\n        }\n\n        if (values.length === 1) {\n          return values[0];\n        }\n\n        return values;\n      }\n\n      if (typeof(values) === 'object') {\n        if (Object.keys(values).length === 0) {\n          return undefined;\n        }\n      }\n\n      return values;\n    }\n\n    function _normPrincipal(principal: { [key: string]: any[] }) {\n      const keys = Object.keys(principal);\n      if (keys.length === 0) { return undefined; }\n      const result: any = {};\n      for (const key of keys) {\n        const normVal = _norm(principal[key]);\n        if (normVal) {\n          result[key] = normVal;\n        }\n      }\n      if (Object.keys(result).length === 1 && result.AWS === '*') {\n        return '*';\n      }\n      return result;\n    }\n  }\n}\n\nexport enum PolicyStatementEffect {\n  Allow = 'Allow',\n  Deny = 'Deny',\n}\n\nfunction mergePrincipal(target: { [key: string]: string[] }, source: { [key: string]: string[] }) {\n  for (const key of Object.keys(source)) {\n    target[key] = target[key] || [];\n\n    const value = source[key];\n    if (!Array.isArray(value)) {\n      throw new Error(`Principal value must be an array (it will be normalized later): ${value}`);\n    }\n\n    target[key].push(...value);\n  }\n\n  return target;\n}\n"]}
/**
* A lazy token that requires an instance of Stack to evaluate
*/
class StackDependentToken extends cdk.Token {
constructor(fn) {
super();
this.fn = fn;
}
resolve(context) {
const stack = cdk.Stack.find(context.scope);
return this.fn(stack);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-document.js","sourceRoot":"","sources":["policy-document.ts"],"names":[],"mappings":"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","sourcesContent":["import cdk = require('@aws-cdk/cdk');\n\nexport class PolicyDocument extends cdk.Token {\n  private statements = new Array<PolicyStatement>();\n\n  /**\n   * Creates a new IAM policy document.\n   * @param defaultDocument An IAM policy document to use as an initial\n   * policy. All statements of this document will be copied in.\n   */\n  constructor(private readonly baseDocument?: any) {\n    super();\n  }\n\n  public resolve(_context: cdk.ResolveContext): any {\n    if (this.isEmpty) {\n      return undefined;\n    }\n\n    const doc = this.baseDocument || { };\n    doc.Statement = doc.Statement || [ ];\n    doc.Version = doc.Version || '2012-10-17';\n    doc.Statement = doc.Statement.concat(this.statements);\n    return doc;\n  }\n\n  get isEmpty(): boolean {\n    return this.statements.length === 0;\n  }\n\n  /**\n   * The number of statements already added to this policy.\n   * Can be used, for example, to generate uniuqe \"sid\"s within the policy.\n   */\n  get statementCount(): number {\n    return this.statements.length;\n  }\n\n  public addStatement(statement: PolicyStatement): PolicyDocument {\n    this.statements.push(statement);\n    return this;\n  }\n}\n\n/**\n * Represents an IAM principal.\n */\nexport abstract class PolicyPrincipal {\n  /**\n   * When this Principal is used in an AssumeRole policy, the action to use.\n   */\n  public assumeRoleAction: string = 'sts:AssumeRole';\n\n  /**\n   * Return the policy fragment that identifies this principal in a Policy.\n   */\n  public abstract policyFragment(): PrincipalPolicyFragment;\n}\n\n/**\n * A collection of the fields in a PolicyStatement that can be used to identify a principal.\n *\n * This consists of the JSON used in the \"Principal\" field, and optionally a\n * set of \"Condition\"s that need to be applied to the policy.\n */\nexport class PrincipalPolicyFragment {\n  constructor(\n    public readonly principalJson: { [key: string]: string[] },\n    public readonly conditions: { [key: string]: any } = { }) {\n  }\n}\n\nexport class ArnPrincipal extends PolicyPrincipal {\n  constructor(public readonly arn: string) {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ AWS: [ this.arn ] });\n  }\n}\n\nexport class AccountPrincipal extends ArnPrincipal {\n  constructor(public readonly accountId: any) {\n    super(new StackDependentToken(stack => `arn:${stack.partition}:iam::${accountId}:root`).toString());\n  }\n}\n\n/**\n * An IAM principal that represents an AWS service (i.e. sqs.amazonaws.com).\n */\nexport class ServicePrincipal extends PolicyPrincipal {\n  constructor(public readonly service: string) {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ Service: [ this.service ] });\n  }\n}\n\n/**\n * A policy prinicipal for canonicalUserIds - useful for S3 bucket policies that use\n * Origin Access identities.\n *\n * See https://docs.aws.amazon.com/general/latest/gr/acct-identifiers.html\n *\n * and\n *\n * https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-restricting-access-to-s3.html\n *\n * for more details.\n *\n */\nexport class CanonicalUserPrincipal extends PolicyPrincipal {\n  constructor(public readonly canonicalUserId: string) {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ CanonicalUser: [ this.canonicalUserId ] });\n  }\n}\n\nexport class FederatedPrincipal extends PolicyPrincipal {\n  constructor(\n    public readonly federated: string,\n    public readonly conditions: {[key: string]: any},\n    public assumeRoleAction: string = 'sts:AssumeRole') {\n    super();\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ Federated: [ this.federated ] }, this.conditions);\n  }\n}\n\nexport class AccountRootPrincipal extends AccountPrincipal {\n  constructor() {\n    super(new StackDependentToken(stack => stack.accountId).toString());\n  }\n}\n\n/**\n * A principal representing all identities in all accounts\n */\nexport class AnyPrincipal extends ArnPrincipal {\n  constructor() {\n    super('*');\n  }\n}\n\n/**\n * A principal representing all identities in all accounts\n * @deprecated use `AnyPrincipal`\n */\nexport class Anyone extends AnyPrincipal { }\n\nexport class CompositePrincipal extends PolicyPrincipal {\n  private readonly principals = new Array<PolicyPrincipal>();\n\n  constructor(principal: PolicyPrincipal, ...additionalPrincipals: PolicyPrincipal[]) {\n    super();\n    this.assumeRoleAction = principal.assumeRoleAction;\n    this.addPrincipals(principal);\n    this.addPrincipals(...additionalPrincipals);\n  }\n\n  public addPrincipals(...principals: PolicyPrincipal[]): this {\n    for (const p of principals) {\n      if (p.assumeRoleAction !== this.assumeRoleAction) {\n        throw new Error(\n          `Cannot add multiple principals with different \"assumeRoleAction\". ` +\n          `Expecting \"${this.assumeRoleAction}\", got \"${p.assumeRoleAction}\"`);\n      }\n\n      const fragment = p.policyFragment();\n      if (fragment.conditions && Object.keys(fragment.conditions).length > 0) {\n        throw new Error(\n          `Components of a CompositePrincipal must not have conditions. ` +\n          `Tried to add the following fragment: ${JSON.stringify(fragment)}`);\n      }\n\n      this.principals.push(p);\n    }\n\n    return this;\n  }\n\n  public policyFragment(): PrincipalPolicyFragment {\n    const principalJson: { [key: string]: string[] } = { };\n\n    for (const p of this.principals) {\n      mergePrincipal(principalJson, p.policyFragment().principalJson);\n    }\n\n    return new PrincipalPolicyFragment(principalJson);\n  }\n}\n\n/**\n * Represents a statement in an IAM policy document.\n */\nexport class PolicyStatement extends cdk.Token {\n  private action = new Array<any>();\n  private principal: { [key: string]: any[] } = {};\n  private resource = new Array<any>();\n  private condition: { [key: string]: any } = { };\n  private effect?: PolicyStatementEffect;\n  private sid?: any;\n\n  constructor(effect: PolicyStatementEffect = PolicyStatementEffect.Allow) {\n    super();\n    this.effect = effect;\n  }\n\n  //\n  // Actions\n  //\n\n  public addAction(action: string): PolicyStatement {\n    this.action.push(action);\n    return this;\n  }\n\n  public addActions(...actions: string[]): PolicyStatement {\n    actions.forEach(action => this.addAction(action));\n    return this;\n  }\n\n  //\n  // Principal\n  //\n\n  /**\n   * Indicates if this permission has a \"Principal\" section.\n   */\n  public get hasPrincipal() {\n    return Object.keys(this.principal).length > 0;\n  }\n\n  public addPrincipal(principal: PolicyPrincipal): this {\n    const fragment = principal.policyFragment();\n    mergePrincipal(this.principal, fragment.principalJson);\n    this.addConditions(fragment.conditions);\n    return this;\n  }\n\n  public addAwsPrincipal(arn: string): this {\n    return this.addPrincipal(new ArnPrincipal(arn));\n  }\n\n  public addAwsAccountPrincipal(accountId: string): this {\n    return this.addPrincipal(new AccountPrincipal(accountId));\n  }\n\n  public addArnPrincipal(arn: string): this {\n    return this.addAwsPrincipal(arn);\n  }\n\n  public addServicePrincipal(service: string): this {\n    return this.addPrincipal(new ServicePrincipal(service));\n  }\n\n  public addFederatedPrincipal(federated: any, conditions: {[key: string]: any}): this {\n    return this.addPrincipal(new FederatedPrincipal(federated, conditions));\n  }\n\n  public addAccountRootPrincipal(): this {\n    return this.addPrincipal(new AccountRootPrincipal());\n  }\n\n  public addCanonicalUserPrincipal(canonicalUserId: string): this {\n    return this.addPrincipal(new CanonicalUserPrincipal(canonicalUserId));\n  }\n\n  public addAnyPrincipal(): this {\n    return this.addPrincipal(new Anyone());\n  }\n\n  //\n  // Resources\n  //\n\n  public addResource(arn: string): PolicyStatement {\n    this.resource.push(arn);\n    return this;\n  }\n\n  /**\n   * Adds a ``\"*\"`` resource to this statement.\n   */\n  public addAllResources(): PolicyStatement {\n    return this.addResource('*');\n  }\n\n  public addResources(...arns: string[]): PolicyStatement {\n    arns.forEach(r => this.addResource(r));\n    return this;\n  }\n\n  /**\n   * Indicates if this permission as at least one resource associated with it.\n   */\n  public get hasResource() {\n    return this.resource && this.resource.length > 0;\n  }\n\n  public describe(sid: string): PolicyStatement {\n    this.sid = sid;\n    return this;\n  }\n\n  //\n  // Effect\n  //\n\n  /**\n   * Sets the permission effect to allow access to resources.\n   */\n  public allow(): PolicyStatement {\n    this.effect = PolicyStatementEffect.Allow;\n    return this;\n  }\n\n  /**\n   * Sets the permission effect to deny access to resources.\n   */\n  public deny(): PolicyStatement {\n    this.effect = PolicyStatementEffect.Deny;\n    return this;\n  }\n\n  //\n  // Condition\n  //\n\n  /**\n   * Add a condition to the Policy\n   */\n  public addCondition(key: string, value: any): PolicyStatement {\n    this.condition[key] = value;\n    return this;\n  }\n\n  /**\n   * Add multiple conditions to the Policy\n   */\n  public addConditions(conditions: {[key: string]: any}): PolicyStatement {\n    Object.keys(conditions).map(key => {\n      this.addCondition(key, conditions[key]);\n    });\n    return this;\n  }\n\n  /**\n   * Add a condition to the Policy.\n   *\n   * @deprecated For backwards compatibility. Use addCondition() instead.\n   */\n  public setCondition(key: string, value: any): PolicyStatement {\n    return this.addCondition(key, value);\n  }\n\n  public limitToAccount(accountId: string): PolicyStatement {\n    return this.addCondition('StringEquals', new cdk.Token(() => {\n      return { 'sts:ExternalId': accountId };\n    }));\n  }\n\n  //\n  // Serialization\n  //\n  public resolve(_context: cdk.ResolveContext): any {\n    return this.toJson();\n  }\n\n  public toJson(): any {\n    return {\n      Action: _norm(this.action),\n      Condition: _norm(this.condition),\n      Effect: _norm(this.effect),\n      Principal: _normPrincipal(this.principal),\n      Resource: _norm(this.resource),\n      Sid: _norm(this.sid),\n    };\n\n    function _norm(values: any) {\n\n      if (typeof(values) === 'undefined') {\n        return undefined;\n      }\n\n      if (Array.isArray(values)) {\n        if (!values || values.length === 0) {\n          return undefined;\n        }\n\n        if (values.length === 1) {\n          return values[0];\n        }\n\n        return values;\n      }\n\n      if (typeof(values) === 'object') {\n        if (Object.keys(values).length === 0) {\n          return undefined;\n        }\n      }\n\n      return values;\n    }\n\n    function _normPrincipal(principal: { [key: string]: any[] }) {\n      const keys = Object.keys(principal);\n      if (keys.length === 0) { return undefined; }\n      const result: any = {};\n      for (const key of keys) {\n        const normVal = _norm(principal[key]);\n        if (normVal) {\n          result[key] = normVal;\n        }\n      }\n      if (Object.keys(result).length === 1 && result.AWS === '*') {\n        return '*';\n      }\n      return result;\n    }\n  }\n}\n\nexport enum PolicyStatementEffect {\n  Allow = 'Allow',\n  Deny = 'Deny',\n}\n\nfunction mergePrincipal(target: { [key: string]: string[] }, source: { [key: string]: string[] }) {\n  for (const key of Object.keys(source)) {\n    target[key] = target[key] || [];\n\n    const value = source[key];\n    if (!Array.isArray(value)) {\n      throw new Error(`Principal value must be an array (it will be normalized later): ${value}`);\n    }\n\n    target[key].push(...value);\n  }\n\n  return target;\n}\n\n/**\n * A lazy token that requires an instance of Stack to evaluate\n */\nclass StackDependentToken extends cdk.Token {\n  constructor(private readonly fn: (stack: cdk.Stack) => any) {\n    super();\n  }\n\n  public resolve(context: cdk.ResolveContext) {\n    const stack = cdk.Stack.find(context.scope);\n    return this.fn(stack);\n  }\n}"]}

@@ -88,3 +88,3 @@ import { Construct, IDependable } from '@aws-cdk/cdk';

private readonly groups;
constructor(parent: Construct, name: string, props?: PolicyProps);
constructor(scope: Construct, id: string, props?: PolicyProps);
/**

@@ -106,3 +106,3 @@ * Adds a statement to the policy document.

attachToGroup(group: Group): void;
validate(): string[];
protected validate(): string[];
}

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

class Policy extends cdk_1.Construct {
constructor(parent, name, props = {}) {
super(parent, name);
constructor(scope, id, props = {}) {
super(scope, id);
/**

@@ -26,3 +26,3 @@ * The policy document.

policyDocument: this.document,
policyName: new cdk_1.Token(() => this.policyName),
policyName: new cdk_1.Token(() => this.policyName).toString(),
roles: util_1.undefinedIfEmpty(() => this.roles.map(r => r.roleName)),

@@ -100,2 +100,2 @@ users: util_1.undefinedIfEmpty(() => this.users.map(u => u.userName)),

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, Token } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { CfnPolicy } from './iam.generated';\nimport { PolicyDocument, PolicyPrincipal, PolicyStatement } from './policy-document';\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 type IIdentityResource = 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 CfnPolicy(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, Token } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { CfnPolicy } from './iam.generated';\nimport { PolicyDocument, PolicyPrincipal, PolicyStatement } from './policy-document';\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 type IIdentityResource = 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(scope: Construct, id: string, props: PolicyProps = {}) {\n    super(scope, id);\n\n    const resource = new CfnPolicy(this, 'Resource', {\n      policyDocument: this.document,\n      policyName: new Token(() => this.policyName).toString(),\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  protected 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"]}

@@ -1,2 +0,2 @@

import { Construct, IDependable } from '@aws-cdk/cdk';
import { Construct, IConstruct, IDependable } from '@aws-cdk/cdk';
import { IPrincipal, Policy } from './policy';

@@ -89,3 +89,3 @@ import { PolicyDocument, PolicyPrincipal, PolicyStatement } from './policy-document';

*/
static import(parent: Construct, id: string, props: ImportedRoleProps): IRole;
static import(scope: Construct, id: string, props: RoleImportProps): IRole;
/**

@@ -100,2 +100,7 @@ * The assume role policy document associated with this role.

/**
* Returns the stable and unique string identifying the role. For example,
* AIDAJQABLZS4A3QDU576Q.
*/
readonly roleId: string;
/**
* Returns the name of the role.

@@ -115,3 +120,4 @@ */

private readonly attachedPolicies;
constructor(parent: Construct, name: string, props: RoleProps);
constructor(scope: Construct, id: string, props: RoleProps);
export(): RoleImportProps;
/**

@@ -137,3 +143,3 @@ * Adds a permission to the role's default policy document.

*/
export interface IRole extends IPrincipal, IDependable {
export interface IRole extends IConstruct, IPrincipal, IDependable {
/**

@@ -143,2 +149,11 @@ * Returns the ARN of this role.

readonly roleArn: string;
/**
* Returns the stable and unique string identifying the role. For example,
* AIDAJQABLZS4A3QDU576Q.
*/
readonly roleId: string;
/**
* Export this role to another stack.
*/
export(): RoleImportProps;
}

@@ -148,3 +163,3 @@ /**

*/
export interface ImportedRoleProps {
export interface RoleImportProps {
/**

@@ -154,2 +169,10 @@ * The role's ARN

roleArn: string;
/**
* The stable and unique string identifying the role. For example,
* AIDAJQABLZS4A3QDU576Q.
*
* @default If "roleId" is not specified for an imported role, then
* `role.roleId` will throw an exception. In most cases, role ID is not really needed.
*/
roleId?: string;
}

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

class Role extends cdk_1.Construct {
constructor(parent, name, props) {
super(parent, name);
constructor(scope, id, props) {
super(scope, id);
this.attachedPolicies = new util_1.AttachedPolicies();

@@ -30,2 +30,3 @@ this.assumeRolePolicy = createAssumeRolePolicy(props.assumedBy, props.externalId);

});
this.roleId = role.roleId;
this.roleArn = role.roleArn;

@@ -50,5 +51,11 @@ this.principal = new policy_document_1.ArnPrincipal(this.roleArn);

*/
static import(parent, id, props) {
return new ImportedRole(parent, id, props);
static import(scope, id, props) {
return new ImportedRole(scope, id, props);
}
export() {
return {
roleArn: new cdk_1.Output(this, 'RoleArn', { value: this.roleArn }).makeImportValue(),
roleId: new cdk_1.Output(this, 'RoleId', { value: this.roleId }).makeImportValue()
};
}
/**

@@ -106,8 +113,19 @@ * Adds a permission to the role's default policy document.

class ImportedRole extends cdk_1.Construct {
constructor(parent, id, props) {
super(parent, id);
constructor(scope, id, props) {
super(scope, id);
this.props = props;
this.dependencyElements = [];
this.roleArn = props.roleArn;
this._roleId = props.roleId;
this.principal = new policy_document_1.ArnPrincipal(this.roleArn);
}
get roleId() {
if (!this._roleId) {
throw new Error(`No roleId specified for imported role`);
}
return this._roleId;
}
export() {
return this.props;
}
addToPolicy(_statement) {

@@ -123,2 +141,2 @@ // FIXME: Add warning that we're ignoring this

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["role.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, IDependable } from '@aws-cdk/cdk';\nimport { CfnRole } from './iam.generated';\nimport { IPrincipal, Policy } from './policy';\nimport { ArnPrincipal, PolicyDocument, PolicyPrincipal, PolicyStatement } from './policy-document';\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   * ID that the role assumer needs to provide when assuming this role\n   *\n   * If the configured and provided external IDs do not match, the\n   * AssumeRole operation will fail.\n   *\n   * @default No external ID required\n   */\n  externalId?: string;\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   * A list of named policies to inline into this role. These policies will be\n   * created with the role, whereas those added by ``addToPolicy`` are added\n   * using a separate CloudFormation resource (allowing a way around circular\n   * dependencies that could otherwise be introduced).\n   * @default No policy is inlined in the Role resource.\n   */\n  inlinePolicies?: { [name: string]: PolicyDocument };\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 IRole {\n  /**\n   * Import a role that already exists\n   */\n  public static import(parent: Construct, id: string, props: ImportedRoleProps): IRole {\n    return new ImportedRole(parent, id, props);\n  }\n\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, props.externalId);\n    this.managedPolicyArns = props.managedPolicyArns || [ ];\n\n    validateMaxSessionDuration(props.maxSessionDurationSec);\n\n    const role = new CfnRole(this, 'Resource', {\n      assumeRolePolicyDocument: this.assumeRolePolicy as any,\n      managedPolicyArns: undefinedIfEmpty(() => this.managedPolicyArns),\n      policies: _flatten(props.inlinePolicies),\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    function _flatten(policies?: { [name: string]: PolicyDocument }) {\n      if (policies == null || Object.keys(policies).length === 0) {\n        return undefined;\n      }\n      const result = new Array<CfnRole.PolicyProperty>();\n      for (const policyName of Object.keys(policies)) {\n        const policyDocument = policies[policyName];\n        result.push({ policyName, policyDocument });\n      }\n      return result;\n    }\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\n/**\n * A Role object\n */\nexport interface IRole extends IPrincipal, IDependable {\n  /**\n   * Returns the ARN of this role.\n   */\n  readonly roleArn: string;\n}\n\nfunction createAssumeRolePolicy(principal: PolicyPrincipal, externalId?: string) {\n  const statement = new PolicyStatement();\n  statement\n      .addPrincipal(principal)\n      .addAction(principal.assumeRoleAction);\n\n  if (externalId !== undefined) {\n    statement.addCondition('StringEquals', { 'sts:ExternalId': externalId });\n  }\n\n  return new PolicyDocument().addStatement(statement);\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\n/**\n * Properties to import a Role\n */\nexport interface ImportedRoleProps {\n  /**\n   * The role's ARN\n   */\n  roleArn: string;\n}\n\n/**\n * A role that already exists\n */\nclass ImportedRole extends Construct implements IRole {\n  public readonly roleArn: string;\n  public readonly principal: PolicyPrincipal;\n  public readonly dependencyElements: IDependable[] = [];\n\n  constructor(parent: Construct, id: string, props: ImportedRoleProps) {\n    super(parent, id);\n    this.roleArn = props.roleArn;\n    this.principal = new ArnPrincipal(this.roleArn);\n  }\n\n  public addToPolicy(_statement: PolicyStatement): void {\n    // FIXME: Add warning that we're ignoring this\n  }\n\n  public attachInlinePolicy(_policy: Policy): void {\n    // FIXME: Add warning that we're ignoring this\n  }\n\n  public attachManagedPolicy(_arn: string): void {\n    // FIXME: Add warning that we're ignoring this\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role.js","sourceRoot":"","sources":["role.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, IConstruct, IDependable, Output } from '@aws-cdk/cdk';\nimport { CfnRole } from './iam.generated';\nimport { IPrincipal, Policy } from './policy';\nimport { ArnPrincipal, PolicyDocument, PolicyPrincipal, PolicyStatement } from './policy-document';\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   * ID that the role assumer needs to provide when assuming this role\n   *\n   * If the configured and provided external IDs do not match, the\n   * AssumeRole operation will fail.\n   *\n   * @default No external ID required\n   */\n  externalId?: string;\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   * A list of named policies to inline into this role. These policies will be\n   * created with the role, whereas those added by ``addToPolicy`` are added\n   * using a separate CloudFormation resource (allowing a way around circular\n   * dependencies that could otherwise be introduced).\n   * @default No policy is inlined in the Role resource.\n   */\n  inlinePolicies?: { [name: string]: PolicyDocument };\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 IRole {\n  /**\n   * Import a role that already exists\n   */\n  public static import(scope: Construct, id: string, props: RoleImportProps): IRole {\n    return new ImportedRole(scope, id, props);\n  }\n\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 stable and unique string identifying the role. For example,\n   * AIDAJQABLZS4A3QDU576Q.\n   */\n  public readonly roleId: 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(scope: Construct, id: string, props: RoleProps) {\n    super(scope, id);\n\n    this.assumeRolePolicy = createAssumeRolePolicy(props.assumedBy, props.externalId);\n    this.managedPolicyArns = props.managedPolicyArns || [ ];\n\n    validateMaxSessionDuration(props.maxSessionDurationSec);\n\n    const role = new CfnRole(this, 'Resource', {\n      assumeRolePolicyDocument: this.assumeRolePolicy as any,\n      managedPolicyArns: undefinedIfEmpty(() => this.managedPolicyArns),\n      policies: _flatten(props.inlinePolicies),\n      path: props.path,\n      roleName: props.roleName,\n      maxSessionDuration: props.maxSessionDurationSec,\n    });\n\n    this.roleId = role.roleId;\n    this.roleArn = role.roleArn;\n    this.principal = new ArnPrincipal(this.roleArn);\n    this.roleName = role.roleName;\n    this.dependencyElements = [ role ];\n\n    function _flatten(policies?: { [name: string]: PolicyDocument }) {\n      if (policies == null || Object.keys(policies).length === 0) {\n        return undefined;\n      }\n      const result = new Array<CfnRole.PolicyProperty>();\n      for (const policyName of Object.keys(policies)) {\n        const policyDocument = policies[policyName];\n        result.push({ policyName, policyDocument });\n      }\n      return result;\n    }\n  }\n\n  public export(): RoleImportProps {\n    return {\n      roleArn: new Output(this, 'RoleArn', { value: this.roleArn }).makeImportValue(),\n      roleId: new Output(this, 'RoleId', { value: this.roleId }).makeImportValue()\n    };\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\n/**\n * A Role object\n */\nexport interface IRole extends IConstruct, IPrincipal, IDependable {\n  /**\n   * Returns the ARN of this role.\n   */\n  readonly roleArn: string;\n\n  /**\n   * Returns the stable and unique string identifying the role. For example,\n   * AIDAJQABLZS4A3QDU576Q.\n   */\n  readonly roleId: string;\n\n  /**\n   * Export this role to another stack.\n   */\n  export(): RoleImportProps;\n}\n\nfunction createAssumeRolePolicy(principal: PolicyPrincipal, externalId?: string) {\n  const statement = new PolicyStatement();\n  statement\n      .addPrincipal(principal)\n      .addAction(principal.assumeRoleAction);\n\n  if (externalId !== undefined) {\n    statement.addCondition('StringEquals', { 'sts:ExternalId': externalId });\n  }\n\n  return new PolicyDocument().addStatement(statement);\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\n/**\n * Properties to import a Role\n */\nexport interface RoleImportProps {\n  /**\n   * The role's ARN\n   */\n  roleArn: string;\n\n  /**\n   * The stable and unique string identifying the role. For example,\n   * AIDAJQABLZS4A3QDU576Q.\n   *\n   * @default If \"roleId\" is not specified for an imported role, then\n   * `role.roleId` will throw an exception. In most cases, role ID is not really needed.\n   */\n  roleId?: string;\n}\n\n/**\n * A role that already exists\n */\nclass ImportedRole extends Construct implements IRole {\n  public readonly roleArn: string;\n  public readonly principal: PolicyPrincipal;\n  public readonly dependencyElements: IDependable[] = [];\n\n  private readonly _roleId?: string;\n\n  constructor(scope: Construct, id: string, private readonly props: RoleImportProps) {\n    super(scope, id);\n    this.roleArn = props.roleArn;\n    this._roleId = props.roleId;\n    this.principal = new ArnPrincipal(this.roleArn);\n  }\n\n  public get roleId() {\n    if (!this._roleId) {\n      throw new Error(`No roleId specified for imported role`);\n    }\n    return this._roleId;\n  }\n\n  public export() {\n    return this.props;\n  }\n\n  public addToPolicy(_statement: PolicyStatement): void {\n    // FIXME: Add warning that we're ignoring this\n  }\n\n  public attachInlinePolicy(_policy: Policy): void {\n    // FIXME: Add warning that we're ignoring this\n  }\n\n  public attachManagedPolicy(_arn: string): void {\n    // FIXME: Add warning that we're ignoring this\n  }\n}\n"]}

@@ -73,3 +73,3 @@ import { Construct } from '@aws-cdk/cdk';

private defaultPolicy?;
constructor(parent: Construct, name: string, props?: UserProps);
constructor(scope: Construct, id: string, props?: UserProps);
/**

@@ -76,0 +76,0 @@ * Adds this user to a group.

@@ -9,4 +9,4 @@ "use strict";

class User extends cdk_1.Construct {
constructor(parent, name, props = {}) {
super(parent, name);
constructor(scope, id, props = {}) {
super(scope, id);
this.groups = new Array();

@@ -73,2 +73,2 @@ this.managedPolicyArns = new Array();

exports.User = User;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.js","sourceRoot":"","sources":["user.ts"],"names":[],"mappings":";;AAAA,sCAAyC;AAEzC,mDAA0C;AAC1C,qCAA8C;AAC9C,uDAAmF;AACnF,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,uBAAO,CAAC,IAAI,EAAE,UAAU,EAAE;YACzC,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,8BAAY,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 { Construct } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { CfnUser } from './iam.generated';\nimport { IPrincipal, Policy } from './policy';\nimport { ArnPrincipal, PolicyPrincipal, PolicyStatement } from './policy-document';\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 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 CfnUser(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): CfnUser.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,sCAAyC;AAEzC,mDAA0C;AAC1C,qCAA8C;AAC9C,uDAAmF;AACnF,iCAA4D;AA2D5D,MAAa,IAAK,SAAQ,eAAS;IAsBjC,YAAY,KAAgB,EAAE,EAAU,EAAE,QAAmB,EAAE;QAC7D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QANF,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,uBAAO,CAAC,IAAI,EAAE,UAAU,EAAE;YACzC,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,8BAAY,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 { Construct } from '@aws-cdk/cdk';\nimport { Group } from './group';\nimport { CfnUser } from './iam.generated';\nimport { IPrincipal, Policy } from './policy';\nimport { ArnPrincipal, PolicyPrincipal, PolicyStatement } from './policy-document';\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 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(scope: Construct, id: string, props: UserProps = {}) {\n    super(scope, id);\n\n    const user = new CfnUser(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): CfnUser.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"]}

@@ -1,4 +0,4 @@

import { CloudFormationToken } from '@aws-cdk/cdk';
import { Token } from '@aws-cdk/cdk';
import { Policy } from './policy';
export declare function undefinedIfEmpty<T>(f: () => T[]): CloudFormationToken;
export declare function undefinedIfEmpty<T>(f: () => T[]): Token;
/**

@@ -5,0 +5,0 @@ * Used to generate a unique policy name based on the policy resource construct.

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

function undefinedIfEmpty(f) {
return new cdk_1.CloudFormationToken(() => {
return new cdk_1.Token(() => {
const array = f();

@@ -47,2 +47,2 @@ return (array && array.length > 0) ? array : undefined;

exports.AttachedPolicies = AttachedPolicies;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxzQ0FBbUQ7QUFHbkQsTUFBTSxtQkFBbUIsR0FBRyxHQUFHLENBQUM7QUFFaEMsU0FBZ0IsZ0JBQWdCLENBQUksQ0FBWTtJQUM5QyxPQUFPLElBQUkseUJBQW1CLENBQUMsR0FBRyxFQUFFO1FBQ2xDLE1BQU0sS0FBSyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ2xCLE9BQU8sQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDekQsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBTEQsNENBS0M7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLGtCQUFrQixDQUFDLFNBQWlCO0lBQ2xELE9BQU8sU0FBUyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDLEVBQUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ3BHLENBQUM7QUFGRCxnREFFQztBQUVEOztHQUVHO0FBQ0gsTUFBYSxnQkFBZ0I7SUFBN0I7UUFDVSxhQUFRLEdBQUcsSUFBSSxLQUFLLEVBQVUsQ0FBQztJQW1CekMsQ0FBQztJQWpCQzs7Ozs7T0FLRztJQUNJLE1BQU0sQ0FBQyxNQUFjO1FBQzFCLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssTUFBTSxDQUFDLEVBQUU7WUFDekMsT0FBTyxDQUFDLG1CQUFtQjtTQUM1QjtRQUVELElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLE1BQU0sQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUMvRCxNQUFNLElBQUksS0FBSyxDQUFDLG1CQUFtQixNQUFNLENBQUMsVUFBVSx1QkFBdUIsQ0FBQyxDQUFDO1NBQzlFO1FBRUQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0IsQ0FBQztDQUNGO0FBcEJELDRDQW9CQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsb3VkRm9ybWF0aW9uVG9rZW4gfSBmcm9tICdAYXdzLWNkay9jZGsnO1xuaW1wb3J0IHsgUG9saWN5IH0gZnJvbSAnLi9wb2xpY3knO1xuXG5jb25zdCBNQVhfUE9MSUNZX05BTUVfTEVOID0gMTI4O1xuXG5leHBvcnQgZnVuY3Rpb24gdW5kZWZpbmVkSWZFbXB0eTxUPihmOiAoKSA9PiBUW10pOiBDbG91ZEZvcm1hdGlvblRva2VuIHtcbiAgcmV0dXJuIG5ldyBDbG91ZEZvcm1hdGlvblRva2VuKCgpID0+IHtcbiAgICBjb25zdCBhcnJheSA9IGYoKTtcbiAgICByZXR1cm4gKGFycmF5ICYmIGFycmF5Lmxlbmd0aCA+IDApID8gYXJyYXkgOiB1bmRlZmluZWQ7XG4gIH0pO1xufVxuXG4vKipcbiAqIFVzZWQgdG8gZ2VuZXJhdGUgYSB1bmlxdWUgcG9saWN5IG5hbWUgYmFzZWQgb24gdGhlIHBvbGljeSByZXNvdXJjZSBjb25zdHJ1Y3QuXG4gKiBUaGUgbG9naWNhbCBJRCBvZiB0aGUgcmVzb3VyY2UgaXMgYSBncmVhdCBjYW5kaWRhdGUgYXMgbG9uZyBhcyBpdCBkb2Vzbid0IGV4Y2VlZFxuICogMTI4IGNoYXJhY3RlcnMsIHNvIHdlIHRha2UgdGhlIGxhc3QgMTI4IGNoYXJhY3RlcnMgKGluIG9yZGVyIHRvIG1ha2Ugc3VyZSB0aGUgaGFzaFxuICogaXMgdGhlcmUpLlxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2VuZXJhdGVQb2xpY3lOYW1lKGxvZ2ljYWxJZDogc3RyaW5nKSB7XG4gIHJldHVybiBsb2dpY2FsSWQuc3Vic3RyaW5nKE1hdGgubWF4KGxvZ2ljYWxJZC5sZW5ndGggLSBNQVhfUE9MSUNZX05BTUVfTEVOLCAwKSwgbG9naWNhbElkLmxlbmd0aCk7XG59XG5cbi8qKlxuICogSGVscGVyIGNsYXNzIHRoYXQgbWFpbnRhaW5zIHRoZSBzZXQgb2YgYXR0YWNoZWQgcG9saWNpZXMgZm9yIGEgcHJpbmNpcGFsLlxuICovXG5leHBvcnQgY2xhc3MgQXR0YWNoZWRQb2xpY2llcyB7XG4gIHByaXZhdGUgcG9saWNpZXMgPSBuZXcgQXJyYXk8UG9saWN5PigpO1xuXG4gIC8qKlxuICAgKiBBZGRzIGEgcG9saWN5IHRvIHRoZSBsaXN0IG9mIGF0dGFjaGVkIHBvbGljaWVzLlxuICAgKlxuICAgKiBJZiB0aGlzIHBvbGljeSBpcyBhbHJlYWR5LCBhdHRhY2hlZCwgcmV0dXJucyBmYWxzZS5cbiAgICogSWYgdGhlcmUgaXMgYW5vdGhlciBwb2xpY3kgYXR0YWNoZWQgd2l0aCB0aGUgc2FtZSBuYW1lLCB0aHJvd3MgYW4gZXhjZXB0aW9uLlxuICAgKi9cbiAgcHVibGljIGF0dGFjaChwb2xpY3k6IFBvbGljeSkge1xuICAgIGlmICh0aGlzLnBvbGljaWVzLmZpbmQocCA9PiBwID09PSBwb2xpY3kpKSB7XG4gICAgICByZXR1cm47IC8vIGFscmVhZHkgYXR0YWNoZWRcbiAgICB9XG5cbiAgICBpZiAodGhpcy5wb2xpY2llcy5maW5kKHAgPT4gcC5wb2xpY3lOYW1lID09PSBwb2xpY3kucG9saWN5TmFtZSkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgQSBwb2xpY3kgbmFtZWQgXCIke3BvbGljeS5wb2xpY3lOYW1lfVwiIGlzIGFscmVhZHkgYXR0YWNoZWRgKTtcbiAgICB9XG5cbiAgICB0aGlzLnBvbGljaWVzLnB1c2gocG9saWN5KTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInV0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxzQ0FBcUM7QUFHckMsTUFBTSxtQkFBbUIsR0FBRyxHQUFHLENBQUM7QUFFaEMsU0FBZ0IsZ0JBQWdCLENBQUksQ0FBWTtJQUM5QyxPQUFPLElBQUksV0FBSyxDQUFDLEdBQUcsRUFBRTtRQUNwQixNQUFNLEtBQUssR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNsQixPQUFPLENBQUMsS0FBSyxJQUFJLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO0lBQ3pELENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUxELDRDQUtDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFnQixrQkFBa0IsQ0FBQyxTQUFpQjtJQUNsRCxPQUFPLFNBQVMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsTUFBTSxHQUFHLG1CQUFtQixFQUFFLENBQUMsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUNwRyxDQUFDO0FBRkQsZ0RBRUM7QUFFRDs7R0FFRztBQUNILE1BQWEsZ0JBQWdCO0lBQTdCO1FBQ1UsYUFBUSxHQUFHLElBQUksS0FBSyxFQUFVLENBQUM7SUFtQnpDLENBQUM7SUFqQkM7Ozs7O09BS0c7SUFDSSxNQUFNLENBQUMsTUFBYztRQUMxQixJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLE1BQU0sQ0FBQyxFQUFFO1lBQ3pDLE9BQU8sQ0FBQyxtQkFBbUI7U0FDNUI7UUFFRCxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxNQUFNLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDL0QsTUFBTSxJQUFJLEtBQUssQ0FBQyxtQkFBbUIsTUFBTSxDQUFDLFVBQVUsdUJBQXVCLENBQUMsQ0FBQztTQUM5RTtRQUVELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdCLENBQUM7Q0FDRjtBQXBCRCw0Q0FvQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUb2tlbiB9IGZyb20gJ0Bhd3MtY2RrL2Nkayc7XG5pbXBvcnQgeyBQb2xpY3kgfSBmcm9tICcuL3BvbGljeSc7XG5cbmNvbnN0IE1BWF9QT0xJQ1lfTkFNRV9MRU4gPSAxMjg7XG5cbmV4cG9ydCBmdW5jdGlvbiB1bmRlZmluZWRJZkVtcHR5PFQ+KGY6ICgpID0+IFRbXSk6IFRva2VuIHtcbiAgcmV0dXJuIG5ldyBUb2tlbigoKSA9PiB7XG4gICAgY29uc3QgYXJyYXkgPSBmKCk7XG4gICAgcmV0dXJuIChhcnJheSAmJiBhcnJheS5sZW5ndGggPiAwKSA/IGFycmF5IDogdW5kZWZpbmVkO1xuICB9KTtcbn1cblxuLyoqXG4gKiBVc2VkIHRvIGdlbmVyYXRlIGEgdW5pcXVlIHBvbGljeSBuYW1lIGJhc2VkIG9uIHRoZSBwb2xpY3kgcmVzb3VyY2UgY29uc3RydWN0LlxuICogVGhlIGxvZ2ljYWwgSUQgb2YgdGhlIHJlc291cmNlIGlzIGEgZ3JlYXQgY2FuZGlkYXRlIGFzIGxvbmcgYXMgaXQgZG9lc24ndCBleGNlZWRcbiAqIDEyOCBjaGFyYWN0ZXJzLCBzbyB3ZSB0YWtlIHRoZSBsYXN0IDEyOCBjaGFyYWN0ZXJzIChpbiBvcmRlciB0byBtYWtlIHN1cmUgdGhlIGhhc2hcbiAqIGlzIHRoZXJlKS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdlbmVyYXRlUG9saWN5TmFtZShsb2dpY2FsSWQ6IHN0cmluZykge1xuICByZXR1cm4gbG9naWNhbElkLnN1YnN0cmluZyhNYXRoLm1heChsb2dpY2FsSWQubGVuZ3RoIC0gTUFYX1BPTElDWV9OQU1FX0xFTiwgMCksIGxvZ2ljYWxJZC5sZW5ndGgpO1xufVxuXG4vKipcbiAqIEhlbHBlciBjbGFzcyB0aGF0IG1haW50YWlucyB0aGUgc2V0IG9mIGF0dGFjaGVkIHBvbGljaWVzIGZvciBhIHByaW5jaXBhbC5cbiAqL1xuZXhwb3J0IGNsYXNzIEF0dGFjaGVkUG9saWNpZXMge1xuICBwcml2YXRlIHBvbGljaWVzID0gbmV3IEFycmF5PFBvbGljeT4oKTtcblxuICAvKipcbiAgICogQWRkcyBhIHBvbGljeSB0byB0aGUgbGlzdCBvZiBhdHRhY2hlZCBwb2xpY2llcy5cbiAgICpcbiAgICogSWYgdGhpcyBwb2xpY3kgaXMgYWxyZWFkeSwgYXR0YWNoZWQsIHJldHVybnMgZmFsc2UuXG4gICAqIElmIHRoZXJlIGlzIGFub3RoZXIgcG9saWN5IGF0dGFjaGVkIHdpdGggdGhlIHNhbWUgbmFtZSwgdGhyb3dzIGFuIGV4Y2VwdGlvbi5cbiAgICovXG4gIHB1YmxpYyBhdHRhY2gocG9saWN5OiBQb2xpY3kpIHtcbiAgICBpZiAodGhpcy5wb2xpY2llcy5maW5kKHAgPT4gcCA9PT0gcG9saWN5KSkge1xuICAgICAgcmV0dXJuOyAvLyBhbHJlYWR5IGF0dGFjaGVkXG4gICAgfVxuXG4gICAgaWYgKHRoaXMucG9saWNpZXMuZmluZChwID0+IHAucG9saWN5TmFtZSA9PT0gcG9saWN5LnBvbGljeU5hbWUpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEEgcG9saWN5IG5hbWVkIFwiJHtwb2xpY3kucG9saWN5TmFtZX1cIiBpcyBhbHJlYWR5IGF0dGFjaGVkYCk7XG4gICAgfVxuXG4gICAgdGhpcy5wb2xpY2llcy5wdXNoKHBvbGljeSk7XG4gIH1cbn1cbiJdfQ==
{
"name": "@aws-cdk/aws-iam",
"version": "0.21.0",
"version": "0.22.0",
"description": "CDK routines for easily assigning correct and minimal IAM permissions",

@@ -37,3 +37,5 @@ "main": "lib/index.js",

"integ": "cdk-integ",
"package": "cdk-package"
"package": "cdk-package",
"awslint": "cdk-awslint",
"cfn2ts": "cfn2ts"
},

@@ -58,14 +60,14 @@ "cdk-build": {

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

@@ -72,0 +74,0 @@ "engines": {

import cdk = require('@aws-cdk/cdk');
export declare class ExampleConstruct extends cdk.Construct {
constructor(parent: cdk.Construct, id: string);
constructor(scope: cdk.Construct, id: string);
}

@@ -6,4 +6,4 @@ "use strict";

class ExampleConstruct extends cdk.Construct {
constructor(parent, id) {
super(parent, id);
constructor(scope, id) {
super(scope, id);
/// !show

@@ -19,2 +19,2 @@ const user = new lib_1.User(this, 'MyUser', { password: '1234' });

exports.ExampleConstruct = ExampleConstruct;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5hdHRhY2hpbmcubGl0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXhhbXBsZS5hdHRhY2hpbmcubGl0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsb0NBQXFDO0FBQ3JDLGdDQUE2QztBQUU3QyxNQUFhLGdCQUFpQixTQUFRLEdBQUcsQ0FBQyxTQUFTO0lBQ2pELFlBQVksTUFBcUIsRUFBRSxFQUFVO1FBQzNDLEtBQUssQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFbEIsU0FBUztRQUNULE1BQU0sSUFBSSxHQUFHLElBQUksVUFBSSxDQUFDLElBQUksRUFBRSxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUM1RCxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFFekMsTUFBTSxNQUFNLEdBQUcsSUFBSSxZQUFNLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzVDLE1BQU0sQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUIsS0FBSyxDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2pDLFNBQVM7SUFDWCxDQUFDO0NBQ0Y7QUFiRCw0Q0FhQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IEdyb3VwLCBQb2xpY3ksIFVzZXIgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgY2xhc3MgRXhhbXBsZUNvbnN0cnVjdCBleHRlbmRzIGNkay5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcblxuICAgIC8vLyAhc2hvd1xuICAgIGNvbnN0IHVzZXIgPSBuZXcgVXNlcih0aGlzLCAnTXlVc2VyJywgeyBwYXNzd29yZDogJzEyMzQnIH0pO1xuICAgIGNvbnN0IGdyb3VwID0gbmV3IEdyb3VwKHRoaXMsICdNeUdyb3VwJyk7XG5cbiAgICBjb25zdCBwb2xpY3kgPSBuZXcgUG9saWN5KHRoaXMsICdNeVBvbGljeScpO1xuICAgIHBvbGljeS5hdHRhY2hUb1VzZXIodXNlcik7XG4gICAgZ3JvdXAuYXR0YWNoSW5saW5lUG9saWN5KHBvbGljeSk7XG4gICAgLy8vICFoaWRlXG4gIH1cbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5hdHRhY2hpbmcubGl0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZXhhbXBsZS5hdHRhY2hpbmcubGl0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsb0NBQXFDO0FBQ3JDLGdDQUE2QztBQUU3QyxNQUFhLGdCQUFpQixTQUFRLEdBQUcsQ0FBQyxTQUFTO0lBQ2pELFlBQVksS0FBb0IsRUFBRSxFQUFVO1FBQzFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsU0FBUztRQUNULE1BQU0sSUFBSSxHQUFHLElBQUksVUFBSSxDQUFDLElBQUksRUFBRSxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUM1RCxNQUFNLEtBQUssR0FBRyxJQUFJLFdBQUssQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFFekMsTUFBTSxNQUFNLEdBQUcsSUFBSSxZQUFNLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzVDLE1BQU0sQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUIsS0FBSyxDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2pDLFNBQVM7SUFDWCxDQUFDO0NBQ0Y7QUFiRCw0Q0FhQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IEdyb3VwLCBQb2xpY3ksIFVzZXIgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgY2xhc3MgRXhhbXBsZUNvbnN0cnVjdCBleHRlbmRzIGNkay5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICAvLy8gIXNob3dcbiAgICBjb25zdCB1c2VyID0gbmV3IFVzZXIodGhpcywgJ015VXNlcicsIHsgcGFzc3dvcmQ6ICcxMjM0JyB9KTtcbiAgICBjb25zdCBncm91cCA9IG5ldyBHcm91cCh0aGlzLCAnTXlHcm91cCcpO1xuXG4gICAgY29uc3QgcG9saWN5ID0gbmV3IFBvbGljeSh0aGlzLCAnTXlQb2xpY3knKTtcbiAgICBwb2xpY3kuYXR0YWNoVG9Vc2VyKHVzZXIpO1xuICAgIGdyb3VwLmF0dGFjaElubGluZVBvbGljeShwb2xpY3kpO1xuICAgIC8vLyAhaGlkZVxuICB9XG59Il19
import cdk = require('@aws-cdk/cdk');
export declare class ExampleConstruct extends cdk.Construct {
constructor(parent: cdk.Construct, id: string);
constructor(scope: cdk.Construct, id: string);
}

@@ -6,4 +6,4 @@ "use strict";

class ExampleConstruct extends cdk.Construct {
constructor(parent, id) {
super(parent, id);
constructor(scope, id) {
super(scope, id);
/// !show

@@ -19,2 +19,2 @@ const role = new iam.Role(this, 'MyRole', {

exports.ExampleConstruct = ExampleConstruct;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5leHRlcm5hbC1pZC5saXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJleGFtcGxlLmV4dGVybmFsLWlkLmxpdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUNyQyw4QkFBK0I7QUFFL0IsTUFBYSxnQkFBaUIsU0FBUSxHQUFHLENBQUMsU0FBUztJQUNqRCxZQUFZLE1BQXFCLEVBQUUsRUFBVTtRQUMzQyxLQUFLLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWxCLFNBQVM7UUFDVCxNQUFNLElBQUksR0FBRyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRTtZQUN4QyxTQUFTLEVBQUUsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxDQUFDO1lBQ25ELFVBQVUsRUFBRSxXQUFXO1NBQ3hCLENBQUMsQ0FBQztRQUNILFNBQVM7UUFFVCxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3RCLENBQUM7Q0FDRjtBQWJELDRDQWFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IGlhbSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5leHBvcnQgY2xhc3MgRXhhbXBsZUNvbnN0cnVjdCBleHRlbmRzIGNkay5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcblxuICAgIC8vLyAhc2hvd1xuICAgIGNvbnN0IHJvbGUgPSBuZXcgaWFtLlJvbGUodGhpcywgJ015Um9sZScsIHtcbiAgICAgIGFzc3VtZWRCeTogbmV3IGlhbS5BY2NvdW50UHJpbmNpcGFsKCcxMjM0NTY3ODkwMTInKSxcbiAgICAgIGV4dGVybmFsSWQ6ICdTVVBQTFktTUUnLFxuICAgIH0pO1xuICAgIC8vLyAhaGlkZVxuXG4gICAgQXJyYXkuaXNBcnJheShyb2xlKTtcbiAgfVxufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5leHRlcm5hbC1pZC5saXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJleGFtcGxlLmV4dGVybmFsLWlkLmxpdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLG9DQUFxQztBQUNyQyw4QkFBK0I7QUFFL0IsTUFBYSxnQkFBaUIsU0FBUSxHQUFHLENBQUMsU0FBUztJQUNqRCxZQUFZLEtBQW9CLEVBQUUsRUFBVTtRQUMxQyxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLFNBQVM7UUFDVCxNQUFNLElBQUksR0FBRyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRTtZQUN4QyxTQUFTLEVBQUUsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxDQUFDO1lBQ25ELFVBQVUsRUFBRSxXQUFXO1NBQ3hCLENBQUMsQ0FBQztRQUNILFNBQVM7UUFFVCxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3RCLENBQUM7Q0FDRjtBQWJELDRDQWFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IGlhbSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5leHBvcnQgY2xhc3MgRXhhbXBsZUNvbnN0cnVjdCBleHRlbmRzIGNkay5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICAvLy8gIXNob3dcbiAgICBjb25zdCByb2xlID0gbmV3IGlhbS5Sb2xlKHRoaXMsICdNeVJvbGUnLCB7XG4gICAgICBhc3N1bWVkQnk6IG5ldyBpYW0uQWNjb3VudFByaW5jaXBhbCgnMTIzNDU2Nzg5MDEyJyksXG4gICAgICBleHRlcm5hbElkOiAnU1VQUExZLU1FJyxcbiAgICB9KTtcbiAgICAvLy8gIWhpZGVcblxuICAgIEFycmF5LmlzQXJyYXkocm9sZSk7XG4gIH1cbn0iXX0=
import cdk = require('@aws-cdk/cdk');
export declare class ExampleConstruct extends cdk.Construct {
constructor(parent: cdk.Construct, id: string);
constructor(scope: cdk.Construct, id: string);
}

@@ -6,4 +6,4 @@ "use strict";

class ExampleConstruct extends cdk.Construct {
constructor(parent, id) {
super(parent, id);
constructor(scope, id) {
super(scope, id);
/// !show

@@ -16,2 +16,2 @@ const group = new lib_1.Group(this, 'MyGroup');

exports.ExampleConstruct = ExampleConstruct;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5tYW5hZ2VkcG9saWN5LmxpdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImV4YW1wbGUubWFuYWdlZHBvbGljeS5saXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsZ0NBQStCO0FBRS9CLE1BQWEsZ0JBQWlCLFNBQVEsR0FBRyxDQUFDLFNBQVM7SUFDakQsWUFBWSxNQUFxQixFQUFFLEVBQVU7UUFDM0MsS0FBSyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVsQixTQUFTO1FBQ1QsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3pDLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyw2Q0FBNkMsQ0FBQyxDQUFDO1FBQ3pFLFNBQVM7SUFDWCxDQUFDO0NBQ0Y7QUFURCw0Q0FTQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IEdyb3VwIH0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0IGNsYXNzIEV4YW1wbGVDb25zdHJ1Y3QgZXh0ZW5kcyBjZGsuQ29uc3RydWN0IHtcbiAgY29uc3RydWN0b3IocGFyZW50OiBjZGsuQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG4gICAgc3VwZXIocGFyZW50LCBpZCk7XG5cbiAgICAvLy8gIXNob3dcbiAgICBjb25zdCBncm91cCA9IG5ldyBHcm91cCh0aGlzLCAnTXlHcm91cCcpO1xuICAgIGdyb3VwLmF0dGFjaE1hbmFnZWRQb2xpY3koJ2Fybjphd3M6aWFtOjphd3M6cG9saWN5L0FkbWluaXN0cmF0b3JBY2Nlc3MnKTtcbiAgICAvLy8gIWhpZGVcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5tYW5hZ2VkcG9saWN5LmxpdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImV4YW1wbGUubWFuYWdlZHBvbGljeS5saXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsZ0NBQStCO0FBRS9CLE1BQWEsZ0JBQWlCLFNBQVEsR0FBRyxDQUFDLFNBQVM7SUFDakQsWUFBWSxLQUFvQixFQUFFLEVBQVU7UUFDMUMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixTQUFTO1FBQ1QsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFLLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3pDLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyw2Q0FBNkMsQ0FBQyxDQUFDO1FBQ3pFLFNBQVM7SUFDWCxDQUFDO0NBQ0Y7QUFURCw0Q0FTQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IEdyb3VwIH0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0IGNsYXNzIEV4YW1wbGVDb25zdHJ1Y3QgZXh0ZW5kcyBjZGsuQ29uc3RydWN0IHtcbiAgY29uc3RydWN0b3Ioc2NvcGU6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgLy8vICFzaG93XG4gICAgY29uc3QgZ3JvdXAgPSBuZXcgR3JvdXAodGhpcywgJ015R3JvdXAnKTtcbiAgICBncm91cC5hdHRhY2hNYW5hZ2VkUG9saWN5KCdhcm46YXdzOmlhbTo6YXdzOnBvbGljeS9BZG1pbmlzdHJhdG9yQWNjZXNzJyk7XG4gICAgLy8vICFoaWRlXG4gIH1cbn1cbiJdfQ==
import cdk = require('@aws-cdk/cdk');
export declare class ExampleConstruct extends cdk.Construct {
constructor(parent: cdk.Construct, id: string);
constructor(scope: cdk.Construct, id: string);
}

@@ -6,4 +6,4 @@ "use strict";

class ExampleConstruct extends cdk.Construct {
constructor(parent, id) {
super(parent, id);
constructor(scope, id) {
super(scope, id);
/// !show

@@ -20,2 +20,2 @@ const role = new lib_1.Role(this, 'MyRole', {

exports.ExampleConstruct = ExampleConstruct;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5yb2xlLmxpdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImV4YW1wbGUucm9sZS5saXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsZ0NBQWlFO0FBRWpFLE1BQWEsZ0JBQWlCLFNBQVEsR0FBRyxDQUFDLFNBQVM7SUFDakQsWUFBWSxNQUFxQixFQUFFLEVBQVU7UUFDM0MsS0FBSyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVsQixTQUFTO1FBQ1QsTUFBTSxJQUFJLEdBQUcsSUFBSSxVQUFJLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRTtZQUNwQyxTQUFTLEVBQUUsSUFBSSxzQkFBZ0IsQ0FBQyxtQkFBbUIsQ0FBQztTQUNyRCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUkscUJBQWUsRUFBRTthQUNqQyxlQUFlLEVBQUU7YUFDakIsU0FBUyxDQUFDLHVCQUF1QixDQUFDLENBQUMsQ0FBQztRQUN6QyxTQUFTO0lBQ1gsQ0FBQztDQUNGO0FBZEQsNENBY0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBQb2xpY3lTdGF0ZW1lbnQsIFJvbGUsIFNlcnZpY2VQcmluY2lwYWwgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgY2xhc3MgRXhhbXBsZUNvbnN0cnVjdCBleHRlbmRzIGNkay5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5Db25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcblxuICAgIC8vLyAhc2hvd1xuICAgIGNvbnN0IHJvbGUgPSBuZXcgUm9sZSh0aGlzLCAnTXlSb2xlJywge1xuICAgICAgYXNzdW1lZEJ5OiBuZXcgU2VydmljZVByaW5jaXBhbCgnc25zLmFtYXpvbmF3cy5jb20nKVxuICAgIH0pO1xuXG4gICAgcm9sZS5hZGRUb1BvbGljeShuZXcgUG9saWN5U3RhdGVtZW50KClcbiAgICAgICAgLmFkZEFsbFJlc291cmNlcygpXG4gICAgICAgIC5hZGRBY3Rpb24oJ2xhbWJkYTpJbnZva2VGdW5jdGlvbicpKTtcbiAgICAvLy8gIWhpZGVcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5yb2xlLmxpdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImV4YW1wbGUucm9sZS5saXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsZ0NBQWlFO0FBRWpFLE1BQWEsZ0JBQWlCLFNBQVEsR0FBRyxDQUFDLFNBQVM7SUFDakQsWUFBWSxLQUFvQixFQUFFLEVBQVU7UUFDMUMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixTQUFTO1FBQ1QsTUFBTSxJQUFJLEdBQUcsSUFBSSxVQUFJLENBQUMsSUFBSSxFQUFFLFFBQVEsRUFBRTtZQUNwQyxTQUFTLEVBQUUsSUFBSSxzQkFBZ0IsQ0FBQyxtQkFBbUIsQ0FBQztTQUNyRCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUkscUJBQWUsRUFBRTthQUNqQyxlQUFlLEVBQUU7YUFDakIsU0FBUyxDQUFDLHVCQUF1QixDQUFDLENBQUMsQ0FBQztRQUN6QyxTQUFTO0lBQ1gsQ0FBQztDQUNGO0FBZEQsNENBY0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgeyBQb2xpY3lTdGF0ZW1lbnQsIFJvbGUsIFNlcnZpY2VQcmluY2lwYWwgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgY2xhc3MgRXhhbXBsZUNvbnN0cnVjdCBleHRlbmRzIGNkay5Db25zdHJ1Y3Qge1xuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkNvbnN0cnVjdCwgaWQ6IHN0cmluZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICAvLy8gIXNob3dcbiAgICBjb25zdCByb2xlID0gbmV3IFJvbGUodGhpcywgJ015Um9sZScsIHtcbiAgICAgIGFzc3VtZWRCeTogbmV3IFNlcnZpY2VQcmluY2lwYWwoJ3Nucy5hbWF6b25hd3MuY29tJylcbiAgICB9KTtcblxuICAgIHJvbGUuYWRkVG9Qb2xpY3kobmV3IFBvbGljeVN0YXRlbWVudCgpXG4gICAgICAgIC5hZGRBbGxSZXNvdXJjZXMoKVxuICAgICAgICAuYWRkQWN0aW9uKCdsYW1iZGE6SW52b2tlRnVuY3Rpb24nKSk7XG4gICAgLy8vICFoaWRlXG4gIH1cbn1cbiJdfQ==

@@ -6,4 +6,4 @@ "use strict";

class TestStack extends cdk.Stack {
constructor(parent, id) {
super(parent, id);
constructor(scope, id) {
super(scope, id);
new iam.Role(this, 'RoleWithCompositePrincipal', {

@@ -17,2 +17,2 @@ assumedBy: new iam.CompositePrincipal(new iam.ServicePrincipal('ec2.amazonaws.com'), new iam.AnyPrincipal())

app.run();
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY29tcG9zaXRlLXByaW5jaXBhbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmNvbXBvc2l0ZS1wcmluY2lwYWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsOEJBQStCO0FBRS9CLE1BQU0sU0FBVSxTQUFRLEdBQUcsQ0FBQyxLQUFLO0lBQy9CLFlBQVksTUFBZSxFQUFFLEVBQVU7UUFDckMsS0FBSyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVsQixJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLDRCQUE0QixFQUFFO1lBQy9DLFNBQVMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxrQkFBa0IsQ0FDbkMsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLENBQUMsbUJBQW1CLENBQUMsRUFDN0MsSUFBSSxHQUFHLENBQUMsWUFBWSxFQUFFLENBQ3ZCO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBRUQsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7QUFFMUIsSUFBSSxTQUFTLENBQUMsR0FBRyxFQUFFLCtCQUErQixDQUFDLENBQUM7QUFFcEQsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IGlhbSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jbGFzcyBUZXN0U3RhY2sgZXh0ZW5kcyBjZGsuU3RhY2sge1xuICBjb25zdHJ1Y3RvcihwYXJlbnQ6IGNkay5BcHAsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihwYXJlbnQsIGlkKTtcblxuICAgIG5ldyBpYW0uUm9sZSh0aGlzLCAnUm9sZVdpdGhDb21wb3NpdGVQcmluY2lwYWwnLCB7XG4gICAgICBhc3N1bWVkQnk6IG5ldyBpYW0uQ29tcG9zaXRlUHJpbmNpcGFsKFxuICAgICAgICBuZXcgaWFtLlNlcnZpY2VQcmluY2lwYWwoJ2VjMi5hbWF6b25hd3MuY29tJyksXG4gICAgICAgIG5ldyBpYW0uQW55UHJpbmNpcGFsKClcbiAgICAgIClcbiAgICB9KTtcbiAgfVxufVxuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xuXG5uZXcgVGVzdFN0YWNrKGFwcCwgJ2lhbS1pbnRlZy1jb21wb3NpdGUtcHJpbmNpcGFsJyk7XG5cbmFwcC5ydW4oKTsiXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY29tcG9zaXRlLXByaW5jaXBhbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmNvbXBvc2l0ZS1wcmluY2lwYWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxvQ0FBcUM7QUFDckMsOEJBQStCO0FBRS9CLE1BQU0sU0FBVSxTQUFRLEdBQUcsQ0FBQyxLQUFLO0lBQy9CLFlBQVksS0FBYyxFQUFFLEVBQVU7UUFDcEMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLDRCQUE0QixFQUFFO1lBQy9DLFNBQVMsRUFBRSxJQUFJLEdBQUcsQ0FBQyxrQkFBa0IsQ0FDbkMsSUFBSSxHQUFHLENBQUMsZ0JBQWdCLENBQUMsbUJBQW1CLENBQUMsRUFDN0MsSUFBSSxHQUFHLENBQUMsWUFBWSxFQUFFLENBQ3ZCO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBRUQsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7QUFFMUIsSUFBSSxTQUFTLENBQUMsR0FBRyxFQUFFLCtCQUErQixDQUFDLENBQUM7QUFFcEQsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IGlhbSA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jbGFzcyBUZXN0U3RhY2sgZXh0ZW5kcyBjZGsuU3RhY2sge1xuICBjb25zdHJ1Y3RvcihzY29wZTogY2RrLkFwcCwgaWQ6IHN0cmluZykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICBuZXcgaWFtLlJvbGUodGhpcywgJ1JvbGVXaXRoQ29tcG9zaXRlUHJpbmNpcGFsJywge1xuICAgICAgYXNzdW1lZEJ5OiBuZXcgaWFtLkNvbXBvc2l0ZVByaW5jaXBhbChcbiAgICAgICAgbmV3IGlhbS5TZXJ2aWNlUHJpbmNpcGFsKCdlYzIuYW1hem9uYXdzLmNvbScpLFxuICAgICAgICBuZXcgaWFtLkFueVByaW5jaXBhbCgpXG4gICAgICApXG4gICAgfSk7XG4gIH1cbn1cblxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcblxubmV3IFRlc3RTdGFjayhhcHAsICdpYW0taW50ZWctY29tcG9zaXRlLXByaW5jaXBhbCcpO1xuXG5hcHAucnVuKCk7Il19

@@ -6,4 +6,5 @@ "use strict";

'simple managed policy'(test) {
const mp = new lib_1.AwsManagedPolicy("service-role/SomePolicy");
test.deepEqual(cdk.resolve(mp.policyArn), {
const stack = new cdk.Stack();
const mp = new lib_1.AwsManagedPolicy("service-role/SomePolicy", stack);
test.deepEqual(stack.node.resolve(mp.policyArn), {
"Fn::Join": ['', [

@@ -18,2 +19,2 @@ 'arn:',

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5tYW5hZ2VkLXBvbGljeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QubWFuYWdlZC1wb2xpY3kudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLG9DQUFxQztBQUVyQyxnQ0FBMEM7QUFFMUMsaUJBQVM7SUFDUCx1QkFBdUIsQ0FBQyxJQUFVO1FBQ2hDLE1BQU0sRUFBRSxHQUFHLElBQUksc0JBQWdCLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUUzRCxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3hDLFVBQVUsRUFBRSxDQUFDLEVBQUUsRUFBRTtvQkFDZixNQUFNO29CQUNOLEVBQUUsR0FBRyxFQUFFLGdCQUFnQixFQUFFO29CQUN6QiwwQ0FBMEM7aUJBQzNDLENBQUM7U0FDSCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDZCxDQUFDO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCB7IFRlc3QgfSBmcm9tICdub2RldW5pdCc7XG5pbXBvcnQgeyBBd3NNYW5hZ2VkUG9saWN5IH0gZnJvbSAnLi4vbGliJztcblxuZXhwb3J0ID0ge1xuICAnc2ltcGxlIG1hbmFnZWQgcG9saWN5Jyh0ZXN0OiBUZXN0KSB7XG4gICAgY29uc3QgbXAgPSBuZXcgQXdzTWFuYWdlZFBvbGljeShcInNlcnZpY2Utcm9sZS9Tb21lUG9saWN5XCIpO1xuXG4gICAgdGVzdC5kZWVwRXF1YWwoY2RrLnJlc29sdmUobXAucG9saWN5QXJuKSwge1xuICAgICAgXCJGbjo6Sm9pblwiOiBbJycsIFtcbiAgICAgICAgJ2FybjonLFxuICAgICAgICB7IFJlZjogJ0FXUzo6UGFydGl0aW9uJyB9LFxuICAgICAgICAnOmlhbTo6YXdzOnBvbGljeS9zZXJ2aWNlLXJvbGUvU29tZVBvbGljeSdcbiAgICAgIF1dXG4gICAgfSk7XG5cbiAgICB0ZXN0LmRvbmUoKTtcbiAgfSxcbn07XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5tYW5hZ2VkLXBvbGljeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QubWFuYWdlZC1wb2xpY3kudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLG9DQUFxQztBQUVyQyxnQ0FBMEM7QUFFMUMsaUJBQVM7SUFDUCx1QkFBdUIsQ0FBQyxJQUFVO1FBQ2hDLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzlCLE1BQU0sRUFBRSxHQUFHLElBQUksc0JBQWdCLENBQUMseUJBQXlCLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFbEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsU0FBUyxDQUFDLEVBQUU7WUFDL0MsVUFBVSxFQUFFLENBQUMsRUFBRSxFQUFFO29CQUNmLE1BQU07b0JBQ04sRUFBRSxHQUFHLEVBQUUsZ0JBQWdCLEVBQUU7b0JBQ3pCLDBDQUEwQztpQkFDM0MsQ0FBQztTQUNILENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IHsgVGVzdCB9IGZyb20gJ25vZGV1bml0JztcbmltcG9ydCB7IEF3c01hbmFnZWRQb2xpY3kgfSBmcm9tICcuLi9saWInO1xuXG5leHBvcnQgPSB7XG4gICdzaW1wbGUgbWFuYWdlZCBwb2xpY3knKHRlc3Q6IFRlc3QpIHtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBjZGsuU3RhY2soKTtcbiAgICBjb25zdCBtcCA9IG5ldyBBd3NNYW5hZ2VkUG9saWN5KFwic2VydmljZS1yb2xlL1NvbWVQb2xpY3lcIiwgc3RhY2spO1xuXG4gICAgdGVzdC5kZWVwRXF1YWwoc3RhY2subm9kZS5yZXNvbHZlKG1wLnBvbGljeUFybiksIHtcbiAgICAgIFwiRm46OkpvaW5cIjogWycnLCBbXG4gICAgICAgICdhcm46JyxcbiAgICAgICAgeyBSZWY6ICdBV1M6OlBhcnRpdGlvbicgfSxcbiAgICAgICAgJzppYW06OmF3czpwb2xpY3kvc2VydmljZS1yb2xlL1NvbWVQb2xpY3knXG4gICAgICBdXVxuICAgIH0pO1xuXG4gICAgdGVzdC5kb25lKCk7XG4gIH0sXG59O1xuIl19

@@ -7,2 +7,3 @@ "use strict";

'the Permission class is a programming model for iam'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyStatement();

@@ -14,5 +15,5 @@ p.addAction('sqs:SendMessage');

p.addAllResources();
p.addAwsAccountPrincipal(new cdk_1.FnConcat('my', { account: 'account' }, 'name').toString());
p.addAwsAccountPrincipal(`my${new cdk_1.Token({ account: 'account' })}name`);
p.limitToAccount('12221121221');
test.deepEqual(cdk_1.resolve(p), { Action: ['sqs:SendMessage',
test.deepEqual(stack.node.resolve(p), { Action: ['sqs:SendMessage',
'dynamodb:CreateTable',

@@ -32,2 +33,3 @@ 'dynamodb:DeleteTable'],

'the PolicyDocument class is a dom for iam policy documents'(test) {
const stack = new cdk_1.Stack();
const doc = new lib_1.PolicyDocument();

@@ -42,3 +44,3 @@ const p1 = new lib_1.PolicyStatement();

doc.addStatement(p2);
test.deepEqual(cdk_1.resolve(doc), {
test.deepEqual(stack.node.resolve(doc), {
Version: '2012-10-17',

@@ -51,2 +53,3 @@ Statement: [{ Effect: 'Allow', Action: 'sqs:SendMessage', Resource: '*' },

'A PolicyDocument can be initialized with an existing policy, which is merged upon serialization'(test) {
const stack = new cdk_1.Stack();
const base = {

@@ -62,3 +65,3 @@ Version: 'Foo',

doc.addStatement(new lib_1.PolicyStatement().addResource('resource').addAction('action'));
test.deepEqual(cdk_1.resolve(doc), { Version: 'Foo',
test.deepEqual(stack.node.resolve(doc), { Version: 'Foo',
Something: 123,

@@ -71,4 +74,5 @@ Statement: [{ Statement1: 1 },

'Permission allows specifying multiple actions upon construction'(test) {
const stack = new cdk_1.Stack();
const perm = new lib_1.PolicyStatement().addResource('MyResource').addActions('Action1', 'Action2', 'Action3');
test.deepEqual(cdk_1.resolve(perm), {
test.deepEqual(stack.node.resolve(perm), {
Effect: 'Allow',

@@ -81,11 +85,13 @@ Action: ['Action1', 'Action2', 'Action3'],

'PolicyDoc resolves to undefined if there are no permissions'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyDocument();
test.deepEqual(cdk_1.resolve(p), undefined);
test.deepEqual(stack.node.resolve(p), undefined);
test.done();
},
'canonicalUserPrincipal adds a principal to a policy with the passed canonical user id'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyStatement();
const canoncialUser = "averysuperduperlongstringfor";
p.addPrincipal(new lib_1.CanonicalUserPrincipal(canoncialUser));
test.deepEqual(cdk_1.resolve(p), {
test.deepEqual(stack.node.resolve(p), {
Effect: "Allow",

@@ -99,5 +105,6 @@ Principal: {

'addAccountRootPrincipal adds a principal with the current account root'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyStatement();
p.addAccountRootPrincipal();
test.deepEqual(cdk_1.resolve(p), {
test.deepEqual(stack.node.resolve(p), {
Effect: "Allow",

@@ -122,5 +129,6 @@ Principal: {

'addFederatedPrincipal adds a Federated principal with the passed value'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyStatement();
p.addFederatedPrincipal("com.amazon.cognito", { StringEquals: { key: 'value' } });
test.deepEqual(cdk_1.resolve(p), {
test.deepEqual(stack.node.resolve(p), {
Effect: "Allow",

@@ -137,6 +145,7 @@ Principal: {

'addAwsAccountPrincipal can be used multiple times'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyStatement();
p.addAwsAccountPrincipal('1234');
p.addAwsAccountPrincipal('5678');
test.deepEqual(cdk_1.resolve(p), {
test.deepEqual(stack.node.resolve(p), {
Effect: 'Allow',

@@ -191,2 +200,3 @@ Principal: {

'the { AWS: "*" } principal is represented as `Anyone` or `AnyPrincipal`'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyDocument();

@@ -196,3 +206,3 @@ p.addStatement(new lib_1.PolicyStatement().addPrincipal(new lib_1.Anyone()));

p.addStatement(new lib_1.PolicyStatement().addAnyPrincipal());
test.deepEqual(cdk_1.resolve(p), {
test.deepEqual(stack.node.resolve(p), {
Statement: [

@@ -208,2 +218,3 @@ { Effect: 'Allow', Principal: '*' },

'addAwsPrincipal/addArnPrincipal are the aliases'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyDocument();

@@ -213,3 +224,3 @@ p.addStatement(new lib_1.PolicyStatement().addAwsPrincipal('111222-A'));

p.addStatement(new lib_1.PolicyStatement().addPrincipal(new lib_2.ArnPrincipal('111222-C')));
test.deepEqual(cdk_1.resolve(p), {
test.deepEqual(stack.node.resolve(p), {
Statement: [{

@@ -226,6 +237,7 @@ Effect: 'Allow', Principal: { AWS: '111222-A' }

'addCanonicalUserPrincipal can be used to add cannonical user principals'(test) {
const stack = new cdk_1.Stack();
const p = new lib_1.PolicyDocument();
p.addStatement(new lib_1.PolicyStatement().addCanonicalUserPrincipal('cannonical-user-1'));
p.addStatement(new lib_1.PolicyStatement().addPrincipal(new lib_1.CanonicalUserPrincipal('cannonical-user-2')));
test.deepEqual(cdk_1.resolve(p), {
test.deepEqual(stack.node.resolve(p), {
Statement: [

@@ -240,2 +252,3 @@ { Effect: 'Allow', Principal: { CanonicalUser: 'cannonical-user-1' } },

'addPrincipal correctly merges array in'(test) {
const stack = new cdk_1.Stack();
const arrayPrincipal = {

@@ -247,3 +260,3 @@ assumeRoleAction: 'sts:AssumeRole',

.addPrincipal(arrayPrincipal);
test.deepEqual(cdk_1.resolve(s), {
test.deepEqual(stack.node.resolve(s), {
Effect: 'Allow',

@@ -261,2 +274,3 @@ Principal: {

'policy statements with multiple principal types can be created using multiple addPrincipal calls'(test) {
const stack = new cdk_1.Stack();
const s = new lib_1.PolicyStatement()

@@ -267,3 +281,3 @@ .addAwsPrincipal('349494949494')

.addAction('action');
test.deepEqual(cdk_1.resolve(s), {
test.deepEqual(stack.node.resolve(s), {
Action: 'action',

@@ -278,5 +292,6 @@ Effect: 'Allow',

'with a single principal'(test) {
const stack = new cdk_1.Stack();
const p = new lib_2.CompositePrincipal(new lib_2.ArnPrincipal('i:am:an:arn'));
const statement = new lib_1.PolicyStatement().addPrincipal(p);
test.deepEqual(cdk_1.resolve(statement), { Effect: 'Allow', Principal: { AWS: 'i:am:an:arn' } });
test.deepEqual(stack.node.resolve(statement), { Effect: 'Allow', Principal: { AWS: 'i:am:an:arn' } });
test.done();

@@ -290,2 +305,3 @@ },

'principals and conditions are a big nice merge'(test) {
const stack = new cdk_1.Stack();
// add via ctor

@@ -299,3 +315,3 @@ const p = new lib_2.CompositePrincipal(new lib_2.ArnPrincipal('i:am:an:arn'), new lib_2.ServicePrincipal('amazon.com'));

statement.addCondition('cond2', { boom: 123 });
test.deepEqual(cdk_1.resolve(statement), {
test.deepEqual(stack.node.resolve(statement), {
Condition: {

@@ -321,2 +337,2 @@ cond2: { boom: 123 }

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.policy-document.js","sourceRoot":"","sources":["test.policy-document.ts"],"names":[],"mappings":"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","sourcesContent":["import { FnConcat, resolve } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Anyone, AnyPrincipal, CanonicalUserPrincipal, PolicyDocument, PolicyPrincipal, PolicyStatement } from '../lib';\nimport { ArnPrincipal, CompositePrincipal, FederatedPrincipal, PrincipalPolicyFragment, ServicePrincipal } from '../lib';\n\nexport = {\n  'the Permission class is a programming model for iam'(test: Test) {\n    const p = new PolicyStatement();\n    p.addAction('sqs:SendMessage');\n    p.addActions('dynamodb:CreateTable', 'dynamodb:DeleteTable');\n    p.addResource('myQueue');\n    p.addResource('yourQueue');\n\n    p.addAllResources();\n    p.addAwsAccountPrincipal(new FnConcat('my', { account: 'account' }, 'name').toString());\n    p.limitToAccount('12221121221');\n\n    test.deepEqual(resolve(p), { Action:\n      [ 'sqs:SendMessage',\n        'dynamodb:CreateTable',\n        'dynamodb:DeleteTable' ],\n       Resource: [ 'myQueue', 'yourQueue', '*' ],\n       Effect: 'Allow',\n       Principal:\n      { AWS:\n         { 'Fn::Join':\n          [ '',\n          [ 'arn:',\n            { Ref: 'AWS::Partition' },\n            ':iam::my',\n            { account: 'account' },\n            'name:root' ] ] } },\n       Condition: { StringEquals: { 'sts:ExternalId': '12221121221' } } });\n\n    test.done();\n  },\n\n  'the PolicyDocument class is a dom for iam policy documents'(test: Test) {\n    const doc = new PolicyDocument();\n    const p1 = new PolicyStatement();\n    p1.addAction('sqs:SendMessage');\n    p1.addResource('*');\n\n    const p2 = new PolicyStatement();\n    p2.deny();\n    p2.addActions('cloudformation:CreateStack');\n\n    doc.addStatement(p1);\n    doc.addStatement(p2);\n\n    test.deepEqual(resolve(doc), {\n      Version: '2012-10-17',\n      Statement:\n        [ { Effect: 'Allow', Action: 'sqs:SendMessage', Resource: '*' },\n          { Effect: 'Deny', Action: 'cloudformation:CreateStack' } ] });\n\n    test.done();\n  },\n\n  'A PolicyDocument can be initialized with an existing policy, which is merged upon serialization'(test: Test) {\n    const base = {\n      Version: 'Foo',\n      Something: 123,\n      Statement: [\n        { Statement1: 1 },\n        { Statement2: 2 }\n      ]\n    };\n    const doc = new PolicyDocument(base);\n    doc.addStatement(new PolicyStatement().addResource('resource').addAction('action'));\n\n    test.deepEqual(resolve(doc), { Version: 'Foo',\n    Something: 123,\n    Statement:\n     [ { Statement1: 1 },\n       { Statement2: 2 },\n       { Effect: 'Allow', Action: 'action', Resource: 'resource' } ] });\n    test.done();\n  },\n\n  'Permission allows specifying multiple actions upon construction'(test: Test) {\n    const perm = new PolicyStatement().addResource('MyResource').addActions('Action1', 'Action2', 'Action3');\n    test.deepEqual(resolve(perm), {\n      Effect: 'Allow',\n      Action: [ 'Action1', 'Action2', 'Action3' ],\n      Resource: 'MyResource' });\n    test.done();\n  },\n\n  'PolicyDoc resolves to undefined if there are no permissions'(test: Test) {\n    const p = new PolicyDocument();\n    test.deepEqual(resolve(p), undefined);\n    test.done();\n  },\n\n  'canonicalUserPrincipal adds a principal to a policy with the passed canonical user id'(test: Test) {\n    const p = new PolicyStatement();\n    const canoncialUser = \"averysuperduperlongstringfor\";\n    p.addPrincipal(new CanonicalUserPrincipal(canoncialUser));\n    test.deepEqual(resolve(p), {\n      Effect: \"Allow\",\n      Principal: {\n        CanonicalUser: canoncialUser\n      }\n    });\n    test.done();\n  },\n\n  'addAccountRootPrincipal adds a principal with the current account root'(test: Test) {\n    const p = new PolicyStatement();\n    p.addAccountRootPrincipal();\n    test.deepEqual(resolve(p), {\n      Effect: \"Allow\",\n      Principal: {\n        AWS: {\n        \"Fn::Join\": [\n          \"\",\n          [\n          \"arn:\",\n          { Ref: \"AWS::Partition\" },\n          \":iam::\",\n          { Ref: \"AWS::AccountId\" },\n          \":root\"\n          ]\n        ]\n        }\n      }\n    });\n    test.done();\n  },\n\n  'addFederatedPrincipal adds a Federated principal with the passed value'(test: Test) {\n    const p = new PolicyStatement();\n    p.addFederatedPrincipal(\"com.amazon.cognito\", { StringEquals: { key: 'value' }});\n    test.deepEqual(resolve(p), {\n      Effect: \"Allow\",\n      Principal: {\n        Federated: \"com.amazon.cognito\"\n      },\n      Condition: {\n        StringEquals: { key: 'value' }\n      }\n    });\n    test.done();\n  },\n\n  'addAwsAccountPrincipal can be used multiple times'(test: Test) {\n    const p = new PolicyStatement();\n    p.addAwsAccountPrincipal('1234');\n    p.addAwsAccountPrincipal('5678');\n    test.deepEqual(resolve(p), {\n      Effect: 'Allow',\n      Principal: {\n        AWS: [\n          { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':iam::1234:root']] },\n          { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':iam::5678:root']] }\n        ]\n      }\n    });\n    test.done();\n  },\n\n  'hasResource': {\n    'false if there are no resources'(test: Test) {\n      test.equal(new PolicyStatement().hasResource, false, 'hasResource should be false for an empty permission');\n      test.done();\n    },\n\n    'true if there is one resource'(test: Test) {\n      test.equal(\n        new PolicyStatement().addResource('one-resource').hasResource,\n        true,\n        'hasResource is true when there is one resource');\n      test.done();\n    },\n\n    'true for multiple resources'(test: Test) {\n      const p = new PolicyStatement();\n      p.addResource('r1');\n      p.addResource('r2');\n      test.equal(p.hasResource, true, 'hasResource is true when there are multiple resource');\n      test.done();\n    },\n  },\n\n  'hasPrincipal': {\n    'false if there is no principal'(test: Test) {\n      test.equal(new PolicyStatement().hasPrincipal, false);\n      test.done();\n    },\n\n    'true if there is a principal'(test: Test) {\n      const p = new PolicyStatement();\n      p.addAwsPrincipal('bla');\n      test.equal(p.hasPrincipal, true);\n      test.done();\n    }\n  },\n\n  'statementCount returns the number of statement in the policy document'(test: Test) {\n    const p = new PolicyDocument();\n    test.equal(p.statementCount, 0);\n    p.addStatement(new PolicyStatement());\n    test.equal(p.statementCount, 1);\n    p.addStatement(new PolicyStatement());\n    test.equal(p.statementCount, 2);\n    test.done();\n  },\n\n  'the { AWS: \"*\" } principal is represented as `Anyone` or `AnyPrincipal`'(test: Test) {\n    const p = new PolicyDocument();\n\n    p.addStatement(new PolicyStatement().addPrincipal(new Anyone()));\n    p.addStatement(new PolicyStatement().addPrincipal(new AnyPrincipal()));\n    p.addStatement(new PolicyStatement().addAnyPrincipal());\n\n    test.deepEqual(resolve(p), {\n      Statement: [\n        { Effect: 'Allow', Principal: '*' },\n        { Effect: 'Allow', Principal: '*' },\n        { Effect: 'Allow', Principal: '*' }\n      ],\n      Version: '2012-10-17'\n    });\n    test.done();\n  },\n\n  'addAwsPrincipal/addArnPrincipal are the aliases'(test: Test) {\n    const p = new PolicyDocument();\n\n    p.addStatement(new PolicyStatement().addAwsPrincipal('111222-A'));\n    p.addStatement(new PolicyStatement().addArnPrincipal('111222-B'));\n    p.addStatement(new PolicyStatement().addPrincipal(new ArnPrincipal('111222-C')));\n\n    test.deepEqual(resolve(p), {\n      Statement: [ {\n        Effect: 'Allow', Principal: { AWS: '111222-A' } },\n        { Effect: 'Allow', Principal: { AWS: '111222-B' } },\n        { Effect: 'Allow', Principal: { AWS: '111222-C' } }\n      ],\n      Version: '2012-10-17'\n    });\n\n    test.done();\n  },\n\n  'addCanonicalUserPrincipal can be used to add cannonical user principals'(test: Test) {\n    const p = new PolicyDocument();\n\n    p.addStatement(new PolicyStatement().addCanonicalUserPrincipal('cannonical-user-1'));\n    p.addStatement(new PolicyStatement().addPrincipal(new CanonicalUserPrincipal('cannonical-user-2')));\n\n    test.deepEqual(resolve(p), {\n      Statement: [\n        { Effect: 'Allow', Principal: { CanonicalUser: 'cannonical-user-1' } },\n        { Effect: 'Allow', Principal: { CanonicalUser: 'cannonical-user-2' } }\n      ],\n      Version: '2012-10-17'\n    });\n\n    test.done();\n  },\n\n  'addPrincipal correctly merges array in'(test: Test) {\n    const arrayPrincipal: PolicyPrincipal = {\n      assumeRoleAction: 'sts:AssumeRole',\n      policyFragment: () => new PrincipalPolicyFragment({ AWS: ['foo', 'bar'] }),\n    };\n    const s = new PolicyStatement().addAccountRootPrincipal()\n                                   .addPrincipal(arrayPrincipal);\n    test.deepEqual(resolve(s), {\n      Effect: 'Allow',\n      Principal: {\n        AWS: [\n          { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':iam::', { Ref: 'AWS::AccountId' }, ':root']] },\n          'foo', 'bar'\n        ]\n      }\n    });\n    test.done();\n  },\n\n  // https://github.com/awslabs/aws-cdk/issues/1201\n  'policy statements with multiple principal types can be created using multiple addPrincipal calls'(test: Test) {\n    const s = new PolicyStatement()\n      .addAwsPrincipal('349494949494')\n      .addServicePrincipal('ec2.amazonaws.com')\n      .addResource('resource')\n      .addAction('action');\n\n    test.deepEqual(resolve(s), {\n      Action: 'action',\n      Effect: 'Allow',\n      Principal: { AWS: '349494949494', Service: 'ec2.amazonaws.com' },\n      Resource: 'resource'\n    });\n\n    test.done();\n  },\n\n  'CompositePrincipal can be used to represent a principal that has multiple types': {\n\n    'with a single principal'(test: Test) {\n      const p = new CompositePrincipal(new ArnPrincipal('i:am:an:arn'));\n      const statement = new PolicyStatement().addPrincipal(p);\n      test.deepEqual(resolve(statement), { Effect: 'Allow', Principal: { AWS: 'i:am:an:arn' } });\n      test.done();\n    },\n\n    'conditions are not allowed on individual principals of a composite'(test: Test) {\n      const p = new CompositePrincipal(new ArnPrincipal('i:am'));\n      test.throws(() => p.addPrincipals(new FederatedPrincipal('federated', { condition: 1 })),\n        /Components of a CompositePrincipal must not have conditions/);\n\n      test.done();\n    },\n\n    'principals and conditions are a big nice merge'(test: Test) {\n      // add via ctor\n      const p = new CompositePrincipal(\n        new ArnPrincipal('i:am:an:arn'),\n        new ServicePrincipal('amazon.com'));\n\n      // add via `addPrincipals` (with condition)\n      p.addPrincipals(\n        new Anyone(),\n        new ServicePrincipal('another.service')\n      );\n\n      const statement = new PolicyStatement().addPrincipal(p);\n\n      // add via policy statement\n      statement.addAwsPrincipal('aws-principal-3');\n      statement.addCondition('cond2', { boom: 123 });\n\n      test.deepEqual(resolve(statement), {\n        Condition: {\n          cond2: { boom: 123 }\n        },\n        Effect: 'Allow',\n        Principal: {\n          AWS: [ 'i:am:an:arn', '*', 'aws-principal-3' ],\n          Service: [ 'amazon.com', 'another.service' ],\n        }\n      });\n      test.done();\n    },\n\n    'cannot mix types of assumeRoleAction in a single composite'(test: Test) {\n      // GIVEN\n      const p = new CompositePrincipal(new ArnPrincipal('arn')); // assumeRoleAction is \"sts:AssumeRule\"\n\n      // THEN\n      test.throws(() => p.addPrincipals(new FederatedPrincipal('fed', {}, 'sts:Boom')),\n        /Cannot add multiple principals with different \"assumeRoleAction\". Expecting \"sts:AssumeRole\", got \"sts:Boom\"/);\n\n      test.done();\n    }\n  },\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.policy-document.js","sourceRoot":"","sources":["test.policy-document.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack, Token } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Anyone, AnyPrincipal, CanonicalUserPrincipal, PolicyDocument, PolicyPrincipal, PolicyStatement } from '../lib';\nimport { ArnPrincipal, CompositePrincipal, FederatedPrincipal, PrincipalPolicyFragment, ServicePrincipal } from '../lib';\n\nexport = {\n  'the Permission class is a programming model for iam'(test: Test) {\n    const stack = new Stack();\n\n    const p = new PolicyStatement();\n    p.addAction('sqs:SendMessage');\n    p.addActions('dynamodb:CreateTable', 'dynamodb:DeleteTable');\n    p.addResource('myQueue');\n    p.addResource('yourQueue');\n\n    p.addAllResources();\n    p.addAwsAccountPrincipal(`my${new Token({ account: 'account' })}name`);\n    p.limitToAccount('12221121221');\n\n    test.deepEqual(stack.node.resolve(p), { Action:\n      [ 'sqs:SendMessage',\n        'dynamodb:CreateTable',\n        'dynamodb:DeleteTable' ],\n       Resource: [ 'myQueue', 'yourQueue', '*' ],\n       Effect: 'Allow',\n       Principal:\n      { AWS:\n         { 'Fn::Join':\n          [ '',\n          [ 'arn:',\n            { Ref: 'AWS::Partition' },\n            ':iam::my',\n            { account: 'account' },\n            'name:root' ] ] } },\n       Condition: { StringEquals: { 'sts:ExternalId': '12221121221' } } });\n\n    test.done();\n  },\n\n  'the PolicyDocument class is a dom for iam policy documents'(test: Test) {\n    const stack = new Stack();\n    const doc = new PolicyDocument();\n    const p1 = new PolicyStatement();\n    p1.addAction('sqs:SendMessage');\n    p1.addResource('*');\n\n    const p2 = new PolicyStatement();\n    p2.deny();\n    p2.addActions('cloudformation:CreateStack');\n\n    doc.addStatement(p1);\n    doc.addStatement(p2);\n\n    test.deepEqual(stack.node.resolve(doc), {\n      Version: '2012-10-17',\n      Statement:\n        [ { Effect: 'Allow', Action: 'sqs:SendMessage', Resource: '*' },\n          { Effect: 'Deny', Action: 'cloudformation:CreateStack' } ] });\n\n    test.done();\n  },\n\n  'A PolicyDocument can be initialized with an existing policy, which is merged upon serialization'(test: Test) {\n    const stack = new Stack();\n    const base = {\n      Version: 'Foo',\n      Something: 123,\n      Statement: [\n        { Statement1: 1 },\n        { Statement2: 2 }\n      ]\n    };\n    const doc = new PolicyDocument(base);\n    doc.addStatement(new PolicyStatement().addResource('resource').addAction('action'));\n\n    test.deepEqual(stack.node.resolve(doc), { Version: 'Foo',\n    Something: 123,\n    Statement:\n     [ { Statement1: 1 },\n       { Statement2: 2 },\n       { Effect: 'Allow', Action: 'action', Resource: 'resource' } ] });\n    test.done();\n  },\n\n  'Permission allows specifying multiple actions upon construction'(test: Test) {\n    const stack = new Stack();\n    const perm = new PolicyStatement().addResource('MyResource').addActions('Action1', 'Action2', 'Action3');\n    test.deepEqual(stack.node.resolve(perm), {\n      Effect: 'Allow',\n      Action: [ 'Action1', 'Action2', 'Action3' ],\n      Resource: 'MyResource' });\n    test.done();\n  },\n\n  'PolicyDoc resolves to undefined if there are no permissions'(test: Test) {\n    const stack = new Stack();\n    const p = new PolicyDocument();\n    test.deepEqual(stack.node.resolve(p), undefined);\n    test.done();\n  },\n\n  'canonicalUserPrincipal adds a principal to a policy with the passed canonical user id'(test: Test) {\n    const stack = new Stack();\n    const p = new PolicyStatement();\n    const canoncialUser = \"averysuperduperlongstringfor\";\n    p.addPrincipal(new CanonicalUserPrincipal(canoncialUser));\n    test.deepEqual(stack.node.resolve(p), {\n      Effect: \"Allow\",\n      Principal: {\n        CanonicalUser: canoncialUser\n      }\n    });\n    test.done();\n  },\n\n  'addAccountRootPrincipal adds a principal with the current account root'(test: Test) {\n    const stack = new Stack();\n\n    const p = new PolicyStatement();\n    p.addAccountRootPrincipal();\n    test.deepEqual(stack.node.resolve(p), {\n      Effect: \"Allow\",\n      Principal: {\n        AWS: {\n        \"Fn::Join\": [\n          \"\",\n          [\n          \"arn:\",\n          { Ref: \"AWS::Partition\" },\n          \":iam::\",\n          { Ref: \"AWS::AccountId\" },\n          \":root\"\n          ]\n        ]\n        }\n      }\n    });\n    test.done();\n  },\n\n  'addFederatedPrincipal adds a Federated principal with the passed value'(test: Test) {\n    const stack = new Stack();\n    const p = new PolicyStatement();\n    p.addFederatedPrincipal(\"com.amazon.cognito\", { StringEquals: { key: 'value' }});\n    test.deepEqual(stack.node.resolve(p), {\n      Effect: \"Allow\",\n      Principal: {\n        Federated: \"com.amazon.cognito\"\n      },\n      Condition: {\n        StringEquals: { key: 'value' }\n      }\n    });\n    test.done();\n  },\n\n  'addAwsAccountPrincipal can be used multiple times'(test: Test) {\n    const stack = new Stack();\n\n    const p = new PolicyStatement();\n    p.addAwsAccountPrincipal('1234');\n    p.addAwsAccountPrincipal('5678');\n    test.deepEqual(stack.node.resolve(p), {\n      Effect: 'Allow',\n      Principal: {\n        AWS: [\n          { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':iam::1234:root']] },\n          { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':iam::5678:root']] }\n        ]\n      }\n    });\n    test.done();\n  },\n\n  'hasResource': {\n    'false if there are no resources'(test: Test) {\n      test.equal(new PolicyStatement().hasResource, false, 'hasResource should be false for an empty permission');\n      test.done();\n    },\n\n    'true if there is one resource'(test: Test) {\n      test.equal(\n        new PolicyStatement().addResource('one-resource').hasResource,\n        true,\n        'hasResource is true when there is one resource');\n      test.done();\n    },\n\n    'true for multiple resources'(test: Test) {\n      const p = new PolicyStatement();\n      p.addResource('r1');\n      p.addResource('r2');\n      test.equal(p.hasResource, true, 'hasResource is true when there are multiple resource');\n      test.done();\n    },\n  },\n\n  'hasPrincipal': {\n    'false if there is no principal'(test: Test) {\n      test.equal(new PolicyStatement().hasPrincipal, false);\n      test.done();\n    },\n\n    'true if there is a principal'(test: Test) {\n      const p = new PolicyStatement();\n      p.addAwsPrincipal('bla');\n      test.equal(p.hasPrincipal, true);\n      test.done();\n    }\n  },\n\n  'statementCount returns the number of statement in the policy document'(test: Test) {\n    const p = new PolicyDocument();\n    test.equal(p.statementCount, 0);\n    p.addStatement(new PolicyStatement());\n    test.equal(p.statementCount, 1);\n    p.addStatement(new PolicyStatement());\n    test.equal(p.statementCount, 2);\n    test.done();\n  },\n\n  'the { AWS: \"*\" } principal is represented as `Anyone` or `AnyPrincipal`'(test: Test) {\n    const stack = new Stack();\n    const p = new PolicyDocument();\n\n    p.addStatement(new PolicyStatement().addPrincipal(new Anyone()));\n    p.addStatement(new PolicyStatement().addPrincipal(new AnyPrincipal()));\n    p.addStatement(new PolicyStatement().addAnyPrincipal());\n\n    test.deepEqual(stack.node.resolve(p), {\n      Statement: [\n        { Effect: 'Allow', Principal: '*' },\n        { Effect: 'Allow', Principal: '*' },\n        { Effect: 'Allow', Principal: '*' }\n      ],\n      Version: '2012-10-17'\n    });\n    test.done();\n  },\n\n  'addAwsPrincipal/addArnPrincipal are the aliases'(test: Test) {\n    const stack = new Stack();\n    const p = new PolicyDocument();\n\n    p.addStatement(new PolicyStatement().addAwsPrincipal('111222-A'));\n    p.addStatement(new PolicyStatement().addArnPrincipal('111222-B'));\n    p.addStatement(new PolicyStatement().addPrincipal(new ArnPrincipal('111222-C')));\n\n    test.deepEqual(stack.node.resolve(p), {\n      Statement: [ {\n        Effect: 'Allow', Principal: { AWS: '111222-A' } },\n        { Effect: 'Allow', Principal: { AWS: '111222-B' } },\n        { Effect: 'Allow', Principal: { AWS: '111222-C' } }\n      ],\n      Version: '2012-10-17'\n    });\n\n    test.done();\n  },\n\n  'addCanonicalUserPrincipal can be used to add cannonical user principals'(test: Test) {\n    const stack = new Stack();\n    const p = new PolicyDocument();\n\n    p.addStatement(new PolicyStatement().addCanonicalUserPrincipal('cannonical-user-1'));\n    p.addStatement(new PolicyStatement().addPrincipal(new CanonicalUserPrincipal('cannonical-user-2')));\n\n    test.deepEqual(stack.node.resolve(p), {\n      Statement: [\n        { Effect: 'Allow', Principal: { CanonicalUser: 'cannonical-user-1' } },\n        { Effect: 'Allow', Principal: { CanonicalUser: 'cannonical-user-2' } }\n      ],\n      Version: '2012-10-17'\n    });\n\n    test.done();\n  },\n\n  'addPrincipal correctly merges array in'(test: Test) {\n    const stack = new Stack();\n    const arrayPrincipal: PolicyPrincipal = {\n      assumeRoleAction: 'sts:AssumeRole',\n      policyFragment: () => new PrincipalPolicyFragment({ AWS: ['foo', 'bar'] }),\n    };\n    const s = new PolicyStatement().addAccountRootPrincipal()\n                                   .addPrincipal(arrayPrincipal);\n    test.deepEqual(stack.node.resolve(s), {\n      Effect: 'Allow',\n      Principal: {\n        AWS: [\n          { 'Fn::Join': ['', ['arn:', { Ref: 'AWS::Partition' }, ':iam::', { Ref: 'AWS::AccountId' }, ':root']] },\n          'foo', 'bar'\n        ]\n      }\n    });\n    test.done();\n  },\n\n  // https://github.com/awslabs/aws-cdk/issues/1201\n  'policy statements with multiple principal types can be created using multiple addPrincipal calls'(test: Test) {\n    const stack = new Stack();\n    const s = new PolicyStatement()\n      .addAwsPrincipal('349494949494')\n      .addServicePrincipal('ec2.amazonaws.com')\n      .addResource('resource')\n      .addAction('action');\n\n    test.deepEqual(stack.node.resolve(s), {\n      Action: 'action',\n      Effect: 'Allow',\n      Principal: { AWS: '349494949494', Service: 'ec2.amazonaws.com' },\n      Resource: 'resource'\n    });\n\n    test.done();\n  },\n\n  'CompositePrincipal can be used to represent a principal that has multiple types': {\n\n    'with a single principal'(test: Test) {\n      const stack = new Stack();\n      const p = new CompositePrincipal(new ArnPrincipal('i:am:an:arn'));\n      const statement = new PolicyStatement().addPrincipal(p);\n      test.deepEqual(stack.node.resolve(statement), { Effect: 'Allow', Principal: { AWS: 'i:am:an:arn' } });\n      test.done();\n    },\n\n    'conditions are not allowed on individual principals of a composite'(test: Test) {\n      const p = new CompositePrincipal(new ArnPrincipal('i:am'));\n      test.throws(() => p.addPrincipals(new FederatedPrincipal('federated', { condition: 1 })),\n        /Components of a CompositePrincipal must not have conditions/);\n\n      test.done();\n    },\n\n    'principals and conditions are a big nice merge'(test: Test) {\n      const stack = new Stack();\n      // add via ctor\n      const p = new CompositePrincipal(\n        new ArnPrincipal('i:am:an:arn'),\n        new ServicePrincipal('amazon.com'));\n\n      // add via `addPrincipals` (with condition)\n      p.addPrincipals(\n        new Anyone(),\n        new ServicePrincipal('another.service')\n      );\n\n      const statement = new PolicyStatement().addPrincipal(p);\n\n      // add via policy statement\n      statement.addAwsPrincipal('aws-principal-3');\n      statement.addCondition('cond2', { boom: 123 });\n\n      test.deepEqual(stack.node.resolve(statement), {\n        Condition: {\n          cond2: { boom: 123 }\n        },\n        Effect: 'Allow',\n        Principal: {\n          AWS: [ 'i:am:an:arn', '*', 'aws-principal-3' ],\n          Service: [ 'amazon.com', 'another.service' ],\n        }\n      });\n      test.done();\n    },\n\n    'cannot mix types of assumeRoleAction in a single composite'(test: Test) {\n      // GIVEN\n      const p = new CompositePrincipal(new ArnPrincipal('arn')); // assumeRoleAction is \"sts:AssumeRule\"\n\n      // THEN\n      test.throws(() => p.addPrincipals(new FederatedPrincipal('fed', {}, 'sts:Boom')),\n        /Cannot add multiple principals with different \"assumeRoleAction\". Expecting \"sts:AssumeRole\", got \"sts:Boom\"/);\n\n      test.done();\n    }\n  },\n};\n"]}

@@ -15,3 +15,4 @@ import { Test } from 'nodeunit';

'allow role with multiple principals'(test: Test): void;
'import/export'(test: Test): void;
};
export = _default;

@@ -176,4 +176,22 @@ "use strict";

test.done();
},
'import/export'(test) {
// GIVEN
const stack = new cdk_1.Stack();
const myRole = new lib_1.Role(stack, 'MyRole', {
assumedBy: new lib_1.ServicePrincipal('boom.boom.boom')
});
// WHEN
const exportedRole = myRole.export();
const importedRole = lib_1.Role.import(stack, 'ImportedRole', exportedRole);
// THEN
test.deepEqual(stack.node.resolve(exportedRole), {
roleArn: { 'Fn::ImportValue': 'MyRoleRoleArn3388B7E2' },
roleId: { 'Fn::ImportValue': 'MyRoleRoleIdF7B258D8' }
});
test.deepEqual(stack.node.resolve(importedRole.roleArn), { 'Fn::ImportValue': 'MyRoleRoleArn3388B7E2' });
test.deepEqual(stack.node.resolve(importedRole.roleId), { 'Fn::ImportValue': 'MyRoleRoleIdF7B258D8' });
test.done();
}
};
//# 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 { Resource, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { ArnPrincipal, CompositePrincipal, FederatedPrincipal, PolicyStatement, Role, ServicePrincipal } 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  'can supply externalId'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n\n    // WHEN\n    new Role(stack, 'MyRole', {\n      assumedBy: new ServicePrincipal('sns.amazonaws.com'),\n      externalId: 'SomeSecret',\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: \"sts:AssumeRole\",\n            Condition: {\n              StringEquals: { \"sts:ExternalId\": \"SomeSecret\" }\n            },\n            Effect: \"Allow\",\n            Principal: { Service: \"sns.amazonaws.com\" }\n          }\n        ],\n        Version: \"2012-10-17\"\n      }\n    }));\n\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        Version: \"2012-10-17\",\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  'allow role with multiple principals'(test: Test) {\n    const stack = new Stack();\n\n    new Role(stack, 'MyRole', {\n      assumedBy: new CompositePrincipal(\n        new ServicePrincipal('boom.amazonaws.com'),\n        new ArnPrincipal('1111111')\n      )\n    });\n\n    expect(stack).to(haveResource('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: \"sts:AssumeRole\",\n            Effect: \"Allow\",\n            Principal: {\n              Service: \"boom.amazonaws.com\",\n              AWS: \"1111111\"\n            }\n          }\n        ],\n        Version: \"2012-10-17\"\n      }\n    }));\n\n    test.done();\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 { Resource, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { ArnPrincipal, CompositePrincipal, FederatedPrincipal, PolicyStatement, Role, ServicePrincipal } 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  'can supply externalId'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n\n    // WHEN\n    new Role(stack, 'MyRole', {\n      assumedBy: new ServicePrincipal('sns.amazonaws.com'),\n      externalId: 'SomeSecret',\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: \"sts:AssumeRole\",\n            Condition: {\n              StringEquals: { \"sts:ExternalId\": \"SomeSecret\" }\n            },\n            Effect: \"Allow\",\n            Principal: { Service: \"sns.amazonaws.com\" }\n          }\n        ],\n        Version: \"2012-10-17\"\n      }\n    }));\n\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        Version: \"2012-10-17\",\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  'allow role with multiple principals'(test: Test) {\n    const stack = new Stack();\n\n    new Role(stack, 'MyRole', {\n      assumedBy: new CompositePrincipal(\n        new ServicePrincipal('boom.amazonaws.com'),\n        new ArnPrincipal('1111111')\n      )\n    });\n\n    expect(stack).to(haveResource('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [\n          {\n            Action: \"sts:AssumeRole\",\n            Effect: \"Allow\",\n            Principal: {\n              Service: \"boom.amazonaws.com\",\n              AWS: \"1111111\"\n            }\n          }\n        ],\n        Version: \"2012-10-17\"\n      }\n    }));\n\n    test.done();\n  },\n\n  'import/export'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const myRole = new Role(stack, 'MyRole', {\n      assumedBy: new ServicePrincipal('boom.boom.boom')\n    });\n\n    // WHEN\n    const exportedRole = myRole.export();\n    const importedRole = Role.import(stack, 'ImportedRole', exportedRole);\n\n    // THEN\n    test.deepEqual(stack.node.resolve(exportedRole), {\n      roleArn: { 'Fn::ImportValue': 'MyRoleRoleArn3388B7E2' },\n      roleId: { 'Fn::ImportValue': 'MyRoleRoleIdF7B258D8' }\n    });\n\n    test.deepEqual(stack.node.resolve(importedRole.roleArn), { 'Fn::ImportValue': 'MyRoleRoleArn3388B7E2' });\n    test.deepEqual(stack.node.resolve(importedRole.roleId), { 'Fn::ImportValue': 'MyRoleRoleIdF7B258D8' });\n    test.done();\n  }\n};\n"]}

@@ -25,5 +25,20 @@ {

"strictNullChecks": true,
"target": "ES2018"
"target": "ES2018",
"composite": true
},
"include": [
"**/*.ts"
],
"exclude": [
"node_modules"
],
"references": [
{
"path": "../cdk"
},
{
"path": "../assert"
}
],
"_generated_by_jsii_": "Generated by jsii - safe to delete, and ideally should be in .gitignore"
}

Sorry, the diff of this file is not supported yet

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

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc