iam-floyd 0.614.0 → 0.616.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.
Files changed (30) hide show
  1. package/README.md +3 -3
  2. package/lib/generated/policy-statements/cloudwatchinternetmonitor.d.ts +8 -0
  3. package/lib/generated/policy-statements/cloudwatchinternetmonitor.js +12 -1
  4. package/lib/generated/policy-statements/codeartifact.d.ts +105 -3
  5. package/lib/generated/policy-statements/codeartifact.js +138 -4
  6. package/lib/generated/policy-statements/costexplorerservice.d.ts +16 -0
  7. package/lib/generated/policy-statements/costexplorerservice.js +23 -1
  8. package/lib/generated/policy-statements/costoptimizationhub.d.ts +1 -1
  9. package/lib/generated/policy-statements/costoptimizationhub.js +2 -2
  10. package/lib/generated/policy-statements/dynamodb.d.ts +26 -2
  11. package/lib/generated/policy-statements/dynamodb.js +38 -3
  12. package/lib/generated/policy-statements/ec2.d.ts +10 -19
  13. package/lib/generated/policy-statements/ec2.js +11 -22
  14. package/lib/generated/policy-statements/managedblockchainquery.d.ts +6 -0
  15. package/lib/generated/policy-statements/managedblockchainquery.js +10 -1
  16. package/lib/generated/policy-statements/migrationhuborchestrator.d.ts +41 -4
  17. package/lib/generated/policy-statements/migrationhuborchestrator.js +53 -5
  18. package/lib/generated/policy-statements/rds.d.ts +9 -9
  19. package/lib/generated/policy-statements/rds.js +10 -10
  20. package/lib/generated/policy-statements/savingsplans.d.ts +16 -4
  21. package/lib/generated/policy-statements/savingsplans.js +21 -6
  22. package/lib/generated/policy-statements/servicequotas.d.ts +46 -6
  23. package/lib/generated/policy-statements/servicequotas.js +47 -7
  24. package/lib/generated/policy-statements/stepfunctions.d.ts +2 -0
  25. package/lib/generated/policy-statements/stepfunctions.js +3 -1
  26. package/lib/generated/policy-statements/timestreaminfluxdb.d.ts +13 -13
  27. package/lib/generated/policy-statements/timestreaminfluxdb.js +14 -14
  28. package/lib/generated/policy-statements/workmail.d.ts +8 -2
  29. package/lib/generated/policy-statements/workmail.js +12 -3
  30. package/package.json +5 -5
package/README.md CHANGED
@@ -17,9 +17,9 @@
17
17
  Support for:
18
18
 
19
19
  - 387 Services
20
- - 16287 Actions
21
- - 1750 Resource Types
22
- - 1694 Condition keys
20
+ - 16309 Actions
21
+ - 1752 Resource Types
22
+ - 1693 Condition keys
23
23
  <!-- /stats -->
24
24
 
