cdk-iam-floyd 0.697.0 → 0.698.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -17,7 +17,7 @@
17
17
  Support for:
18
18
 
19
19
  - 418 Services
20
- - 18451 Actions
20
+ - 18454 Actions
21
21
  - 1981 Resource Types
22
22
  - 1943 Condition keys
23
23
  <!-- /stats -->
@@ -64,8 +64,6 @@ export declare class Account extends PolicyStatement {
64
64
  * Grants permission to retrieve the account information for an account
65
65
  *
66
66
  * Access Level: Read
67
- *
68
- * https://docs.aws.amazon.com/accounts/latest/reference/security_account-permissions-ref.html
69
67
  */
70
68
  toGetAccountInformation(): this;
71
69
  /**
@@ -114,6 +112,14 @@ export declare class Account extends PolicyStatement {
114
112
  * https://docs.aws.amazon.com/accounts/latest/reference/API_ListRegions.html
115
113
  */
116
114
  toListRegions(): this;
115
+ /**
116
+ * Grants permission to update the name for an account
117
+ *
118
+ * Access Level: Write
119
+ *
120
+ * https://docs.aws.amazon.com/accounts/latest/reference/API_PutAccountName.html
121
+ */
122
+ toPutAccountName(): this;
117
123
  /**
118
124
  * Grants permission to modify the alternate contacts for an account
119
125
  *
@@ -74,8 +74,6 @@ class Account extends shared_1.PolicyStatement {
74
74
  * Grants permission to retrieve the account information for an account
75
75
  *
76
76
  * Access Level: Read
77
- *
78
- * https://docs.aws.amazon.com/accounts/latest/reference/security_account-permissions-ref.html
79
77
  */
80
78
  toGetAccountInformation() {
81
79
  return this.to('GetAccountInformation');
@@ -136,6 +134,16 @@ class Account extends shared_1.PolicyStatement {
136
134
  toListRegions() {
137
135
  return this.to('ListRegions');
138
136
  }
137
+ /**
138
+ * Grants permission to update the name for an account
139
+ *
140
+ * Access Level: Write
141
+ *
142
+ * https://docs.aws.amazon.com/accounts/latest/reference/API_PutAccountName.html
143
+ */
144
+ toPutAccountName() {
145
+ return this.to('PutAccountName');
146
+ }
139
147
  /**
140
148
  * Grants permission to modify the alternate contacts for an account
141
149
  *
@@ -280,6 +288,7 @@ class Account extends shared_1.PolicyStatement {
280
288
  'DeleteAlternateContact',
281
289
  'DisableRegion',
282
290
  'EnableRegion',
291
+ 'PutAccountName',
283
292
  'PutAlternateContact',
284
293
  'PutContactInformation',
285
294
  'StartPrimaryEmailUpdate'
@@ -298,4 +307,4 @@ class Account extends shared_1.PolicyStatement {
298
307
  }
299
308
  }
300
309
  exports.Account = Account;
301
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accountmanagement.js","sourceRoot":"","sources":["accountmanagement.ts"],"names":[],"mappings":"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","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\nimport { aws_iam as iam } from \"aws-cdk-lib\";\n\n/**\n * Statement provider for service [account](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsaccountmanagement.html).\n *\n * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n */\nexport class Account extends PolicyStatement {\n  public servicePrefix = 'account';\n\n  /**\n   * Grants permission to accept the process to update the primary email address of an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifEmailTargetDomain()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_AcceptPrimaryEmailUpdate.html\n   */\n  public toAcceptPrimaryEmailUpdate() {\n    return this.to('AcceptPrimaryEmailUpdate');\n  }\n\n  /**\n   * Grants permission to close an account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_account-permissions-ref.html\n   */\n  public toCloseAccount() {\n    return this.to('CloseAccount');\n  }\n\n  /**\n   * Grants permission to delete the alternate contacts for an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAlternateContactTypes()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_DeleteAlternateContact.html\n   */\n  public toDeleteAlternateContact() {\n    return this.to('DeleteAlternateContact');\n  }\n\n  /**\n   * Grants permission to disable use of a Region\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifTargetRegion()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_DisableRegion.html\n   */\n  public toDisableRegion() {\n    return this.to('DisableRegion');\n  }\n\n  /**\n   * Grants permission to enable use of a Region\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifTargetRegion()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_EnableRegion.html\n   */\n  public toEnableRegion() {\n    return this.to('EnableRegion');\n  }\n\n  /**\n   * Grants permission to retrieve the account information for an account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_account-permissions-ref.html\n   */\n  public toGetAccountInformation() {\n    return this.to('GetAccountInformation');\n  }\n\n  /**\n   * Grants permission to retrieve the alternate contacts for an account\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAlternateContactTypes()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetAlternateContact.html\n   */\n  public toGetAlternateContact() {\n    return this.to('GetAlternateContact');\n  }\n\n  /**\n   * Grants permission to retrieve the primary contact information for an account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetContactInformation.html\n   */\n  public toGetContactInformation() {\n    return this.to('GetContactInformation');\n  }\n\n  /**\n   * Grants permission to retrieve the primary email address of an account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetPrimaryEmail.html\n   */\n  public toGetPrimaryEmail() {\n    return this.to('GetPrimaryEmail');\n  }\n\n  /**\n   * Grants permission to get the opt-in status of a Region\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifTargetRegion()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetRegionOptStatus.html\n   */\n  public toGetRegionOptStatus() {\n    return this.to('GetRegionOptStatus');\n  }\n\n  /**\n   * Grants permission to list the available Regions\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_ListRegions.html\n   */\n  public toListRegions() {\n    return this.to('ListRegions');\n  }\n\n  /**\n   * Grants permission to modify the alternate contacts for an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAlternateContactTypes()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_PutAlternateContact.html\n   */\n  public toPutAlternateContact() {\n    return this.to('PutAlternateContact');\n  }\n\n  /**\n   * Grants permission to update the primary contact information for an account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_PutContactInformation.html\n   */\n  public toPutContactInformation() {\n    return this.to('PutContactInformation');\n  }\n\n  /**\n   * Grants permission to start the process to update the primary email address of an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifEmailTargetDomain()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_StartPrimaryEmailUpdate.html\n   */\n  public toStartPrimaryEmailUpdate() {\n    return this.to('StartPrimaryEmailUpdate');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AcceptPrimaryEmailUpdate',\n      'CloseAccount',\n      'DeleteAlternateContact',\n      'DisableRegion',\n      'EnableRegion',\n      'PutAlternateContact',\n      'PutContactInformation',\n      'StartPrimaryEmailUpdate'\n    ],\n    Read: [\n      'GetAccountInformation',\n      'GetAlternateContact',\n      'GetContactInformation',\n      'GetPrimaryEmail',\n      'GetRegionOptStatus'\n    ],\n    List: [\n      'ListRegions'\n    ]\n  };\n\n  /**\n   * Adds a resource of type account to the statement\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-resources\n   *\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   */\n  public onAccount(account?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:account::${ account ?? this.defaultAccount }:account`);\n  }\n\n  /**\n   * Adds a resource of type accountInOrganization to the statement\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-resources\n   *\n   * @param managementAccountId - Identifier for the managementAccountId.\n   * @param organizationId - Identifier for the organizationId.\n   * @param memberAccountId - Identifier for the memberAccountId.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   */\n  public onAccountInOrganization(managementAccountId: string, organizationId: string, memberAccountId: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:account::${ managementAccountId }:account/o-${ organizationId }/${ memberAccountId }`);\n  }\n\n  /**\n   * Filters access by the resource path for an account in an organization\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAccountResourceOrgPaths(value: string | string[], operator?: Operator | string) {\n    return this.if(`AccountResourceOrgPaths`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by resource tags for an account in an organization\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAccountResourceOrgTags(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`AccountResourceOrgTags/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by alternate contact types\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * Applies to actions:\n   * - .toDeleteAlternateContact()\n   * - .toGetAlternateContact()\n   * - .toPutAlternateContact()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAlternateContactTypes(value: string | string[], operator?: Operator | string) {\n    return this.if(`AlternateContactTypes`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by email domain of the target email address\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * Applies to actions:\n   * - .toAcceptPrimaryEmailUpdate()\n   * - .toStartPrimaryEmailUpdate()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifEmailTargetDomain(value: string | string[], operator?: Operator | string) {\n    return this.if(`EmailTargetDomain`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by a list of Regions. Enables or disables all the Regions specified here\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * Applies to actions:\n   * - .toDisableRegion()\n   * - .toEnableRegion()\n   * - .toGetRegionOptStatus()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifTargetRegion(value: string | string[], operator?: Operator | string) {\n    return this.if(`TargetRegion`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Statement provider for service [account](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsaccountmanagement.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
310
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accountmanagement.js","sourceRoot":"","sources":["accountmanagement.ts"],"names":[],"mappings":";;;AACA,yCAAyD;AAGzD;;;;GAIG;AACH,MAAa,OAAQ,SAAQ,wBAAe;IAG1C;;;;;;;;;OASG;IACI,0BAA0B;QAC/B,OAAO,IAAI,CAAC,EAAE,CAAC,0BAA0B,CAAC,CAAC;IAC7C,CAAC;IAED;;;;;;OAMG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;;;;OASG;IACI,wBAAwB;QAC7B,OAAO,IAAI,CAAC,EAAE,CAAC,wBAAwB,CAAC,CAAC;IAC3C,CAAC;IAED;;;;;;;;;OASG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;;;;OASG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;;;;OASG;IACI,qBAAqB;QAC1B,OAAO,IAAI,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC;IACxC,CAAC;IAED;;;;;;OAMG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;OAMG;IACI,iBAAiB;QACtB,OAAO,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;;;;OASG;IACI,oBAAoB;QACzB,OAAO,IAAI,CAAC,EAAE,CAAC,oBAAoB,CAAC,CAAC;IACvC,CAAC;IAED;;;;;;OAMG;IACI,aAAa;QAClB,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;IAChC,CAAC;IAED;;;;;;OAMG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;;;;OASG;IACI,qBAAqB;QAC1B,OAAO,IAAI,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC;IACxC,CAAC;IAED;;;;;;OAMG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;;;;OASG;IACI,yBAAyB;QAC9B,OAAO,IAAI,CAAC,EAAE,CAAC,yBAAyB,CAAC,CAAC;IAC5C,CAAC;IA0BD;;;;;;;OAOG;IACI,SAAS,CAAC,OAAgB,EAAE,SAAkB;QACnD,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,aAAc,OAAO,IAAI,IAAI,CAAC,cAAe,UAAU,CAAC,CAAC;IACrH,CAAC;IAED;;;;;;;;;OASG;IACI,uBAAuB,CAAC,mBAA2B,EAAE,cAAsB,EAAE,eAAuB,EAAE,SAAkB;QAC7H,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,aAAc,mBAAoB,cAAe,cAAe,IAAK,eAAgB,EAAE,CAAC,CAAC;IACrJ,CAAC;IAED;;;;;;;OAOG;IACI,yBAAyB,CAAC,KAAwB,EAAE,QAA4B;QACrF,OAAO,IAAI,CAAC,EAAE,CAAC,yBAAyB,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IAC7E,CAAC;IAED;;;;;;;;OAQG;IACI,wBAAwB,CAAC,MAAc,EAAE,KAAwB,EAAE,QAA4B;QACpG,OAAO,IAAI,CAAC,EAAE,CAAC,0BAA2B,MAAO,EAAE,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACxF,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,uBAAuB,CAAC,KAAwB,EAAE,QAA4B;QACnF,OAAO,IAAI,CAAC,EAAE,CAAC,uBAAuB,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IAC3E,CAAC;IAED;;;;;;;;;;;OAWG;IACI,mBAAmB,CAAC,KAAwB,EAAE,QAA4B;QAC/E,OAAO,IAAI,CAAC,EAAE,CAAC,mBAAmB,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACvE,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,cAAc,CAAC,KAAwB,EAAE,QAA4B;QAC1E,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IAClE,CAAC;IAED;;;OAGG;IACH,YAAY,KAAgC;QAC1C,KAAK,CAAC,KAAK,CAAC,CAAC;QA/TR,kBAAa,GAAG,SAAS,CAAC;QA6LvB,oBAAe,GAAoB;YAC3C,KAAK,EAAE;gBACL,0BAA0B;gBAC1B,cAAc;gBACd,wBAAwB;gBACxB,eAAe;gBACf,cAAc;gBACd,gBAAgB;gBAChB,qBAAqB;gBACrB,uBAAuB;gBACvB,yBAAyB;aAC1B;YACD,IAAI,EAAE;gBACJ,uBAAuB;gBACvB,qBAAqB;gBACrB,uBAAuB;gBACvB,iBAAiB;gBACjB,oBAAoB;aACrB;YACD,IAAI,EAAE;gBACJ,aAAa;aACd;SACF,CAAC;IA6GF,CAAC;CACF;AAlUD,0BAkUC","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\nimport { aws_iam as iam } from \"aws-cdk-lib\";\n\n/**\n * Statement provider for service [account](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsaccountmanagement.html).\n *\n * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n */\nexport class Account extends PolicyStatement {\n  public servicePrefix = 'account';\n\n  /**\n   * Grants permission to accept the process to update the primary email address of an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifEmailTargetDomain()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_AcceptPrimaryEmailUpdate.html\n   */\n  public toAcceptPrimaryEmailUpdate() {\n    return this.to('AcceptPrimaryEmailUpdate');\n  }\n\n  /**\n   * Grants permission to close an account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_account-permissions-ref.html\n   */\n  public toCloseAccount() {\n    return this.to('CloseAccount');\n  }\n\n  /**\n   * Grants permission to delete the alternate contacts for an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAlternateContactTypes()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_DeleteAlternateContact.html\n   */\n  public toDeleteAlternateContact() {\n    return this.to('DeleteAlternateContact');\n  }\n\n  /**\n   * Grants permission to disable use of a Region\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifTargetRegion()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_DisableRegion.html\n   */\n  public toDisableRegion() {\n    return this.to('DisableRegion');\n  }\n\n  /**\n   * Grants permission to enable use of a Region\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifTargetRegion()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_EnableRegion.html\n   */\n  public toEnableRegion() {\n    return this.to('EnableRegion');\n  }\n\n  /**\n   * Grants permission to retrieve the account information for an account\n   *\n   * Access Level: Read\n   */\n  public toGetAccountInformation() {\n    return this.to('GetAccountInformation');\n  }\n\n  /**\n   * Grants permission to retrieve the alternate contacts for an account\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAlternateContactTypes()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetAlternateContact.html\n   */\n  public toGetAlternateContact() {\n    return this.to('GetAlternateContact');\n  }\n\n  /**\n   * Grants permission to retrieve the primary contact information for an account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetContactInformation.html\n   */\n  public toGetContactInformation() {\n    return this.to('GetContactInformation');\n  }\n\n  /**\n   * Grants permission to retrieve the primary email address of an account\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetPrimaryEmail.html\n   */\n  public toGetPrimaryEmail() {\n    return this.to('GetPrimaryEmail');\n  }\n\n  /**\n   * Grants permission to get the opt-in status of a Region\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifTargetRegion()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_GetRegionOptStatus.html\n   */\n  public toGetRegionOptStatus() {\n    return this.to('GetRegionOptStatus');\n  }\n\n  /**\n   * Grants permission to list the available Regions\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_ListRegions.html\n   */\n  public toListRegions() {\n    return this.to('ListRegions');\n  }\n\n  /**\n   * Grants permission to update the name for an account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_PutAccountName.html\n   */\n  public toPutAccountName() {\n    return this.to('PutAccountName');\n  }\n\n  /**\n   * Grants permission to modify the alternate contacts for an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAlternateContactTypes()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_PutAlternateContact.html\n   */\n  public toPutAlternateContact() {\n    return this.to('PutAlternateContact');\n  }\n\n  /**\n   * Grants permission to update the primary contact information for an account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_PutContactInformation.html\n   */\n  public toPutContactInformation() {\n    return this.to('PutContactInformation');\n  }\n\n  /**\n   * Grants permission to start the process to update the primary email address of an account\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifEmailTargetDomain()\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/API_StartPrimaryEmailUpdate.html\n   */\n  public toStartPrimaryEmailUpdate() {\n    return this.to('StartPrimaryEmailUpdate');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AcceptPrimaryEmailUpdate',\n      'CloseAccount',\n      'DeleteAlternateContact',\n      'DisableRegion',\n      'EnableRegion',\n      'PutAccountName',\n      'PutAlternateContact',\n      'PutContactInformation',\n      'StartPrimaryEmailUpdate'\n    ],\n    Read: [\n      'GetAccountInformation',\n      'GetAlternateContact',\n      'GetContactInformation',\n      'GetPrimaryEmail',\n      'GetRegionOptStatus'\n    ],\n    List: [\n      'ListRegions'\n    ]\n  };\n\n  /**\n   * Adds a resource of type account to the statement\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-resources\n   *\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   */\n  public onAccount(account?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:account::${ account ?? this.defaultAccount }:account`);\n  }\n\n  /**\n   * Adds a resource of type accountInOrganization to the statement\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-resources\n   *\n   * @param managementAccountId - Identifier for the managementAccountId.\n   * @param organizationId - Identifier for the organizationId.\n   * @param memberAccountId - Identifier for the memberAccountId.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   */\n  public onAccountInOrganization(managementAccountId: string, organizationId: string, memberAccountId: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:account::${ managementAccountId }:account/o-${ organizationId }/${ memberAccountId }`);\n  }\n\n  /**\n   * Filters access by the resource path for an account in an organization\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAccountResourceOrgPaths(value: string | string[], operator?: Operator | string) {\n    return this.if(`AccountResourceOrgPaths`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by resource tags for an account in an organization\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAccountResourceOrgTags(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`AccountResourceOrgTags/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by alternate contact types\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * Applies to actions:\n   * - .toDeleteAlternateContact()\n   * - .toGetAlternateContact()\n   * - .toPutAlternateContact()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAlternateContactTypes(value: string | string[], operator?: Operator | string) {\n    return this.if(`AlternateContactTypes`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by email domain of the target email address\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * Applies to actions:\n   * - .toAcceptPrimaryEmailUpdate()\n   * - .toStartPrimaryEmailUpdate()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifEmailTargetDomain(value: string | string[], operator?: Operator | string) {\n    return this.if(`EmailTargetDomain`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by a list of Regions. Enables or disables all the Regions specified here\n   *\n   * https://docs.aws.amazon.com/accounts/latest/reference/security_iam_service-with-iam.html#security_iam_service-with-iam-id-based-policies-conditionkeys\n   *\n   * Applies to actions:\n   * - .toDisableRegion()\n   * - .toEnableRegion()\n   * - .toGetRegionOptStatus()\n   *\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifTargetRegion(value: string | string[], operator?: Operator | string) {\n    return this.if(`TargetRegion`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Statement provider for service [account](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsaccountmanagement.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
@@ -548,6 +548,14 @@ export declare class Ecs extends PolicyStatement {
548
548
  * https://docs.aws.amazon.com/AmazonECS/latest/developerguide/cloudwatch-metrics.html#enable_cloudwatch
549
549
  */
550
550
  toStartTelemetrySession(): this;
551
+ /**
552
+ * Grants permission to stop an ongoing service deployment
553
+ *
554
+ * Access Level: Write
555
+ *
556
+ * https://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_StopServiceDeployment.html
557
+ */
558
+ toStopServiceDeployment(): this;
551
559
  /**
552
560
  * Grants permission to stop a running task
553
561
  *
@@ -941,6 +949,7 @@ export declare class Ecs extends PolicyStatement {
941
949
  * - .toRegisterTaskDefinition()
942
950
  * - .toRunTask()
943
951
  * - .toStartTask()
952
+ * - .toStopServiceDeployment()
944
953
  * - .toStopTask()
945
954
  * - .toSubmitAttachmentStateChanges()
946
955
  * - .toSubmitContainerStateChange()
@@ -1095,6 +1104,7 @@ export declare class Ecs extends PolicyStatement {
1095
1104
  * - .toRunTask()
1096
1105
  * - .toStartTask()
1097
1106
  * - .toStartTelemetrySession()
1107
+ * - .toStopServiceDeployment()
1098
1108
  * - .toStopTask()
1099
1109
  * - .toUpdateContainerAgent()
1100
1110
  * - .toUpdateContainerInstancesState()
@@ -1278,6 +1288,7 @@ export declare class Ecs extends PolicyStatement {
1278
1288
  * - .toDescribeServiceDeployments()
1279
1289
  * - .toDescribeServiceRevisions()
1280
1290
  * - .toDescribeTaskSets()
1291
+ * - .toStopServiceDeployment()
1281
1292
  * - .toUpdateTaskSet()
1282
1293
  *
1283
1294
  * Applies to resource types: