group.js
  1  "use strict";
  2  var _a;
  3  Object.defineProperty(exports, "__esModule", { value: true });
  4  exports.Group = void 0;
  5  const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
  6  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
  7  const core_1 = require("@aws-cdk/core");
  8  const iam_generated_1 = require("./iam.generated");
  9  const policy_1 = require("./policy");
 10  const principals_1 = require("./principals");
 11  const util_1 = require("./util");
 12  class GroupBase extends core_1.Resource {
 13      constructor() {
 14          super(...arguments);
 15          /**
 16           * The principal to grant permissions to.
 17           *
 18           * @stability stable
 19           */
 20          this.grantPrincipal = this;
 21          /**
 22           * The AWS account ID of this principal.
 23           *
 24           * Can be undefined when the account is not known
 25           * (for example, for service principals).
 26           * Can be a Token - in that case,
 27           * it's assumed to be AWS::AccountId.
 28           *
 29           * @stability stable
 30           */
 31          this.principalAccount = this.env.account;
 32          /**
 33           * When this Principal is used in an AssumeRole policy, the action to use.
 34           *
 35           * @stability stable
 36           */
 37          this.assumeRoleAction = 'sts:AssumeRole';
 38          this.attachedPolicies = new util_1.AttachedPolicies();
 39      }
 40      /**
 41       * Return the policy fragment that identifies this principal in a Policy.
 42       *
 43       * @stability stable
 44       */
 45      get policyFragment() {
 46          return new principals_1.ArnPrincipal(this.groupArn).policyFragment;
 47      }
 48      /**
 49       * Attaches a policy to this group.
 50       *
 51       * @param policy The policy to attach.
 52       * @stability stable
 53       */
 54      attachInlinePolicy(policy) {
 55          this.attachedPolicies.attach(policy);
 56          policy.attachToGroup(this);
 57      }
 58      addManagedPolicy(_policy) {
 59      }
 60      /**
 61       * Adds a user to this group.
 62       *
 63       * @stability stable
 64       */
 65      addUser(user) {
 66          user.addToGroup(this);
 67      }
 68      /**
 69       * Adds an IAM statement to the default policy.
 70       *
 71       * @stability stable
 72       */
 73      addToPrincipalPolicy(statement) {
 74          if (!this.defaultPolicy) {
 75              this.defaultPolicy = new policy_1.Policy(this, 'DefaultPolicy');
 76              this.defaultPolicy.attachToGroup(this);
 77          }
 78          this.defaultPolicy.addStatements(statement);
 79          return { statementAdded: true, policyDependable: this.defaultPolicy };
 80      }
 81      /**
 82       * Add to the policy of this principal.
 83       *
 84       * @stability stable
 85       */
 86      addToPolicy(statement) {
 87          return this.addToPrincipalPolicy(statement).statementAdded;
 88      }
 89  }
 90  /**
 91   * An IAM Group (collection of IAM users) lets you specify permissions for multiple users, which can make it easier to manage permissions for those users.
 92   *
 93   * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_groups.html
 94   * @stability stable
 95   */
 96  class Group extends GroupBase {
 97      /**
 98       * @stability stable
 99       */
100      constructor(scope, id, props = {}) {
101          super(scope, id, {
102              physicalName: props.groupName,
103          });
104          this.managedPolicies = [];
105          jsiiDeprecationWarnings._aws_cdk_aws_iam_GroupProps(props);
106          this.managedPolicies.push(...props.managedPolicies || []);
107          const group = new iam_generated_1.CfnGroup(this, 'Resource', {
108              groupName: this.physicalName,
109              managedPolicyArns: core_1.Lazy.list({ produce: () => this.managedPolicies.map(p => p.managedPolicyArn) }, { omitEmpty: true }),
110              path: props.path,
111          });
112          this.groupName = this.getResourceNameAttribute(group.ref);
113          this.groupArn = this.getResourceArnAttribute(group.attrArn, {
114              region: '',
115              service: 'iam',
116              resource: 'group',
117              resourceName: this.physicalName,
118          });
119      }
120      /**
121       * Import an external group by ARN.
122       *
123       * If the imported Group ARN is a Token (such as a
124       * `CfnParameter.valueAsString` or a `Fn.importValue()`) *and* the referenced
125       * group has a `path` (like `arn:...:group/AdminGroup/NetworkAdmin`), the
126       * `groupName` property will not resolve to the correct value. Instead it
127       * will resolve to the first path component. We unfortunately cannot express
128       * the correct calculation of the full path name as a CloudFormation
129       * expression. In this scenario the Group ARN should be supplied without the
130       * `path` in order to resolve the correct group resource.
131       *
132       * @param scope construct scope.
133       * @param id construct id.
134       * @param groupArn the ARN of the group to import (e.g. `arn:aws:iam::account-id:group/group-name`).
135       * @stability stable
136       */
137      static fromGroupArn(scope, id, groupArn) {
138          const arnComponents = core_1.Stack.of(scope).splitArn(groupArn, core_1.ArnFormat.SLASH_RESOURCE_NAME);
139          const groupName = arnComponents.resourceName;
140          class Import extends GroupBase {
141              constructor() {
142                  super(...arguments);
143                  this.groupName = groupName;
144                  this.groupArn = groupArn;
145                  this.principalAccount = arnComponents.account;
146              }
147          }
148          return new Import(scope, id);
149      }
150      /**
151       * Attaches a managed policy to this group.
152       *
153       * @param policy The managed policy to attach.
154       * @stability stable
155       */
156      addManagedPolicy(policy) {
157          jsiiDeprecationWarnings._aws_cdk_aws_iam_IManagedPolicy(policy);
158          if (this.managedPolicies.find(mp => mp === policy)) {
159              return;
160          }
161          this.managedPolicies.push(policy);
162      }
163  }
164  exports.Group = Group;
165  _a = JSII_RTTI_SYMBOL_1;
166  Group[_a] = { fqn: "@aws-cdk/aws-iam.Group", version: "1.134.0" };
167  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group.js","sourceRoot":"","sources":["group.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArnFormat, Lazy, Resource, Stack } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnGroup } from './iam.generated';\nimport { IIdentity } from './identity-base';\nimport { IManagedPolicy } from './managed-policy';\nimport { Policy } from './policy';\nimport { PolicyStatement } from './policy-statement';\nimport { AddToPrincipalPolicyResult, ArnPrincipal, IPrincipal, PrincipalPolicyFragment } from './principals';\nimport { IUser } from './user';\nimport { AttachedPolicies } from './util';\n\n                                                                                                              \nexport interface IGroup extends IIdentity {\n                                                                \n  readonly groupName: string;\n\n                                                               \n  readonly groupArn: string;\n}\n\n                                               \nexport interface GroupProps {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            \n  readonly groupName?: string;\n\n                                                                                                                                                                                                                                                \n  readonly managedPolicies?: IManagedPolicy[];\n\n                                                                                                                                                                                                                                        \n  readonly path?: string;\n}\n\nabstract class GroupBase extends Resource implements IGroup {\n  public abstract readonly groupName: string;\n  public abstract readonly groupArn: string;\n\n  public readonly grantPrincipal: IPrincipal = this;\n  public readonly principalAccount: string | undefined = this.env.account;\n  public readonly assumeRoleAction: string = 'sts:AssumeRole';\n\n  private readonly attachedPolicies = new AttachedPolicies();\n  private defaultPolicy?: Policy;\n\n  public get policyFragment(): PrincipalPolicyFragment {\n    return new ArnPrincipal(this.groupArn).policyFragment;\n  }\n\n                                                                                          \n  public attachInlinePolicy(policy: Policy) {\n    this.attachedPolicies.attach(policy);\n    policy.attachToGroup(this);\n  }\n\n  public addManagedPolicy(_policy: IManagedPolicy) {\n    // drop\n  }\n\n                                           \n  public addUser(user: IUser) {\n    user.addToGroup(this);\n  }\n\n                                                             \n  public addToPrincipalPolicy(statement: PolicyStatement): AddToPrincipalPolicyResult {\n    if (!this.defaultPolicy) {\n      this.defaultPolicy = new Policy(this, 'DefaultPolicy');\n      this.defaultPolicy.attachToGroup(this);\n    }\n\n    this.defaultPolicy.addStatements(statement);\n    return { statementAdded: true, policyDependable: this.defaultPolicy };\n  }\n\n  public addToPolicy(statement: PolicyStatement): boolean {\n    return this.addToPrincipalPolicy(statement).statementAdded;\n  }\n}\n\n                                                                                                                                                                                                                                                \nexport class Group extends GroupBase {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             \n  public static fromGroupArn(scope: Construct, id: string, groupArn: string): IGroup {\n    const arnComponents = Stack.of(scope).splitArn(groupArn, ArnFormat.SLASH_RESOURCE_NAME);\n    const groupName = arnComponents.resourceName!;\n    class Import extends GroupBase {\n      public groupName = groupName;\n      public groupArn = groupArn;\n      public principalAccount = arnComponents.account;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly groupName: string;\n  public readonly groupArn: string;\n\n  private readonly managedPolicies: IManagedPolicy[] = [];\n\n  constructor(scope: Construct, id: string, props: GroupProps = {}) {\n    super(scope, id, {\n      physicalName: props.groupName,\n    });\n\n    this.managedPolicies.push(...props.managedPolicies || []);\n\n    const group = new CfnGroup(this, 'Resource', {\n      groupName: this.physicalName,\n      managedPolicyArns: Lazy.list({ produce: () => this.managedPolicies.map(p => p.managedPolicyArn) }, { omitEmpty: true }),\n      path: props.path,\n    });\n\n    this.groupName = this.getResourceNameAttribute(group.ref);\n    this.groupArn = this.getResourceArnAttribute(group.attrArn, {\n      region: '', // IAM is global in each partition\n      service: 'iam',\n      resource: 'group',\n      resourceName: this.physicalName,\n    });\n  }\n\n                                                                                                          \n  public addManagedPolicy(policy: IManagedPolicy) {\n    if (this.managedPolicies.find(mp => mp === policy)) { return; }\n    this.managedPolicies.push(policy);\n  }\n}\n"]}