cdk-iam-floyd 0.629.0 → 0.630.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
|
@@ -92,6 +92,14 @@ export declare class Appmesh extends PolicyStatement {
|
|
|
92
92
|
* https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteMesh.html
|
|
93
93
|
*/
|
|
94
94
|
toDeleteMesh(): this;
|
|
95
|
+
/**
|
|
96
|
+
* Grants permission to delete the RAM access control policy for a mesh
|
|
97
|
+
*
|
|
98
|
+
* Access Level: Write
|
|
99
|
+
*
|
|
100
|
+
* https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html
|
|
101
|
+
*/
|
|
102
|
+
toDeleteMeshPolicy(): this;
|
|
95
103
|
/**
|
|
96
104
|
* Grants permission to delete an existing route
|
|
97
105
|
*
|
|
@@ -188,6 +196,14 @@ export declare class Appmesh extends PolicyStatement {
|
|
|
188
196
|
* https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualService.html
|
|
189
197
|
*/
|
|
190
198
|
toDescribeVirtualService(): this;
|
|
199
|
+
/**
|
|
200
|
+
* Grants permission to read the RAM access control policy for a mesh
|
|
201
|
+
*
|
|
202
|
+
* Access Level: Read
|
|
203
|
+
*
|
|
204
|
+
* https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html
|
|
205
|
+
*/
|
|
206
|
+
toGetMeshPolicy(): this;
|
|
191
207
|
/**
|
|
192
208
|
* Grants permission to list existing gateway routes in a service mesh
|
|
193
209
|
*
|
|
@@ -252,6 +268,14 @@ export declare class Appmesh extends PolicyStatement {
|
|
|
252
268
|
* https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualServices.html
|
|
253
269
|
*/
|
|
254
270
|
toListVirtualServices(): this;
|
|
271
|
+
/**
|
|
272
|
+
* Grants permission to define the RAM access control policy for a mesh
|
|
273
|
+
*
|
|
274
|
+
* Access Level: Write
|
|
275
|
+
*
|
|
276
|
+
* https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html
|
|
277
|
+
*/
|
|
278
|
+
toPutMeshPolicy(): this;
|
|
255
279
|
/**
|
|
256
280
|
* Grants permission to receive streamed resources for an App Mesh endpoint (VirtualNode/VirtualGateway)
|
|
257
281
|
*
|
|
@@ -110,6 +110,16 @@ class Appmesh extends shared_1.PolicyStatement {
|
|
|
110
110
|
toDeleteMesh() {
|
|
111
111
|
return this.to('DeleteMesh');
|
|
112
112
|
}
|
|
113
|
+
/**
|
|
114
|
+
* Grants permission to delete the RAM access control policy for a mesh
|
|
115
|
+
*
|
|
116
|
+
* Access Level: Write
|
|
117
|
+
*
|
|
118
|
+
* https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html
|
|
119
|
+
*/
|
|
120
|
+
toDeleteMeshPolicy() {
|
|
121
|
+
return this.to('DeleteMeshPolicy');
|
|
122
|
+
}
|
|
113
123
|
/**
|
|
114
124
|
* Grants permission to delete an existing route
|
|
115
125
|
*
|
|
@@ -230,6 +240,16 @@ class Appmesh extends shared_1.PolicyStatement {
|
|
|
230
240
|
toDescribeVirtualService() {
|
|
231
241
|
return this.to('DescribeVirtualService');
|
|
232
242
|
}
|
|
243
|
+
/**
|
|
244
|
+
* Grants permission to read the RAM access control policy for a mesh
|
|
245
|
+
*
|
|
246
|
+
* Access Level: Read
|
|
247
|
+
*
|
|
248
|
+
* https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html
|
|
249
|
+
*/
|
|
250
|
+
toGetMeshPolicy() {
|
|
251
|
+
return this.to('GetMeshPolicy');
|
|
252
|
+
}
|
|
233
253
|
/**
|
|
234
254
|
* Grants permission to list existing gateway routes in a service mesh
|
|
235
255
|
*
|
|
@@ -310,6 +330,16 @@ class Appmesh extends shared_1.PolicyStatement {
|
|
|
310
330
|
toListVirtualServices() {
|
|
311
331
|
return this.to('ListVirtualServices');
|
|
312
332
|
}
|
|
333
|
+
/**
|
|
334
|
+
* Grants permission to define the RAM access control policy for a mesh
|
|
335
|
+
*
|
|
336
|
+
* Access Level: Write
|
|
337
|
+
*
|
|
338
|
+
* https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html
|
|
339
|
+
*/
|
|
340
|
+
toPutMeshPolicy() {
|
|
341
|
+
return this.to('PutMeshPolicy');
|
|
342
|
+
}
|
|
313
343
|
/**
|
|
314
344
|
* Grants permission to receive streamed resources for an App Mesh endpoint (VirtualNode/VirtualGateway)
|
|
315
345
|
*
|
|
@@ -620,11 +650,13 @@ class Appmesh extends shared_1.PolicyStatement {
|
|
|
620
650
|
'CreateVirtualService',
|
|
621
651
|
'DeleteGatewayRoute',
|
|
622
652
|
'DeleteMesh',
|
|
653
|
+
'DeleteMeshPolicy',
|
|
623
654
|
'DeleteRoute',
|
|
624
655
|
'DeleteVirtualGateway',
|
|
625
656
|
'DeleteVirtualNode',
|
|
626
657
|
'DeleteVirtualRouter',
|
|
627
658
|
'DeleteVirtualService',
|
|
659
|
+
'PutMeshPolicy',
|
|
628
660
|
'UpdateGatewayRoute',
|
|
629
661
|
'UpdateMesh',
|
|
630
662
|
'UpdateRoute',
|
|
@@ -641,6 +673,7 @@ class Appmesh extends shared_1.PolicyStatement {
|
|
|
641
673
|
'DescribeVirtualNode',
|
|
642
674
|
'DescribeVirtualRouter',
|
|
643
675
|
'DescribeVirtualService',
|
|
676
|
+
'GetMeshPolicy',
|
|
644
677
|
'StreamAggregatedResources'
|
|
645
678
|
],
|
|
646
679
|
List: [
|
|
@@ -661,4 +694,4 @@ class Appmesh extends shared_1.PolicyStatement {
|
|
|
661
694
|
}
|
|
662
695
|
}
|
|
663
696
|
exports.Appmesh = Appmesh;
|
|
664
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"appmesh.js","sourceRoot":"","sources":["appmesh.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 [appmesh](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsappmesh.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 Appmesh extends PolicyStatement {\n  public servicePrefix = 'appmesh';\n\n  /**\n   * Grants permission to create a gateway route that is associated with a virtual gateway\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateGatewayRoute.html\n   */\n  public toCreateGatewayRoute() {\n    return this.to('CreateGatewayRoute');\n  }\n\n  /**\n   * Grants permission to create a service mesh\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateMesh.html\n   */\n  public toCreateMesh() {\n    return this.to('CreateMesh');\n  }\n\n  /**\n   * Grants permission to create a route that is associated with a virtual router\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateRoute.html\n   */\n  public toCreateRoute() {\n    return this.to('CreateRoute');\n  }\n\n  /**\n   * Grants permission to create a virtual gateway within a service mesh\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualGateway.html\n   */\n  public toCreateVirtualGateway() {\n    return this.to('CreateVirtualGateway');\n  }\n\n  /**\n   * Grants permission to create a virtual node within a service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualNode.html\n   */\n  public toCreateVirtualNode() {\n    return this.to('CreateVirtualNode');\n  }\n\n  /**\n   * Grants permission to create a virtual router within a service mesh\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualRouter.html\n   */\n  public toCreateVirtualRouter() {\n    return this.to('CreateVirtualRouter');\n  }\n\n  /**\n   * Grants permission to create a virtual service within a service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualService.html\n   */\n  public toCreateVirtualService() {\n    return this.to('CreateVirtualService');\n  }\n\n  /**\n   * Grants permission to delete an existing gateway route\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteGatewayRoute.html\n   */\n  public toDeleteGatewayRoute() {\n    return this.to('DeleteGatewayRoute');\n  }\n\n  /**\n   * Grants permission to delete an existing service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteMesh.html\n   */\n  public toDeleteMesh() {\n    return this.to('DeleteMesh');\n  }\n\n  /**\n   * Grants permission to delete an existing route\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteRoute.html\n   */\n  public toDeleteRoute() {\n    return this.to('DeleteRoute');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual gateway\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualGateway.html\n   */\n  public toDeleteVirtualGateway() {\n    return this.to('DeleteVirtualGateway');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual node\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualNode.html\n   */\n  public toDeleteVirtualNode() {\n    return this.to('DeleteVirtualNode');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual router\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualRouter.html\n   */\n  public toDeleteVirtualRouter() {\n    return this.to('DeleteVirtualRouter');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual service\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualService.html\n   */\n  public toDeleteVirtualService() {\n    return this.to('DeleteVirtualService');\n  }\n\n  /**\n   * Grants permission to describe an existing gateway route\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeGatewayRoute.html\n   */\n  public toDescribeGatewayRoute() {\n    return this.to('DescribeGatewayRoute');\n  }\n\n  /**\n   * Grants permission to describe an existing service mesh\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeMesh.html\n   */\n  public toDescribeMesh() {\n    return this.to('DescribeMesh');\n  }\n\n  /**\n   * Grants permission to describe an existing route\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeRoute.html\n   */\n  public toDescribeRoute() {\n    return this.to('DescribeRoute');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual gateway\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualGateway.html\n   */\n  public toDescribeVirtualGateway() {\n    return this.to('DescribeVirtualGateway');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual node\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualNode.html\n   */\n  public toDescribeVirtualNode() {\n    return this.to('DescribeVirtualNode');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual router\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualRouter.html\n   */\n  public toDescribeVirtualRouter() {\n    return this.to('DescribeVirtualRouter');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual service\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualService.html\n   */\n  public toDescribeVirtualService() {\n    return this.to('DescribeVirtualService');\n  }\n\n  /**\n   * Grants permission to list existing gateway routes in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListGatewayRoutes.html\n   */\n  public toListGatewayRoutes() {\n    return this.to('ListGatewayRoutes');\n  }\n\n  /**\n   * Grants permission to list existing service meshes\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListMeshes.html\n   */\n  public toListMeshes() {\n    return this.to('ListMeshes');\n  }\n\n  /**\n   * Grants permission to list existing routes in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListRoutes.html\n   */\n  public toListRoutes() {\n    return this.to('ListRoutes');\n  }\n\n  /**\n   * Grants permission to list the tags for an App Mesh resource\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to list existing virtual gateways in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualGateways.html\n   */\n  public toListVirtualGateways() {\n    return this.to('ListVirtualGateways');\n  }\n\n  /**\n   * Grants permission to list existing virtual nodes\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualNodes.html\n   */\n  public toListVirtualNodes() {\n    return this.to('ListVirtualNodes');\n  }\n\n  /**\n   * Grants permission to list existing virtual routers in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualRouters.html\n   */\n  public toListVirtualRouters() {\n    return this.to('ListVirtualRouters');\n  }\n\n  /**\n   * Grants permission to list existing virtual services in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualServices.html\n   */\n  public toListVirtualServices() {\n    return this.to('ListVirtualServices');\n  }\n\n  /**\n   * Grants permission to receive streamed resources for an App Mesh endpoint (VirtualNode/VirtualGateway)\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/envoy.html\n   */\n  public toStreamAggregatedResources() {\n    return this.to('StreamAggregatedResources');\n  }\n\n  /**\n   * Grants permission to tag a resource with a specified resourceArn\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to delete a tag from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update an existing gateway route for a specified service mesh and virtual gateway\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateGatewayRoute.html\n   */\n  public toUpdateGatewayRoute() {\n    return this.to('UpdateGatewayRoute');\n  }\n\n  /**\n   * Grants permission to update an existing service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateMesh.html\n   */\n  public toUpdateMesh() {\n    return this.to('UpdateMesh');\n  }\n\n  /**\n   * Grants permission to update an existing route for a specified service mesh and virtual router\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateRoute.html\n   */\n  public toUpdateRoute() {\n    return this.to('UpdateRoute');\n  }\n\n  /**\n   * Grants permission to update an existing virtual gateway in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualGateway.html\n   */\n  public toUpdateVirtualGateway() {\n    return this.to('UpdateVirtualGateway');\n  }\n\n  /**\n   * Grants permission to update an existing virtual node in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualNode.html\n   */\n  public toUpdateVirtualNode() {\n    return this.to('UpdateVirtualNode');\n  }\n\n  /**\n   * Grants permission to update an existing virtual router in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualRouter.html\n   */\n  public toUpdateVirtualRouter() {\n    return this.to('UpdateVirtualRouter');\n  }\n\n  /**\n   * Grants permission to update an existing virtual service in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualService.html\n   */\n  public toUpdateVirtualService() {\n    return this.to('UpdateVirtualService');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateGatewayRoute',\n      'CreateMesh',\n      'CreateRoute',\n      'CreateVirtualGateway',\n      'CreateVirtualNode',\n      'CreateVirtualRouter',\n      'CreateVirtualService',\n      'DeleteGatewayRoute',\n      'DeleteMesh',\n      'DeleteRoute',\n      'DeleteVirtualGateway',\n      'DeleteVirtualNode',\n      'DeleteVirtualRouter',\n      'DeleteVirtualService',\n      'UpdateGatewayRoute',\n      'UpdateMesh',\n      'UpdateRoute',\n      'UpdateVirtualGateway',\n      'UpdateVirtualNode',\n      'UpdateVirtualRouter',\n      'UpdateVirtualService'\n    ],\n    Read: [\n      'DescribeGatewayRoute',\n      'DescribeMesh',\n      'DescribeRoute',\n      'DescribeVirtualGateway',\n      'DescribeVirtualNode',\n      'DescribeVirtualRouter',\n      'DescribeVirtualService',\n      'StreamAggregatedResources'\n    ],\n    List: [\n      'ListGatewayRoutes',\n      'ListMeshes',\n      'ListRoutes',\n      'ListTagsForResource',\n      'ListVirtualGateways',\n      'ListVirtualNodes',\n      'ListVirtualRouters',\n      'ListVirtualServices'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type mesh to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/meshes.html\n   *\n   * @param meshName - Identifier for the meshName.\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 onMesh(meshName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualService to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_services.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualServiceName - Identifier for the virtualServiceName.\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 onVirtualService(meshName: string, virtualServiceName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualService/${ virtualServiceName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualNode to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_nodes.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualNodeName - Identifier for the virtualNodeName.\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 onVirtualNode(meshName: string, virtualNodeName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualNode/${ virtualNodeName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualRouter to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_routers.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualRouterName - Identifier for the virtualRouterName.\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 onVirtualRouter(meshName: string, virtualRouterName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualRouter/${ virtualRouterName }`);\n  }\n\n  /**\n   * Adds a resource of type route to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/routes.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualRouterName - Identifier for the virtualRouterName.\n   * @param routeName - Identifier for the routeName.\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 onRoute(meshName: string, virtualRouterName: string, routeName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualRouter/${ virtualRouterName }/route/${ routeName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualGateway to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_gateways.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualGatewayName - Identifier for the virtualGatewayName.\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 onVirtualGateway(meshName: string, virtualGatewayName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualGateway/${ virtualGatewayName }`);\n  }\n\n  /**\n   * Adds a resource of type gatewayRoute to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_gateways.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualGatewayName - Identifier for the virtualGatewayName.\n   * @param gatewayRouteName - Identifier for the gatewayRouteName.\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 onGatewayRoute(meshName: string, virtualGatewayName: string, gatewayRouteName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualGateway/${ virtualGatewayName }/gatewayRoute/${ gatewayRouteName }`);\n  }\n\n  /**\n   * Filters actions by the presence of 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   * - .toCreateGatewayRoute()\n   * - .toCreateMesh()\n   * - .toCreateRoute()\n   * - .toCreateVirtualGateway()\n   * - .toCreateVirtualNode()\n   * - .toCreateVirtualRouter()\n   * - .toCreateVirtualService()\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 actions by the 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   * - mesh\n   * - virtualService\n   * - virtualNode\n   * - virtualRouter\n   * - route\n   * - virtualGateway\n   * - gatewayRoute\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 actions by the presence of 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   * - .toCreateGatewayRoute()\n   * - .toCreateMesh()\n   * - .toCreateRoute()\n   * - .toCreateVirtualGateway()\n   * - .toCreateVirtualNode()\n   * - .toCreateVirtualRouter()\n   * - .toCreateVirtualService()\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  /**\n   * Statement provider for service [appmesh](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsappmesh.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
|
|
697
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"appmesh.js","sourceRoot":"","sources":["appmesh.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 [appmesh](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsappmesh.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 Appmesh extends PolicyStatement {\n  public servicePrefix = 'appmesh';\n\n  /**\n   * Grants permission to create a gateway route that is associated with a virtual gateway\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateGatewayRoute.html\n   */\n  public toCreateGatewayRoute() {\n    return this.to('CreateGatewayRoute');\n  }\n\n  /**\n   * Grants permission to create a service mesh\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateMesh.html\n   */\n  public toCreateMesh() {\n    return this.to('CreateMesh');\n  }\n\n  /**\n   * Grants permission to create a route that is associated with a virtual router\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateRoute.html\n   */\n  public toCreateRoute() {\n    return this.to('CreateRoute');\n  }\n\n  /**\n   * Grants permission to create a virtual gateway within a service mesh\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualGateway.html\n   */\n  public toCreateVirtualGateway() {\n    return this.to('CreateVirtualGateway');\n  }\n\n  /**\n   * Grants permission to create a virtual node within a service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualNode.html\n   */\n  public toCreateVirtualNode() {\n    return this.to('CreateVirtualNode');\n  }\n\n  /**\n   * Grants permission to create a virtual router within a service mesh\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualRouter.html\n   */\n  public toCreateVirtualRouter() {\n    return this.to('CreateVirtualRouter');\n  }\n\n  /**\n   * Grants permission to create a virtual service within a service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_CreateVirtualService.html\n   */\n  public toCreateVirtualService() {\n    return this.to('CreateVirtualService');\n  }\n\n  /**\n   * Grants permission to delete an existing gateway route\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteGatewayRoute.html\n   */\n  public toDeleteGatewayRoute() {\n    return this.to('DeleteGatewayRoute');\n  }\n\n  /**\n   * Grants permission to delete an existing service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteMesh.html\n   */\n  public toDeleteMesh() {\n    return this.to('DeleteMesh');\n  }\n\n  /**\n   * Grants permission to delete the RAM access control policy for a mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html\n   */\n  public toDeleteMeshPolicy() {\n    return this.to('DeleteMeshPolicy');\n  }\n\n  /**\n   * Grants permission to delete an existing route\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteRoute.html\n   */\n  public toDeleteRoute() {\n    return this.to('DeleteRoute');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual gateway\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualGateway.html\n   */\n  public toDeleteVirtualGateway() {\n    return this.to('DeleteVirtualGateway');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual node\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualNode.html\n   */\n  public toDeleteVirtualNode() {\n    return this.to('DeleteVirtualNode');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual router\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualRouter.html\n   */\n  public toDeleteVirtualRouter() {\n    return this.to('DeleteVirtualRouter');\n  }\n\n  /**\n   * Grants permission to delete an existing virtual service\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DeleteVirtualService.html\n   */\n  public toDeleteVirtualService() {\n    return this.to('DeleteVirtualService');\n  }\n\n  /**\n   * Grants permission to describe an existing gateway route\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeGatewayRoute.html\n   */\n  public toDescribeGatewayRoute() {\n    return this.to('DescribeGatewayRoute');\n  }\n\n  /**\n   * Grants permission to describe an existing service mesh\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeMesh.html\n   */\n  public toDescribeMesh() {\n    return this.to('DescribeMesh');\n  }\n\n  /**\n   * Grants permission to describe an existing route\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeRoute.html\n   */\n  public toDescribeRoute() {\n    return this.to('DescribeRoute');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual gateway\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualGateway.html\n   */\n  public toDescribeVirtualGateway() {\n    return this.to('DescribeVirtualGateway');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual node\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualNode.html\n   */\n  public toDescribeVirtualNode() {\n    return this.to('DescribeVirtualNode');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual router\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualRouter.html\n   */\n  public toDescribeVirtualRouter() {\n    return this.to('DescribeVirtualRouter');\n  }\n\n  /**\n   * Grants permission to describe an existing virtual service\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_DescribeVirtualService.html\n   */\n  public toDescribeVirtualService() {\n    return this.to('DescribeVirtualService');\n  }\n\n  /**\n   * Grants permission to read the RAM access control policy for a mesh\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html\n   */\n  public toGetMeshPolicy() {\n    return this.to('GetMeshPolicy');\n  }\n\n  /**\n   * Grants permission to list existing gateway routes in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListGatewayRoutes.html\n   */\n  public toListGatewayRoutes() {\n    return this.to('ListGatewayRoutes');\n  }\n\n  /**\n   * Grants permission to list existing service meshes\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListMeshes.html\n   */\n  public toListMeshes() {\n    return this.to('ListMeshes');\n  }\n\n  /**\n   * Grants permission to list existing routes in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListRoutes.html\n   */\n  public toListRoutes() {\n    return this.to('ListRoutes');\n  }\n\n  /**\n   * Grants permission to list the tags for an App Mesh resource\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to list existing virtual gateways in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualGateways.html\n   */\n  public toListVirtualGateways() {\n    return this.to('ListVirtualGateways');\n  }\n\n  /**\n   * Grants permission to list existing virtual nodes\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualNodes.html\n   */\n  public toListVirtualNodes() {\n    return this.to('ListVirtualNodes');\n  }\n\n  /**\n   * Grants permission to list existing virtual routers in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualRouters.html\n   */\n  public toListVirtualRouters() {\n    return this.to('ListVirtualRouters');\n  }\n\n  /**\n   * Grants permission to list existing virtual services in a service mesh\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_ListVirtualServices.html\n   */\n  public toListVirtualServices() {\n    return this.to('ListVirtualServices');\n  }\n\n  /**\n   * Grants permission to define the RAM access control policy for a mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html\n   */\n  public toPutMeshPolicy() {\n    return this.to('PutMeshPolicy');\n  }\n\n  /**\n   * Grants permission to receive streamed resources for an App Mesh endpoint (VirtualNode/VirtualGateway)\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/envoy.html\n   */\n  public toStreamAggregatedResources() {\n    return this.to('StreamAggregatedResources');\n  }\n\n  /**\n   * Grants permission to tag a resource with a specified resourceArn\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to delete a tag from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update an existing gateway route for a specified service mesh and virtual gateway\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateGatewayRoute.html\n   */\n  public toUpdateGatewayRoute() {\n    return this.to('UpdateGatewayRoute');\n  }\n\n  /**\n   * Grants permission to update an existing service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateMesh.html\n   */\n  public toUpdateMesh() {\n    return this.to('UpdateMesh');\n  }\n\n  /**\n   * Grants permission to update an existing route for a specified service mesh and virtual router\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateRoute.html\n   */\n  public toUpdateRoute() {\n    return this.to('UpdateRoute');\n  }\n\n  /**\n   * Grants permission to update an existing virtual gateway in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualGateway.html\n   */\n  public toUpdateVirtualGateway() {\n    return this.to('UpdateVirtualGateway');\n  }\n\n  /**\n   * Grants permission to update an existing virtual node in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualNode.html\n   */\n  public toUpdateVirtualNode() {\n    return this.to('UpdateVirtualNode');\n  }\n\n  /**\n   * Grants permission to update an existing virtual router in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualRouter.html\n   */\n  public toUpdateVirtualRouter() {\n    return this.to('UpdateVirtualRouter');\n  }\n\n  /**\n   * Grants permission to update an existing virtual service in a specified service mesh\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/APIReference/API_UpdateVirtualService.html\n   */\n  public toUpdateVirtualService() {\n    return this.to('UpdateVirtualService');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CreateGatewayRoute',\n      'CreateMesh',\n      'CreateRoute',\n      'CreateVirtualGateway',\n      'CreateVirtualNode',\n      'CreateVirtualRouter',\n      'CreateVirtualService',\n      'DeleteGatewayRoute',\n      'DeleteMesh',\n      'DeleteMeshPolicy',\n      'DeleteRoute',\n      'DeleteVirtualGateway',\n      'DeleteVirtualNode',\n      'DeleteVirtualRouter',\n      'DeleteVirtualService',\n      'PutMeshPolicy',\n      'UpdateGatewayRoute',\n      'UpdateMesh',\n      'UpdateRoute',\n      'UpdateVirtualGateway',\n      'UpdateVirtualNode',\n      'UpdateVirtualRouter',\n      'UpdateVirtualService'\n    ],\n    Read: [\n      'DescribeGatewayRoute',\n      'DescribeMesh',\n      'DescribeRoute',\n      'DescribeVirtualGateway',\n      'DescribeVirtualNode',\n      'DescribeVirtualRouter',\n      'DescribeVirtualService',\n      'GetMeshPolicy',\n      'StreamAggregatedResources'\n    ],\n    List: [\n      'ListGatewayRoutes',\n      'ListMeshes',\n      'ListRoutes',\n      'ListTagsForResource',\n      'ListVirtualGateways',\n      'ListVirtualNodes',\n      'ListVirtualRouters',\n      'ListVirtualServices'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type mesh to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/meshes.html\n   *\n   * @param meshName - Identifier for the meshName.\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 onMesh(meshName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualService to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_services.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualServiceName - Identifier for the virtualServiceName.\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 onVirtualService(meshName: string, virtualServiceName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualService/${ virtualServiceName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualNode to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_nodes.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualNodeName - Identifier for the virtualNodeName.\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 onVirtualNode(meshName: string, virtualNodeName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualNode/${ virtualNodeName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualRouter to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_routers.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualRouterName - Identifier for the virtualRouterName.\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 onVirtualRouter(meshName: string, virtualRouterName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualRouter/${ virtualRouterName }`);\n  }\n\n  /**\n   * Adds a resource of type route to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/routes.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualRouterName - Identifier for the virtualRouterName.\n   * @param routeName - Identifier for the routeName.\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 onRoute(meshName: string, virtualRouterName: string, routeName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualRouter/${ virtualRouterName }/route/${ routeName }`);\n  }\n\n  /**\n   * Adds a resource of type virtualGateway to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_gateways.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualGatewayName - Identifier for the virtualGatewayName.\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 onVirtualGateway(meshName: string, virtualGatewayName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualGateway/${ virtualGatewayName }`);\n  }\n\n  /**\n   * Adds a resource of type gatewayRoute to the statement\n   *\n   * https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_gateways.html\n   *\n   * @param meshName - Identifier for the meshName.\n   * @param virtualGatewayName - Identifier for the virtualGatewayName.\n   * @param gatewayRouteName - Identifier for the gatewayRouteName.\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 onGatewayRoute(meshName: string, virtualGatewayName: string, gatewayRouteName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:appmesh:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:mesh/${ meshName }/virtualGateway/${ virtualGatewayName }/gatewayRoute/${ gatewayRouteName }`);\n  }\n\n  /**\n   * Filters actions by the presence of 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   * - .toCreateGatewayRoute()\n   * - .toCreateMesh()\n   * - .toCreateRoute()\n   * - .toCreateVirtualGateway()\n   * - .toCreateVirtualNode()\n   * - .toCreateVirtualRouter()\n   * - .toCreateVirtualService()\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 actions by the 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   * - mesh\n   * - virtualService\n   * - virtualNode\n   * - virtualRouter\n   * - route\n   * - virtualGateway\n   * - gatewayRoute\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 actions by the presence of 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   * - .toCreateGatewayRoute()\n   * - .toCreateMesh()\n   * - .toCreateRoute()\n   * - .toCreateVirtualGateway()\n   * - .toCreateVirtualNode()\n   * - .toCreateVirtualRouter()\n   * - .toCreateVirtualService()\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  /**\n   * Statement provider for service [appmesh](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsappmesh.html).\n   *\n   */\n  constructor(props?: iam.PolicyStatementProps) {\n    super(props);\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
},
|
|
8
8
|
"name": "cdk-iam-floyd",
|
|
9
9
|
"description": "AWS IAM policy statement generator with fluent interface for AWS CDK",
|
|
10
|
-
"version": "0.
|
|
10
|
+
"version": "0.630.0",
|
|
11
11
|
"license": "Apache-2.0",
|
|
12
12
|
"author": {
|
|
13
13
|
"name": "Daniel Schroeder",
|
|
@@ -50,8 +50,8 @@
|
|
|
50
50
|
"@types/node": "20.12.7",
|
|
51
51
|
"@types/request": "^2.48.12",
|
|
52
52
|
"@types/request-promise-native": "^1.0.21",
|
|
53
|
-
"@typescript-eslint/eslint-plugin": "7.7.
|
|
54
|
-
"@typescript-eslint/parser": "7.7.
|
|
53
|
+
"@typescript-eslint/eslint-plugin": "7.7.1",
|
|
54
|
+
"@typescript-eslint/parser": "7.7.1",
|
|
55
55
|
"aws-cdk-lib": "^2.0.0",
|
|
56
56
|
"cheerio": "^1.0.0-rc.12",
|
|
57
57
|
"colors": "1.4.0",
|