@aws-cdk/aws-iam
Version:
CDK routines for easily assigning correct and minimal IAM permissions
866 lines • 88.8 kB
JavaScript
"use strict";
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v;
Object.defineProperty(exports, "__esModule", { value: true });
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;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cdk = require("@aws-cdk/core");
const region_info_1 = require("@aws-cdk/region-info");
const policy_statement_1 = require("./policy-statement");
const assume_role_policy_1 = require("./private/assume-role-policy");
const util_1 = require("./util");
/**
* Helper class for working with `IComparablePrincipal`s
*/
class ComparablePrincipal {
/**
* Whether or not the given principal is a comparable principal
*/
static isComparablePrincipal(x) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(x);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.isComparablePrincipal);
}
throw error;
}
return 'dedupeString' in x;
}
/**
* Return the dedupeString of the given principal, if available
*/
static dedupeStringFor(x) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(x);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.dedupeStringFor);
}
throw error;
}
return ComparablePrincipal.isComparablePrincipal(x) ? x.dedupeString() : undefined;
}
}
exports.ComparablePrincipal = ComparablePrincipal;
_a = JSII_RTTI_SYMBOL_1;
ComparablePrincipal[_a] = { fqn: "@aws-cdk/aws-iam.ComparablePrincipal", version: "1.201.0" };
/**
* Base class for policy principals
*/
class PrincipalBase {
constructor() {
this.grantPrincipal = this;
this.principalAccount = undefined;
/**
* When this Principal is used in an AssumeRole policy, the action to use.
*/
this.assumeRoleAction = 'sts:AssumeRole';
}
addToPolicy(statement) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyStatement(statement);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addToPolicy);
}
throw error;
}
return this.addToPrincipalPolicy(statement).statementAdded;
}
addToPrincipalPolicy(_statement) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyStatement(_statement);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addToPrincipalPolicy);
}
throw error;
}
// This base class is used for non-identity principals. None of them
// have a PolicyDocument to add to.
return { statementAdded: false };
}
addToAssumeRolePolicy(document) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyDocument(document);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addToAssumeRolePolicy);
}
throw error;
}
// Default implementation of this protocol, compatible with the legacy behavior
document.addStatements(new policy_statement_1.PolicyStatement({
actions: [this.assumeRoleAction],
principals: [this],
}));
}
toString() {
// This is a first pass to make the object readable. Descendant principals
// should return something nicer.
return JSON.stringify(this.policyFragment.principalJson);
}
/**
* JSON-ify the principal
*
* Used when JSON.stringify() is called
*/
toJSON() {
// Have to implement toJSON() because the default will lead to infinite recursion.
return this.policyFragment.principalJson;
}
/**
* Returns a new PrincipalWithConditions using this principal as the base, with the
* passed conditions added.
*
* When there is a value for the same operator and key in both the principal and the
* conditions parameter, the value from the conditions parameter will be used.
*
* @returns a new PrincipalWithConditions object.
*/
withConditions(conditions) {
return new PrincipalWithConditions(this, conditions);
}
/**
* Returns a new principal using this principal as the base, with session tags enabled.
*
* @returns a new SessionTagsPrincipal object.
*/
withSessionTags() {
return new SessionTagsPrincipal(this);
}
}
exports.PrincipalBase = PrincipalBase;
_b = JSII_RTTI_SYMBOL_1;
PrincipalBase[_b] = { fqn: "@aws-cdk/aws-iam.PrincipalBase", version: "1.201.0" };
/**
* Base class for Principals that wrap other principals
*/
class PrincipalAdapter extends PrincipalBase {
constructor(wrapped) {
super();
this.wrapped = wrapped;
this.assumeRoleAction = this.wrapped.assumeRoleAction;
this.principalAccount = this.wrapped.principalAccount;
}
get policyFragment() { return this.wrapped.policyFragment; }
addToPolicy(statement) {
return this.wrapped.addToPolicy(statement);
}
addToPrincipalPolicy(statement) {
return this.wrapped.addToPrincipalPolicy(statement);
}
/**
* Append the given string to the wrapped principal's dedupe string (if available)
*/
appendDedupe(append) {
const inner = ComparablePrincipal.dedupeStringFor(this.wrapped);
return inner !== undefined ? `${this.constructor.name}:${inner}:${append}` : undefined;
}
}
/**
* An IAM principal with additional conditions specifying when the policy is in effect.
*
* For more information about conditions, see:
* https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html
*/
class PrincipalWithConditions extends PrincipalAdapter {
constructor(principal, conditions) {
super(principal);
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principal);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, PrincipalWithConditions);
}
throw error;
}
this.additionalConditions = conditions;
}
/**
* Add a condition to the principal
*/
addCondition(key, value) {
const existingValue = this.additionalConditions[key];
this.additionalConditions[key] = existingValue ? { ...existingValue, ...value } : value;
}
/**
* Adds multiple conditions to the principal
*
* Values from the conditions parameter will overwrite existing values with the same operator
* and key.
*/
addConditions(conditions) {
Object.entries(conditions).forEach(([key, value]) => {
this.addCondition(key, value);
});
}
/**
* The conditions under which the policy is in effect.
* See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
*/
get conditions() {
return this.mergeConditions(this.wrapped.policyFragment.conditions, this.additionalConditions);
}
get policyFragment() {
return new PrincipalPolicyFragment(this.wrapped.policyFragment.principalJson, this.conditions);
}
toString() {
return this.wrapped.toString();
}
/**
* JSON-ify the principal
*
* Used when JSON.stringify() is called
*/
toJSON() {
// Have to implement toJSON() because the default will lead to infinite recursion.
return this.policyFragment.principalJson;
}
dedupeString() {
return this.appendDedupe(JSON.stringify(this.conditions));
}
mergeConditions(principalConditions, additionalConditions) {
const mergedConditions = {};
Object.entries(principalConditions).forEach(([operator, condition]) => {
mergedConditions[operator] = condition;
});
Object.entries(additionalConditions).forEach(([operator, condition]) => {
// merge the conditions if one of the additional conditions uses an
// operator that's already used by the principal's conditions merge the
// inner structure.
const existing = mergedConditions[operator];
if (!existing) {
mergedConditions[operator] = condition;
return; // continue
}
// if either the existing condition or the new one contain unresolved
// tokens, fail the merge. this is as far as we go at this point.
if (cdk.Token.isUnresolved(condition) || cdk.Token.isUnresolved(existing)) {
throw new Error(`multiple "${operator}" conditions cannot be merged if one of them contains an unresolved token`);
}
mergedConditions[operator] = { ...existing, ...condition };
});
return mergedConditions;
}
}
exports.PrincipalWithConditions = PrincipalWithConditions;
_c = JSII_RTTI_SYMBOL_1;
PrincipalWithConditions[_c] = { fqn: "@aws-cdk/aws-iam.PrincipalWithConditions", version: "1.201.0" };
/**
* Enables session tags on role assumptions from a principal
*
* For more information on session tags, see:
* https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html
*/
class SessionTagsPrincipal extends PrincipalAdapter {
constructor(principal) {
super(principal);
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principal);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, SessionTagsPrincipal);
}
throw error;
}
}
addToAssumeRolePolicy(doc) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyDocument(doc);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addToAssumeRolePolicy);
}
throw error;
}
// Lazy import to avoid circular import dependencies during startup
// eslint-disable-next-line @typescript-eslint/no-require-imports
const adapter = require('./private/policydoc-adapter');
assume_role_policy_1.defaultAddPrincipalToAssumeRole(this.wrapped, new adapter.MutatingPolicyDocumentAdapter(doc, (statement) => {
statement.addActions('sts:TagSession');
return statement;
}));
}
dedupeString() {
return this.appendDedupe('');
}
}
exports.SessionTagsPrincipal = SessionTagsPrincipal;
_d = JSII_RTTI_SYMBOL_1;
SessionTagsPrincipal[_d] = { fqn: "@aws-cdk/aws-iam.SessionTagsPrincipal", version: "1.201.0" };
/**
* A collection of the fields in a PolicyStatement that can be used to identify a principal.
*
* This consists of the JSON used in the "Principal" field, and optionally a
* set of "Condition"s that need to be applied to the policy.
*
* Generally, a principal looks like:
*
* { '<TYPE>': ['ID', 'ID', ...] }
*
* And this is also the type of the field `principalJson`. However, there is a
* special type of principal that is just the string '*', which is treated
* differently by some services. To represent that principal, `principalJson`
* should contain `{ 'LiteralString': ['*'] }`.
*/
class PrincipalPolicyFragment {
/**
*
* @param principalJson JSON of the "Principal" section in a policy statement
* @param conditions conditions that need to be applied to this policy
*/
constructor(principalJson,
/**
* The conditions under which the policy is in effect.
* See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
*/
conditions = {}) {
this.principalJson = principalJson;
this.conditions = conditions;
}
}
exports.PrincipalPolicyFragment = PrincipalPolicyFragment;
_e = JSII_RTTI_SYMBOL_1;
PrincipalPolicyFragment[_e] = { fqn: "@aws-cdk/aws-iam.PrincipalPolicyFragment", version: "1.201.0" };
/**
* Specify a principal by the Amazon Resource Name (ARN).
* You can specify AWS accounts, IAM users, Federated SAML users, IAM roles, and specific assumed-role sessions.
* You cannot specify IAM groups or instance profiles as principals
*
* @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_principal.html
*/
class ArnPrincipal extends PrincipalBase {
/**
*
* @param arn Amazon Resource Name (ARN) of the principal entity (i.e. arn:aws:iam::123456789012:user/user-name)
*/
constructor(arn) {
super();
this.arn = arn;
}
get policyFragment() {
return new PrincipalPolicyFragment({ AWS: [this.arn] });
}
toString() {
return `ArnPrincipal(${this.arn})`;
}
/**
* A convenience method for adding a condition that the principal is part of the specified
* AWS Organization.
*/
inOrganization(organizationId) {
return this.withConditions({
StringEquals: {
'aws:PrincipalOrgID': organizationId,
},
});
}
dedupeString() {
return `ArnPrincipal:${this.arn}`;
}
}
exports.ArnPrincipal = ArnPrincipal;
_f = JSII_RTTI_SYMBOL_1;
ArnPrincipal[_f] = { fqn: "@aws-cdk/aws-iam.ArnPrincipal", version: "1.201.0" };
/**
* Specify AWS account ID as the principal entity in a policy to delegate authority to the account.
*/
class AccountPrincipal extends ArnPrincipal {
/**
*
* @param accountId AWS account ID (i.e. 123456789012)
*/
constructor(accountId) {
super(new StackDependentToken(stack => `arn:${stack.partition}:iam::${accountId}:root`).toString());
this.accountId = accountId;
if (!cdk.Token.isUnresolved(accountId) && typeof accountId !== 'string') {
throw new Error('accountId should be of type string');
}
this.principalAccount = accountId;
}
toString() {
return `AccountPrincipal(${this.accountId})`;
}
}
exports.AccountPrincipal = AccountPrincipal;
_g = JSII_RTTI_SYMBOL_1;
AccountPrincipal[_g] = { fqn: "@aws-cdk/aws-iam.AccountPrincipal", version: "1.201.0" };
/**
* An IAM principal that represents an AWS service (i.e. sqs.amazonaws.com).
*/
class ServicePrincipal extends PrincipalBase {
/**
*
* @param service AWS service (i.e. sqs.amazonaws.com)
*/
constructor(service, opts = {}) {
super();
this.service = service;
this.opts = opts;
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_ServicePrincipalOpts(opts);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, ServicePrincipal);
}
throw error;
}
}
/**
* Translate the given service principal name based on the region it's used in.
*
* For example, for Chinese regions this may (depending on whether that's necessary
* for the given service principal) append `.cn` to the name.
*
* The `region-info` module is used to obtain this information.
*
* @example
* const principalName = iam.ServicePrincipal.servicePrincipalName('ec2.amazonaws.com');
*/
static servicePrincipalName(service) {
return new ServicePrincipalToken(service, {}).toString();
}
get policyFragment() {
return new PrincipalPolicyFragment({
Service: [
new ServicePrincipalToken(this.service, this.opts).toString(),
],
}, this.opts.conditions);
}
toString() {
return `ServicePrincipal(${this.service})`;
}
dedupeString() {
return `ServicePrincipal:${this.service}:${JSON.stringify(this.opts)}`;
}
}
exports.ServicePrincipal = ServicePrincipal;
_h = JSII_RTTI_SYMBOL_1;
ServicePrincipal[_h] = { fqn: "@aws-cdk/aws-iam.ServicePrincipal", version: "1.201.0" };
/**
* A principal that represents an AWS Organization
*/
class OrganizationPrincipal extends PrincipalBase {
/**
*
* @param organizationId The unique identifier (ID) of an organization (i.e. o-12345abcde)
*/
constructor(organizationId) {
super();
this.organizationId = organizationId;
}
get policyFragment() {
return new PrincipalPolicyFragment({ AWS: ['*'] }, { StringEquals: { 'aws:PrincipalOrgID': this.organizationId } });
}
toString() {
return `OrganizationPrincipal(${this.organizationId})`;
}
dedupeString() {
return `OrganizationPrincipal:${this.organizationId}`;
}
}
exports.OrganizationPrincipal = OrganizationPrincipal;
_j = JSII_RTTI_SYMBOL_1;
OrganizationPrincipal[_j] = { fqn: "@aws-cdk/aws-iam.OrganizationPrincipal", version: "1.201.0" };
/**
* A policy principal for canonicalUserIds - useful for S3 bucket policies that use
* Origin Access identities.
*
* See https://docs.aws.amazon.com/general/latest/gr/acct-identifiers.html
*
* and
*
* https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-restricting-access-to-s3.html
*
* for more details.
*
*/
class CanonicalUserPrincipal extends PrincipalBase {
/**
*
* @param canonicalUserId unique identifier assigned by AWS for every account.
* root user and IAM users for an account all see the same ID.
* (i.e. 79a59df900b949e55d96a1e698fbacedfd6e09d98eacf8f8d5218e7cd47ef2be)
*/
constructor(canonicalUserId) {
super();
this.canonicalUserId = canonicalUserId;
}
get policyFragment() {
return new PrincipalPolicyFragment({ CanonicalUser: [this.canonicalUserId] });
}
toString() {
return `CanonicalUserPrincipal(${this.canonicalUserId})`;
}
dedupeString() {
return `CanonicalUserPrincipal:${this.canonicalUserId}`;
}
}
exports.CanonicalUserPrincipal = CanonicalUserPrincipal;
_k = JSII_RTTI_SYMBOL_1;
CanonicalUserPrincipal[_k] = { fqn: "@aws-cdk/aws-iam.CanonicalUserPrincipal", version: "1.201.0" };
/**
* Principal entity that represents a federated identity provider such as Amazon Cognito,
* that can be used to provide temporary security credentials to users who have been authenticated.
* Additional condition keys are available when the temporary security credentials are used to make a request.
* You can use these keys to write policies that limit the access of federated users.
*
* @see https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_iam-condition-keys.html#condition-keys-wif
*/
class FederatedPrincipal extends PrincipalBase {
/**
*
* @param federated federated identity provider (i.e. 'cognito-identity.amazonaws.com' for users authenticated through Cognito)
* @param conditions The conditions under which the policy is in effect.
* See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
* @param sessionTags Whether to enable session tagging (see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html)
*/
constructor(federated, conditions, assumeRoleAction = 'sts:AssumeRole') {
super();
this.federated = federated;
this.conditions = conditions;
this.assumeRoleAction = assumeRoleAction;
}
get policyFragment() {
return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);
}
toString() {
return `FederatedPrincipal(${this.federated})`;
}
dedupeString() {
return `FederatedPrincipal:${this.federated}:${this.assumeRoleAction}:${JSON.stringify(this.conditions)}`;
}
}
exports.FederatedPrincipal = FederatedPrincipal;
_l = JSII_RTTI_SYMBOL_1;
FederatedPrincipal[_l] = { fqn: "@aws-cdk/aws-iam.FederatedPrincipal", version: "1.201.0" };
/**
* A principal that represents a federated identity provider as Web Identity such as Cognito, Amazon,
* Facebook, Google, etc.
*/
class WebIdentityPrincipal extends FederatedPrincipal {
/**
*
* @param identityProvider identity provider (i.e. 'cognito-identity.amazonaws.com' for users authenticated through Cognito)
* @param conditions The conditions under which the policy is in effect.
* See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
* @param sessionTags Whether to enable session tagging (see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html)
*/
constructor(identityProvider, conditions = {}) {
super(identityProvider, conditions ?? {}, 'sts:AssumeRoleWithWebIdentity');
}
get policyFragment() {
return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);
}
toString() {
return `WebIdentityPrincipal(${this.federated})`;
}
}
exports.WebIdentityPrincipal = WebIdentityPrincipal;
_m = JSII_RTTI_SYMBOL_1;
WebIdentityPrincipal[_m] = { fqn: "@aws-cdk/aws-iam.WebIdentityPrincipal", version: "1.201.0" };
/**
* A principal that represents a federated identity provider as from a OpenID Connect provider.
*/
class OpenIdConnectPrincipal extends WebIdentityPrincipal {
/**
*
* @param openIdConnectProvider OpenID Connect provider
* @param conditions The conditions under which the policy is in effect.
* See [the IAM documentation](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition.html).
*/
constructor(openIdConnectProvider, conditions = {}) {
super(openIdConnectProvider.openIdConnectProviderArn, conditions ?? {});
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_IOpenIdConnectProvider(openIdConnectProvider);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, OpenIdConnectPrincipal);
}
throw error;
}
}
get policyFragment() {
return new PrincipalPolicyFragment({ Federated: [this.federated] }, this.conditions);
}
toString() {
return `OpenIdConnectPrincipal(${this.federated})`;
}
}
exports.OpenIdConnectPrincipal = OpenIdConnectPrincipal;
_o = JSII_RTTI_SYMBOL_1;
OpenIdConnectPrincipal[_o] = { fqn: "@aws-cdk/aws-iam.OpenIdConnectPrincipal", version: "1.201.0" };
/**
* Principal entity that represents a SAML federated identity provider
*/
class SamlPrincipal extends FederatedPrincipal {
constructor(samlProvider, conditions) {
super(samlProvider.samlProviderArn, conditions, 'sts:AssumeRoleWithSAML');
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_ISamlProvider(samlProvider);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, SamlPrincipal);
}
throw error;
}
}
toString() {
return `SamlPrincipal(${this.federated})`;
}
}
exports.SamlPrincipal = SamlPrincipal;
_p = JSII_RTTI_SYMBOL_1;
SamlPrincipal[_p] = { fqn: "@aws-cdk/aws-iam.SamlPrincipal", version: "1.201.0" };
/**
* Principal entity that represents a SAML federated identity provider for
* programmatic and AWS Management Console access.
*/
class SamlConsolePrincipal extends SamlPrincipal {
constructor(samlProvider, conditions = {}) {
super(samlProvider, {
...conditions,
StringEquals: {
'SAML:aud': 'https://signin.aws.amazon.com/saml',
},
});
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_ISamlProvider(samlProvider);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, SamlConsolePrincipal);
}
throw error;
}
}
toString() {
return `SamlConsolePrincipal(${this.federated})`;
}
}
exports.SamlConsolePrincipal = SamlConsolePrincipal;
_q = JSII_RTTI_SYMBOL_1;
SamlConsolePrincipal[_q] = { fqn: "@aws-cdk/aws-iam.SamlConsolePrincipal", version: "1.201.0" };
/**
* Use the AWS account into which a stack is deployed as the principal entity in a policy
*/
class AccountRootPrincipal extends AccountPrincipal {
constructor() {
super(new StackDependentToken(stack => stack.account).toString());
}
toString() {
return 'AccountRootPrincipal()';
}
}
exports.AccountRootPrincipal = AccountRootPrincipal;
_r = JSII_RTTI_SYMBOL_1;
AccountRootPrincipal[_r] = { fqn: "@aws-cdk/aws-iam.AccountRootPrincipal", version: "1.201.0" };
/**
* A principal representing all AWS identities in all accounts
*
* Some services behave differently when you specify `Principal: '*'`
* or `Principal: { AWS: "*" }` in their resource policy.
*
* `AnyPrincipal` renders to `Principal: { AWS: "*" }`. This is correct
* most of the time, but in cases where you need the other principal,
* use `StarPrincipal` instead.
*/
class AnyPrincipal extends ArnPrincipal {
constructor() {
super('*');
}
toString() {
return 'AnyPrincipal()';
}
}
exports.AnyPrincipal = AnyPrincipal;
_s = JSII_RTTI_SYMBOL_1;
AnyPrincipal[_s] = { fqn: "@aws-cdk/aws-iam.AnyPrincipal", version: "1.201.0" };
/**
* A principal representing all identities in all accounts
* @deprecated use `AnyPrincipal`
*/
class Anyone extends AnyPrincipal {
}
exports.Anyone = Anyone;
_t = JSII_RTTI_SYMBOL_1;
Anyone[_t] = { fqn: "@aws-cdk/aws-iam.Anyone", version: "1.201.0" };
/**
* A principal that uses a literal '*' in the IAM JSON language
*
* Some services behave differently when you specify `Principal: "*"`
* or `Principal: { AWS: "*" }` in their resource policy.
*
* `StarPrincipal` renders to `Principal: *`. Most of the time, you
* should use `AnyPrincipal` instead.
*/
class StarPrincipal extends PrincipalBase {
constructor() {
super(...arguments);
this.policyFragment = {
principalJson: { [util_1.LITERAL_STRING_KEY]: ['*'] },
conditions: {},
};
}
toString() {
return 'StarPrincipal()';
}
dedupeString() {
return 'StarPrincipal';
}
}
exports.StarPrincipal = StarPrincipal;
_u = JSII_RTTI_SYMBOL_1;
StarPrincipal[_u] = { fqn: "@aws-cdk/aws-iam.StarPrincipal", version: "1.201.0" };
/**
* Represents a principal that has multiple types of principals. A composite principal cannot
* have conditions. i.e. multiple ServicePrincipals that form a composite principal
*/
class CompositePrincipal extends PrincipalBase {
constructor(...principals) {
super();
this.principals = new Array();
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principals);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, CompositePrincipal);
}
throw error;
}
if (principals.length === 0) {
throw new Error('CompositePrincipals must be constructed with at least 1 Principal but none were passed.');
}
this.assumeRoleAction = principals[0].assumeRoleAction;
this.addPrincipals(...principals);
}
/**
* Adds IAM principals to the composite principal. Composite principals cannot have
* conditions.
*
* @param principals IAM principals that will be added to the composite principal
*/
addPrincipals(...principals) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_IPrincipal(principals);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addPrincipals);
}
throw error;
}
this.principals.push(...principals);
return this;
}
addToAssumeRolePolicy(doc) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_iam_PolicyDocument(doc);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addToAssumeRolePolicy);
}
throw error;
}
for (const p of this.principals) {
assume_role_policy_1.defaultAddPrincipalToAssumeRole(p, doc);
}
}
get policyFragment() {
// We only have a problem with conditions if we are trying to render composite
// princpals into a single statement (which is when `policyFragment` would get called)
for (const p of this.principals) {
const fragment = p.policyFragment;
if (fragment.conditions && Object.keys(fragment.conditions).length > 0) {
throw new Error('Components of a CompositePrincipal must not have conditions. ' +
`Tried to add the following fragment: ${JSON.stringify(fragment)}`);
}
}
const principalJson = {};
for (const p of this.principals) {
util_1.mergePrincipal(principalJson, p.policyFragment.principalJson);
}
return new PrincipalPolicyFragment(principalJson);
}
toString() {
return `CompositePrincipal(${this.principals})`;
}
dedupeString() {
const inner = this.principals.map(ComparablePrincipal.dedupeStringFor);
if (inner.some(x => x === undefined)) {
return undefined;
}
return `CompositePrincipal[${inner.join(',')}]`;
}
}
exports.CompositePrincipal = CompositePrincipal;
_v = JSII_RTTI_SYMBOL_1;
CompositePrincipal[_v] = { fqn: "@aws-cdk/aws-iam.CompositePrincipal", version: "1.201.0" };
/**
* A lazy token that requires an instance of Stack to evaluate
*/
class StackDependentToken {
constructor(fn) {
this.fn = fn;
this.creationStack = cdk.captureStackTrace();
}
resolve(context) {
return this.fn(cdk.Stack.of(context.scope));
}
toString() {
return cdk.Token.asString(this);
}
/**
* JSON-ify the token
*
* Used when JSON.stringify() is called
*/
toJSON() {
return '<unresolved-token>';
}
}
class ServicePrincipalToken {
constructor(service, opts) {
this.service = service;
this.opts = opts;
this.creationStack = cdk.captureStackTrace();
}
resolve(ctx) {
if (this.opts.region) {
// Special case, handle it separately to not break legacy behavior.
return region_info_1.RegionInfo.get(this.opts.region).servicePrincipal(this.service) ??
region_info_1.Default.servicePrincipal(this.service, this.opts.region, cdk.Aws.URL_SUFFIX);
}
const stack = cdk.Stack.of(ctx.scope);
return stack.regionalFact(region_info_1.FactName.servicePrincipal(this.service), region_info_1.Default.servicePrincipal(this.service, stack.region, cdk.Aws.URL_SUFFIX));
}
toString() {
return cdk.Token.asString(this, {
displayHint: this.service,
});
}
/**
* JSON-ify the token
*
* Used when JSON.stringify() is called
*/
toJSON() {
return `<${this.service}>`;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"principals.js","sourceRoot":"","sources":["principals.ts"],"names":[],"mappings":";;;;;;AAAA,qCAAqC;AACrC,sDAAqE;AAGrE,yDAA4E;AAC5E,qEAA+E;AAE/E,iCAA4D;AA+E5D;;GAEG;AACH,MAAa,mBAAmB;IAC9B;;OAEG;IACI,MAAM,CAAC,qBAAqB,CAAC,CAAa;;;;;;;;;;QAC/C,OAAO,cAAc,IAAI,CAAC,CAAC;KAC5B;IAED;;OAEG;IACI,MAAM,CAAC,eAAe,CAAC,CAAa;;;;;;;;;;QACzC,OAAO,mBAAmB,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;KACpF;;AAbH,kDAcC;;;AAuCD;;GAEG;AACH,MAAsB,aAAa;IAAnC;QACkB,mBAAc,GAAe,IAAI,CAAC;QAClC,qBAAgB,GAAuB,SAAS,CAAC;QAOjE;;WAEG;QACa,qBAAgB,GAAW,gBAAgB,CAAC;KA8D7D;IA5DQ,WAAW,CAAC,SAA0B;;;;;;;;;;QAC3C,OAAO,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,cAAc,CAAC;KAC5D;IAEM,oBAAoB,CAAC,UAA2B;;;;;;;;;;QACrD,oEAAoE;QACpE,mCAAmC;QACnC,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC;KAClC;IAEM,qBAAqB,CAAC,QAAwB;;;;;;;;;;QACnD,+EAA+E;QAC/E,QAAQ,CAAC,aAAa,CAAC,IAAI,kCAAe,CAAC;YACzC,OAAO,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC;YAChC,UAAU,EAAE,CAAC,IAAI,CAAC;SACnB,CAAC,CAAC,CAAC;KACL;IAEM,QAAQ;QACb,0EAA0E;QAC1E,iCAAiC;QACjC,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;KAC1D;IAED;;;;OAIG;IACI,MAAM;QACX,kFAAkF;QAClF,OAAO,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;KAC1C;IAED;;;;;;;;OAQG;IACI,cAAc,CAAC,UAAsB;QAC1C,OAAO,IAAI,uBAAuB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;KACtD;IAED;;;;OAIG;IACI,eAAe;QACpB,OAAO,IAAI,oBAAoB,CAAC,IAAI,CAAC,CAAC;KACvC;;AApEH,sCA0EC;;;AAED;;GAEG;AACH,MAAe,gBAAiB,SAAQ,aAAa;IAInD,YAA+B,OAAmB;QAChD,KAAK,EAAE,CAAC;QADqB,YAAO,GAAP,OAAO,CAAY;QAHlC,qBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC;QACjD,qBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC;KAIhE;IAED,IAAW,cAAc,KAA8B,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;IAE5F,WAAW,CAAC,SAA0B;QACpC,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;KAC5C;IACD,oBAAoB,CAAC,SAA0B;QAC7C,OAAO,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;KACrD;IAED;;OAEG;IACO,YAAY,CAAC,MAAc;QACnC,MAAM,KAAK,GAAG,mBAAmB,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAChE,OAAO,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,KAAK,IAAI,MAAM,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;KACxF;CACF;AAED;;;;;GAKG;AACH,MAAa,uBAAwB,SAAQ,gBAAgB;IAG3D,YAAY,SAAqB,EAAE,UAAsB;QACvD,KAAK,CAAC,SAAS,CAAC,CAAC;;;;;;+CAJR,uBAAuB;;;;QAKhC,IAAI,CAAC,oBAAoB,GAAG,UAAU,CAAC;KACxC;IAED;;OAEG;IACI,YAAY,CAAC,GAAW,EAAE,KAAgB;QAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC;QACrD,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,EAAE,GAAG,aAAa,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;KACzF;IAED;;;;;OAKG;IACI,aAAa,CAAC,UAAsB;QACzC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YAClD,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;KACJ;IAED;;;OAGG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,UAAU,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;KAChG;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;KAChG;IAEM,QAAQ;QACb,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;KAChC;IAED;;;;OAIG;IACI,MAAM;QACX,kFAAkF;QAClF,OAAO,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;KAC1C;IAEM,YAAY;QACjB,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;KAC3D;IAEO,eAAe,CAAC,mBAA+B,EAAE,oBAAgC;QACvF,MAAM,gBAAgB,GAAe,EAAE,CAAC;QACxC,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,SAAS,CAAC,EAAE,EAAE;YACpE,gBAAgB,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAC;QACzC,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,SAAS,CAAC,EAAE,EAAE;YACrE,mEAAmE;YACnE,uEAAuE;YACvE,mBAAmB;YACnB,MAAM,QAAQ,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;YAC5C,IAAI,CAAC,QAAQ,EAAE;gBACb,gBAAgB,CAAC,QAAQ,CAAC,GAAG,SAAS,CAAC;gBACvC,OAAO,CAAC,WAAW;aACpB;YAED,qEAAqE;YACrE,iEAAiE;YACjE,IAAI,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE;gBACzE,MAAM,IAAI,KAAK,CAAC,aAAa,QAAQ,2EAA2E,CAAC,CAAC;aACnH;YAED,gBAAgB,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,QAAQ,EAAE,GAAG,SAAS,EAAE,CAAC;QAC7D,CAAC,CAAC,CAAC;QACH,OAAO,gBAAgB,CAAC;KACzB;;AAnFH,0DAoFC;;;AAED;;;;;GAKG;AACH,MAAa,oBAAqB,SAAQ,gBAAgB;IACxD,YAAY,SAAqB;QAC/B,KAAK,CAAC,SAAS,CAAC,CAAC;;;;;;+CAFR,oBAAoB;;;;KAG9B;IAEM,qBAAqB,CAAC,GAAmB;;;;;;;;;;QAC9C,mEAAmE;QAEnE,iEAAiE;QACjE,MAAM,OAAO,GAAiD,OAAO,CAAC,6BAA6B,CAAC,CAAC;QAErG,oDAA+B,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,OAAO,CAAC,6BAA6B,CAAC,GAAG,EAAE,CAAC,SAAS,EAAE,EAAE;YACzG,SAAS,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;YACvC,OAAO,SAAS,CAAC;QACnB,CAAC,CAAC,CAAC,CAAC;KACL;IAEM,YAAY;QACjB,OAAO,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;KAC9B;;AAnBH,oDAoBC;;;AAED;;;;;;;;;;;;;;GAcG;AACH,MAAa,uBAAuB;IAClC;;;;OAIG;IACH,YACkB,aAA0C;IAC1D;;;OAGG;IACa,aAAyB,EAAE;QAL3B,kBAAa,GAAb,aAAa,CAA6B;QAK1C,eAAU,GAAV,UAAU,CAAiB;KAC5C;;AAbH,0DAcC;;;AAED;;;;;;GAMG;AACH,MAAa,YAAa,SAAQ,aAAa;IAC7C;;;OAGG;IACH,YAA4B,GAAW;QACrC,KAAK,EAAE,CAAC;QADkB,QAAG,GAAH,GAAG,CAAQ;KAEtC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAAC,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;KACzD;IAEM,QAAQ;QACb,OAAO,gBAAgB,IAAI,CAAC,GAAG,GAAG,CAAC;KACpC;IAED;;;OAGG;IACI,cAAc,CAAC,cAAsB;QAC1C,OAAO,IAAI,CAAC,cAAc,CAAC;YACzB,YAAY,EAAE;gBACZ,oBAAoB,EAAE,cAAc;aACrC;SACF,CAAC,CAAC;KACJ;IAEM,YAAY;QACjB,OAAO,gBAAgB,IAAI,CAAC,GAAG,EAAE,CAAC;KACnC;;AA/BH,oCAgCC;;;AAED;;GAEG;AACH,MAAa,gBAAiB,SAAQ,YAAY;IAGhD;;;OAGG;IACH,YAA4B,SAAc;QACxC,KAAK,CAAC,IAAI,mBAAmB,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,KAAK,CAAC,SAAS,SAAS,SAAS,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;QAD1E,cAAS,GAAT,SAAS,CAAK;QAExC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE;YACvE,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;SACvD;QACD,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC;KACnC;IAEM,QAAQ;QACb,OAAO,oBAAoB,IAAI,CAAC,SAAS,GAAG,CAAC;KAC9C;;AAjBH,4CAkBC;;;AAsBD;;GAEG;AACH,MAAa,gBAAiB,SAAQ,aAAa;IAgBjD;;;OAGG;IACH,YAA4B,OAAe,EAAmB,OAA6B,EAAE;QAC3F,KAAK,EAAE,CAAC;QADkB,YAAO,GAAP,OAAO,CAAQ;QAAmB,SAAI,GAAJ,IAAI,CAA2B;;;;;;+CApBlF,gBAAgB;;;;KAsB1B;IArBD;;;;;;;;;;OAUG;IACI,MAAM,CAAC,oBAAoB,CAAC,OAAe;QAChD,OAAO,IAAI,qBAAqB,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;KAC1D;IAUD,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAAC;YACjC,OAAO,EAAE;gBACP,IAAI,qBAAqB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE;aAC9D;SACF,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;KAC1B;IAEM,QAAQ;QACb,OAAO,oBAAoB,IAAI,CAAC,OAAO,GAAG,CAAC;KAC5C;IAEM,YAAY;QACjB,OAAO,oBAAoB,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;KACxE;;AAtCH,4CAuCC;;;AAED;;GAEG;AACH,MAAa,qBAAsB,SAAQ,aAAa;IACtD;;;OAGG;IACH,YAA4B,cAAsB;QAChD,KAAK,EAAE,CAAC;QADkB,mBAAc,GAAd,cAAc,CAAQ;KAEjD;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAChC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,EACd,EAAE,YAAY,EAAE,EAAE,oBAAoB,EAAE,IAAI,CAAC,cAAc,EAAE,EAAE,CAChE,CAAC;KACH;IAEM,QAAQ;QACb,OAAO,yBAAyB,IAAI,CAAC,cAAc,GAAG,CAAC;KACxD;IAEM,YAAY;QACjB,OAAO,yBAAyB,IAAI,CAAC,cAAc,EAAE,CAAC;KACvD;;AAtBH,sDAuBC;;;AAED;;;;;;;;;;;;GAYG;AACH,MAAa,sBAAuB,SAAQ,aAAa;IACvD;;;;;OAKG;IACH,YAA4B,eAAuB;QACjD,KAAK,EAAE,CAAC;QADkB,oBAAe,GAAf,eAAe,CAAQ;KAElD;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAAC,EAAE,aAAa,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;KAC/E;IAEM,QAAQ;QACb,OAAO,0BAA0B,IAAI,CAAC,eAAe,GAAG,CAAC;KAC1D;IAEM,YAAY;QACjB,OAAO,0BAA0B,IAAI,CAAC,eAAe,EAAE,CAAC;KACzD;;AArBH,wDAsBC;;;AAED;;;;;;;GAOG;AACH,MAAa,kBAAmB,SAAQ,aAAa;IAGnD;;;;;;OAMG;IACH,YACkB,SAAiB,EACjB,UAAsB,EACtC,mBAA2B,gBAAgB;QAC3C,KAAK,EAAE,CAAC;QAHQ,cAAS,GAAT,SAAS,CAAQ;QACjB,eAAU,GAAV,UAAU,CAAY;QAItC,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;KAC1C;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAAC,EAAE,SAAS,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;KACtF;IAEM,QAAQ;QACb,OAAO,sBAAsB,IAAI,CAAC,SAAS,GAAG,CAAC;KAChD;IAEM,YAAY;QACjB,OAAO,sBAAsB,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;KAC3G;;AA7BH,gDA8BC;;;AAED;;;GAGG;AACH,MAAa,oBAAqB,SAAQ,kBAAkB;IAE1D;;;;;;OAMG;IACH,YAAY,gBAAwB,EAAE,aAAyB,EAAE;QAC/D,KAAK,CAAC,gBAAgB,EAAE,UAAU,IAAI,EAAE,EAAE,+BAA+B,CAAC,CAAC;KAC5E;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAAC,EAAE,SAAS,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;KACtF;IAEM,QAAQ;QACb,OAAO,wBAAwB,IAAI,CAAC,SAAS,GAAG,CAAC;KAClD;;AAnBH,oDAoBC;;;AAED;;GAEG;AACH,MAAa,sBAAuB,SAAQ,oBAAoB;IAE9D;;;;;OAKG;IACH,YAAY,qBAA6C,EAAE,aAAyB,EAAE;QACpF,KAAK,CAAC,qBAAqB,CAAC,wBAAwB,EAAE,UAAU,IAAI,EAAE,CAAC,CAAC;;;;;;+CAT/D,sBAAsB;;;;KAUhC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,uBAAuB,CAAC,EAAE,SAAS,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;KACtF;IAEM,QAAQ;QACb,OAAO,0BAA0B,IAAI,CAAC,SAAS,GAAG,CAAC;KACpD;;AAlBH,wDAmBC;;;AAED;;GAEG;AACH,MAAa,aAAc,SAAQ,kBAAkB;IACnD,YAAY,YAA2B,EAAE,UAAsB;QAC7D,KAAK,CAAC,YAAY,CAAC,eAAe,EAAE,UAAU,EAAE,wBAAwB,CAAC,CAAC;;;;;;+CAFjE,aAAa;;;;KAGvB;IAEM,QAAQ;QACb,OAAO,iBAAiB,IAAI,CAAC,SAAS,GAAG,CAAC;KAC3C;;AAPH,sCAQC;;;AAED;;;GAGG;AACH,MAAa,oBAAqB,SAAQ,aAAa;IACrD,YAAY,YAA2B,EAAE,aAAyB,EAAE;QAClE,KAAK,CAAC,YAAY,EAAE;YAClB,GAAG,UAAU;YACb,YAAY,EAAE;gBACZ,UAAU,EAAE,oCAAoC;aACjD;SACF,CAAC,CAAC;;;;;;+CAPM,oBAAoB;;;;KAQ9B;IAEM,QAAQ;QACb,OAAO,wBAAwB,IAAI,CAAC,SAAS,GAAG,CAAC;KAClD;;AAZH,oDAaC;;;AAED;;GAEG;AACH,MAAa,oBAAqB,SAAQ,gBAAgB;IACxD;QACE,KAAK,CAAC,IAAI,mBAAmB,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;KACnE;IAEM,QAAQ;QACb,OAAO,wBAAwB,CAAC;KACjC;;AAPH,oDAQC;;;AAED;;;;;;;;;GASG;AACH,MAAa,YAAa,SAAQ,YAAY;IAC5C;QACE,KAAK,CAAC,GAAG,CAAC,CAAC;KACZ;IAEM,QAAQ;QACb,OAAO,gBAAgB,CAAC;KACzB;;AAPH,oCAQC;;;AAED;;;GAGG;AACH,MAAa,MAAO,SAAQ,YAAY;;AAAxC,wBAA4C;;;AAE5C;;;;;;;;GAQG;AACH,MAAa,aAAc,SAAQ,aAAa;IAAhD;;QACkB,mBAAc,GAA4B;YACxD,aAAa,EAAE,EAAE,CAAC,yBAAkB,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE;YAC9C,UAAU,EAAE,EAAE;SACf,CAAC;KASH;IAPQ,QAAQ;QACb,OAAO,iBAAiB,CAAC;KAC1B;IAEM,YAAY;QACjB,OAAO,eAAe,CAAC;KACxB;;AAZH,sCAaC;;;AAED;;;GAGG;AACH,MAAa,kBAAmB,SAAQ,aAAa;IAInD,YAAY,GAAG,UAAwB;QACrC,KAAK,EAAE,CAAC;QAHO,eAAU,GAAG,IAAI,KAAK,EAAc,CAAC;;;;;;+CAF3C,kBAAkB;;;;QAM3B,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,yFAAyF,CAAC,CAAC;SAC5G;QACD,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC;QACvD,IAAI,CAAC,aAAa,CAAC,GAAG,UAAU,CAAC,CAAC;KACnC;IAED;;;;;OAKG;IACI,aAAa,CAAC,GAAG,UAAwB;;;;;;;;;;QAC9C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,CAAC;QACpC,OAAO,IAAI,CAAC;KACb;IAEM,qBAAqB,CAAC,GAAmB;;;;;;;;;;QAC9C,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE;YAC/B,oDAA+B,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SACzC;KACF;IAED,IAAW,cAAc;QACvB,8EAA8E;QAC9E,sFAAsF;QACtF,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE;YAC/B,MAAM,QAAQ,GAAG,CAAC,CAAC,cAAc,CAAC;YAClC,IAAI,QAAQ,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;gBACtE,MAAM,IAAI,KAAK,CACb,+DAA+D;oBAC/D,wCAAwC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;aACvE;SACF;QAED,MAAM,aAAa,GAAgC,EAAE,CAAC;QAEtD,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE;YAC/B,qBAAc,CAAC,aAAa,EAAE,CAAC,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;SAC/D;QAED,OAAO,IAAI,uBAAuB,CAAC,aAAa,CAAC,CAAC;KACnD;IAEM,QAAQ;QACb,OAAO,sBAAsB,IAAI,CAAC,UAAU,GAAG,CAAC;KACjD;IAEM,YAAY;QACjB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,mBAAmB,CAAC,eAAe,CAAC,CAAC;QACvE,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,EAAE;YAAE,OAAO,SAAS,CAAC;SAAE;QAC3D,OAAO,sBAAsB,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;KACjD;;AA3DH,gDA4DC;;;AAED;;GAEG;AACH,MAAM,mBAAmB;IAEvB,YAA6B,EAA6B;QAA7B,OAAE,GAAF,EAAE,CAA2B;QACxD,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,iBAAiB,EAAE,CAAC;KAC9C;IAEM,OAAO,CAAC,OAA4B;QACzC,OAAO,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;KAC7C;IAEM,QAAQ;QACb,OAAO,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;KACjC;IAED;;;;OAIG;IACI,MAAM;QACX,OAAO,oBAAoB,CAAC;KAC7B;CACF;AAED,MAAM,qBAAqB;IAEzB,YACmB,OAAe,EACf,IAA0B;QAD1B,YAAO,GAAP,OAAO,CAAQ;QACf,SAAI,GAAJ,IAAI,CAAsB;QAC3C,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,iBAAiB,EAAE,CAAC;KAC9C;IAEM,OAAO,CAAC,GAAwB;QACrC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACpB,mEAAmE;YACnE,OAAO,wBAAU,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC;gBACpE,qBAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;SAChF;QAED,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACtC,OAAO,KAAK,CAAC,YAAY,CACvB,sBAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,EACvC,qBAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,CACzE,CAAC;KACH;IAEM,QAAQ;QACb,OAAO,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE;YAC9B,WAAW,EAAE,IAAI,CAAC,OAAO;SAC1B,CAAC,CAAC;KACJ;IAED;;;;OAIG;IACI,MAAM;QACX,OAAO,IAAI,IAAI,CAAC,OAAO,GAAG,CAAC;KAC5B;CACF","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  re