1 | ;
|
2 | var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.CompositePrincipal = exports.StarPrincipal = exports.Anyone = exports.AnyPrincipal = exports.AccountRootPrincipal = exports.SamlConsolePrincipal = exports.SamlPrincipal = exports.OpenIdConnectPrincipal = exports.WebIdentityPrincipal = exports.FederatedPrincipal = exports.CanonicalUserPrincipal = exports.OrganizationPrincipal = exports.ServicePrincipal = exports.AccountPrincipal = exports.ArnPrincipal = exports.PrincipalPolicyFragment = exports.SessionTagsPrincipal = exports.PrincipalWithConditions = exports.PrincipalBase = exports.ComparablePrincipal = 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 region_info_1 = require("@aws-cdk/region-info");
|
9 | const policy_statement_1 = require("./policy-statement");
|
10 | const assume_role_policy_1 = require("./private/assume-role-policy");
|
11 | const util_1 = require("./util");
|
12 | /**
|
13 | * Helper class for working with `IComparablePrincipal`s
|
14 | */
|
15 | class ComparablePrincipal {
|
16 | /**
|
17 | * Whether or not the given principal is a comparable principal
|
18 | */
|
19 | static isComparablePrincipal(x) {
|
20 | try {
|
21 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(x);
|
22 | }
|
23 | catch (error) {
|
24 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
25 | Error.captureStackTrace(error, this.isComparablePrincipal);
|
26 | }
|
27 | throw error;
|
28 | }
|
29 | return 'dedupeString' in x;
|
30 | }
|
31 | /**
|
32 | * Return the dedupeString of the given principal, if available
|
33 | */
|
34 | static dedupeStringFor(x) {
|
35 | try {
|
36 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(x);
|
37 | }
|
38 | catch (error) {
|
39 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
40 | Error.captureStackTrace(error, this.dedupeStringFor);
|
41 | }
|
42 | throw error;
|
43 | }
|
44 | return ComparablePrincipal.isComparablePrincipal(x) ? x.dedupeString() : undefined;
|
45 | }
|
46 | }
|
47 | exports.ComparablePrincipal = ComparablePrincipal;
|
48 | _a = JSII_RTTI_SYMBOL_1;
|
49 | ComparablePrincipal[_a] = { fqn: "@aws-cdk/aws-iam.ComparablePrincipal", version: "1.161.0" };
|
50 | /**
|
51 | * Base class for policy principals
|
52 | */
|
53 | class PrincipalBase {
|
54 | constructor() {
|
55 | this.grantPrincipal = this;
|
56 | this.principalAccount = undefined;
|
57 | /**
|
58 | * When this Principal is used in an AssumeRole policy, the action to use.
|
59 | */
|
60 | this.assumeRoleAction = 'sts:AssumeRole';
|
61 | }
|
62 | addToPolicy(statement) {
|
63 | try {
|
64 | jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyStatement(statement);
|
65 | }
|
66 | catch (error) {
|
67 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
68 | Error.captureStackTrace(error, this.addToPolicy);
|
69 | }
|
70 | throw error;
|
71 | }
|
72 | return this.addToPrincipalPolicy(statement).statementAdded;
|
73 | }
|
74 | addToPrincipalPolicy(_statement) {
|
75 | try {
|
76 | jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyStatement(_statement);
|
77 | }
|
78 | catch (error) {
|
79 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
80 | Error.captureStackTrace(error, this.addToPrincipalPolicy);
|
81 | }
|
82 | throw error;
|
83 | }
|
84 | // This base class is used for non-identity principals. None of them
|
85 | // have a PolicyDocument to add to.
|
86 | return { statementAdded: false };
|
87 | }
|
88 | addToAssumeRolePolicy(document) {
|
89 | try {
|
90 | jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyDocument(document);
|
91 | }
|
92 | catch (error) {
|
93 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
94 | Error.captureStackTrace(error, this.addToAssumeRolePolicy);
|
95 | }
|
96 | throw error;
|
97 | }
|
98 | // Default implementation of this protocol, compatible with the legacy behavior
|
99 | document.addStatements(new policy_statement_1.PolicyStatement({
|
100 | actions: [this.assumeRoleAction],
|
101 | principals: [this],
|
102 | }));
|
103 | }
|
104 | toString() {
|
105 | // This is a first pass to make the object readable. Descendant principals
|
106 | // should return something nicer.
|
107 | return JSON.stringify(this.policyFragment.principalJson);
|
108 | }
|
109 | /**
|
110 | * JSON-ify the principal
|
111 | *
|
112 | * Used when JSON.stringify() is called
|
113 | */
|
114 | toJSON() {
|
115 | // Have to implement toJSON() because the default will lead to infinite recursion.
|
116 | return this.policyFragment.principalJson;
|
117 | }
|
118 | /**
|
119 | * Returns a new PrincipalWithConditions using this principal as the base, with the
|
120 | * passed conditions added.
|
121 | *
|
122 | * When there is a value for the same operator and key in both the principal and the
|
123 | * conditions parameter, the value from the conditions parameter will be used.
|
124 | *
|
125 | * @returns a new PrincipalWithConditions object.
|
126 | */
|
127 | withConditions(conditions) {
|
128 | return new PrincipalWithConditions(this, conditions);
|
129 | }
|
130 | /**
|
131 | * Returns a new principal using this principal as the base, with session tags enabled.
|
132 | *
|
133 | * @returns a new SessionTagsPrincipal object.
|
134 | */
|
135 | withSessionTags() {
|
136 | return new SessionTagsPrincipal(this);
|
137 | }
|
138 | }
|
139 | exports.PrincipalBase = PrincipalBase;
|
140 | _b = JSII_RTTI_SYMBOL_1;
|
141 | PrincipalBase[_b] = { fqn: "@aws-cdk/aws-iam.PrincipalBase", version: "1.161.0" };
|
142 | /**
|
143 | * Base class for Principals that wrap other principals
|
144 | */
|
145 | class PrincipalAdapter extends PrincipalBase {
|
146 | constructor(wrapped) {
|
147 | super();
|
148 | this.wrapped = wrapped;
|
149 | this.assumeRoleAction = this.wrapped.assumeRoleAction;
|
150 | this.principalAccount = this.wrapped.principalAccount;
|
151 | }
|
152 | get policyFragment() { return this.wrapped.policyFragment; }
|
153 | addToPolicy(statement) {
|
154 | return this.wrapped.addToPolicy(statement);
|
155 | }
|
156 | addToPrincipalPolicy(statement) {
|
157 | return this.wrapped.addToPrincipalPolicy(statement);
|
158 | }
|
159 | /**
|
160 | * Append the given string to the wrapped principal's dedupe string (if available)
|
161 | */
|
162 | appendDedupe(append) {
|
163 | const inner = ComparablePrincipal.dedupeStringFor(this.wrapped);
|
164 | return inner !== undefined ? `${this.constructor.name}:${inner}:${append}` : undefined;
|
165 | }
|
166 | }
|
167 | /**
|
168 | * An IAM principal with additional conditions specifying when the policy is in effect.
|
169 | *
|
170 | * For more information about conditions, see:
|
171 | * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html
|
172 | */
|
173 | class PrincipalWithConditions extends PrincipalAdapter {
|
174 | constructor(principal, conditions) {
|
175 | super(principal);
|
176 | try {
|
177 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principal);
|
178 | }
|
179 | catch (error) {
|
180 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
181 | Error.captureStackTrace(error, PrincipalWithConditions);
|
182 | }
|
183 | throw error;
|
184 | }
|
185 | this.additionalConditions = conditions;
|
186 | }
|
187 | /**
|
188 | * Add a condition to the principal
|
189 | */
|
190 | addCondition(key, value) {
|
191 | const existingValue = this.additionalConditions[key];
|
192 | this.additionalConditions[key] = existingValue ? { ...existingValue, ...value } : value;
|
193 | }
|
194 | /**
|
195 | * Adds multiple conditions to the principal
|
196 | *
|
197 | * Values from the conditions parameter will overwrite existing values with the same operator
|
198 | * and key.
|
199 | */
|
200 | addConditions(conditions) {
|
201 | Object.entries(conditions).forEach(([key, value]) => {
|
202 | this.addCondition(key, value);
|
203 | });
|
204 | }
|
205 | /**
|
206 | * The conditions under which the policy is in effect.
|
207 | * See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
|
208 | */
|
209 | get conditions() {
|
210 | return this.mergeConditions(this.wrapped.policyFragment.conditions, this.additionalConditions);
|
211 | }
|
212 | get policyFragment() {
|
213 | return new PrincipalPolicyFragment(this.wrapped.policyFragment.principalJson, this.conditions);
|
214 | }
|
215 | toString() {
|
216 | return this.wrapped.toString();
|
217 | }
|
218 | /**
|
219 | * JSON-ify the principal
|
220 | *
|
221 | * Used when JSON.stringify() is called
|
222 | */
|
223 | toJSON() {
|
224 | // Have to implement toJSON() because the default will lead to infinite recursion.
|
225 | return this.policyFragment.principalJson;
|
226 | }
|
227 | dedupeString() {
|
228 | return this.appendDedupe(JSON.stringify(this.conditions));
|
229 | }
|
230 | mergeConditions(principalConditions, additionalConditions) {
|
231 | const mergedConditions = {};
|
232 | Object.entries(principalConditions).forEach(([operator, condition]) => {
|
233 | mergedConditions[operator] = condition;
|
234 | });
|
235 | Object.entries(additionalConditions).forEach(([operator, condition]) => {
|
236 | // merge the conditions if one of the additional conditions uses an
|
237 | // operator that's already used by the principal's conditions merge the
|
238 | // inner structure.
|
239 | const existing = mergedConditions[operator];
|
240 | if (!existing) {
|
241 | mergedConditions[operator] = condition;
|
242 | return; // continue
|
243 | }
|
244 | // if either the existing condition or the new one contain unresolved
|
245 | // tokens, fail the merge. this is as far as we go at this point.
|
246 | if (cdk.Token.isUnresolved(condition) || cdk.Token.isUnresolved(existing)) {
|
247 | throw new Error(`multiple "${operator}" conditions cannot be merged if one of them contains an unresolved token`);
|
248 | }
|
249 | mergedConditions[operator] = { ...existing, ...condition };
|
250 | });
|
251 | return mergedConditions;
|
252 | }
|
253 | }
|
254 | exports.PrincipalWithConditions = PrincipalWithConditions;
|
255 | _c = JSII_RTTI_SYMBOL_1;
|
256 | PrincipalWithConditions[_c] = { fqn: "@aws-cdk/aws-iam.PrincipalWithConditions", version: "1.161.0" };
|
257 | /**
|
258 | * Enables session tags on role assumptions from a principal
|
259 | *
|
260 | * For more information on session tags, see:
|
261 | * https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html
|
262 | */
|
263 | class SessionTagsPrincipal extends PrincipalAdapter {
|
264 | constructor(principal) {
|
265 | super(principal);
|
266 | try {
|
267 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principal);
|
268 | }
|
269 | catch (error) {
|
270 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
271 | Error.captureStackTrace(error, SessionTagsPrincipal);
|
272 | }
|
273 | throw error;
|
274 | }
|
275 | }
|
276 | addToAssumeRolePolicy(doc) {
|
277 | try {
|
278 | jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyDocument(doc);
|
279 | }
|
280 | catch (error) {
|
281 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
282 | Error.captureStackTrace(error, this.addToAssumeRolePolicy);
|
283 | }
|
284 | throw error;
|
285 | }
|
286 | // Lazy import to avoid circular import dependencies during startup
|
287 | // eslint-disable-next-line @typescript-eslint/no-require-imports
|
288 | const adapter = require('./private/policydoc-adapter');
|
289 | assume_role_policy_1.defaultAddPrincipalToAssumeRole(this.wrapped, new adapter.MutatingPolicyDocumentAdapter(doc, (statement) => {
|
290 | statement.addActions('sts:TagSession');
|
291 | return statement;
|
292 | }));
|
293 | }
|
294 | dedupeString() {
|
295 | return this.appendDedupe('');
|
296 | }
|
297 | }
|
298 | exports.SessionTagsPrincipal = SessionTagsPrincipal;
|
299 | _d = JSII_RTTI_SYMBOL_1;
|
300 | SessionTagsPrincipal[_d] = { fqn: "@aws-cdk/aws-iam.SessionTagsPrincipal", version: "1.161.0" };
|
301 | /**
|
302 | * A collection of the fields in a PolicyStatement that can be used to identify a principal.
|
303 | *
|
304 | * This consists of the JSON used in the "Principal" field, and optionally a
|
305 | * set of "Condition"s that need to be applied to the policy.
|
306 | *
|
307 | * Generally, a principal looks like:
|
308 | *
|
309 | * { '<TYPE>': ['ID', 'ID', ...] }
|
310 | *
|
311 | * And this is also the type of the field `principalJson`. However, there is a
|
312 | * special type of principal that is just the string '*', which is treated
|
313 | * differently by some services. To represent that principal, `principalJson`
|
314 | * should contain `{ 'LiteralString': ['*'] }`.
|
315 | */
|
316 | class PrincipalPolicyFragment {
|
317 | /**
|
318 | *
|
319 | * @param principalJson JSON of the "Principal" section in a policy statement
|
320 | * @param conditions conditions that need to be applied to this policy
|
321 | */
|
322 | constructor(principalJson,
|
323 | /**
|
324 | * The conditions under which the policy is in effect.
|
325 | * See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
|
326 | */
|
327 | conditions = {}) {
|
328 | this.principalJson = principalJson;
|
329 | this.conditions = conditions;
|
330 | }
|
331 | }
|
332 | exports.PrincipalPolicyFragment = PrincipalPolicyFragment;
|
333 | _e = JSII_RTTI_SYMBOL_1;
|
334 | PrincipalPolicyFragment[_e] = { fqn: "@aws-cdk/aws-iam.PrincipalPolicyFragment", version: "1.161.0" };
|
335 | /**
|
336 | * Specify a principal by the Amazon Resource Name (ARN).
|
337 | * You can specify AWS accounts, IAM users, Federated SAML users, IAM roles, and specific assumed-role sessions.
|
338 | * You cannot specify IAM groups or instance profiles as principals
|
339 | *
|
340 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_principal.html
|
341 | */
|
342 | class ArnPrincipal extends PrincipalBase {
|
343 | /**
|
344 | *
|
345 | * @param arn Amazon Resource Name (ARN) of the principal entity (i.e. arn:aws:iam::123456789012:user/user-name)
|
346 | */
|
347 | constructor(arn) {
|
348 | super();
|
349 | this.arn = arn;
|
350 | }
|
351 | get policyFragment() {
|
352 | return new PrincipalPolicyFragment({ AWS: [this.arn] });
|
353 | }
|
354 | toString() {
|
355 | return `ArnPrincipal(${this.arn})`;
|
356 | }
|
357 | /**
|
358 | * A convenience method for adding a condition that the principal is part of the specified
|
359 | * AWS Organization.
|
360 | */
|
361 | inOrganization(organizationId) {
|
362 | return this.withConditions({
|
363 | StringEquals: {
|
364 | 'aws:PrincipalOrgID': organizationId,
|
365 | },
|
366 | });
|
367 | }
|
368 | dedupeString() {
|
369 | return `ArnPrincipal:${this.arn}`;
|
370 | }
|
371 | }
|
372 | exports.ArnPrincipal = ArnPrincipal;
|
373 | _f = JSII_RTTI_SYMBOL_1;
|
374 | ArnPrincipal[_f] = { fqn: "@aws-cdk/aws-iam.ArnPrincipal", version: "1.161.0" };
|
375 | /**
|
376 | * Specify AWS account ID as the principal entity in a policy to delegate authority to the account.
|
377 | */
|
378 | class AccountPrincipal extends ArnPrincipal {
|
379 | /**
|
380 | *
|
381 | * @param accountId AWS account ID (i.e. 123456789012)
|
382 | */
|
383 | constructor(accountId) {
|
384 | super(new StackDependentToken(stack => `arn:${stack.partition}:iam::${accountId}:root`).toString());
|
385 | this.accountId = accountId;
|
386 | if (!cdk.Token.isUnresolved(accountId) && typeof accountId !== 'string') {
|
387 | throw new Error('accountId should be of type string');
|
388 | }
|
389 | this.principalAccount = accountId;
|
390 | }
|
391 | toString() {
|
392 | return `AccountPrincipal(${this.accountId})`;
|
393 | }
|
394 | }
|
395 | exports.AccountPrincipal = AccountPrincipal;
|
396 | _g = JSII_RTTI_SYMBOL_1;
|
397 | AccountPrincipal[_g] = { fqn: "@aws-cdk/aws-iam.AccountPrincipal", version: "1.161.0" };
|
398 | /**
|
399 | * An IAM principal that represents an AWS service (i.e. sqs.amazonaws.com).
|
400 | */
|
401 | class ServicePrincipal extends PrincipalBase {
|
402 | /**
|
403 | *
|
404 | * @param service AWS service (i.e. sqs.amazonaws.com)
|
405 | */
|
406 | constructor(service, opts = {}) {
|
407 | super();
|
408 | this.service = service;
|
409 | this.opts = opts;
|
410 | try {
|
411 | jsiiDeprecationWarnings._aws_cdk_aws_iam_ServicePrincipalOpts(opts);
|
412 | }
|
413 | catch (error) {
|
414 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
415 | Error.captureStackTrace(error, ServicePrincipal);
|
416 | }
|
417 | throw error;
|
418 | }
|
419 | }
|
420 | /**
|
421 | * Translate the given service principal name based on the region it's used in.
|
422 | *
|
423 | * For example, for Chinese regions this may (depending on whether that's necessary
|
424 | * for the given service principal) append `.cn` to the name.
|
425 | *
|
426 | * The `region-info` module is used to obtain this information.
|
427 | *
|
428 | * @example
|
429 | * const principalName = iam.ServicePrincipal.servicePrincipalName('ec2.amazonaws.com');
|
430 | */
|
431 | static servicePrincipalName(service) {
|
432 | return new ServicePrincipalToken(service, {}).toString();
|
433 | }
|
434 | get policyFragment() {
|
435 | return new PrincipalPolicyFragment({
|
436 | Service: [
|
437 | new ServicePrincipalToken(this.service, this.opts).toString(),
|
438 | ],
|
439 | }, this.opts.conditions);
|
440 | }
|
441 | toString() {
|
442 | return `ServicePrincipal(${this.service})`;
|
443 | }
|
444 | dedupeString() {
|
445 | return `ServicePrincipal:${this.service}:${JSON.stringify(this.opts)}`;
|
446 | }
|
447 | }
|
448 | exports.ServicePrincipal = ServicePrincipal;
|
449 | _h = JSII_RTTI_SYMBOL_1;
|
450 | ServicePrincipal[_h] = { fqn: "@aws-cdk/aws-iam.ServicePrincipal", version: "1.161.0" };
|
451 | /**
|
452 | * A principal that represents an AWS Organization
|
453 | */
|
454 | class OrganizationPrincipal extends PrincipalBase {
|
455 | /**
|
456 | *
|
457 | * @param organizationId The unique identifier (ID) of an organization (i.e. o-12345abcde)
|
458 | */
|
459 | constructor(organizationId) {
|
460 | super();
|
461 | this.organizationId = organizationId;
|
462 | }
|
463 | get policyFragment() {
|
464 | return new PrincipalPolicyFragment({ AWS: ['*'] }, { StringEquals: { 'aws:PrincipalOrgID': this.organizationId } });
|
465 | }
|
466 | toString() {
|
467 | return `OrganizationPrincipal(${this.organizationId})`;
|
468 | }
|
469 | dedupeString() {
|
470 | return `OrganizationPrincipal:${this.organizationId}`;
|
471 | }
|
472 | }
|
473 | exports.OrganizationPrincipal = OrganizationPrincipal;
|
474 | _j = JSII_RTTI_SYMBOL_1;
|
475 | OrganizationPrincipal[_j] = { fqn: "@aws-cdk/aws-iam.OrganizationPrincipal", version: "1.161.0" };
|
476 | /**
|
477 | * A policy principal for canonicalUserIds - useful for S3 bucket policies that use
|
478 | * Origin Access identities.
|
479 | *
|
480 | * See https://docs.aws.amazon.com/general/latest/gr/acct-identifiers.html
|
481 | *
|
482 | * and
|
483 | *
|
484 | * https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-restricting-access-to-s3.html
|
485 | *
|
486 | * for more details.
|
487 | *
|
488 | */
|
489 | class CanonicalUserPrincipal extends PrincipalBase {
|
490 | /**
|
491 | *
|
492 | * @param canonicalUserId unique identifier assigned by AWS for every account.
|
493 | * root user and IAM users for an account all see the same ID.
|
494 | * (i.e. 79a59df900b949e55d96a1e698fbacedfd6e09d98eacf8f8d5218e7cd47ef2be)
|
495 | */
|
496 | constructor(canonicalUserId) {
|
497 | super();
|
498 | this.canonicalUserId = canonicalUserId;
|
499 | }
|
500 | get policyFragment() {
|
501 | return new PrincipalPolicyFragment({ CanonicalUser: [this.canonicalUserId] });
|
502 | }
|
503 | toString() {
|
504 | return `CanonicalUserPrincipal(${this.canonicalUserId})`;
|
505 | }
|
506 | dedupeString() {
|
507 | return `CanonicalUserPrincipal:${this.canonicalUserId}`;
|
508 | }
|
509 | }
|
510 | exports.CanonicalUserPrincipal = CanonicalUserPrincipal;
|
511 | _k = JSII_RTTI_SYMBOL_1;
|
512 | CanonicalUserPrincipal[_k] = { fqn: "@aws-cdk/aws-iam.CanonicalUserPrincipal", version: "1.161.0" };
|
513 | /**
|
514 | * Principal entity that represents a federated identity provider such as Amazon Cognito,
|
515 | * that can be used to provide temporary security credentials to users who have been authenticated.
|
516 | * Additional condition keys are available when the temporary security credentials are used to make a request.
|
517 | * You can use these keys to write policies that limit the access of federated users.
|
518 | *
|
519 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_iam-condition-keys.html#condition-keys-wif
|
520 | */
|
521 | class FederatedPrincipal extends PrincipalBase {
|
522 | /**
|
523 | *
|
524 | * @param federated federated identity provider (i.e. 'cognito-identity.amazonaws.com' for users authenticated through Cognito)
|
525 | * @param conditions The conditions under which the policy is in effect.
|
526 | * See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
|
527 | * @param sessionTags Whether to enable session tagging (see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html)
|
528 | */
|
529 | constructor(federated, conditions, assumeRoleAction = 'sts:AssumeRole') {
|
530 | super();
|
531 | this.federated = federated;
|
532 | this.conditions = conditions;
|
533 | this.assumeRoleAction = assumeRoleAction;
|
534 | }
|
535 | get policyFragment() {
|
536 | return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);
|
537 | }
|
538 | toString() {
|
539 | return `FederatedPrincipal(${this.federated})`;
|
540 | }
|
541 | dedupeString() {
|
542 | return `FederatedPrincipal:${this.federated}:${this.assumeRoleAction}:${JSON.stringify(this.conditions)}`;
|
543 | }
|
544 | }
|
545 | exports.FederatedPrincipal = FederatedPrincipal;
|
546 | _l = JSII_RTTI_SYMBOL_1;
|
547 | FederatedPrincipal[_l] = { fqn: "@aws-cdk/aws-iam.FederatedPrincipal", version: "1.161.0" };
|
548 | /**
|
549 | * A principal that represents a federated identity provider as Web Identity such as Cognito, Amazon,
|
550 | * Facebook, Google, etc.
|
551 | */
|
552 | class WebIdentityPrincipal extends FederatedPrincipal {
|
553 | /**
|
554 | *
|
555 | * @param identityProvider identity provider (i.e. 'cognito-identity.amazonaws.com' for users authenticated through Cognito)
|
556 | * @param conditions The conditions under which the policy is in effect.
|
557 | * See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
|
558 | * @param sessionTags Whether to enable session tagging (see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html)
|
559 | */
|
560 | constructor(identityProvider, conditions = {}) {
|
561 | super(identityProvider, conditions ?? {}, 'sts:AssumeRoleWithWebIdentity');
|
562 | }
|
563 | get policyFragment() {
|
564 | return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);
|
565 | }
|
566 | toString() {
|
567 | return `WebIdentityPrincipal(${this.federated})`;
|
568 | }
|
569 | }
|
570 | exports.WebIdentityPrincipal = WebIdentityPrincipal;
|
571 | _m = JSII_RTTI_SYMBOL_1;
|
572 | WebIdentityPrincipal[_m] = { fqn: "@aws-cdk/aws-iam.WebIdentityPrincipal", version: "1.161.0" };
|
573 | /**
|
574 | * A principal that represents a federated identity provider as from a OpenID Connect provider.
|
575 | */
|
576 | class OpenIdConnectPrincipal extends WebIdentityPrincipal {
|
577 | /**
|
578 | *
|
579 | * @param openIdConnectProvider OpenID Connect provider
|
580 | * @param conditions The conditions under which the policy is in effect.
|
581 | * See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
|
582 | */
|
583 | constructor(openIdConnectProvider, conditions = {}) {
|
584 | super(openIdConnectProvider.openIdConnectProviderArn, conditions ?? {});
|
585 | try {
|
586 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IOpenIdConnectProvider(openIdConnectProvider);
|
587 | }
|
588 | catch (error) {
|
589 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
590 | Error.captureStackTrace(error, OpenIdConnectPrincipal);
|
591 | }
|
592 | throw error;
|
593 | }
|
594 | }
|
595 | get policyFragment() {
|
596 | return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);
|
597 | }
|
598 | toString() {
|
599 | return `OpenIdConnectPrincipal(${this.federated})`;
|
600 | }
|
601 | }
|
602 | exports.OpenIdConnectPrincipal = OpenIdConnectPrincipal;
|
603 | _o = JSII_RTTI_SYMBOL_1;
|
604 | OpenIdConnectPrincipal[_o] = { fqn: "@aws-cdk/aws-iam.OpenIdConnectPrincipal", version: "1.161.0" };
|
605 | /**
|
606 | * Principal entity that represents a SAML federated identity provider
|
607 | */
|
608 | class SamlPrincipal extends FederatedPrincipal {
|
609 | constructor(samlProvider, conditions) {
|
610 | super(samlProvider.samlProviderArn, conditions, 'sts:AssumeRoleWithSAML');
|
611 | try {
|
612 | jsiiDeprecationWarnings._aws_cdk_aws_iam_ISamlProvider(samlProvider);
|
613 | }
|
614 | catch (error) {
|
615 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
616 | Error.captureStackTrace(error, SamlPrincipal);
|
617 | }
|
618 | throw error;
|
619 | }
|
620 | }
|
621 | toString() {
|
622 | return `SamlPrincipal(${this.federated})`;
|
623 | }
|
624 | }
|
625 | exports.SamlPrincipal = SamlPrincipal;
|
626 | _p = JSII_RTTI_SYMBOL_1;
|
627 | SamlPrincipal[_p] = { fqn: "@aws-cdk/aws-iam.SamlPrincipal", version: "1.161.0" };
|
628 | /**
|
629 | * Principal entity that represents a SAML federated identity provider for
|
630 | * programmatic and AWS Management Console access.
|
631 | */
|
632 | class SamlConsolePrincipal extends SamlPrincipal {
|
633 | constructor(samlProvider, conditions = {}) {
|
634 | super(samlProvider, {
|
635 | ...conditions,
|
636 | StringEquals: {
|
637 | 'SAML:aud': 'https://signin.aws.amazon.com/saml',
|
638 | },
|
639 | });
|
640 | try {
|
641 | jsiiDeprecationWarnings._aws_cdk_aws_iam_ISamlProvider(samlProvider);
|
642 | }
|
643 | catch (error) {
|
644 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
645 | Error.captureStackTrace(error, SamlConsolePrincipal);
|
646 | }
|
647 | throw error;
|
648 | }
|
649 | }
|
650 | toString() {
|
651 | return `SamlConsolePrincipal(${this.federated})`;
|
652 | }
|
653 | }
|
654 | exports.SamlConsolePrincipal = SamlConsolePrincipal;
|
655 | _q = JSII_RTTI_SYMBOL_1;
|
656 | SamlConsolePrincipal[_q] = { fqn: "@aws-cdk/aws-iam.SamlConsolePrincipal", version: "1.161.0" };
|
657 | /**
|
658 | * Use the AWS account into which a stack is deployed as the principal entity in a policy
|
659 | */
|
660 | class AccountRootPrincipal extends AccountPrincipal {
|
661 | constructor() {
|
662 | super(new StackDependentToken(stack => stack.account).toString());
|
663 | }
|
664 | toString() {
|
665 | return 'AccountRootPrincipal()';
|
666 | }
|
667 | }
|
668 | exports.AccountRootPrincipal = AccountRootPrincipal;
|
669 | _r = JSII_RTTI_SYMBOL_1;
|
670 | AccountRootPrincipal[_r] = { fqn: "@aws-cdk/aws-iam.AccountRootPrincipal", version: "1.161.0" };
|
671 | /**
|
672 | * A principal representing all AWS identities in all accounts
|
673 | *
|
674 | * Some services behave differently when you specify `Principal: '*'`
|
675 | * or `Principal: { AWS: "*" }` in their resource policy.
|
676 | *
|
677 | * `AnyPrincipal` renders to `Principal: { AWS: "*" }`. This is correct
|
678 | * most of the time, but in cases where you need the other principal,
|
679 | * use `StarPrincipal` instead.
|
680 | */
|
681 | class AnyPrincipal extends ArnPrincipal {
|
682 | constructor() {
|
683 | super('*');
|
684 | }
|
685 | toString() {
|
686 | return 'AnyPrincipal()';
|
687 | }
|
688 | }
|
689 | exports.AnyPrincipal = AnyPrincipal;
|
690 | _s = JSII_RTTI_SYMBOL_1;
|
691 | AnyPrincipal[_s] = { fqn: "@aws-cdk/aws-iam.AnyPrincipal", version: "1.161.0" };
|
692 | /**
|
693 | * A principal representing all identities in all accounts
|
694 | * @deprecated use `AnyPrincipal`
|
695 | */
|
696 | class Anyone extends AnyPrincipal {
|
697 | }
|
698 | exports.Anyone = Anyone;
|
699 | _t = JSII_RTTI_SYMBOL_1;
|
700 | Anyone[_t] = { fqn: "@aws-cdk/aws-iam.Anyone", version: "1.161.0" };
|
701 | /**
|
702 | * A principal that uses a literal '*' in the IAM JSON language
|
703 | *
|
704 | * Some services behave differently when you specify `Principal: "*"`
|
705 | * or `Principal: { AWS: "*" }` in their resource policy.
|
706 | *
|
707 | * `StarPrincipal` renders to `Principal: *`. Most of the time, you
|
708 | * should use `AnyPrincipal` instead.
|
709 | */
|
710 | class StarPrincipal extends PrincipalBase {
|
711 | constructor() {
|
712 | super(...arguments);
|
713 | this.policyFragment = {
|
714 | principalJson: { [util_1.LITERAL_STRING_KEY]: ['*'] },
|
715 | conditions: {},
|
716 | };
|
717 | }
|
718 | toString() {
|
719 | return 'StarPrincipal()';
|
720 | }
|
721 | dedupeString() {
|
722 | return 'StarPrincipal';
|
723 | }
|
724 | }
|
725 | exports.StarPrincipal = StarPrincipal;
|
726 | _u = JSII_RTTI_SYMBOL_1;
|
727 | StarPrincipal[_u] = { fqn: "@aws-cdk/aws-iam.StarPrincipal", version: "1.161.0" };
|
728 | /**
|
729 | * Represents a principal that has multiple types of principals. A composite principal cannot
|
730 | * have conditions. i.e. multiple ServicePrincipals that form a composite principal
|
731 | */
|
732 | class CompositePrincipal extends PrincipalBase {
|
733 | constructor(...principals) {
|
734 | super();
|
735 | this.principals = new Array();
|
736 | try {
|
737 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principals);
|
738 | }
|
739 | catch (error) {
|
740 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
741 | Error.captureStackTrace(error, CompositePrincipal);
|
742 | }
|
743 | throw error;
|
744 | }
|
745 | if (principals.length === 0) {
|
746 | throw new Error('CompositePrincipals must be constructed with at least 1 Principal but none were passed.');
|
747 | }
|
748 | this.assumeRoleAction = principals[0].assumeRoleAction;
|
749 | this.addPrincipals(...principals);
|
750 | }
|
751 | /**
|
752 | * Adds IAM principals to the composite principal. Composite principals cannot have
|
753 | * conditions.
|
754 | *
|
755 | * @param principals IAM principals that will be added to the composite principal
|
756 | */
|
757 | addPrincipals(...principals) {
|
758 | try {
|
759 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principals);
|
760 | }
|
761 | catch (error) {
|
762 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
763 | Error.captureStackTrace(error, this.addPrincipals);
|
764 | }
|
765 | throw error;
|
766 | }
|
767 | this.principals.push(...principals);
|
768 | return this;
|
769 | }
|
770 | addToAssumeRolePolicy(doc) {
|
771 | try {
|
772 | jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyDocument(doc);
|
773 | }
|
774 | catch (error) {
|
775 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
776 | Error.captureStackTrace(error, this.addToAssumeRolePolicy);
|
777 | }
|
778 | throw error;
|
779 | }
|
780 | for (const p of this.principals) {
|
781 | assume_role_policy_1.defaultAddPrincipalToAssumeRole(p, doc);
|
782 | }
|
783 | }
|
784 | get policyFragment() {
|
785 | // We only have a problem with conditions if we are trying to render composite
|
786 | // princpals into a single statement (which is when `policyFragment` would get called)
|
787 | for (const p of this.principals) {
|
788 | const fragment = p.policyFragment;
|
789 | if (fragment.conditions && Object.keys(fragment.conditions).length > 0) {
|
790 | throw new Error('Components of a CompositePrincipal must not have conditions. ' +
|
791 | `Tried to add the following fragment: ${JSON.stringify(fragment)}`);
|
792 | }
|
793 | }
|
794 | const principalJson = {};
|
795 | for (const p of this.principals) {
|
796 | util_1.mergePrincipal(principalJson, p.policyFragment.principalJson);
|
797 | }
|
798 | return new PrincipalPolicyFragment(principalJson);
|
799 | }
|
800 | toString() {
|
801 | return `CompositePrincipal(${this.principals})`;
|
802 | }
|
803 | dedupeString() {
|
804 | const inner = this.principals.map(ComparablePrincipal.dedupeStringFor);
|
805 | if (inner.some(x => x === undefined)) {
|
806 | return undefined;
|
807 | }
|
808 | return `CompositePrincipal[${inner.join(',')}]`;
|
809 | }
|
810 | }
|
811 | exports.CompositePrincipal = CompositePrincipal;
|
812 | _v = JSII_RTTI_SYMBOL_1;
|
813 | CompositePrincipal[_v] = { fqn: "@aws-cdk/aws-iam.CompositePrincipal", version: "1.161.0" };
|
814 | /**
|
815 | * A lazy token that requires an instance of Stack to evaluate
|
816 | */
|
817 | class StackDependentToken {
|
818 | constructor(fn) {
|
819 | this.fn = fn;
|
820 | this.creationStack = cdk.captureStackTrace();
|
821 | }
|
822 | resolve(context) {
|
823 | return this.fn(cdk.Stack.of(context.scope));
|
824 | }
|
825 | toString() {
|
826 | return cdk.Token.asString(this);
|
827 | }
|
828 | /**
|
829 | * JSON-ify the token
|
830 | *
|
831 | * Used when JSON.stringify() is called
|
832 | */
|
833 | toJSON() {
|
834 | return '<unresolved-token>';
|
835 | }
|
836 | }
|
837 | class ServicePrincipalToken {
|
838 | constructor(service, opts) {
|
839 | this.service = service;
|
840 | this.opts = opts;
|
841 | this.creationStack = cdk.captureStackTrace();
|
842 | }
|
843 | resolve(ctx) {
|
844 | if (this.opts.region) {
|
845 | // Special case, handle it separately to not break legacy behavior.
|
846 | return region_info_1.RegionInfo.get(this.opts.region).servicePrincipal(this.service) ??
|
847 | region_info_1.Default.servicePrincipal(this.service, this.opts.region, cdk.Aws.URL_SUFFIX);
|
848 | }
|
849 | const stack = cdk.Stack.of(ctx.scope);
|
850 | return stack.regionalFact(region_info_1.FactName.servicePrincipal(this.service), region_info_1.Default.servicePrincipal(this.service, stack.region, cdk.Aws.URL_SUFFIX));
|
851 | }
|
852 | toString() {
|
853 | return cdk.Token.asString(this, {
|
854 | displayHint: this.service,
|
855 | });
|
856 | }
|
857 | /**
|
858 | * JSON-ify the token
|
859 | *
|
860 | * Used when JSON.stringify() is called
|
861 | */
|
862 | toJSON() {
|
863 | return `<${this.service}>`;
|
864 | }
|
865 | }
|
866 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"principals.js","sourceRoot":"","sources":["principals.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { Default, FactName, RegionInfo } from '@aws-cdk/region-info';\nimport { IOpenIdConnectProvider } from './oidc-provider';\nimport { PolicyDocument } from './policy-document';\nimport { Condition, Conditions, PolicyStatement } from './policy-statement';\nimport { defaultAddPrincipalToAssumeRole } from './private/assume-role-policy';\nimport { ISamlProvider } from './saml-provider';\nimport { LITERAL_STRING_KEY, mergePrincipal } from './util';\n\n/**\n * Any object that has an associated principal that a permission can be granted to\n */\nexport interface IGrantable {\n  /**\n   * The principal to grant permissions to\n   */\n  readonly grantPrincipal: IPrincipal;\n}\n\n/**\n * Represents a logical IAM principal.\n *\n * An IPrincipal describes a logical entity that can perform AWS API calls\n * against sets of resources, optionally under certain conditions.\n *\n * Examples of simple principals are IAM objects that you create, such\n * as Users or Roles.\n *\n * An example of a more complex principals is a `ServicePrincipal` (such as\n * `new ServicePrincipal(\"sns.amazonaws.com\")`, which represents the Simple\n * Notifications Service).\n *\n * A single logical Principal may also map to a set of physical principals.\n * For example, `new OrganizationPrincipal('o-1234')` represents all\n * identities that are part of the given AWS Organization.\n */\nexport interface IPrincipal extends IGrantable {\n  /**\n   * When this Principal is used in an AssumeRole policy, the action to use.\n   */\n  readonly assumeRoleAction: string;\n\n  /**\n   * Return the policy fragment that identifies this principal in a Policy.\n   */\n  readonly policyFragment: PrincipalPolicyFragment;\n\n  /**\n   * The AWS account ID of this principal.\n   * Can be undefined when the account is not known\n   * (for example, for service principals).\n   * Can be a Token - in that case,\n   * it's assumed to be AWS::AccountId.\n   */\n  readonly principalAccount?: string;\n\n  /**\n   * Add to the policy of this principal.\n   *\n   * @returns true if the statement was added, false if the principal in\n   * question does not have a policy document to add the statement to.\n   *\n   * @deprecated Use `addToPrincipalPolicy` instead.\n   */\n  addToPolicy(statement: PolicyStatement): boolean;\n\n  /**\n   * Add to the policy of this principal.\n   */\n  addToPrincipalPolicy(statement: PolicyStatement): AddToPrincipalPolicyResult;\n}\n\n/**\n * Interface for principals that can be compared.\n *\n * This only needs to be implemented for principals that could potentially be value-equal.\n * Identity-equal principals will be handled correctly by default.\n */\nexport interface IComparablePrincipal extends IPrincipal {\n  /**\n   * Return a string format of this principal which should be identical if the two\n   * principals are the same.\n   */\n  dedupeString(): string | undefined;\n}\n\n/**\n * Helper class for working with `IComparablePrincipal`s\n */\nexport class ComparablePrincipal {\n  /**\n   * Whether or not the given principal is a comparable principal\n   */\n  public static isComparablePrincipal(x: IPrincipal): x is IComparablePrincipal {\n    return 'dedupeString' in x;\n  }\n\n  /**\n   * Return the dedupeString of the given principal, if available\n   */\n  public static dedupeStringFor(x: IPrincipal): string | undefined {\n    return ComparablePrincipal.isComparablePrincipal(x) ? x.dedupeString() : undefined;\n  }\n}\n\n/**\n * A type of principal that has more control over its own representation in AssumeRolePolicyDocuments\n *\n * More complex types of identity providers need more control over Role's policy documents\n * than simply `{ Effect: 'Allow', Action: 'AssumeRole', Principal: <Whatever> }`.\n *\n * If that control is necessary, they can implement `IAssumeRolePrincipal` to get full\n * access to a Role's AssumeRolePolicyDocument.\n */\nexport interface IAssumeRolePrincipal extends IPrincipal {\n  /**\n   * Add the princpial to the AssumeRolePolicyDocument\n   *\n   * Add the statements to the AssumeRolePolicyDocument necessary to give this principal\n   * permissions to assume the given role.\n   */\n  addToAssumeRolePolicy(document: PolicyDocument): void;\n}\n\n/**\n * Result of calling `addToPrincipalPolicy`\n */\nexport interface AddToPrincipalPolicyResult {\n  /**\n   * Whether the statement was added to the identity's policies.\n   *\n   */\n  readonly statementAdded: boolean;\n\n  /**\n   * Dependable which allows depending on the policy change being applied\n   *\n   * @default - Required if `statementAdded` is true.\n   */\n  readonly policyDependable?: cdk.IDependable;\n}\n\n/**\n * Base class for policy principals\n */\nexport abstract class PrincipalBase implements IAssumeRolePrincipal, IComparablePrincipal {\n  public readonly grantPrincipal: IPrincipal = this;\n  public readonly principalAccount: string | undefined = undefined;\n\n  /**\n   * Return the policy fragment that identifies this principal in a Policy.\n   */\n  public abstract readonly policyFragment: PrincipalPolicyFragment;\n\n  /**\n   * When this Principal is used in an AssumeRole policy, the action to use.\n   */\n  public readonly assumeRoleAction: string = 'sts:AssumeRole';\n\n  public addToPolicy(statement: PolicyStatement): boolean {\n    return this.addToPrincipalPolicy(statement).statementAdded;\n  }\n\n  public addToPrincipalPolicy(_statement: PolicyStatement): AddToPrincipalPolicyResult {\n    // This base class is used for non-identity principals. None of them\n    // have a PolicyDocument to add to.\n    return { statementAdded: false };\n  }\n\n  public addToAssumeRolePolicy(document: PolicyDocument): void {\n    // Default implementation of this protocol, compatible with the legacy behavior\n    document.addStatements(new PolicyStatement({\n      actions: [this.assumeRoleAction],\n      principals: [this],\n    }));\n  }\n\n  public toString() {\n    // This is a first pass to make the object readable. Descendant principals\n    // should return something nicer.\n    return JSON.stringify(this.policyFragment.principalJson);\n  }\n\n  /**\n   * JSON-ify the principal\n   *\n   * Used when JSON.stringify() is called\n   */\n  public toJSON() {\n    // Have to implement toJSON() because the default will lead to infinite recursion.\n    return this.policyFragment.principalJson;\n  }\n\n  /**\n   * Returns a new PrincipalWithConditions using this principal as the base, with the\n   * passed conditions added.\n   *\n   * When there is a value for the same operator and key in both the principal and the\n   * conditions parameter, the value from the conditions parameter will be used.\n   *\n   * @returns a new PrincipalWithConditions object.\n   */\n  public withConditions(conditions: Conditions): PrincipalBase {\n    return new PrincipalWithConditions(this, conditions);\n  }\n\n  /**\n   * Returns a new principal using this principal as the base, with session tags enabled.\n   *\n   * @returns a new SessionTagsPrincipal object.\n   */\n  public withSessionTags(): PrincipalBase {\n    return new SessionTagsPrincipal(this);\n  }\n\n  /**\n   * Return whether or not this principal is equal to the given principal\n   */\n  public abstract dedupeString(): string | undefined;\n}\n\n/**\n * Base class for Principals that wrap other principals\n */\nabstract class PrincipalAdapter extends PrincipalBase {\n  public readonly assumeRoleAction = this.wrapped.assumeRoleAction;\n  public readonly principalAccount = this.wrapped.principalAccount;\n\n  constructor(protected readonly wrapped: IPrincipal) {\n    super();\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment { return this.wrapped.policyFragment; }\n\n  addToPolicy(statement: PolicyStatement): boolean {\n    return this.wrapped.addToPolicy(statement);\n  }\n  addToPrincipalPolicy(statement: PolicyStatement): AddToPrincipalPolicyResult {\n    return this.wrapped.addToPrincipalPolicy(statement);\n  }\n\n  /**\n   * Append the given string to the wrapped principal's dedupe string (if available)\n   */\n  protected appendDedupe(append: string): string | undefined {\n    const inner = ComparablePrincipal.dedupeStringFor(this.wrapped);\n    return inner !== undefined ? `${this.constructor.name}:${inner}:${append}` : undefined;\n  }\n}\n\n/**\n * An IAM principal with additional conditions specifying when the policy is in effect.\n *\n * For more information about conditions, see:\n * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html\n */\nexport class PrincipalWithConditions extends PrincipalAdapter {\n  private additionalConditions: Conditions;\n\n  constructor(principal: IPrincipal, conditions: Conditions) {\n    super(principal);\n    this.additionalConditions = conditions;\n  }\n\n  /**\n   * Add a condition to the principal\n   */\n  public addCondition(key: string, value: Condition) {\n    const existingValue = this.additionalConditions[key];\n    this.additionalConditions[key] = existingValue ? { ...existingValue, ...value } : value;\n  }\n\n  /**\n   * Adds multiple conditions to the principal\n   *\n   * Values from the conditions parameter will overwrite existing values with the same operator\n   * and key.\n   */\n  public addConditions(conditions: Conditions) {\n    Object.entries(conditions).forEach(([key, value]) => {\n      this.addCondition(key, value);\n    });\n  }\n\n  /**\n   * 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 get conditions() {\n    return this.mergeConditions(this.wrapped.policyFragment.conditions, this.additionalConditions);\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment(this.wrapped.policyFragment.principalJson, this.conditions);\n  }\n\n  public toString() {\n    return this.wrapped.toString();\n  }\n\n  /**\n   * JSON-ify the principal\n   *\n   * Used when JSON.stringify() is called\n   */\n  public toJSON() {\n    // Have to implement toJSON() because the default will lead to infinite recursion.\n    return this.policyFragment.principalJson;\n  }\n\n  public dedupeString(): string | undefined {\n    return this.appendDedupe(JSON.stringify(this.conditions));\n  }\n\n  private mergeConditions(principalConditions: Conditions, additionalConditions: Conditions): Conditions {\n    const mergedConditions: Conditions = {};\n    Object.entries(principalConditions).forEach(([operator, condition]) => {\n      mergedConditions[operator] = condition;\n    });\n\n    Object.entries(additionalConditions).forEach(([operator, condition]) => {\n      // merge the conditions if one of the additional conditions uses an\n      // operator that's already used by the principal's conditions merge the\n      // inner structure.\n      const existing = mergedConditions[operator];\n      if (!existing) {\n        mergedConditions[operator] = condition;\n        return; // continue\n      }\n\n      // if either the existing condition or the new one contain unresolved\n      // tokens, fail the merge. this is as far as we go at this point.\n      if (cdk.Token.isUnresolved(condition) || cdk.Token.isUnresolved(existing)) {\n        throw new Error(`multiple \"${operator}\" conditions cannot be merged if one of them contains an unresolved token`);\n      }\n\n      mergedConditions[operator] = { ...existing, ...condition };\n    });\n    return mergedConditions;\n  }\n}\n\n/**\n * Enables session tags on role assumptions from a principal\n *\n * For more information on session tags, see:\n * https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html\n */\nexport class SessionTagsPrincipal extends PrincipalAdapter {\n  constructor(principal: IPrincipal) {\n    super(principal);\n  }\n\n  public addToAssumeRolePolicy(doc: PolicyDocument) {\n    // Lazy import to avoid circular import dependencies during startup\n\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const adapter: typeof import('./private/policydoc-adapter') = require('./private/policydoc-adapter');\n\n    defaultAddPrincipalToAssumeRole(this.wrapped, new adapter.MutatingPolicyDocumentAdapter(doc, (statement) => {\n      statement.addActions('sts:TagSession');\n      return statement;\n    }));\n  }\n\n  public dedupeString(): string | undefined {\n    return this.appendDedupe('');\n  }\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 *\n * Generally, a principal looks like:\n *\n *     { '<TYPE>': ['ID', 'ID', ...] }\n *\n * And this is also the type of the field `principalJson`.  However, there is a\n * special type of principal that is just the string '*', which is treated\n * differently by some services. To represent that principal, `principalJson`\n * should contain `{ 'LiteralString': ['*'] }`.\n */\nexport class PrincipalPolicyFragment {\n  /**\n   *\n   * @param principalJson JSON of the \"Principal\" section in a policy statement\n   * @param conditions conditions that need to be applied to this policy\n   */\n  constructor(\n    public readonly principalJson: { [key: string]: string[] },\n    /**\n     * 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 readonly conditions: Conditions = {}) {\n  }\n}\n\n/**\n * Specify a principal by the Amazon Resource Name (ARN).\n * You can specify AWS accounts, IAM users, Federated SAML users, IAM roles, and specific assumed-role sessions.\n * You cannot specify IAM groups or instance profiles as principals\n *\n * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_principal.html\n */\nexport class ArnPrincipal extends PrincipalBase {\n  /**\n   *\n   * @param arn Amazon Resource Name (ARN) of the principal entity (i.e. arn:aws:iam::123456789012:user/user-name)\n   */\n  constructor(public readonly arn: string) {\n    super();\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ AWS: [this.arn] });\n  }\n\n  public toString() {\n    return `ArnPrincipal(${this.arn})`;\n  }\n\n  /**\n   * A convenience method for adding a condition that the principal is part of the specified\n   * AWS Organization.\n   */\n  public inOrganization(organizationId: string) {\n    return this.withConditions({\n      StringEquals: {\n        'aws:PrincipalOrgID': organizationId,\n      },\n    });\n  }\n\n  public dedupeString(): string | undefined {\n    return `ArnPrincipal:${this.arn}`;\n  }\n}\n\n/**\n * Specify AWS account ID as the principal entity in a policy to delegate authority to the account.\n */\nexport class AccountPrincipal extends ArnPrincipal {\n  public readonly principalAccount: string | undefined;\n\n  /**\n   *\n   * @param accountId AWS account ID (i.e. 123456789012)\n   */\n  constructor(public readonly accountId: any) {\n    super(new StackDependentToken(stack => `arn:${stack.partition}:iam::${accountId}:root`).toString());\n    if (!cdk.Token.isUnresolved(accountId) && typeof accountId !== 'string') {\n      throw new Error('accountId should be of type string');\n    }\n    this.principalAccount = accountId;\n  }\n\n  public toString() {\n    return `AccountPrincipal(${this.accountId})`;\n  }\n}\n\n/**\n * Options for a service principal.\n */\nexport interface ServicePrincipalOpts {\n  /**\n   * The region in which the service is operating.\n   *\n   * @default - the current Stack's region.\n   * @deprecated You should not need to set this. The stack's region is always correct.\n   */\n  readonly region?: string;\n\n  /**\n   * Additional conditions to add to the Service Principal\n   *\n   * @default - No conditions\n   */\n  readonly conditions?: { [key: string]: any };\n}\n\n/**\n * An IAM principal that represents an AWS service (i.e. sqs.amazonaws.com).\n */\nexport class ServicePrincipal extends PrincipalBase {\n  /**\n   * Translate the given service principal name based on the region it's used in.\n   *\n   * For example, for Chinese regions this may (depending on whether that's necessary\n   * for the given service principal) append `.cn` to the name.\n   *\n   * The `region-info` module is used to obtain this information.\n   *\n   * @example\n   * const principalName = iam.ServicePrincipal.servicePrincipalName('ec2.amazonaws.com');\n   */\n  public static servicePrincipalName(service: string): string {\n    return new ServicePrincipalToken(service, {}).toString();\n  }\n\n  /**\n   *\n   * @param service AWS service (i.e. sqs.amazonaws.com)\n   */\n  constructor(public readonly service: string, private readonly opts: ServicePrincipalOpts = {}) {\n    super();\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({\n      Service: [\n        new ServicePrincipalToken(this.service, this.opts).toString(),\n      ],\n    }, this.opts.conditions);\n  }\n\n  public toString() {\n    return `ServicePrincipal(${this.service})`;\n  }\n\n  public dedupeString(): string | undefined {\n    return `ServicePrincipal:${this.service}:${JSON.stringify(this.opts)}`;\n  }\n}\n\n/**\n * A principal that represents an AWS Organization\n */\nexport class OrganizationPrincipal extends PrincipalBase {\n  /**\n   *\n   * @param organizationId The unique identifier (ID) of an organization (i.e. o-12345abcde)\n   */\n  constructor(public readonly organizationId: string) {\n    super();\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment(\n      { AWS: ['*'] },\n      { StringEquals: { 'aws:PrincipalOrgID': this.organizationId } },\n    );\n  }\n\n  public toString() {\n    return `OrganizationPrincipal(${this.organizationId})`;\n  }\n\n  public dedupeString(): string | undefined {\n    return `OrganizationPrincipal:${this.organizationId}`;\n  }\n}\n\n/**\n * A policy principal 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 PrincipalBase {\n  /**\n   *\n   * @param canonicalUserId unique identifier assigned by AWS for every account.\n   *   root user and IAM users for an account all see the same ID.\n   *   (i.e. 79a59df900b949e55d96a1e698fbacedfd6e09d98eacf8f8d5218e7cd47ef2be)\n   */\n  constructor(public readonly canonicalUserId: string) {\n    super();\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ CanonicalUser: [this.canonicalUserId] });\n  }\n\n  public toString() {\n    return `CanonicalUserPrincipal(${this.canonicalUserId})`;\n  }\n\n  public dedupeString(): string | undefined {\n    return `CanonicalUserPrincipal:${this.canonicalUserId}`;\n  }\n}\n\n/**\n * Principal entity that represents a federated identity provider such as Amazon Cognito,\n * that can be used to provide temporary security credentials to users who have been authenticated.\n * Additional condition keys are available when the temporary security credentials are used to make a request.\n * You can use these keys to write policies that limit the access of federated users.\n *\n * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_iam-condition-keys.html#condition-keys-wif\n */\nexport class FederatedPrincipal extends PrincipalBase {\n  public readonly assumeRoleAction: string;\n\n  /**\n   *\n   * @param federated federated identity provider (i.e. 'cognito-identity.amazonaws.com' for users authenticated through Cognito)\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   * @param sessionTags Whether to enable session tagging (see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html)\n   */\n  constructor(\n    public readonly federated: string,\n    public readonly conditions: Conditions,\n    assumeRoleAction: string = 'sts:AssumeRole') {\n    super();\n\n    this.assumeRoleAction = assumeRoleAction;\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);\n  }\n\n  public toString() {\n    return `FederatedPrincipal(${this.federated})`;\n  }\n\n  public dedupeString(): string | undefined {\n    return `FederatedPrincipal:${this.federated}:${this.assumeRoleAction}:${JSON.stringify(this.conditions)}`;\n  }\n}\n\n/**\n * A principal that represents a federated identity provider as Web Identity such as Cognito, Amazon,\n * Facebook, Google, etc.\n */\nexport class WebIdentityPrincipal extends FederatedPrincipal {\n\n  /**\n   *\n   * @param identityProvider identity provider (i.e. 'cognito-identity.amazonaws.com' for users authenticated through Cognito)\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   * @param sessionTags Whether to enable session tagging (see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html)\n   */\n  constructor(identityProvider: string, conditions: Conditions = {}) {\n    super(identityProvider, conditions ?? {}, 'sts:AssumeRoleWithWebIdentity');\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);\n  }\n\n  public toString() {\n    return `WebIdentityPrincipal(${this.federated})`;\n  }\n}\n\n/**\n * A principal that represents a federated identity provider as from a OpenID Connect provider.\n */\nexport class OpenIdConnectPrincipal extends WebIdentityPrincipal {\n\n  /**\n   *\n   * @param openIdConnectProvider OpenID Connect provider\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  constructor(openIdConnectProvider: IOpenIdConnectProvider, conditions: Conditions = {}) {\n    super(openIdConnectProvider.openIdConnectProviderArn, conditions ?? {});\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);\n  }\n\n  public toString() {\n    return `OpenIdConnectPrincipal(${this.federated})`;\n  }\n}\n\n/**\n * Principal entity that represents a SAML federated identity provider\n */\nexport class SamlPrincipal extends FederatedPrincipal {\n  constructor(samlProvider: ISamlProvider, conditions: Conditions) {\n    super(samlProvider.samlProviderArn, conditions, 'sts:AssumeRoleWithSAML');\n  }\n\n  public toString() {\n    return `SamlPrincipal(${this.federated})`;\n  }\n}\n\n/**\n * Principal entity that represents a SAML federated identity provider for\n * programmatic and AWS Management Console access.\n */\nexport class SamlConsolePrincipal extends SamlPrincipal {\n  constructor(samlProvider: ISamlProvider, conditions: Conditions = {}) {\n    super(samlProvider, {\n      ...conditions,\n      StringEquals: {\n        'SAML:aud': 'https://signin.aws.amazon.com/saml',\n      },\n    });\n  }\n\n  public toString() {\n    return `SamlConsolePrincipal(${this.federated})`;\n  }\n}\n\n/**\n * Use the AWS account into which a stack is deployed as the principal entity in a policy\n */\nexport class AccountRootPrincipal extends AccountPrincipal {\n  constructor() {\n    super(new StackDependentToken(stack => stack.account).toString());\n  }\n\n  public toString() {\n    return 'AccountRootPrincipal()';\n  }\n}\n\n/**\n * A principal representing all AWS identities in all accounts\n *\n * Some services behave differently when you specify `Principal: '*'`\n * or `Principal: { AWS: \"*\" }` in their resource policy.\n *\n * `AnyPrincipal` renders to `Principal: { AWS: \"*\" }`. This is correct\n * most of the time, but in cases where you need the other principal,\n * use `StarPrincipal` instead.\n */\nexport class AnyPrincipal extends ArnPrincipal {\n  constructor() {\n    super('*');\n  }\n\n  public toString() {\n    return 'AnyPrincipal()';\n  }\n}\n\n/**\n * A principal representing all identities in all accounts\n * @deprecated use `AnyPrincipal`\n */\nexport class Anyone extends AnyPrincipal { }\n\n/**\n * A principal that uses a literal '*' in the IAM JSON language\n *\n * Some services behave differently when you specify `Principal: \"*\"`\n * or `Principal: { AWS: \"*\" }` in their resource policy.\n *\n * `StarPrincipal` renders to `Principal: *`. Most of the time, you\n * should use `AnyPrincipal` instead.\n */\nexport class StarPrincipal extends PrincipalBase {\n  public readonly policyFragment: PrincipalPolicyFragment = {\n    principalJson: { [LITERAL_STRING_KEY]: ['*'] },\n    conditions: {},\n  };\n\n  public toString() {\n    return 'StarPrincipal()';\n  }\n\n  public dedupeString(): string | undefined {\n    return 'StarPrincipal';\n  }\n}\n\n/**\n * Represents a principal that has multiple types of principals. A composite principal cannot\n * have conditions. i.e. multiple ServicePrincipals that form a composite principal\n */\nexport class CompositePrincipal extends PrincipalBase {\n  public readonly assumeRoleAction: string;\n  private readonly principals = new Array<IPrincipal>();\n\n  constructor(...principals: IPrincipal[]) {\n    super();\n    if (principals.length === 0) {\n      throw new Error('CompositePrincipals must be constructed with at least 1 Principal but none were passed.');\n    }\n    this.assumeRoleAction = principals[0].assumeRoleAction;\n    this.addPrincipals(...principals);\n  }\n\n  /**\n   * Adds IAM principals to the composite principal. Composite principals cannot have\n   * conditions.\n   *\n   * @param principals IAM principals that will be added to the composite principal\n   */\n  public addPrincipals(...principals: IPrincipal[]): this {\n    this.principals.push(...principals);\n    return this;\n  }\n\n  public addToAssumeRolePolicy(doc: PolicyDocument) {\n    for (const p of this.principals) {\n      defaultAddPrincipalToAssumeRole(p, doc);\n    }\n  }\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    // We only have a problem with conditions if we are trying to render composite\n    // princpals into a single statement (which is when `policyFragment` would get called)\n    for (const p of this.principals) {\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\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  public toString() {\n    return `CompositePrincipal(${this.principals})`;\n  }\n\n  public dedupeString(): string | undefined {\n    const inner = this.principals.map(ComparablePrincipal.dedupeStringFor);\n    if (inner.some(x => x === undefined)) { return undefined; }\n    return `CompositePrincipal[${inner.join(',')}]`;\n  }\n}\n\n/**\n * A lazy token that requires an instance of Stack to evaluate\n */\nclass StackDependentToken implements cdk.IResolvable {\n  public readonly creationStack: string[];\n  constructor(private readonly fn: (stack: cdk.Stack) => any) {\n    this.creationStack = cdk.captureStackTrace();\n  }\n\n  public resolve(context: cdk.IResolveContext) {\n    return this.fn(cdk.Stack.of(context.scope));\n  }\n\n  public toString() {\n    return cdk.Token.asString(this);\n  }\n\n  /**\n   * JSON-ify the token\n   *\n   * Used when JSON.stringify() is called\n   */\n  public toJSON() {\n    return '<unresolved-token>';\n  }\n}\n\nclass ServicePrincipalToken implements cdk.IResolvable {\n  public readonly creationStack: string[];\n  constructor(\n    private readonly service: string,\n    private readonly opts: ServicePrincipalOpts) {\n    this.creationStack = cdk.captureStackTrace();\n  }\n\n  public resolve(ctx: cdk.IResolveContext) {\n    if (this.opts.region) {\n      // Special case, handle it separately to not break legacy behavior.\n      return RegionInfo.get(this.opts.region).servicePrincipal(this.service) ??\n        Default.servicePrincipal(this.service, this.opts.region, cdk.Aws.URL_SUFFIX);\n    }\n\n    const stack = cdk.Stack.of(ctx.scope);\n    return stack.regionalFact(\n      FactName.servicePrincipal(this.service),\n      Default.servicePrincipal(this.service, stack.region, cdk.Aws.URL_SUFFIX),\n    );\n  }\n\n  public toString() {\n    return cdk.Token.asString(this, {\n      displayHint: this.service,\n    });\n  }\n\n  /**\n   * JSON-ify the token\n   *\n   * Used when JSON.stringify() is called\n   */\n  public toJSON() {\n    return `<${this.service}>`;\n  }\n}\n"]} |
\ | No newline at end of file |