1 | ;
|
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 | this.grantPrincipal = this;
|
16 | this.principalAccount = this.env.account;
|
17 | this.assumeRoleAction = 'sts:AssumeRole';
|
18 | this.attachedPolicies = new util_1.AttachedPolicies();
|
19 | }
|
20 | get policyFragment() {
|
21 | return new principals_1.ArnPrincipal(this.groupArn).policyFragment;
|
22 | }
|
23 | /**
|
24 | * Attaches a policy to this group.
|
25 | * @param policy The policy to attach.
|
26 | */
|
27 | attachInlinePolicy(policy) {
|
28 | this.attachedPolicies.attach(policy);
|
29 | policy.attachToGroup(this);
|
30 | }
|
31 | addManagedPolicy(_policy) {
|
32 | }
|
33 | /**
|
34 | * Adds a user to this group.
|
35 | */
|
36 | addUser(user) {
|
37 | user.addToGroup(this);
|
38 | }
|
39 | /**
|
40 | * Adds an IAM statement to the default policy.
|
41 | */
|
42 | addToPrincipalPolicy(statement) {
|
43 | if (!this.defaultPolicy) {
|
44 | this.defaultPolicy = new policy_1.Policy(this, 'DefaultPolicy');
|
45 | this.defaultPolicy.attachToGroup(this);
|
46 | }
|
47 | this.defaultPolicy.addStatements(statement);
|
48 | return { statementAdded: true, policyDependable: this.defaultPolicy };
|
49 | }
|
50 | addToPolicy(statement) {
|
51 | return this.addToPrincipalPolicy(statement).statementAdded;
|
52 | }
|
53 | }
|
54 | /**
|
55 | * An IAM Group (collection of IAM users) lets you specify permissions for
|
56 | * multiple users, which can make it easier to manage permissions for those users.
|
57 | *
|
58 | * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_groups.html
|
59 | */
|
60 | class Group extends GroupBase {
|
61 | constructor(scope, id, props = {}) {
|
62 | super(scope, id, {
|
63 | physicalName: props.groupName,
|
64 | });
|
65 | this.managedPolicies = [];
|
66 | try {
|
67 | jsiiDeprecationWarnings._aws_cdk_aws_iam_GroupProps(props);
|
68 | }
|
69 | catch (error) {
|
70 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
71 | Error.captureStackTrace(error, Group);
|
72 | }
|
73 | throw error;
|
74 | }
|
75 | this.managedPolicies.push(...props.managedPolicies || []);
|
76 | const group = new iam_generated_1.CfnGroup(this, 'Resource', {
|
77 | groupName: this.physicalName,
|
78 | managedPolicyArns: core_1.Lazy.list({ produce: () => this.managedPolicies.map(p => p.managedPolicyArn) }, { omitEmpty: true }),
|
79 | path: props.path,
|
80 | });
|
81 | this.groupName = this.getResourceNameAttribute(group.ref);
|
82 | this.groupArn = this.getResourceArnAttribute(group.attrArn, {
|
83 | region: '',
|
84 | service: 'iam',
|
85 | resource: 'group',
|
86 | // Removes leading slash from path
|
87 | resourceName: `${props.path ? props.path.substr(props.path.charAt(0) === '/' ? 1 : 0) : ''}${this.physicalName}`,
|
88 | });
|
89 | }
|
90 | /**
|
91 | * Import an external group by ARN.
|
92 | *
|
93 | * If the imported Group ARN is a Token (such as a
|
94 | * `CfnParameter.valueAsString` or a `Fn.importValue()`) *and* the referenced
|
95 | * group has a `path` (like `arn:...:group/AdminGroup/NetworkAdmin`), the
|
96 | * `groupName` property will not resolve to the correct value. Instead it
|
97 | * will resolve to the first path component. We unfortunately cannot express
|
98 | * the correct calculation of the full path name as a CloudFormation
|
99 | * expression. In this scenario the Group ARN should be supplied without the
|
100 | * `path` in order to resolve the correct group resource.
|
101 | *
|
102 | * @param scope construct scope
|
103 | * @param id construct id
|
104 | * @param groupArn the ARN of the group to import (e.g. `arn:aws:iam::account-id:group/group-name`)
|
105 | */
|
106 | static fromGroupArn(scope, id, groupArn) {
|
107 | const arnComponents = core_1.Stack.of(scope).splitArn(groupArn, core_1.ArnFormat.SLASH_RESOURCE_NAME);
|
108 | const groupName = arnComponents.resourceName;
|
109 | class Import extends GroupBase {
|
110 | constructor() {
|
111 | super(...arguments);
|
112 | this.groupName = groupName;
|
113 | this.groupArn = groupArn;
|
114 | this.principalAccount = arnComponents.account;
|
115 | }
|
116 | }
|
117 | return new Import(scope, id);
|
118 | }
|
119 | /**
|
120 | * Import an existing group by given name (with path).
|
121 | * This method has same caveats of `fromGroupArn`
|
122 | *
|
123 | * @param scope construct scope
|
124 | * @param id construct id
|
125 | * @param groupName the groupName (path included) of the existing group to import
|
126 | */
|
127 | static fromGroupName(scope, id, groupName) {
|
128 | const groupArn = core_1.Stack.of(scope).formatArn({
|
129 | service: 'iam',
|
130 | region: '',
|
131 | resource: 'group',
|
132 | resourceName: groupName,
|
133 | });
|
134 | return Group.fromGroupArn(scope, id, groupArn);
|
135 | }
|
136 | /**
|
137 | * Attaches a managed policy to this group.
|
138 | * @param policy The managed policy to attach.
|
139 | */
|
140 | addManagedPolicy(policy) {
|
141 | try {
|
142 | jsiiDeprecationWarnings._aws_cdk_aws_iam_IManagedPolicy(policy);
|
143 | }
|
144 | catch (error) {
|
145 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
146 | Error.captureStackTrace(error, this.addManagedPolicy);
|
147 | }
|
148 | throw error;
|
149 | }
|
150 | if (this.managedPolicies.find(mp => mp === policy)) {
|
151 | return;
|
152 | }
|
153 | this.managedPolicies.push(policy);
|
154 | }
|
155 | }
|
156 | exports.Group = Group;
|
157 | _a = JSII_RTTI_SYMBOL_1;
|
158 | Group[_a] = { fqn: "@aws-cdk/aws-iam.Group", version: "1.161.0" };
|
159 | //# 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/**\n * Represents an IAM Group.\n *\n * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_groups.html\n */\nexport interface IGroup extends IIdentity {\n  /**\n   * Returns the IAM Group Name\n   *\n   * @attribute\n   */\n  readonly groupName: string;\n\n  /**\n   * Returns the IAM Group ARN\n   *\n   * @attribute\n   */\n  readonly groupArn: string;\n}\n\n/**\n * Properties for defining an IAM group\n */\nexport interface GroupProps {\n  /**\n   * A name for the IAM group. For valid values, see the GroupName parameter\n   * for the CreateGroup action in the IAM API Reference. If you don't specify\n   * a name, AWS CloudFormation generates a unique physical ID and uses that\n   * ID for the group name.\n   *\n   * If you specify a name, you must specify the CAPABILITY_NAMED_IAM value to\n   * acknowledge your template's capabilities. For more information, see\n   * Acknowledging IAM Resources in AWS CloudFormation Templates.\n   *\n   * @default Generated by CloudFormation (recommended)\n   */\n  readonly groupName?: string;\n\n  /**\n   * A list of managed policies associated with this role.\n   *\n   * You can add managed policies later using\n   * `addManagedPolicy(ManagedPolicy.fromAwsManagedPolicyName(policyName))`.\n   *\n   * @default - No managed policies.\n   */\n  readonly managedPolicies?: IManagedPolicy[];\n\n  /**\n   * The path to the group. For more information about paths, see [IAM\n   * Identifiers](http://docs.aws.amazon.com/IAM/latest/UserGuide/index.html?Using_Identifiers.html)\n   * in the IAM User Guide.\n   *\n   * @default /\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   * Attaches a policy to this group.\n   * @param policy The policy to attach.\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   * Adds a user to this group.\n   */\n  public addUser(user: IUser) {\n    user.addToGroup(this);\n  }\n\n  /**\n   * Adds an IAM statement to the default policy.\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/**\n * An IAM Group (collection of IAM users) lets you specify permissions for\n * multiple users, which can make it easier to manage permissions for those users.\n *\n * @see https://docs.aws.amazon.com/IAM/latest/UserGuide/id_groups.html\n */\nexport class Group extends GroupBase {\n  /**\n   * Import an external group by ARN.\n   *\n   * If the imported Group ARN is a Token (such as a\n   * `CfnParameter.valueAsString` or a `Fn.importValue()`) *and* the referenced\n   * group has a `path` (like `arn:...:group/AdminGroup/NetworkAdmin`), the\n   * `groupName` property will not resolve to the correct value. Instead it\n   * will resolve to the first path component. We unfortunately cannot express\n   * the correct calculation of the full path name as a CloudFormation\n   * expression. In this scenario the Group ARN should be supplied without the\n   * `path` in order to resolve the correct group resource.\n   *\n   * @param scope construct scope\n   * @param id construct id\n   * @param groupArn the ARN of the group to import (e.g. `arn:aws:iam::account-id:group/group-name`)\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  /**\n   * Import an existing group by given name (with path).\n   * This method has same caveats of `fromGroupArn`\n   *\n   * @param scope construct scope\n   * @param id construct id\n   * @param groupName the groupName (path included) of the existing group to import\n   */\n  static fromGroupName(scope: Construct, id: string, groupName: string) {\n    const groupArn = Stack.of(scope).formatArn({\n      service: 'iam',\n      region: '',\n      resource: 'group',\n      resourceName: groupName,\n    });\n    return Group.fromGroupArn(scope, id, groupArn);\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      // Removes leading slash from path\n      resourceName: `${props.path ? props.path.substr(props.path.charAt(0) === '/' ? 1 : 0) : ''}${this.physicalName}`,\n    });\n  }\n\n  /**\n   * Attaches a managed policy to this group.\n   * @param policy The managed policy to attach.\n   */\n  public addManagedPolicy(policy: IManagedPolicy) {\n    if (this.managedPolicies.find(mp => mp === policy)) { return; }\n    this.managedPolicies.push(policy);\n  }\n}\n"]} |
\ | No newline at end of file |