25
25
  ![EXPERIMENTAL](https://img.shields.io/badge/stability-experimantal-orange?style=for-the-badge)**<br>This is an early version of the package. The API will change while I implement new features. Therefore make sure you use an exact version in your `package.json` before it reaches 1.0.0.**
@@ -65,6 +65,14 @@ export declare class Internetmonitor extends PolicyStatement {
65
65
  * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryStatus.html
66
66
  */
67
67
  toGetQueryStatus(): this;
68
+ /**
69
+ * Grants permission to share Internet Monitor resources with a monitoring account
70
+ *
71
+ * Access Level: Write
72
+ *
73
+ * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-Unified-Cross-Account-Setup.html#CloudWatch-Unified-Cross-Account-Setup-permissions
74
+ */
75
+ toLink(): this;
68
76
  /**
69
77
  * Grants permission to list all health events for a monitor
70
78
  *
@@ -20,6 +20,7 @@ class Internetmonitor extends shared_1.PolicyStatement {
20
20
  Write: [
21
21
  'CreateMonitor',
22
22
  'DeleteMonitor',
23
+ 'Link',
23
24
  'UpdateMonitor'
24
25
  ],
25
26
  Read: [
@@ -105,6 +106,16 @@ class Internetmonitor extends shared_1.PolicyStatement {
105
106
  toGetQueryStatus() {
106
107
  return this.to('GetQueryStatus');
107
108
  }
109
+ /**
110
+ * Grants permission to share Internet Monitor resources with a monitoring account
111
+ *
112
+ * Access Level: Write
113
+ *
114
+ * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-Unified-Cross-Account-Setup.html#CloudWatch-Unified-Cross-Account-Setup-permissions
115
+ */
116
+ toLink() {
117
+ return this.to('Link');
118
+ }
108
119
  /**
109
120
  * Grants permission to list all health events for a monitor
110
121
  *
@@ -271,4 +282,4 @@ class Internetmonitor extends shared_1.PolicyStatement {
271
282
  }
272
283
  }
273
284
  exports.Internetmonitor = Internetmonitor;
274
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudwatchinternetmonitor.js","sourceRoot":"","sources":["cloudwatchinternetmonitor.ts"],"names":[],"mappings":";;;AACA,yCAAyD;AAEzD;;;;GAIG;AACH,MAAa,eAAgB,SAAQ,wBAAe;IAGlD;;;;OAIG;IACH,YAAY,GAAY;QACtB,KAAK,CAAC,GAAG,CAAC,CAAC;QARN,kBAAa,GAAG,iBAAiB,CAAC;QAgL/B,oBAAe,GAAoB;YAC3C,KAAK,EAAE;gBACL,eAAe;gBACf,eAAe;gBACf,eAAe;aAChB;YACD,IAAI,EAAE;gBACJ,gBAAgB;gBAChB,YAAY;gBACZ,iBAAiB;gBACjB,gBAAgB;gBAChB,qBAAqB;gBACrB,YAAY;gBACZ,WAAW;aACZ;YACD,IAAI,EAAE;gBACJ,kBAAkB;gBAClB,cAAc;aACf;YACD,OAAO,EAAE;gBACP,aAAa;gBACb,eAAe;aAChB;SACF,CAAC;IA9LF,CAAC;IAED;;;;;;;;;;OAUG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;OAMG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;OAMG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACI,YAAY;QACjB,OAAO,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;OAMG;IACI,iBAAiB;QACtB,OAAO,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC;IACnC,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACvB,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACI,qBAAqB;QAC1B,OAAO,IAAI,CAAC,EAAE,CAAC,qBAAqB,CAAC,CAAC;IACxC,CAAC;IAED;;;;;;OAMG;IACI,YAAY;QACjB,OAAO,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;OAMG;IACI,WAAW;QAChB,OAAO,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC;IAC9B,CAAC;IAED;;;;;;;;;;OAUG;IACI,aAAa;QAClB,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;IAChC,CAAC;IAED;;;;;;;;;OASG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;OAMG;IACI,eAAe;QACpB,OAAO,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,CAAC;IAClC,CAAC;IA2BD;;;;;;;;;;OAUG;IACI,aAAa,CAAC,WAAmB,EAAE,OAAe,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QAC9G,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,oBAAqB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,YAAa,WAAY,iBAAkB,OAAQ,EAAE,CAAC,CAAC;IACzM,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,SAAS,CAAC,WAAmB,EAAE,OAAgB,EAAE,MAAe,EAAE,SAAkB;QACzF,OAAO,IAAI,CAAC,EAAE,CAAC,OAAQ,SAAS,IAAI,IAAI,CAAC,gBAAiB,oBAAqB,MAAM,IAAI,IAAI,CAAC,aAAc,IAAK,OAAO,IAAI,IAAI,CAAC,cAAe,YAAa,WAAY,EAAE,CAAC,CAAC;IAC/K,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,eAAe,CAAC,MAAc,EAAE,KAAwB,EAAE,QAA4B;QAC3F,OAAO,IAAI,CAAC,EAAE,CAAC,kBAAmB,MAAO,EAAE,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IAChF,CAAC;IAED;;;;;;;;;;;OAWG;IACI,gBAAgB,CAAC,MAAc,EAAE,KAAwB,EAAE,QAA4B;QAC5F,OAAO,IAAI,CAAC,EAAE,CAAC,mBAAoB,MAAO,EAAE,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACjF,CAAC;IAED;;;;;;;;;;;;OAYG;IACI,YAAY,CAAC,KAAwB,EAAE,QAA4B;QACxE,OAAO,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,KAAK,EAAE,QAAQ,IAAI,YAAY,CAAC,CAAC;IACjE,CAAC;CACF;AA3RD,0CA2RC","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\n\n/**\n * Statement provider for service [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.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 Internetmonitor extends PolicyStatement {\n  public servicePrefix = 'internetmonitor';\n\n  /**\n   * Statement provider for service [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.html).\n   *\n   * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n   */\n  constructor(sid?: string) {\n    super(sid);\n  }\n\n  /**\n   * Grants permission to create a monitor\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_CreateMonitor.html\n   */\n  public toCreateMonitor() {\n    return this.to('CreateMonitor');\n  }\n\n  /**\n   * Grants permission to delete a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_DeleteMonitor.html\n   */\n  public toDeleteMonitor() {\n    return this.to('DeleteMonitor');\n  }\n\n  /**\n   * Grants permission to get information about a health event for a specified monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetHealthEvent.html\n   */\n  public toGetHealthEvent() {\n    return this.to('GetHealthEvent');\n  }\n\n  /**\n   * Grants permission to get information about a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetMonitor.html\n   */\n  public toGetMonitor() {\n    return this.to('GetMonitor');\n  }\n\n  /**\n   * Grants permission to get results for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryResults.html\n   */\n  public toGetQueryResults() {\n    return this.to('GetQueryResults');\n  }\n\n  /**\n   * Grants permission to get status for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryStatus.html\n   */\n  public toGetQueryStatus() {\n    return this.to('GetQueryStatus');\n  }\n\n  /**\n   * Grants permission to list all health events for a monitor\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListHealthEvents.html\n   */\n  public toListHealthEvents() {\n    return this.to('ListHealthEvents');\n  }\n\n  /**\n   * Grants permission to list all monitors in an account and their statuses\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListMonitors.html\n   */\n  public toListMonitors() {\n    return this.to('ListMonitors');\n  }\n\n  /**\n   * Grants permission to list the tags for a resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to start a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StartQuery.html\n   */\n  public toStartQuery() {\n    return this.to('StartQuery');\n  }\n\n  /**\n   * Grants permission to stop a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StopQuery.html\n   */\n  public toStopQuery() {\n    return this.to('StopQuery');\n  }\n\n  /**\n   * Grants permission to add tags to a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove tags from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UpdateMonitor.html\n   */\n  public toUpdateMonitor() {\n    return this.to('UpdateMonitor');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateMonitor',\n      'DeleteMonitor',\n      'UpdateMonitor'\n    ],\n    Read: [\n      'GetHealthEvent',\n      'GetMonitor',\n      'GetQueryResults',\n      'GetQueryStatus',\n      'ListTagsForResource',\n      'StartQuery',\n      'StopQuery'\n    ],\n    List: [\n      'ListHealthEvents',\n      'ListMonitors'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type HealthEvent to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\n   * @param eventId - Identifier for the eventId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\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 onHealthEvent(monitorName: string, eventId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }/health-event/${ eventId }`);\n  }\n\n  /**\n   * Adds a resource of type Monitor to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\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   * Possible conditions:\n   * - .ifAwsResourceTag()\n   */\n  public onMonitor(monitorName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }`);\n  }\n\n  /**\n   * Filters access by tag key-value pairs in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag\n   *\n   * Applies to actions:\n   * - .toCreateMonitor()\n   * - .toTagResource()\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 ifAwsRequestTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:RequestTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by tag key-value pairs attached to the resource\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag\n   *\n   * Applies to resource types:\n   * - Monitor\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 ifAwsResourceTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:ResourceTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by tag keys in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys\n   *\n   * Applies to actions:\n   * - .toCreateMonitor()\n   * - .toTagResource()\n   * - .toUntagResource()\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 ifAwsTagKeys(value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:TagKeys`, value, operator ?? 'StringLike');\n  }\n}\n"]}
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudwatchinternetmonitor.js","sourceRoot":"","sources":["cloudwatchinternetmonitor.ts"],"names":[],"mappings":"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","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement, Operator } from '../../shared';\n\n/**\n * Statement provider for service [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.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 Internetmonitor extends PolicyStatement {\n  public servicePrefix = 'internetmonitor';\n\n  /**\n   * Statement provider for service [internetmonitor](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazoncloudwatchinternetmonitor.html).\n   *\n   * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement\n   */\n  constructor(sid?: string) {\n    super(sid);\n  }\n\n  /**\n   * Grants permission to create a monitor\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_CreateMonitor.html\n   */\n  public toCreateMonitor() {\n    return this.to('CreateMonitor');\n  }\n\n  /**\n   * Grants permission to delete a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_DeleteMonitor.html\n   */\n  public toDeleteMonitor() {\n    return this.to('DeleteMonitor');\n  }\n\n  /**\n   * Grants permission to get information about a health event for a specified monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetHealthEvent.html\n   */\n  public toGetHealthEvent() {\n    return this.to('GetHealthEvent');\n  }\n\n  /**\n   * Grants permission to get information about a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetMonitor.html\n   */\n  public toGetMonitor() {\n    return this.to('GetMonitor');\n  }\n\n  /**\n   * Grants permission to get results for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryResults.html\n   */\n  public toGetQueryResults() {\n    return this.to('GetQueryResults');\n  }\n\n  /**\n   * Grants permission to get status for a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_GetQueryStatus.html\n   */\n  public toGetQueryStatus() {\n    return this.to('GetQueryStatus');\n  }\n\n  /**\n   * Grants permission to share Internet Monitor resources with a monitoring account\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-Unified-Cross-Account-Setup.html#CloudWatch-Unified-Cross-Account-Setup-permissions\n   */\n  public toLink() {\n    return this.to('Link');\n  }\n\n  /**\n   * Grants permission to list all health events for a monitor\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListHealthEvents.html\n   */\n  public toListHealthEvents() {\n    return this.to('ListHealthEvents');\n  }\n\n  /**\n   * Grants permission to list all monitors in an account and their statuses\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListMonitors.html\n   */\n  public toListMonitors() {\n    return this.to('ListMonitors');\n  }\n\n  /**\n   * Grants permission to list the tags for a resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to start a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StartQuery.html\n   */\n  public toStartQuery() {\n    return this.to('StartQuery');\n  }\n\n  /**\n   * Grants permission to stop a data query for a monitor\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_StopQuery.html\n   */\n  public toStopQuery() {\n    return this.to('StopQuery');\n  }\n\n  /**\n   * Grants permission to add tags to a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove tags from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update a monitor\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/internet-monitor/latest/api/API_UpdateMonitor.html\n   */\n  public toUpdateMonitor() {\n    return this.to('UpdateMonitor');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateMonitor',\n      'DeleteMonitor',\n      'Link',\n      'UpdateMonitor'\n    ],\n    Read: [\n      'GetHealthEvent',\n      'GetMonitor',\n      'GetQueryResults',\n      'GetQueryStatus',\n      'ListTagsForResource',\n      'StartQuery',\n      'StopQuery'\n    ],\n    List: [\n      'ListHealthEvents',\n      'ListMonitors'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type HealthEvent to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\n   * @param eventId - Identifier for the eventId.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\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 onHealthEvent(monitorName: string, eventId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }/health-event/${ eventId }`);\n  }\n\n  /**\n   * Adds a resource of type Monitor to the statement\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/CloudWatch-IM-components.html\n   *\n   * @param monitorName - Identifier for the monitorName.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.\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   * Possible conditions:\n   * - .ifAwsResourceTag()\n   */\n  public onMonitor(monitorName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:internetmonitor:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:monitor/${ monitorName }`);\n  }\n\n  /**\n   * Filters access by tag key-value pairs in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag\n   *\n   * Applies to actions:\n   * - .toCreateMonitor()\n   * - .toTagResource()\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 ifAwsRequestTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:RequestTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by tag key-value pairs attached to the resource\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag\n   *\n   * Applies to resource types:\n   * - Monitor\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 ifAwsResourceTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:ResourceTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by tag keys in the request\n   *\n   * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys\n   *\n   * Applies to actions:\n   * - .toCreateMonitor()\n   * - .toTagResource()\n   * - .toUntagResource()\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 ifAwsTagKeys(value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:TagKeys`, value, operator ?? 'StringLike');\n  }\n}\n"]}
@@ -49,6 +49,18 @@ export declare class Codeartifact extends PolicyStatement {
49
49
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_CreateDomain.html
50
50
  */
51
51
  toCreateDomain(): this;
52
+ /**
53
+ * Grants permission to create a package group
54
+ *
55
+ * Access Level: Write
56
+ *
57
+ * Possible conditions:
58
+ * - .ifAwsRequestTag()
59
+ * - .ifAwsTagKeys()
60
+ *
61
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_CreatePackageGroup.html
62
+ */
63
+ toCreatePackageGroup(): this;
52
64
  /**
53
65
  * Grants permission to create a new repository
54
66
  *
@@ -85,6 +97,14 @@ export declare class Codeartifact extends PolicyStatement {
85
97
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_DeletePackage.html
86
98
  */
87
99
  toDeletePackage(): this;
100
+ /**
101
+ * Grants permission to delete a package group
102
+ *
103
+ * Access Level: Write
104
+ *
105
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_DeletePackageGroup.html
106
+ */
107
+ toDeletePackageGroup(): this;
88
108
  /**
89
109
  * Grants permission to delete package versions
90
110
  *
@@ -125,6 +145,14 @@ export declare class Codeartifact extends PolicyStatement {
125
145
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_DescribePackage.html
126
146
  */
127
147
  toDescribePackage(): this;
148
+ /**
149
+ * Grants permission to return detailed information about a package group
150
+ *
151
+ * Access Level: Read
152
+ *
153
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_DescribePackageGroup.html
154
+ */
155
+ toDescribePackageGroup(): this;
128
156
  /**
129
157
  * Grants permission to return information about a package version
130
158
  *
@@ -157,6 +185,14 @@ export declare class Codeartifact extends PolicyStatement {
157
185
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_DisposePackageVersions.html
158
186
  */
159
187
  toDisposePackageVersions(): this;
188
+ /**
189
+ * Grants permission to return a package's associated package group
190
+ *
191
+ * Access Level: Read
192
+ *
193
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_GetAssociatedPackageGroup.html
194
+ */
195
+ toGetAssociatedPackageGroup(): this;
160
196
  /**
161
197
  * Grants permission to generate a temporary authentication token for accessing repositories in a domain
162
198
  *
@@ -205,6 +241,22 @@ export declare class Codeartifact extends PolicyStatement {
205
241
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_GetRepositoryPermissionsPolicy.html
206
242
  */
207
243
  toGetRepositoryPermissionsPolicy(): this;
244
+ /**
245
+ * Grants permission to list the allowed repositories for a package group
246
+ *
247
+ * Access Level: List
248
+ *
249
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_ListRepositoriesInDomain.html
250
+ */
251
+ toListAllowedRepositoriesForGroup(): this;
252
+ /**
253
+ * Grants permission to list the packages associated to a package group
254
+ *
255
+ * Access Level: List
256
+ *
257
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_ListAssociatedPackages.html
258
+ */
259
+ toListAssociatedPackages(): this;
208
260
  /**
209
261
  * Grants permission to list the domains in the current user's AWS account
210
262
  *
@@ -213,6 +265,14 @@ export declare class Codeartifact extends PolicyStatement {
213
265
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_ListDomains.html
214
266
  */
215
267
  toListDomains(): this;
268
+ /**
269
+ * Grants permission to list the package groups in a domain
270
+ *
271
+ * Access Level: List
272
+ *
273
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_ListPackageGroups.html
274
+ */
275
+ toListPackageGroups(): this;
216
276
  /**
217
277
  * Grants permission to list a package version's assets
218
278
  *
@@ -261,6 +321,14 @@ export declare class Codeartifact extends PolicyStatement {
261
321
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_ListRepositoriesInDomain.html
262
322
  */
263
323
  toListRepositoriesInDomain(): this;
324
+ /**
325
+ * Grants permission to list the sub package groups for a parent package group
326
+ *
327
+ * Access Level: List
328
+ *
329
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_ListSubPackageGroups.html
330
+ */
331
+ toListSubPackageGroups(): this;
264
332
  /**
265
333
  * Grants permission to list tags for a CodeArtifact resource
266
334
  *
@@ -340,6 +408,22 @@ export declare class Codeartifact extends PolicyStatement {
340
408
  * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_UntagResource.html
341
409
  */
342
410
  toUntagResource(): this;
411
+ /**
412
+ * Grants permission to modify the properties of a package group
413
+ *
414
+ * Access Level: Write
415
+ *
416
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_UpdatePackageGroup.html
417
+ */
418
+ toUpdatePackageGroup(): this;
419
+ /**
420
+ * Grants permission to modify the package origin configuration of a package group
421
+ *
422
+ * Access Level: Write
423
+ *
424
+ * https://docs.aws.amazon.com/codeartifact/latest/APIReference/API_UpdatePackageGroupOriginConfiguration.html
425
+ */
426
+ toUpdatePackageGroupOriginConfiguration(): this;
343
427
  /**
344
428
  * Grants permission to modify the status of one or more versions of a package
345
429
  *
@@ -360,7 +444,7 @@ export declare class Codeartifact extends PolicyStatement {
360
444
  /**
361
445
  * Adds a resource of type domain to the statement
362
446
  *
363
- * https://docs.aws.amazon.com/codeartifact/latest/ug/auth-and-access-control-iam-access-control-identity-based.html#arn-formats
447
+ * https://docs.aws.amazon.com/codeartifact/latest/ug/domains.html
364
448
  *
365
449
  * @param domainName - Identifier for the domainName.
366
450
  * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
@@ -374,7 +458,7 @@ export declare class Codeartifact extends PolicyStatement {
374
458
  /**
375
459
  * Adds a resource of type repository to the statement
376
460
  *
377
- * https://docs.aws.amazon.com/codeartifact/latest/ug/repo-policies.html
461
+ * https://docs.aws.amazon.com/codeartifact/latest/ug/repos.html
378
462
  *
379
463
  * @param domainName - Identifier for the domainName.
380
464
  * @param repositoryName - Identifier for the repositoryName.
@@ -386,10 +470,25 @@ export declare class Codeartifact extends PolicyStatement {
386
470
  * - .ifAwsResourceTag()
387
471
  */
388
472
  onRepository(domainName: string, repositoryName: string, account?: string, region?: string, partition?: string): this;
473
+ /**
474
+ * Adds a resource of type package-group to the statement
475
+ *
476
+ * https://docs.aws.amazon.com/codeartifact/latest/ug/package-groups.html
477
+ *
478
+ * @param domainName - Identifier for the domainName.
479
+ * @param encodedPackageGroupPattern - Identifier for the encodedPackageGroupPattern.
480
+ * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.
481
+ * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region.
482
+ * @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.
483
+ *
484
+ * Possible conditions:
485
+ * - .ifAwsResourceTag()
486
+ */
487
+ onPackageGroup(domainName: string, encodedPackageGroupPattern: string, account?: string, region?: string, partition?: string): this;
389
488
  /**
390
489
  * Adds a resource of type package to the statement
391
490
  *
392
- * https://docs.aws.amazon.com/codeartifact/latest/ug/repo-policies.html
491
+ * https://docs.aws.amazon.com/codeartifact/latest/ug/packages.html
393
492
  *
394
493
  * @param domainName - Identifier for the domainName.
395
494
  * @param repositoryName - Identifier for the repositoryName.
@@ -408,6 +507,7 @@ export declare class Codeartifact extends PolicyStatement {
408
507
  *
409
508
  * Applies to actions:
410
509
  * - .toCreateDomain()
510
+ * - .toCreatePackageGroup()
411
511
  * - .toCreateRepository()
412
512
  * - .toTagResource()
413
513
  *
@@ -424,6 +524,7 @@ export declare class Codeartifact extends PolicyStatement {
424
524
  * Applies to resource types:
425
525
  * - domain
426
526
  * - repository
527
+ * - package-group
427
528
  *
428
529
  * @param tagKey The tag key to check
429
530
  * @param value The value(s) to check
@@ -437,6 +538,7 @@ export declare class Codeartifact extends PolicyStatement {
437
538
  *
438
539
  * Applies to actions:
439
540
  * - .toCreateDomain()
541
+ * - .toCreatePackageGroup()
440
542
  * - .toCreateRepository()
441
543
  * - .toTagResource()
442
544
  * - .toUntagResource()