UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

498 lines 60.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Amplifybackend = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [amplifybackend](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsamplifyadmin.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class Amplifybackend extends shared_1.PolicyStatement { /** * Statement provider for service [amplifybackend](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsamplifyadmin.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ constructor(sid) { super(sid); this.servicePrefix = 'amplifybackend'; this.accessLevelList = { Write: [ 'CloneBackend', 'CreateBackend', 'CreateBackendAPI', 'CreateBackendAuth', 'CreateBackendConfig', 'CreateBackendStorage', 'CreateToken', 'DeleteBackend', 'DeleteBackendAPI', 'DeleteBackendAuth', 'DeleteBackendStorage', 'DeleteToken', 'GenerateBackendAPIModels', 'ImportBackendAuth', 'ImportBackendStorage', 'RemoveAllBackends', 'RemoveBackendConfig', 'UpdateBackendAPI', 'UpdateBackendAuth', 'UpdateBackendConfig', 'UpdateBackendJob', 'UpdateBackendStorage' ], Read: [ 'GetBackend', 'GetBackendAPI', 'GetBackendAPIModels', 'GetBackendAuth', 'GetBackendJob', 'GetBackendStorage', 'GetToken' ], List: [ 'ListBackendJobs', 'ListS3Buckets' ] }; } /** * Grants permission to clone an existing Amplify Admin backend environment into a new Amplify Admin backend enviroment * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-environments-backendenvironmentname-clone.html#CloneBackend */ toCloneBackend() { return this.to('CloneBackend'); } /** * Grants permission to create a new Amplify Admin backend environment by Amplify appId * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend.html#CreateBackend */ toCreateBackend() { return this.to('CreateBackend'); } /** * Grants permission to create an API for an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api.html#CreateBackendAPI */ toCreateBackendAPI() { return this.to('CreateBackendAPI'); } /** * Grants permission to create an auth resource for an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth.html#CreateBackendAuth */ toCreateBackendAuth() { return this.to('CreateBackendAuth'); } /** * Grants permission to create a new Amplify Admin backend config by Amplify appId * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-config.html#CreateBackendConfig */ toCreateBackendConfig() { return this.to('CreateBackendConfig'); } /** * Grants permission to create a backend storage resource * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#CreateBackendStorage */ toCreateBackendStorage() { return this.to('CreateBackendStorage'); } /** * Grants permission to create an Amplify Admin challenge token by appId * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-challenge.html#CreateToken */ toCreateToken() { return this.to('CreateToken'); } /** * Grants permission to delete an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-environments-backendenvironmentname-remove.html#DeleteBackend */ toDeleteBackend() { return this.to('DeleteBackend'); } /** * Grants permission to delete an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-remove.html#DeleteBackendAPI */ toDeleteBackendAPI() { return this.to('DeleteBackendAPI'); } /** * Grants permission to delete an auth resource of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname-remove.html#DeleteBackendAuth */ toDeleteBackendAuth() { return this.to('DeleteBackendAuth'); } /** * Grants permission to delete a backend storage resource * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#DeleteBackendStorage */ toDeleteBackendStorage() { return this.to('DeleteBackendStorage'); } /** * Grants permission to delete an Amplify Admin challenge token by appId * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-challenge-sessionid-remove.html#DeleteToken */ toDeleteToken() { return this.to('DeleteToken'); } /** * Grants permission to generate models for an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-generatemodels.html#GenerateBackendAPIModels */ toGenerateBackendAPIModels() { return this.to('GenerateBackendAPIModels'); } /** * Grants permission to retrieve an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Read * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-details.html#GetBackend */ toGetBackend() { return this.to('GetBackend'); } /** * Grants permission to retrieve an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Read * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-details.html#GetBackendAPI */ toGetBackendAPI() { return this.to('GetBackendAPI'); } /** * Grants permission to retrieve models for an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Read * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-getmodels.html#GetBackendAPIModels */ toGetBackendAPIModels() { return this.to('GetBackendAPIModels'); } /** * Grants permission to retrieve an auth resource of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Read * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname-details.html#GetBackendAuth */ toGetBackendAuth() { return this.to('GetBackendAuth'); } /** * Grants permission to retrieve a job of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Read * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-job-backendenvironmentname-jobid.html#GetBackendJob */ toGetBackendJob() { return this.to('GetBackendJob'); } /** * Grants permission to retrieve an existing backend storage resource * * Access Level: Read * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#GetBackendStorage */ toGetBackendStorage() { return this.to('GetBackendStorage'); } /** * Grants permission to retrieve an Amplify Admin challenge token by appId * * Access Level: Read * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-challenge-sessionid.html#GetToken */ toGetToken() { return this.to('GetToken'); } /** * Grants permission to import an existing auth resource of an Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname.html#ImportBackendAuth */ toImportBackendAuth() { return this.to('ImportBackendAuth'); } /** * Grants permission to import an existing backend storage resource * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#ImportBackendStorage */ toImportBackendStorage() { return this.to('ImportBackendStorage'); } /** * Grants permission to retrieve the jobs of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: List * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-job-backendenvironmentname.html#ListBackendJobs */ toListBackendJobs() { return this.to('ListBackendJobs'); } /** * Grants permission to retrieve s3 buckets * * Access Level: List * * Dependent actions: * - s3:ListAllMyBuckets * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#ListS3Buckets */ toListS3Buckets() { return this.to('ListS3Buckets'); } /** * Grants permission to delete all existing Amplify Admin backend environments by appId * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-remove.html#RemoveAllBackends */ toRemoveAllBackends() { return this.to('RemoveAllBackends'); } /** * Grants permission to delete an Amplify Admin backend config by Amplify appId * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-config-remove.html#RemoveBackendConfig */ toRemoveBackendConfig() { return this.to('RemoveBackendConfig'); } /** * Grants permission to update an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname.html#UpdateBackendAPI */ toUpdateBackendAPI() { return this.to('UpdateBackendAPI'); } /** * Grants permission to update an auth resource of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname.html#UpdateBackendAuth */ toUpdateBackendAuth() { return this.to('UpdateBackendAuth'); } /** * Grants permission to update an Amplify Admin backend config by Amplify appId * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-config-update.html#UpdateBackendConfig */ toUpdateBackendConfig() { return this.to('UpdateBackendConfig'); } /** * Grants permission to update a job of an existing Amplify Admin backend environment by appId and backendEnvironmentName * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-job-backendenvironmentname-jobid.html#UpdateBackendJob */ toUpdateBackendJob() { return this.to('UpdateBackendJob'); } /** * Grants permission to update a backend storage resource * * Access Level: Write * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#UpdateBackendStorage */ toUpdateBackendStorage() { return this.to('UpdateBackendStorage'); } /** * Adds a resource of type created-backend to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend.html * * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onCreatedBackend(resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${resourceName}`); } /** * Adds a resource of type backend to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend.html * * @param appId - Identifier for the appId. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onBackend(appId, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/*`); } /** * Adds a resource of type environment to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-details.html * * @param appId - Identifier for the appId. * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onEnvironment(appId, resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/environments/${resourceName}`); } /** * Adds a resource of type api to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api.html * * @param appId - Identifier for the appId. * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onApi(appId, resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/api/${resourceName}`); } /** * Adds a resource of type auth to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth.html * * @param appId - Identifier for the appId. * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onAuth(appId, resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/auth/${resourceName}`); } /** * Adds a resource of type job to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-job-backendenvironmentname.html * * @param appId - Identifier for the appId. * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onJob(appId, resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/job/${resourceName}`); } /** * Adds a resource of type config to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-config.html * * @param appId - Identifier for the appId. * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onConfig(appId, resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/config/${resourceName}`); } /** * Adds a resource of type token to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-token.html * * @param appId - Identifier for the appId. * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onToken(appId, resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/challenge/${resourceName}`); } /** * Adds a resource of type storage to the statement * * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html * * @param appId - Identifier for the appId. * @param resourceName - Identifier for the resourceName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @param region - Region of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's region. * @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. */ onStorage(appId, resourceName, account, region, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:amplifybackend:${region ?? this.defaultRegion}:${account ?? this.defaultAccount}:/backend/${appId}/storage/${resourceName}`); } } exports.Amplifybackend = Amplifybackend; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplifyadmin.js","sourceRoot":"","sources":["amplifyadmin.ts"],"names":[],"mappings":"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","sourcesContent":["import { AccessLevelList } from '../../shared/access-level';\nimport { PolicyStatement } from '../../shared';\n\n/**\n * Statement provider for service [amplifybackend](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsamplifyadmin.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 Amplifybackend extends PolicyStatement {\n  public servicePrefix = 'amplifybackend';\n\n  /**\n   * Statement provider for service [amplifybackend](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awsamplifyadmin.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 clone an existing Amplify Admin backend environment into a new Amplify Admin backend enviroment\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-environments-backendenvironmentname-clone.html#CloneBackend\n   */\n  public toCloneBackend() {\n    return this.to('CloneBackend');\n  }\n\n  /**\n   * Grants permission to create a new Amplify Admin backend environment by Amplify appId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend.html#CreateBackend\n   */\n  public toCreateBackend() {\n    return this.to('CreateBackend');\n  }\n\n  /**\n   * Grants permission to create an API for an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api.html#CreateBackendAPI\n   */\n  public toCreateBackendAPI() {\n    return this.to('CreateBackendAPI');\n  }\n\n  /**\n   * Grants permission to create an auth resource for an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth.html#CreateBackendAuth\n   */\n  public toCreateBackendAuth() {\n    return this.to('CreateBackendAuth');\n  }\n\n  /**\n   * Grants permission to create a new Amplify Admin backend config by Amplify appId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-config.html#CreateBackendConfig\n   */\n  public toCreateBackendConfig() {\n    return this.to('CreateBackendConfig');\n  }\n\n  /**\n   * Grants permission to create a backend storage resource\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#CreateBackendStorage\n   */\n  public toCreateBackendStorage() {\n    return this.to('CreateBackendStorage');\n  }\n\n  /**\n   * Grants permission to create an Amplify Admin challenge token by appId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-challenge.html#CreateToken\n   */\n  public toCreateToken() {\n    return this.to('CreateToken');\n  }\n\n  /**\n   * Grants permission to delete an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-environments-backendenvironmentname-remove.html#DeleteBackend\n   */\n  public toDeleteBackend() {\n    return this.to('DeleteBackend');\n  }\n\n  /**\n   * Grants permission to delete an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-remove.html#DeleteBackendAPI\n   */\n  public toDeleteBackendAPI() {\n    return this.to('DeleteBackendAPI');\n  }\n\n  /**\n   * Grants permission to delete an auth resource of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname-remove.html#DeleteBackendAuth\n   */\n  public toDeleteBackendAuth() {\n    return this.to('DeleteBackendAuth');\n  }\n\n  /**\n   * Grants permission to delete a backend storage resource\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#DeleteBackendStorage\n   */\n  public toDeleteBackendStorage() {\n    return this.to('DeleteBackendStorage');\n  }\n\n  /**\n   * Grants permission to delete an Amplify Admin challenge token by appId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-challenge-sessionid-remove.html#DeleteToken\n   */\n  public toDeleteToken() {\n    return this.to('DeleteToken');\n  }\n\n  /**\n   * Grants permission to generate models for an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-generatemodels.html#GenerateBackendAPIModels\n   */\n  public toGenerateBackendAPIModels() {\n    return this.to('GenerateBackendAPIModels');\n  }\n\n  /**\n   * Grants permission to retrieve an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-details.html#GetBackend\n   */\n  public toGetBackend() {\n    return this.to('GetBackend');\n  }\n\n  /**\n   * Grants permission to retrieve an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-details.html#GetBackendAPI\n   */\n  public toGetBackendAPI() {\n    return this.to('GetBackendAPI');\n  }\n\n  /**\n   * Grants permission to retrieve models for an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname-getmodels.html#GetBackendAPIModels\n   */\n  public toGetBackendAPIModels() {\n    return this.to('GetBackendAPIModels');\n  }\n\n  /**\n   * Grants permission to retrieve an auth resource of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname-details.html#GetBackendAuth\n   */\n  public toGetBackendAuth() {\n    return this.to('GetBackendAuth');\n  }\n\n  /**\n   * Grants permission to retrieve a job of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-job-backendenvironmentname-jobid.html#GetBackendJob\n   */\n  public toGetBackendJob() {\n    return this.to('GetBackendJob');\n  }\n\n  /**\n   * Grants permission to retrieve an existing backend storage resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#GetBackendStorage\n   */\n  public toGetBackendStorage() {\n    return this.to('GetBackendStorage');\n  }\n\n  /**\n   * Grants permission to retrieve an Amplify Admin challenge token by appId\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-challenge-sessionid.html#GetToken\n   */\n  public toGetToken() {\n    return this.to('GetToken');\n  }\n\n  /**\n   * Grants permission to import an existing auth resource of an Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname.html#ImportBackendAuth\n   */\n  public toImportBackendAuth() {\n    return this.to('ImportBackendAuth');\n  }\n\n  /**\n   * Grants permission to import an existing backend storage resource\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#ImportBackendStorage\n   */\n  public toImportBackendStorage() {\n    return this.to('ImportBackendStorage');\n  }\n\n  /**\n   * Grants permission to retrieve the jobs of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-job-backendenvironmentname.html#ListBackendJobs\n   */\n  public toListBackendJobs() {\n    return this.to('ListBackendJobs');\n  }\n\n  /**\n   * Grants permission to retrieve s3 buckets\n   *\n   * Access Level: List\n   *\n   * Dependent actions:\n   * - s3:ListAllMyBuckets\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#ListS3Buckets\n   */\n  public toListS3Buckets() {\n    return this.to('ListS3Buckets');\n  }\n\n  /**\n   * Grants permission to delete all existing Amplify Admin backend environments by appId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-remove.html#RemoveAllBackends\n   */\n  public toRemoveAllBackends() {\n    return this.to('RemoveAllBackends');\n  }\n\n  /**\n   * Grants permission to delete an Amplify Admin backend config by Amplify appId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-config-remove.html#RemoveBackendConfig\n   */\n  public toRemoveBackendConfig() {\n    return this.to('RemoveBackendConfig');\n  }\n\n  /**\n   * Grants permission to update an API of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-api-backendenvironmentname.html#UpdateBackendAPI\n   */\n  public toUpdateBackendAPI() {\n    return this.to('UpdateBackendAPI');\n  }\n\n  /**\n   * Grants permission to update an auth resource of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-auth-backendenvironmentname.html#UpdateBackendAuth\n   */\n  public toUpdateBackendAuth() {\n    return this.to('UpdateBackendAuth');\n  }\n\n  /**\n   * Grants permission to update an Amplify Admin backend config by Amplify appId\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-config-update.html#UpdateBackendConfig\n   */\n  public toUpdateBackendConfig() {\n    return this.to('UpdateBackendConfig');\n  }\n\n  /**\n   * Grants permission to update a job of an existing Amplify Admin backend environment by appId and backendEnvironmentName\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-job-backendenvironmentname-jobid.html#UpdateBackendJob\n   */\n  public toUpdateBackendJob() {\n    return this.to('UpdateBackendJob');\n  }\n\n  /**\n   * Grants permission to update a backend storage resource\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend-appid-storage.html#UpdateBackendStorage\n   */\n  public toUpdateBackendStorage() {\n    return this.to('UpdateBackendStorage');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'CloneBackend',\n      'CreateBackend',\n      'CreateBackendAPI',\n      'CreateBackendAuth',\n      'CreateBackendConfig',\n      'CreateBackendStorage',\n      'CreateToken',\n      'DeleteBackend',\n      'DeleteBackendAPI',\n      'DeleteBackendAuth',\n      'DeleteBackendStorage',\n      'DeleteToken',\n      'GenerateBackendAPIModels',\n      'ImportBackendAuth',\n      'ImportBackendStorage',\n      'RemoveAllBackends',\n      'RemoveBackendConfig',\n      'UpdateBackendAPI',\n      'UpdateBackendAuth',\n      'UpdateBackendConfig',\n      'UpdateBackendJob',\n      'UpdateBackendStorage'\n    ],\n    Read: [\n      'GetBackend',\n      'GetBackendAPI',\n      'GetBackendAPIModels',\n      'GetBackendAuth',\n      'GetBackendJob',\n      'GetBackendStorage',\n      'GetToken'\n    ],\n    List: [\n      'ListBackendJobs',\n      'ListS3Buckets'\n    ]\n  };\n\n  /**\n   * Adds a resource of type created-backend to the statement\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend.html\n   *\n   * @param resourceName - Identifier for the resourceName.\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 onCreatedBackend(resourceName: string, account?: string, region?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:amplifybackend:${ region ?? this.defaultRegion }:${ account ?? this.defaultAccount }:/backend/${ resourceName }`);\n  }\n\n  /**\n   * Adds a resource of type backend to the statement\n   *\n   * https://docs.aws.amazon.com/amplify-admin-ui/latest/APIReference/backend.html\n   *\n   * @param appId - Identifier for the appId.\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 onBackend(appId: string, account?: string, region?: string, partition?: string) {\n    return this.on(`a