1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.Effect = exports.PolicyStatement = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const cdk = require("@aws-cdk/core");
|
8 | const group_1 = require("./group");
|
9 | const principals_1 = require("./principals");
|
10 | const postprocess_policy_document_1 = require("./private/postprocess-policy-document");
|
11 | const util_1 = require("./util");
|
12 | const ensureArrayOrUndefined = (field) => {
|
13 | if (field === undefined) {
|
14 | return undefined;
|
15 | }
|
16 | if (typeof (field) !== 'string' && !Array.isArray(field)) {
|
17 | throw new Error('Fields must be either a string or an array of strings');
|
18 | }
|
19 | if (Array.isArray(field) && !!field.find((f) => typeof (f) !== 'string')) {
|
20 | throw new Error('Fields must be either a string or an array of strings');
|
21 | }
|
22 | return Array.isArray(field) ? field : [field];
|
23 | };
|
24 | /**
|
25 | * Represents a statement in an IAM policy document.
|
26 | */
|
27 | class PolicyStatement {
|
28 | constructor(props = {}) {
|
29 | this.action = new Array();
|
30 | this.notAction = new Array();
|
31 | this.principal = {};
|
32 | this.notPrincipal = {};
|
33 | this.resource = new Array();
|
34 | this.notResource = new Array();
|
35 | this.condition = {};
|
36 | // Hold on to those principals
|
37 | this._principals = new Array();
|
38 | try {
|
39 | jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyStatementProps(props);
|
40 | }
|
41 | catch (error) {
|
42 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
43 | Error.captureStackTrace(error, this.constructor);
|
44 | }
|
45 | throw error;
|
46 | }
|
47 | // Validate actions
|
48 | for (const action of [...props.actions || [], ...props.notActions || []]) {
|
49 | if (!/^(\*|[a-zA-Z0-9-]+:[a-zA-Z0-9*]+)$/.test(action) && !cdk.Token.isUnresolved(action)) {
|
50 | throw new Error(`Action '${action}' is invalid. An action string consists of a service namespace, a colon, and the name of an action. Action names can include wildcards.`);
|
51 | }
|
52 | }
|
53 | this.sid = props.sid;
|
54 | this.effect = props.effect || Effect.ALLOW;
|
55 | this.addActions(...props.actions || []);
|
56 | this.addNotActions(...props.notActions || []);
|
57 | this.addPrincipals(...props.principals || []);
|
58 | this.addNotPrincipals(...props.notPrincipals || []);
|
59 | this.addResources(...props.resources || []);
|
60 | this.addNotResources(...props.notResources || []);
|
61 | if (props.conditions !== undefined) {
|
62 | this.addConditions(props.conditions);
|
63 | }
|
64 | }
|
65 | /**
|
66 | * Creates a new PolicyStatement based on the object provided.
|
67 | * This will accept an object created from the `.toJSON()` call
|
68 | * @param obj the PolicyStatement in object form.
|
69 | */
|
70 | static fromJson(obj) {
|
71 | const ret = new PolicyStatement({
|
72 | sid: obj.Sid,
|
73 | actions: ensureArrayOrUndefined(obj.Action),
|
74 | resources: ensureArrayOrUndefined(obj.Resource),
|
75 | conditions: obj.Condition,
|
76 | effect: obj.Effect,
|
77 | notActions: ensureArrayOrUndefined(obj.NotAction),
|
78 | notResources: ensureArrayOrUndefined(obj.NotResource),
|
79 | principals: obj.Principal ? [new JsonPrincipal(obj.Principal)] : undefined,
|
80 | notPrincipals: obj.NotPrincipal ? [new JsonPrincipal(obj.NotPrincipal)] : undefined,
|
81 | });
|
82 | // validate that the PolicyStatement has the correct shape
|
83 | const errors = ret.validateForAnyPolicy();
|
84 | if (errors.length > 0) {
|
85 | throw new Error('Incorrect Policy Statement: ' + errors.join('\n'));
|
86 | }
|
87 | return ret;
|
88 | }
|
89 | //
|
90 | // Actions
|
91 | //
|
92 | /**
|
93 | * Specify allowed actions into the "Action" section of the policy statement.
|
94 | *
|
95 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_action.html
|
96 | *
|
97 | * @param actions actions that will be allowed.
|
98 | */
|
99 | addActions(...actions) {
|
100 | if (actions.length > 0 && this.notAction.length > 0) {
|
101 | throw new Error('Cannot add \'Actions\' to policy statement if \'NotActions\' have been added');
|
102 | }
|
103 | this.action.push(...actions);
|
104 | }
|
105 | /**
|
106 | * Explicitly allow all actions except the specified list of actions into the "NotAction" section
|
107 | * of the policy document.
|
108 | *
|
109 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notaction.html
|
110 | *
|
111 | * @param notActions actions that will be denied. All other actions will be permitted.
|
112 | */
|
113 | addNotActions(...notActions) {
|
114 | if (notActions.length > 0 && this.action.length > 0) {
|
115 | throw new Error('Cannot add \'NotActions\' to policy statement if \'Actions\' have been added');
|
116 | }
|
117 | this.notAction.push(...notActions);
|
118 | }
|
119 | //
|
120 | // Principal
|
121 | //
|
122 | /**
|
123 | * Indicates if this permission has a "Principal" section.
|
124 | */
|
125 | get hasPrincipal() {
|
126 | return Object.keys(this.principal).length > 0 || Object.keys(this.notPrincipal).length > 0;
|
127 | }
|
128 | /**
|
129 | * Adds principals to the "Principal" section of a policy statement.
|
130 | *
|
131 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_principal.html
|
132 | *
|
133 | * @param principals IAM principals that will be added
|
134 | */
|
135 | addPrincipals(...principals) {
|
136 | try {
|
137 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principals);
|
138 | }
|
139 | catch (error) {
|
140 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
141 | Error.captureStackTrace(error, this.addPrincipals);
|
142 | }
|
143 | throw error;
|
144 | }
|
145 | this._principals.push(...principals);
|
146 | if (Object.keys(principals).length > 0 && Object.keys(this.notPrincipal).length > 0) {
|
147 | throw new Error('Cannot add \'Principals\' to policy statement if \'NotPrincipals\' have been added');
|
148 | }
|
149 | for (const principal of principals) {
|
150 | this.validatePolicyPrincipal(principal);
|
151 | const fragment = principal.policyFragment;
|
152 | util_1.mergePrincipal(this.principal, fragment.principalJson);
|
153 | this.addPrincipalConditions(fragment.conditions);
|
154 | }
|
155 | }
|
156 | /**
|
157 | * Expose principals to allow their ARNs to be replaced by account ID strings
|
158 | * in policy statements for resources policies that don't allow full account ARNs,
|
159 | * such as AWS::Logs::ResourcePolicy.
|
160 | */
|
161 | get principals() {
|
162 | return [...this._principals];
|
163 | }
|
164 | /**
|
165 | * Specify principals that is not allowed or denied access to the "NotPrincipal" section of
|
166 | * a policy statement.
|
167 | *
|
168 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notprincipal.html
|
169 | *
|
170 | * @param notPrincipals IAM principals that will be denied access
|
171 | */
|
172 | addNotPrincipals(...notPrincipals) {
|
173 | try {
|
174 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(notPrincipals);
|
175 | }
|
176 | catch (error) {
|
177 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
178 | Error.captureStackTrace(error, this.addNotPrincipals);
|
179 | }
|
180 | throw error;
|
181 | }
|
182 | if (Object.keys(notPrincipals).length > 0 && Object.keys(this.principal).length > 0) {
|
183 | throw new Error('Cannot add \'NotPrincipals\' to policy statement if \'Principals\' have been added');
|
184 | }
|
185 | for (const notPrincipal of notPrincipals) {
|
186 | this.validatePolicyPrincipal(notPrincipal);
|
187 | const fragment = notPrincipal.policyFragment;
|
188 | util_1.mergePrincipal(this.notPrincipal, fragment.principalJson);
|
189 | this.addPrincipalConditions(fragment.conditions);
|
190 | }
|
191 | }
|
192 | validatePolicyPrincipal(principal) {
|
193 | if (principal instanceof group_1.Group) {
|
194 | throw new Error('Cannot use an IAM Group as the \'Principal\' or \'NotPrincipal\' in an IAM Policy');
|
195 | }
|
196 | }
|
197 | /**
|
198 | * Specify AWS account ID as the principal entity to the "Principal" section of a policy statement.
|
199 | */
|
200 | addAwsAccountPrincipal(accountId) {
|
201 | this.addPrincipals(new principals_1.AccountPrincipal(accountId));
|
202 | }
|
203 | /**
|
204 | * Specify a principal using the ARN identifier of the principal.
|
205 | * You cannot specify IAM groups and instance profiles as principals.
|
206 | *
|
207 | * @param arn ARN identifier of AWS account, IAM user, or IAM role (i.e. arn:aws:iam::123456789012:user/user-name)
|
208 | */
|
209 | addArnPrincipal(arn) {
|
210 | this.addPrincipals(new principals_1.ArnPrincipal(arn));
|
211 | }
|
212 | /**
|
213 | * Adds a service principal to this policy statement.
|
214 | *
|
215 | * @param service the service name for which a service principal is requested (e.g: `s3.amazonaws.com`).
|
216 | * @param opts options for adding the service principal (such as specifying a principal in a different region)
|
217 | */
|
218 | addServicePrincipal(service, opts) {
|
219 | try {
|
220 | jsiiDeprecationWarnings._aws_cdk_aws_iam_ServicePrincipalOpts(opts);
|
221 | }
|
222 | catch (error) {
|
223 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
224 | Error.captureStackTrace(error, this.addServicePrincipal);
|
225 | }
|
226 | throw error;
|
227 | }
|
228 | this.addPrincipals(new principals_1.ServicePrincipal(service, opts));
|
229 | }
|
230 | /**
|
231 | * Adds a federated identity provider such as Amazon Cognito to this policy statement.
|
232 | *
|
233 | * @param federated federated identity provider (i.e. 'cognito-identity.amazonaws.com')
|
234 | * @param conditions The conditions under which the policy is in effect.
|
235 | * See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
|
236 | */
|
237 | addFederatedPrincipal(federated, conditions) {
|
238 | this.addPrincipals(new principals_1.FederatedPrincipal(federated, conditions));
|
239 | }
|
240 | /**
|
241 | * Adds an AWS account root user principal to this policy statement
|
242 | */
|
243 | addAccountRootPrincipal() {
|
244 | this.addPrincipals(new principals_1.AccountRootPrincipal());
|
245 | }
|
246 | /**
|
247 | * Adds a canonical user ID principal to this policy document
|
248 | *
|
249 | * @param canonicalUserId unique identifier assigned by AWS for every account
|
250 | */
|
251 | addCanonicalUserPrincipal(canonicalUserId) {
|
252 | this.addPrincipals(new principals_1.CanonicalUserPrincipal(canonicalUserId));
|
253 | }
|
254 | /**
|
255 | * Adds all identities in all accounts ("*") to this policy statement
|
256 | */
|
257 | addAnyPrincipal() {
|
258 | this.addPrincipals(new principals_1.AnyPrincipal());
|
259 | }
|
260 | //
|
261 | // Resources
|
262 | //
|
263 | /**
|
264 | * Specify resources that this policy statement applies into the "Resource" section of
|
265 | * this policy statement.
|
266 | *
|
267 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_resource.html
|
268 | *
|
269 | * @param arns Amazon Resource Names (ARNs) of the resources that this policy statement applies to
|
270 | */
|
271 | addResources(...arns) {
|
272 | if (arns.length > 0 && this.notResource.length > 0) {
|
273 | throw new Error('Cannot add \'Resources\' to policy statement if \'NotResources\' have been added');
|
274 | }
|
275 | this.resource.push(...arns);
|
276 | }
|
277 | /**
|
278 | * Specify resources that this policy statement will not apply to in the "NotResource" section
|
279 | * of this policy statement. All resources except the specified list will be matched.
|
280 | *
|
281 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notresource.html
|
282 | *
|
283 | * @param arns Amazon Resource Names (ARNs) of the resources that this policy statement does not apply to
|
284 | */
|
285 | addNotResources(...arns) {
|
286 | if (arns.length > 0 && this.resource.length > 0) {
|
287 | throw new Error('Cannot add \'NotResources\' to policy statement if \'Resources\' have been added');
|
288 | }
|
289 | this.notResource.push(...arns);
|
290 | }
|
291 | /**
|
292 | * Adds a ``"*"`` resource to this statement.
|
293 | */
|
294 | addAllResources() {
|
295 | this.addResources('*');
|
296 | }
|
297 | /**
|
298 | * Indicates if this permission has at least one resource associated with it.
|
299 | */
|
300 | get hasResource() {
|
301 | return this.resource && this.resource.length > 0;
|
302 | }
|
303 | //
|
304 | // Condition
|
305 | //
|
306 | /**
|
307 | * Add a condition to the Policy
|
308 | *
|
309 | * If multiple calls are made to add a condition with the same operator and field, only
|
310 | * the last one wins. For example:
|
311 | *
|
312 | * ```ts
|
313 | * declare const stmt: iam.PolicyStatement;
|
314 | *
|
315 | * stmt.addCondition('StringEquals', { 'aws:SomeField': '1' });
|
316 | * stmt.addCondition('StringEquals', { 'aws:SomeField': '2' });
|
317 | * ```
|
318 | *
|
319 | * Will end up with the single condition `StringEquals: { 'aws:SomeField': '2' }`.
|
320 | *
|
321 | * If you meant to add a condition to say that the field can be *either* `1` or `2`, write
|
322 | * this:
|
323 | *
|
324 | * ```ts
|
325 | * declare const stmt: iam.PolicyStatement;
|
326 | *
|
327 | * stmt.addCondition('StringEquals', { 'aws:SomeField': ['1', '2'] });
|
328 | * ```
|
329 | */
|
330 | addCondition(key, value) {
|
331 | const existingValue = this.condition[key];
|
332 | this.condition[key] = existingValue ? { ...existingValue, ...value } : value;
|
333 | }
|
334 | /**
|
335 | * Add multiple conditions to the Policy
|
336 | *
|
337 | * See the `addCondition` function for a caveat on calling this method multiple times.
|
338 | */
|
339 | addConditions(conditions) {
|
340 | Object.keys(conditions).map(key => {
|
341 | this.addCondition(key, conditions[key]);
|
342 | });
|
343 | }
|
344 | /**
|
345 | * Add a condition that limits to a given account
|
346 | *
|
347 | * This method can only be called once: subsequent calls will overwrite earlier calls.
|
348 | */
|
349 | addAccountCondition(accountId) {
|
350 | this.addCondition('StringEquals', { 'sts:ExternalId': accountId });
|
351 | }
|
352 | /**
|
353 | * Create a new `PolicyStatement` with the same exact properties
|
354 | * as this one, except for the overrides
|
355 | */
|
356 | copy(overrides = {}) {
|
357 | var _b, _c, _d, _e, _f, _g;
|
358 | try {
|
359 | jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyStatementProps(overrides);
|
360 | }
|
361 | catch (error) {
|
362 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
363 | Error.captureStackTrace(error, this.copy);
|
364 | }
|
365 | throw error;
|
366 | }
|
367 | return new PolicyStatement({
|
368 | sid: (_b = overrides.sid) !== null && _b !== void 0 ? _b : this.sid,
|
369 | effect: (_c = overrides.effect) !== null && _c !== void 0 ? _c : this.effect,
|
370 | actions: (_d = overrides.actions) !== null && _d !== void 0 ? _d : this.action,
|
371 | notActions: (_e = overrides.notActions) !== null && _e !== void 0 ? _e : this.notAction,
|
372 | principals: overrides.principals,
|
373 | notPrincipals: overrides.notPrincipals,
|
374 | resources: (_f = overrides.resources) !== null && _f !== void 0 ? _f : this.resource,
|
375 | notResources: (_g = overrides.notResources) !== null && _g !== void 0 ? _g : this.notResource,
|
376 | });
|
377 | }
|
378 | /**
|
379 | * JSON-ify the policy statement
|
380 | *
|
381 | * Used when JSON.stringify() is called
|
382 | */
|
383 | toStatementJson() {
|
384 | return postprocess_policy_document_1.normalizeStatement({
|
385 | Action: this.action,
|
386 | NotAction: this.notAction,
|
387 | Condition: this.condition,
|
388 | Effect: this.effect,
|
389 | Principal: this.principal,
|
390 | NotPrincipal: this.notPrincipal,
|
391 | Resource: this.resource,
|
392 | NotResource: this.notResource,
|
393 | Sid: this.sid,
|
394 | });
|
395 | }
|
396 | /**
|
397 | * String representation of this policy statement
|
398 | */
|
399 | toString() {
|
400 | return cdk.Token.asString(this, {
|
401 | displayHint: 'PolicyStatement',
|
402 | });
|
403 | }
|
404 | /**
|
405 | * JSON-ify the statement
|
406 | *
|
407 | * Used when JSON.stringify() is called
|
408 | */
|
409 | toJSON() {
|
410 | return this.toStatementJson();
|
411 | }
|
412 | /**
|
413 | * Add a principal's conditions
|
414 | *
|
415 | * For convenience, principals have been modeled as both a principal
|
416 | * and a set of conditions. This makes it possible to have a single
|
417 | * object represent e.g. an "SNS Topic" (SNS service principal + aws:SourcArn
|
418 | * condition) or an Organization member (* + aws:OrgId condition).
|
419 | *
|
420 | * However, when using multiple principals in the same policy statement,
|
421 | * they must all have the same conditions or the OR samentics
|
422 | * implied by a list of principals cannot be guaranteed (user needs to
|
423 | * add multiple statements in that case).
|
424 | */
|
425 | addPrincipalConditions(conditions) {
|
426 | // Stringifying the conditions is an easy way to do deep equality
|
427 | const theseConditions = JSON.stringify(conditions);
|
428 | if (this.principalConditionsJson === undefined) {
|
429 | // First principal, anything goes
|
430 | this.principalConditionsJson = theseConditions;
|
431 | }
|
432 | else {
|
433 | if (this.principalConditionsJson !== theseConditions) {
|
434 | throw new Error(`All principals in a PolicyStatement must have the same Conditions (got '${this.principalConditionsJson}' and '${theseConditions}'). Use multiple statements instead.`);
|
435 | }
|
436 | }
|
437 | this.addConditions(conditions);
|
438 | }
|
439 | /**
|
440 | * Validate that the policy statement satisfies base requirements for a policy.
|
441 | */
|
442 | validateForAnyPolicy() {
|
443 | const errors = new Array();
|
444 | if (this.action.length === 0 && this.notAction.length === 0) {
|
445 | errors.push('A PolicyStatement must specify at least one \'action\' or \'notAction\'.');
|
446 | }
|
447 | return errors;
|
448 | }
|
449 | /**
|
450 | * Validate that the policy statement satisfies all requirements for a resource-based policy.
|
451 | */
|
452 | validateForResourcePolicy() {
|
453 | const errors = this.validateForAnyPolicy();
|
454 | if (Object.keys(this.principal).length === 0 && Object.keys(this.notPrincipal).length === 0) {
|
455 | errors.push('A PolicyStatement used in a resource-based policy must specify at least one IAM principal.');
|
456 | }
|
457 | return errors;
|
458 | }
|
459 | /**
|
460 | * Validate that the policy statement satisfies all requirements for an identity-based policy.
|
461 | */
|
462 | validateForIdentityPolicy() {
|
463 | const errors = this.validateForAnyPolicy();
|
464 | if (Object.keys(this.principal).length > 0 || Object.keys(this.notPrincipal).length > 0) {
|
465 | errors.push('A PolicyStatement used in an identity-based policy cannot specify any IAM principals.');
|
466 | }
|
467 | if (Object.keys(this.resource).length === 0 && Object.keys(this.notResource).length === 0) {
|
468 | errors.push('A PolicyStatement used in an identity-based policy must specify at least one resource.');
|
469 | }
|
470 | return errors;
|
471 | }
|
472 | }
|
473 | exports.PolicyStatement = PolicyStatement;
|
474 | _a = JSII_RTTI_SYMBOL_1;
|
475 | PolicyStatement[_a] = { fqn: "@aws-cdk/aws-iam.PolicyStatement", version: "1.156.1" };
|
476 | /**
|
477 | * The Effect element of an IAM policy
|
478 | *
|
479 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_effect.html
|
480 | */
|
481 | var Effect;
|
482 | (function (Effect) {
|
483 | /**
|
484 | * Allows access to a resource in an IAM policy statement. By default, access to resources are denied.
|
485 | */
|
486 | Effect["ALLOW"] = "Allow";
|
487 | /**
|
488 | * Explicitly deny access to a resource. By default, all requests are denied implicitly.
|
489 | *
|
490 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_evaluation-logic.html
|
491 | */
|
492 | Effect["DENY"] = "Deny";
|
493 | })(Effect = exports.Effect || (exports.Effect = {}));
|
494 | class JsonPrincipal extends principals_1.PrincipalBase {
|
495 | constructor(json = {}) {
|
496 | super();
|
497 | // special case: if principal is a string, turn it into a "LiteralString" principal,
|
498 | // so we render the exact same string back out.
|
499 | if (typeof (json) === 'string') {
|
500 | json = { [util_1.LITERAL_STRING_KEY]: [json] };
|
501 | }
|
502 | if (typeof (json) !== 'object') {
|
503 | throw new Error(`JSON IAM principal should be an object, got ${JSON.stringify(json)}`);
|
504 | }
|
505 | this.policyFragment = {
|
506 | principalJson: json,
|
507 | conditions: {},
|
508 | };
|
509 | }
|
510 | }
|
511 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-statement.js","sourceRoot":"","sources":["policy-statement.ts"],"names":[],"mappings":";;;;;;AAAA,qCAAqC;AACrC,mCAAgC;AAChC,6CAGsB;AACtB,uFAA2E;AAC3E,iCAA4D;AAE5D,MAAM,sBAAsB,GAAG,CAAC,KAAU,EAAE,EAAE;IAC5C,IAAI,KAAK,KAAK,SAAS,EAAE;QACvB,OAAO,SAAS,CAAC;KAClB;IACD,IAAI,OAAO,CAAC,KAAK,CAAC,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;QACxD,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;KAC1E;IACD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,EAAE;QAC7E,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;KAC1E;IACD,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AAChD,CAAC,CAAC;AAEF;;GAEG;AACH,MAAa,eAAe;IAkD1B,YAAY,QAA8B,EAAE;QAZ3B,WAAM,GAAG,IAAI,KAAK,EAAO,CAAC;QAC1B,cAAS,GAAG,IAAI,KAAK,EAAO,CAAC;QAC7B,cAAS,GAA6B,EAAE,CAAC;QACzC,iBAAY,GAA6B,EAAE,CAAC;QAC5C,aAAQ,GAAG,IAAI,KAAK,EAAO,CAAC;QAC5B,gBAAW,GAAG,IAAI,KAAK,EAAO,CAAC;QAC/B,cAAS,GAA2B,EAAG,CAAC;QAGzD,8BAA8B;QACb,gBAAW,GAAG,IAAI,KAAK,EAAc,CAAC;;;;;;;;;;QAGrD,mBAAmB;QACnB,KAAK,MAAM,MAAM,IAAI,CAAC,GAAG,KAAK,CAAC,OAAO,IAAI,EAAE,EAAE,GAAG,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,EAAE;YAExE,IAAI,CAAC,oCAAoC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;gBACzF,MAAM,IAAI,KAAK,CAAC,WAAW,MAAM,yIAAyI,CAAC,CAAC;aAC7K;SACF;QAED,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,MAAM,CAAC,KAAK,CAAC;QAE3C,IAAI,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;QACxC,IAAI,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;QAC9C,IAAI,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC;QAC5C,IAAI,CAAC,eAAe,CAAC,GAAG,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;QAClD,IAAI,KAAK,CAAC,UAAU,KAAK,SAAS,EAAE;YAClC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;SACtC;KACF;IArED;;;;OAIG;IACI,MAAM,CAAC,QAAQ,CAAC,GAAQ;QAC7B,MAAM,GAAG,GAAG,IAAI,eAAe,CAAC;YAC9B,GAAG,EAAE,GAAG,CAAC,GAAG;YACZ,OAAO,EAAE,sBAAsB,CAAC,GAAG,CAAC,MAAM,CAAC;YAC3C,SAAS,EAAE,sBAAsB,CAAC,GAAG,CAAC,QAAQ,CAAC;YAC/C,UAAU,EAAE,GAAG,CAAC,SAAS;YACzB,MAAM,EAAE,GAAG,CAAC,MAAM;YAClB,UAAU,EAAE,sBAAsB,CAAC,GAAG,CAAC,SAAS,CAAC;YACjD,YAAY,EAAE,sBAAsB,CAAC,GAAG,CAAC,WAAW,CAAC;YACrD,UAAU,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;YAC1E,aAAa,EAAE,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;SACpF,CAAC,CAAC;QAEH,0DAA0D;QAC1D,MAAM,MAAM,GAAG,GAAG,CAAC,oBAAoB,EAAE,CAAC;QAC1C,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YACrB,MAAM,IAAI,KAAK,CAAC,8BAA8B,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SACrE;QAED,OAAO,GAAG,CAAC;KACZ;IA8CD,EAAE;IACF,UAAU;IACV,EAAE;IAEF;;;;;;OAMG;IACI,UAAU,CAAC,GAAG,OAAiB;QACpC,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACnD,MAAM,IAAI,KAAK,CAAC,8EAA8E,CAAC,CAAC;SACjG;QACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;KAC9B;IAED;;;;;;;OAOG;IACI,aAAa,CAAC,GAAG,UAAoB;QAC1C,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YACnD,MAAM,IAAI,KAAK,CAAC,8EAA8E,CAAC,CAAC;SACjG;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,CAAC;KACpC;IAED,EAAE;IACF,YAAY;IACZ,EAAE;IAEF;;OAEG;IACH,IAAW,YAAY;QACrB,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;KAC5F;IAED;;;;;;OAMG;IACI,aAAa,CAAC,GAAG,UAAwB;;;;;;;;;;QAC9C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,CAAC;QACrC,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YACnF,MAAM,IAAI,KAAK,CAAC,oFAAoF,CAAC,CAAC;SACvG;QACD,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE;YAClC,IAAI,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC;YACxC,MAAM,QAAQ,GAAG,SAAS,CAAC,cAAc,CAAC;YAC1C,qBAAc,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;YACvD,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;SAClD;KACF;IAED;;;;OAIG;IACH,IAAW,UAAU;QACnB,OAAO,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;KAC9B;IAED;;;;;;;OAOG;IACI,gBAAgB,CAAC,GAAG,aAA2B;;;;;;;;;;QACpD,IAAI,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YACnF,MAAM,IAAI,KAAK,CAAC,oFAAoF,CAAC,CAAC;SACvG;QACD,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE;YACxC,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC;YAC3C,MAAM,QAAQ,GAAG,YAAY,CAAC,cAAc,CAAC;YAC7C,qBAAc,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;YAC1D,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;SAClD;KACF;IAEO,uBAAuB,CAAC,SAAqB;QACnD,IAAI,SAAS,YAAY,aAAK,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,mFAAmF,CAAC,CAAC;SACtG;KACF;IAED;;OAEG;IACI,sBAAsB,CAAC,SAAiB;QAC7C,IAAI,CAAC,aAAa,CAAC,IAAI,6BAAgB,CAAC,SAAS,CAAC,CAAC,CAAC;KACrD;IAED;;;;;OAKG;IACI,eAAe,CAAC,GAAW;QAChC,IAAI,CAAC,aAAa,CAAC,IAAI,yBAAY,CAAC,GAAG,CAAC,CAAC,CAAC;KAC3C;IAED;;;;;OAKG;IACI,mBAAmB,CAAC,OAAe,EAAE,IAA2B;;;;;;;;;;QACrE,IAAI,CAAC,aAAa,CAAC,IAAI,6BAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC;KACzD;IAED;;;;;;OAMG;IACI,qBAAqB,CAAC,SAAc,EAAE,UAAsB;QACjE,IAAI,CAAC,aAAa,CAAC,IAAI,+BAAkB,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC;KACnE;IAED;;OAEG;IACI,uBAAuB;QAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,iCAAoB,EAAE,CAAC,CAAC;KAChD;IAED;;;;OAIG;IACI,yBAAyB,CAAC,eAAuB;QACtD,IAAI,CAAC,aAAa,CAAC,IAAI,mCAAsB,CAAC,eAAe,CAAC,CAAC,CAAC;KACjE;IAED;;OAEG;IACI,eAAe;QACpB,IAAI,CAAC,aAAa,CAAC,IAAI,yBAAY,EAAE,CAAC,CAAC;KACxC;IAED,EAAE;IACF,YAAY;IACZ,EAAE;IAEF;;;;;;;OAOG;IACI,YAAY,CAAC,GAAG,IAAc;QACnC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;YAClD,MAAM,IAAI,KAAK,CAAC,kFAAkF,CAAC,CAAC;SACrG;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;KAC7B;IAED;;;;;;;OAOG;IACI,eAAe,CAAC,GAAG,IAAc;QACtC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/C,MAAM,IAAI,KAAK,CAAC,kFAAkF,CAAC,CAAC;SACrG;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;KAChC;IAED;;OAEG;IACI,eAAe;QACpB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;KACxB;IAED;;OAEG;IACH,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;KAClD;IAED,EAAE;IACF,YAAY;IACZ,EAAE;IAEF;;;;;;;;;;;;;;;;;;;;;;;OAuBG;IACI,YAAY,CAAC,GAAW,EAAE,KAAgB;QAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,EAAE,GAAG,aAAa,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;KAC9E;IAED;;;;OAIG;IACI,aAAa,CAAC,UAAsB;QACzC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YAChC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;KACJ;IAED;;;;OAIG;IACI,mBAAmB,CAAC,SAAiB;QAC1C,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,EAAE,gBAAgB,EAAE,SAAS,EAAE,CAAC,CAAC;KACpE;IAED;;;OAGG;IACI,IAAI,CAAC,YAAkC,EAAE;;;;;;;;;;;QAC9C,OAAO,IAAI,eAAe,CAAC;YACzB,GAAG,QAAE,SAAS,CAAC,GAAG,mCAAI,IAAI,CAAC,GAAG;YAC9B,MAAM,QAAE,SAAS,CAAC,MAAM,mCAAI,IAAI,CAAC,MAAM;YACvC,OAAO,QAAE,SAAS,CAAC,OAAO,mCAAI,IAAI,CAAC,MAAM;YACzC,UAAU,QAAE,SAAS,CAAC,UAAU,mCAAI,IAAI,CAAC,SAAS;YAElD,UAAU,EAAE,SAAS,CAAC,UAAU;YAChC,aAAa,EAAE,SAAS,CAAC,aAAa;YAEtC,SAAS,QAAE,SAAS,CAAC,SAAS,mCAAI,IAAI,CAAC,QAAQ;YAC/C,YAAY,QAAE,SAAS,CAAC,YAAY,mCAAI,IAAI,CAAC,WAAW;SACzD,CAAC,CAAC;KACJ;IAED;;;;OAIG;IACI,eAAe;QACpB,OAAO,gDAAkB,CAAC;YACxB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC,CAAC;KACJ;IAED;;OAEG;IACI,QAAQ;QACb,OAAO,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE;YAC9B,WAAW,EAAE,iBAAiB;SAC/B,CAAC,CAAC;KACJ;IAED;;;;OAIG;IACI,MAAM;QACX,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC;KAC/B;IAED;;;;;;;;;;;;OAYG;IACK,sBAAsB,CAAC,UAAsB;QACnD,iEAAiE;QACjE,MAAM,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACnD,IAAI,IAAI,CAAC,uBAAuB,KAAK,SAAS,EAAE;YAC9C,iCAAiC;YACjC,IAAI,CAAC,uBAAuB,GAAG,eAAe,CAAC;SAChD;aAAM;YACL,IAAI,IAAI,CAAC,uBAAuB,KAAK,eAAe,EAAE;gBACpD,MAAM,IAAI,KAAK,CAAC,2EAA2E,IAAI,CAAC,uBAAuB,UAAU,eAAe,sCAAsC,CAAC,CAAC;aACzL;SACF;QACD,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;KAChC;IAED;;OAEG;IACI,oBAAoB;QACzB,MAAM,MAAM,GAAG,IAAI,KAAK,EAAU,CAAC;QACnC,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3D,MAAM,CAAC,IAAI,CAAC,0EAA0E,CAAC,CAAC;SACzF;QACD,OAAO,MAAM,CAAC;KACf;IAED;;OAEG;IACI,yBAAyB;QAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC3C,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3F,MAAM,CAAC,IAAI,CAAC,4FAA4F,CAAC,CAAC;SAC3G;QACD,OAAO,MAAM,CAAC;KACf;IAED;;OAEG;IACI,yBAAyB;QAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC3C,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YACvF,MAAM,CAAC,IAAI,CAAC,uFAAuF,CAAC,CAAC;SACtG;QACD,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;YACzF,MAAM,CAAC,IAAI,CAAC,wFAAwF,CAAC,CAAC;SACvG;QACD,OAAO,MAAM,CAAC;KACf;;AAncH,0CAocC;;;AAED;;;;GAIG;AACH,IAAY,MAYX;AAZD,WAAY,MAAM;IAChB;;OAEG;IACH,yBAAe,CAAA;IAEf;;;;OAIG;IACH,uBAAa,CAAA;AACf,CAAC,EAZW,MAAM,GAAN,cAAM,KAAN,cAAM,QAYjB;AAwGD,MAAM,aAAc,SAAQ,0BAAa;IAGvC,YAAY,OAAY,EAAG;QACzB,KAAK,EAAE,CAAC;QAER,oFAAoF;QACpF,+CAA+C;QAC/C,IAAI,OAAM,CAAC,IAAI,CAAC,KAAK,QAAQ,EAAE;YAC7B,IAAI,GAAG,EAAE,CAAC,yBAAkB,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;SACzC;QACD,IAAI,OAAM,CAAC,IAAI,CAAC,KAAK,QAAQ,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,+CAA+C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SACxF;QAED,IAAI,CAAC,cAAc,GAAG;YACpB,aAAa,EAAE,IAAI;YACnB,UAAU,EAAE,EAAE;SACf,CAAC;KACH;CACF","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { Group } from './group';\nimport {\n  AccountPrincipal, AccountRootPrincipal, AnyPrincipal, ArnPrincipal, CanonicalUserPrincipal,\n  FederatedPrincipal, IPrincipal, PrincipalBase, PrincipalPolicyFragment, ServicePrincipal, ServicePrincipalOpts,\n} from './principals';\nimport { normalizeStatement } from './private/postprocess-policy-document';\nimport { LITERAL_STRING_KEY, mergePrincipal } from './util';\n\nconst ensureArrayOrUndefined = (field: any) => {\n  if (field === undefined) {\n    return undefined;\n  }\n  if (typeof (field) !== 'string' && !Array.isArray(field)) {\n    throw new Error('Fields must be either a string or an array of strings');\n  }\n  if (Array.isArray(field) && !!field.find((f: any) => typeof (f) !== 'string')) {\n    throw new Error('Fields must be either a string or an array of strings');\n  }\n  return Array.isArray(field) ? field : [field];\n};\n\n/**\n * Represents a statement in an IAM policy document.\n */\nexport class PolicyStatement {\n\n  /**\n   * Creates a new PolicyStatement based on the object provided.\n   * This will accept an object created from the `.toJSON()` call\n   * @param obj the PolicyStatement in object form.\n   */\n  public static fromJson(obj: any) {\n    const ret = new PolicyStatement({\n      sid: obj.Sid,\n      actions: ensureArrayOrUndefined(obj.Action),\n      resources: ensureArrayOrUndefined(obj.Resource),\n      conditions: obj.Condition,\n      effect: obj.Effect,\n      notActions: ensureArrayOrUndefined(obj.NotAction),\n      notResources: ensureArrayOrUndefined(obj.NotResource),\n      principals: obj.Principal ? [new JsonPrincipal(obj.Principal)] : undefined,\n      notPrincipals: obj.NotPrincipal ? [new JsonPrincipal(obj.NotPrincipal)] : undefined,\n    });\n\n    // validate that the PolicyStatement has the correct shape\n    const errors = ret.validateForAnyPolicy();\n    if (errors.length > 0) {\n      throw new Error('Incorrect Policy Statement: ' + errors.join('\\n'));\n    }\n\n    return ret;\n  }\n\n  /**\n   * Statement ID for this statement\n   */\n  public sid?: string;\n  /**\n   * Whether to allow or deny the actions in this statement\n   */\n  public effect: Effect;\n\n  private readonly action = new Array<any>();\n  private readonly notAction = new Array<any>();\n  private readonly principal: { [key: string]: any[] } = {};\n  private readonly notPrincipal: { [key: string]: any[] } = {};\n  private readonly resource = new Array<any>();\n  private readonly notResource = new Array<any>();\n  private readonly condition: { [key: string]: any } = { };\n  private principalConditionsJson?: string;\n\n  // Hold on to those principals\n  private readonly _principals = new Array<IPrincipal>();\n\n  constructor(props: PolicyStatementProps = {}) {\n    // Validate actions\n    for (const action of [...props.actions || [], ...props.notActions || []]) {\n\n      if (!/^(\\*|[a-zA-Z0-9-]+:[a-zA-Z0-9*]+)$/.test(action) && !cdk.Token.isUnresolved(action)) {\n        throw new Error(`Action '${action}' is invalid. An action string consists of a service namespace, a colon, and the name of an action. Action names can include wildcards.`);\n      }\n    }\n\n    this.sid = props.sid;\n    this.effect = props.effect || Effect.ALLOW;\n\n    this.addActions(...props.actions || []);\n    this.addNotActions(...props.notActions || []);\n    this.addPrincipals(...props.principals || []);\n    this.addNotPrincipals(...props.notPrincipals || []);\n    this.addResources(...props.resources || []);\n    this.addNotResources(...props.notResources || []);\n    if (props.conditions !== undefined) {\n      this.addConditions(props.conditions);\n    }\n  }\n\n  //\n  // Actions\n  //\n\n  /**\n   * Specify allowed actions into the \"Action\" section of the policy statement.\n   *\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_action.html\n   *\n   * @param actions actions that will be allowed.\n   */\n  public addActions(...actions: string[]) {\n    if (actions.length > 0 && this.notAction.length > 0) {\n      throw new Error('Cannot add \\'Actions\\' to policy statement if \\'NotActions\\' have been added');\n    }\n    this.action.push(...actions);\n  }\n\n  /**\n   * Explicitly allow all actions except the specified list of actions into the \"NotAction\" section\n   * of the policy document.\n   *\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notaction.html\n   *\n   * @param notActions actions that will be denied. All other actions will be permitted.\n   */\n  public addNotActions(...notActions: string[]) {\n    if (notActions.length > 0 && this.action.length > 0) {\n      throw new Error('Cannot add \\'NotActions\\' to policy statement if \\'Actions\\' have been added');\n    }\n    this.notAction.push(...notActions);\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 || Object.keys(this.notPrincipal).length > 0;\n  }\n\n  /**\n   * Adds principals to the \"Principal\" section of a policy statement.\n   *\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_principal.html\n   *\n   * @param principals IAM principals that will be added\n   */\n  public addPrincipals(...principals: IPrincipal[]) {\n    this._principals.push(...principals);\n    if (Object.keys(principals).length > 0 && Object.keys(this.notPrincipal).length > 0) {\n      throw new Error('Cannot add \\'Principals\\' to policy statement if \\'NotPrincipals\\' have been added');\n    }\n    for (const principal of principals) {\n      this.validatePolicyPrincipal(principal);\n      const fragment = principal.policyFragment;\n      mergePrincipal(this.principal, fragment.principalJson);\n      this.addPrincipalConditions(fragment.conditions);\n    }\n  }\n\n  /**\n   * Expose principals to allow their ARNs to be replaced by account ID strings\n   * in policy statements for resources policies that don't allow full account ARNs,\n   * such as AWS::Logs::ResourcePolicy.\n   */\n  public get principals(): IPrincipal[] {\n    return [...this._principals];\n  }\n\n  /**\n   * Specify principals that is not allowed or denied access to the \"NotPrincipal\" section of\n   * a policy statement.\n   *\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notprincipal.html\n   *\n   * @param notPrincipals IAM principals that will be denied access\n   */\n  public addNotPrincipals(...notPrincipals: IPrincipal[]) {\n    if (Object.keys(notPrincipals).length > 0 && Object.keys(this.principal).length > 0) {\n      throw new Error('Cannot add \\'NotPrincipals\\' to policy statement if \\'Principals\\' have been added');\n    }\n    for (const notPrincipal of notPrincipals) {\n      this.validatePolicyPrincipal(notPrincipal);\n      const fragment = notPrincipal.policyFragment;\n      mergePrincipal(this.notPrincipal, fragment.principalJson);\n      this.addPrincipalConditions(fragment.conditions);\n    }\n  }\n\n  private validatePolicyPrincipal(principal: IPrincipal) {\n    if (principal instanceof Group) {\n      throw new Error('Cannot use an IAM Group as the \\'Principal\\' or \\'NotPrincipal\\' in an IAM Policy');\n    }\n  }\n\n  /**\n   * Specify AWS account ID as the principal entity to the \"Principal\" section of a policy statement.\n   */\n  public addAwsAccountPrincipal(accountId: string) {\n    this.addPrincipals(new AccountPrincipal(accountId));\n  }\n\n  /**\n   * Specify a principal using the ARN  identifier of the principal.\n   * You cannot specify IAM groups and instance profiles as principals.\n   *\n   * @param arn ARN identifier of AWS account, IAM user, or IAM role (i.e. arn:aws:iam::123456789012:user/user-name)\n   */\n  public addArnPrincipal(arn: string) {\n    this.addPrincipals(new ArnPrincipal(arn));\n  }\n\n  /**\n   * Adds a service principal to this policy statement.\n   *\n   * @param service the service name for which a service principal is requested (e.g: `s3.amazonaws.com`).\n   * @param opts    options for adding the service principal (such as specifying a principal in a different region)\n   */\n  public addServicePrincipal(service: string, opts?: ServicePrincipalOpts) {\n    this.addPrincipals(new ServicePrincipal(service, opts));\n  }\n\n  /**\n   * Adds a federated identity provider such as Amazon Cognito to this policy statement.\n   *\n   * @param federated federated identity provider (i.e. 'cognito-identity.amazonaws.com')\n   * @param conditions The conditions under which the policy is in effect.\n   *   See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).\n   */\n  public addFederatedPrincipal(federated: any, conditions: Conditions) {\n    this.addPrincipals(new FederatedPrincipal(federated, conditions));\n  }\n\n  /**\n   * Adds an AWS account root user principal to this policy statement\n   */\n  public addAccountRootPrincipal() {\n    this.addPrincipals(new AccountRootPrincipal());\n  }\n\n  /**\n   * Adds a canonical user ID principal to this policy document\n   *\n   * @param canonicalUserId unique identifier assigned by AWS for every account\n   */\n  public addCanonicalUserPrincipal(canonicalUserId: string) {\n    this.addPrincipals(new CanonicalUserPrincipal(canonicalUserId));\n  }\n\n  /**\n   * Adds all identities in all accounts (\"*\") to this policy statement\n   */\n  public addAnyPrincipal() {\n    this.addPrincipals(new AnyPrincipal());\n  }\n\n  //\n  // Resources\n  //\n\n  /**\n   * Specify resources that this policy statement applies into the \"Resource\" section of\n   * this policy statement.\n   *\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_resource.html\n   *\n   * @param arns Amazon Resource Names (ARNs) of the resources that this policy statement applies to\n   */\n  public addResources(...arns: string[]) {\n    if (arns.length > 0 && this.notResource.length > 0) {\n      throw new Error('Cannot add \\'Resources\\' to policy statement if \\'NotResources\\' have been added');\n    }\n    this.resource.push(...arns);\n  }\n\n  /**\n   * Specify resources that this policy statement will not apply to in the \"NotResource\" section\n   * of this policy statement. All resources except the specified list will be matched.\n   *\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_notresource.html\n   *\n   * @param arns Amazon Resource Names (ARNs) of the resources that this policy statement does not apply to\n   */\n  public addNotResources(...arns: string[]) {\n    if (arns.length > 0 && this.resource.length > 0) {\n      throw new Error('Cannot add \\'NotResources\\' to policy statement if \\'Resources\\' have been added');\n    }\n    this.notResource.push(...arns);\n  }\n\n  /**\n   * Adds a ``\"*\"`` resource to this statement.\n   */\n  public addAllResources() {\n    this.addResources('*');\n  }\n\n  /**\n   * Indicates if this permission has at least one resource associated with it.\n   */\n  public get hasResource() {\n    return this.resource && this.resource.length > 0;\n  }\n\n  //\n  // Condition\n  //\n\n  /**\n   * Add a condition to the Policy\n   *\n   * If multiple calls are made to add a condition with the same operator and field, only\n   * the last one wins. For example:\n   *\n   * ```ts\n   * declare const stmt: iam.PolicyStatement;\n   *\n   * stmt.addCondition('StringEquals', { 'aws:SomeField': '1' });\n   * stmt.addCondition('StringEquals', { 'aws:SomeField': '2' });\n   * ```\n   *\n   * Will end up with the single condition `StringEquals: { 'aws:SomeField': '2' }`.\n   *\n   * If you meant to add a condition to say that the field can be *either* `1` or `2`, write\n   * this:\n   *\n   * ```ts\n   * declare const stmt: iam.PolicyStatement;\n   *\n   * stmt.addCondition('StringEquals', { 'aws:SomeField': ['1', '2'] });\n   * ```\n   */\n  public addCondition(key: string, value: Condition) {\n    const existingValue = this.condition[key];\n    this.condition[key] = existingValue ? { ...existingValue, ...value } : value;\n  }\n\n  /**\n   * Add multiple conditions to the Policy\n   *\n   * See the `addCondition` function for a caveat on calling this method multiple times.\n   */\n  public addConditions(conditions: Conditions) {\n    Object.keys(conditions).map(key => {\n      this.addCondition(key, conditions[key]);\n    });\n  }\n\n  /**\n   * Add a condition that limits to a given account\n   *\n   * This method can only be called once: subsequent calls will overwrite earlier calls.\n   */\n  public addAccountCondition(accountId: string) {\n    this.addCondition('StringEquals', { 'sts:ExternalId': accountId });\n  }\n\n  /**\n   * Create a new `PolicyStatement` with the same exact properties\n   * as this one, except for the overrides\n   */\n  public copy(overrides: PolicyStatementProps = {}) {\n    return new PolicyStatement({\n      sid: overrides.sid ?? this.sid,\n      effect: overrides.effect ?? this.effect,\n      actions: overrides.actions ?? this.action,\n      notActions: overrides.notActions ?? this.notAction,\n\n      principals: overrides.principals,\n      notPrincipals: overrides.notPrincipals,\n\n      resources: overrides.resources ?? this.resource,\n      notResources: overrides.notResources ?? this.notResource,\n    });\n  }\n\n  /**\n   * JSON-ify the policy statement\n   *\n   * Used when JSON.stringify() is called\n   */\n  public toStatementJson(): any {\n    return normalizeStatement({\n      Action: this.action,\n      NotAction: this.notAction,\n      Condition: this.condition,\n      Effect: this.effect,\n      Principal: this.principal,\n      NotPrincipal: this.notPrincipal,\n      Resource: this.resource,\n      NotResource: this.notResource,\n      Sid: this.sid,\n    });\n  }\n\n  /**\n   * String representation of this policy statement\n   */\n  public toString() {\n    return cdk.Token.asString(this, {\n      displayHint: 'PolicyStatement',\n    });\n  }\n\n  /**\n   * JSON-ify the statement\n   *\n   * Used when JSON.stringify() is called\n   */\n  public toJSON() {\n    return this.toStatementJson();\n  }\n\n  /**\n   * Add a principal's conditions\n   *\n   * For convenience, principals have been modeled as both a principal\n   * and a set of conditions. This makes it possible to have a single\n   * object represent e.g. an \"SNS Topic\" (SNS service principal + aws:SourcArn\n   * condition) or an Organization member (* + aws:OrgId condition).\n   *\n   * However, when using multiple principals in the same policy statement,\n   * they must all have the same conditions or the OR samentics\n   * implied by a list of principals cannot be guaranteed (user needs to\n   * add multiple statements in that case).\n   */\n  private addPrincipalConditions(conditions: Conditions) {\n    // Stringifying the conditions is an easy way to do deep equality\n    const theseConditions = JSON.stringify(conditions);\n    if (this.principalConditionsJson === undefined) {\n      // First principal, anything goes\n      this.principalConditionsJson = theseConditions;\n    } else {\n      if (this.principalConditionsJson !== theseConditions) {\n        throw new Error(`All principals in a PolicyStatement must have the same Conditions (got '${this.principalConditionsJson}' and '${theseConditions}'). Use multiple statements instead.`);\n      }\n    }\n    this.addConditions(conditions);\n  }\n\n  /**\n   * Validate that the policy statement satisfies base requirements for a policy.\n   */\n  public validateForAnyPolicy(): string[] {\n    const errors = new Array<string>();\n    if (this.action.length === 0 && this.notAction.length === 0) {\n      errors.push('A PolicyStatement must specify at least one \\'action\\' or \\'notAction\\'.');\n    }\n    return errors;\n  }\n\n  /**\n   * Validate that the policy statement satisfies all requirements for a resource-based policy.\n   */\n  public validateForResourcePolicy(): string[] {\n    const errors = this.validateForAnyPolicy();\n    if (Object.keys(this.principal).length === 0 && Object.keys(this.notPrincipal).length === 0) {\n      errors.push('A PolicyStatement used in a resource-based policy must specify at least one IAM principal.');\n    }\n    return errors;\n  }\n\n  /**\n   * Validate that the policy statement satisfies all requirements for an identity-based policy.\n   */\n  public validateForIdentityPolicy(): string[] {\n    const errors = this.validateForAnyPolicy();\n    if (Object.keys(this.principal).length > 0 || Object.keys(this.notPrincipal).length > 0) {\n      errors.push('A PolicyStatement used in an identity-based policy cannot specify any IAM principals.');\n    }\n    if (Object.keys(this.resource).length === 0 && Object.keys(this.notResource).length === 0) {\n      errors.push('A PolicyStatement used in an identity-based policy must specify at least one resource.');\n    }\n    return errors;\n  }\n}\n\n/**\n * The Effect element of an IAM policy\n *\n * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_effect.html\n */\nexport enum Effect {\n  /**\n   * Allows access to a resource in an IAM policy statement. By default, access to resources are denied.\n   */\n  ALLOW = 'Allow',\n\n  /**\n   * Explicitly deny access to a resource. By default, all requests are denied implicitly.\n   *\n   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_evaluation-logic.html\n   */\n  DENY = 'Deny',\n}\n\n/**\n * Condition for when an IAM policy is in effect. Maps from the keys in a request's context to\n * a string value or array of string values. See the Conditions interface for more details.\n */\nexport type Condition = any;\n\n// NOTE! We'd ideally like to type this as `Record<string, any>`, because the\n// API expects a map which can take either strings or lists of strings.\n//\n// However, if we were to change this right now, the Java bindings for CDK would\n// emit a type of `Map<String, Object>`, but the most common types people would\n// instantiate would be an `ImmutableMap<String, String>` which would not be\n// assignable to `Map<String, Object>`. The types don't have a built-in notion\n// of co-contravariance, you have to indicate that on the type. So jsii would first\n// need to emit the type as `Map<String, ? extends Object>`.\n//\n// Feature request in https://github.com/aws/jsii/issues/1517\n\n/**\n * Conditions for when an IAM Policy is in effect, specified in the following structure:\n *\n * `{ \"Operator\": { \"keyInRequestContext\": \"value\" } }`\n *\n * The value can be either a single string value or an array of string values.\n *\n * For more information, including which operators are supported, see [the IAM\n * documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).\n */\nexport type Conditions = Record<string, Condition>;\n\n/**\n * Interface for creating a policy statement\n */\nexport interface PolicyStatementProps {\n  /**\n   * The Sid (statement ID) is an optional identifier that you provide for the\n   * policy statement. You can assign a Sid value to each statement in a\n   * statement array. In services that let you specify an ID element, such as\n   * SQS and SNS, the Sid value is just a sub-ID of the policy document's ID. In\n   * IAM, the Sid value must be unique within a JSON policy.\n   *\n   * @default - no sid\n   */\n  readonly sid?: string;\n\n  /**\n   * List of actions to add to the statement\n   *\n   * @default - no actions\n   */\n  readonly actions?: string[];\n\n  /**\n   * List of not actions to add to the statement\n   *\n   * @default - no not-actions\n   */\n  readonly notActions?: string[];\n\n  /**\n   * List of principals to add to the statement\n   *\n   * @default - no principals\n   */\n  readonly principals?: IPrincipal[];\n\n  /**\n   * List of not principals to add to the statement\n   *\n   * @default - no not principals\n   */\n  readonly notPrincipals?: IPrincipal[];\n\n  /**\n   * Resource ARNs to add to the statement\n   *\n   * @default - no resources\n   */\n  readonly resources?: string[];\n\n  /**\n   * NotResource ARNs to add to the statement\n   *\n   * @default - no not-resources\n   */\n  readonly notResources?: string[];\n\n  /**\n   * Conditions to add to the statement\n   *\n   * @default - no condition\n   */\n  readonly conditions?: {[key: string]: any};\n\n  /**\n   * Whether to allow or deny the actions in this statement\n   *\n   * @default Effect.ALLOW\n   */\n  readonly effect?: Effect;\n}\n\nclass JsonPrincipal extends PrincipalBase {\n  public readonly policyFragment: PrincipalPolicyFragment;\n\n  constructor(json: any = { }) {\n    super();\n\n    // special case: if principal is a string, turn it into a \"LiteralString\" principal,\n    // so we render the exact same string back out.\n    if (typeof(json) === 'string') {\n      json = { [LITERAL_STRING_KEY]: [json] };\n    }\n    if (typeof(json) !== 'object') {\n      throw new Error(`JSON IAM principal should be an object, got ${JSON.stringify(json)}`);\n    }\n\n    this.policyFragment = {\n      principalJson: json,\n      conditions: {},\n    };\n  }\n}\n"]} |
\ | No newline at end of file |