UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

491 lines 45.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Worklink = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [worklink](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonworklink.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class Worklink extends shared_1.PolicyStatement { /** * Statement provider for service [worklink](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonworklink.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 = 'worklink'; this.accessLevelList = { Write: [ 'AssociateDomain', 'AssociateWebsiteAuthorizationProvider', 'AssociateWebsiteCertificateAuthority', 'CreateFleet', 'DeleteFleet', 'DisassociateDomain', 'DisassociateWebsiteAuthorizationProvider', 'DisassociateWebsiteCertificateAuthority', 'RestoreDomainAccess', 'RevokeDomainAccess', 'SignOutUser', 'UpdateAuditStreamConfiguration', 'UpdateCompanyNetworkConfiguration', 'UpdateDevicePolicyConfiguration', 'UpdateDomainMetadata', 'UpdateFleetMetadata', 'UpdateIdentityProviderConfiguration' ], Read: [ 'DescribeAuditStreamConfiguration', 'DescribeCompanyNetworkConfiguration', 'DescribeDevice', 'DescribeDevicePolicyConfiguration', 'DescribeDomain', 'DescribeFleetMetadata', 'DescribeIdentityProviderConfiguration', 'DescribeWebsiteCertificateAuthority', 'ListTagsForResource' ], List: [ 'ListDevices', 'ListDomains', 'ListFleets', 'ListWebsiteAuthorizationProviders', 'ListWebsiteCertificateAuthorities', 'SearchEntity' ], Tagging: [ 'TagResource', 'UntagResource' ] }; } /** * Grants permission to associate a domain with an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_AssociateDomain.html */ toAssociateDomain() { return this.to('AssociateDomain'); } /** * Grants permission to associate a website authorization provider with an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_AssociateWebsiteAuthorizationProvider.html */ toAssociateWebsiteAuthorizationProvider() { return this.to('AssociateWebsiteAuthorizationProvider'); } /** * Grants permission to associate a website certificate authority with an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_AssociateWebsiteCertificateAuthority.html */ toAssociateWebsiteCertificateAuthority() { return this.to('AssociateWebsiteCertificateAuthority'); } /** * Grants permission to create an Amazon WorkLink fleet * * Access Level: Write * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/worklink/latest/api/API_CreateFleet.html */ toCreateFleet() { return this.to('CreateFleet'); } /** * Grants permission to delete an Amazon WorkLink fleet * * Access Level: Write * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/worklink/latest/api/API_DeleteFleet.html */ toDeleteFleet() { return this.to('DeleteFleet'); } /** * Grants permission to describe the audit stream configuration for an Amazon WorkLink fleet * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeAuditStreamConfiguration.html */ toDescribeAuditStreamConfiguration() { return this.to('DescribeAuditStreamConfiguration'); } /** * Grants permission to describe the company network configuration for an Amazon WorkLink fleet * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeCompanyNetworkConfiguration.html */ toDescribeCompanyNetworkConfiguration() { return this.to('DescribeCompanyNetworkConfiguration'); } /** * Grants permission to describe details of a device associated with an Amazon WorkLink fleet * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeDevice.html */ toDescribeDevice() { return this.to('DescribeDevice'); } /** * Grants permission to describe the device policy configuration for an Amazon WorkLink fleet * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeDevicePolicyConfiguration.html */ toDescribeDevicePolicyConfiguration() { return this.to('DescribeDevicePolicyConfiguration'); } /** * Grants permission to describe details about a domain associated with an Amazon WorkLink fleet * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeDomain.html */ toDescribeDomain() { return this.to('DescribeDomain'); } /** * Grants permission to describe metadata of an Amazon WorkLink fleet * * Access Level: Read * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeFleetMetadata.html */ toDescribeFleetMetadata() { return this.to('DescribeFleetMetadata'); } /** * Grants permission to describe the identity provider configuration for an Amazon WorkLink fleet * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeIdentityProviderConfiguration.html */ toDescribeIdentityProviderConfiguration() { return this.to('DescribeIdentityProviderConfiguration'); } /** * Grants permission to describe a website certificate authority associated with an Amazon WorkLink fleet * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeWebsiteCertificateAuthority.html */ toDescribeWebsiteCertificateAuthority() { return this.to('DescribeWebsiteCertificateAuthority'); } /** * Grants permission to disassociate a domain from an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_DisassociateDomain.html */ toDisassociateDomain() { return this.to('DisassociateDomain'); } /** * Grants permission to disassociate a website authorization provider from an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_DisassociateWebsiteAuthorizationProvider.html */ toDisassociateWebsiteAuthorizationProvider() { return this.to('DisassociateWebsiteAuthorizationProvider'); } /** * Grants permission to disassociate a website certificate authority from an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_DisassociateWebsiteCertificateAuthority.html */ toDisassociateWebsiteCertificateAuthority() { return this.to('DisassociateWebsiteCertificateAuthority'); } /** * Grants permission to list the devices associated with an Amazon WorkLink fleet * * Access Level: List * * https://docs.aws.amazon.com/worklink/latest/api/API_ListDevices.html */ toListDevices() { return this.to('ListDevices'); } /** * Grants permission to list the associated domains for an Amazon WorkLink fleet * * Access Level: List * * https://docs.aws.amazon.com/worklink/latest/api/API_ListDomains.html */ toListDomains() { return this.to('ListDomains'); } /** * Grants permission to list the Amazon WorkLink fleets associated with the account * * Access Level: List * * https://docs.aws.amazon.com/worklink/latest/api/API_ListFleets.html */ toListFleets() { return this.to('ListFleets'); } /** * Grants permission to list tags for a resource * * Access Level: Read * * https://docs.aws.amazon.com/worklink/latest/api/API_ListTagsForResource.html */ toListTagsForResource() { return this.to('ListTagsForResource'); } /** * Grants permission to list the website authorization providers for an Amazon WorkLink fleet * * Access Level: List * * https://docs.aws.amazon.com/worklink/latest/api/API_ListWebsiteAuthorizationProviders.html */ toListWebsiteAuthorizationProviders() { return this.to('ListWebsiteAuthorizationProviders'); } /** * Grants permission to list the website certificate authorities associated with an Amazon WorkLink fleet * * Access Level: List * * https://docs.aws.amazon.com/worklink/latest/api/API_ListWebsiteCertificateAuthorities.html */ toListWebsiteCertificateAuthorities() { return this.to('ListWebsiteCertificateAuthorities'); } /** * Grants permission to restore access to a domain associated with an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_RestoreDomainAccess.html */ toRestoreDomainAccess() { return this.to('RestoreDomainAccess'); } /** * Grants permission to revoke access to a domain associated with an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_RevokeDomainAccess.html */ toRevokeDomainAccess() { return this.to('RevokeDomainAccess'); } /** * Grants permission to list devices for an Amazon WorkLink fleet * * Access Level: List * * https://docs.aws.amazon.com/worklink/latest/ag/manage-devices.html */ toSearchEntity() { return this.to('SearchEntity'); } /** * Grants permission to sign out a user from an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_SignOutUser.html */ toSignOutUser() { return this.to('SignOutUser'); } /** * Grants permission to add one or more tags to a resource * * Access Level: Tagging * * Possible conditions: * - .ifAwsRequestTag() * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/worklink/latest/api/API_TagResource.html */ toTagResource() { return this.to('TagResource'); } /** * Grants permission to remove one or more tags from a resource * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/worklink/latest/api/API_UntagResource.html */ toUntagResource() { return this.to('UntagResource'); } /** * Grants permission to update the audit stream configuration for an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateAuditStreamConfiguration.html */ toUpdateAuditStreamConfiguration() { return this.to('UpdateAuditStreamConfiguration'); } /** * Grants permission to update the company network configuration for an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateCompanyNetworkConfiguration.html */ toUpdateCompanyNetworkConfiguration() { return this.to('UpdateCompanyNetworkConfiguration'); } /** * Grants permission to update the device policy configuration for an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateDevicePolicyConfiguration.html */ toUpdateDevicePolicyConfiguration() { return this.to('UpdateDevicePolicyConfiguration'); } /** * Grants permission to update the metadata for a domain associated with an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateDomainMetadata.html */ toUpdateDomainMetadata() { return this.to('UpdateDomainMetadata'); } /** * Grants permission to update the metadata of an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateFleetMetadata.html */ toUpdateFleetMetadata() { return this.to('UpdateFleetMetadata'); } /** * Grants permission to update the identity provider configuration for an Amazon WorkLink fleet * * Access Level: Write * * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateIdentityProviderConfiguration.html */ toUpdateIdentityProviderConfiguration() { return this.to('UpdateIdentityProviderConfiguration'); } /** * Adds a resource of type fleet to the statement * * https://docs.aws.amazon.com/worklink/latest/api/API_CreateFleet.html * * @param fleetName - Identifier for the fleetName. * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account. * @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. * * Possible conditions: * - .ifAwsResourceTag() */ onFleet(fleetName, account, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:worklink::${account ?? this.defaultAccount}:fleet/${fleetName}`); } /** * Filters actions based on the presence of tag key-value pairs in the request * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag * * Applies to actions: * - .toCreateFleet() * - .toDeleteFleet() * - .toDescribeFleetMetadata() * - .toTagResource() * * @param tagKey The tag key to check * @param value The value(s) to check * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike` */ ifAwsRequestTag(tagKey, value, operator) { return this.if(`aws:RequestTag/${tagKey}`, value, operator ?? 'StringLike'); } /** * Filters actions based on tag key-value pairs attached to the resource * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag * * Applies to resource types: * - fleet * * @param tagKey The tag key to check * @param value The value(s) to check * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike` */ ifAwsResourceTag(tagKey, value, operator) { return this.if(`aws:ResourceTag/${tagKey}`, value, operator ?? 'StringLike'); } /** * Filters actions based on the presence of tag keys in the request * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys * * Applies to actions: * - .toCreateFleet() * - .toDeleteFleet() * - .toDescribeFleetMetadata() * - .toTagResource() * - .toUntagResource() * * @param value The value(s) to check * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike` */ ifAwsTagKeys(value, operator) { return this.if(`aws:TagKeys`, value, operator ?? 'StringLike'); } } exports.Worklink = Worklink; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"worklink.js","sourceRoot":"","sources":["worklink.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 [worklink](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonworklink.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 Worklink extends PolicyStatement {\n  public servicePrefix = 'worklink';\n\n  /**\n   * Statement provider for service [worklink](https://docs.aws.amazon.com/service-authorization/latest/reference/list_amazonworklink.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 associate a domain with an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_AssociateDomain.html\n   */\n  public toAssociateDomain() {\n    return this.to('AssociateDomain');\n  }\n\n  /**\n   * Grants permission to associate a website authorization provider with an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_AssociateWebsiteAuthorizationProvider.html\n   */\n  public toAssociateWebsiteAuthorizationProvider() {\n    return this.to('AssociateWebsiteAuthorizationProvider');\n  }\n\n  /**\n   * Grants permission to associate a website certificate authority with an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_AssociateWebsiteCertificateAuthority.html\n   */\n  public toAssociateWebsiteCertificateAuthority() {\n    return this.to('AssociateWebsiteCertificateAuthority');\n  }\n\n  /**\n   * Grants permission to create an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_CreateFleet.html\n   */\n  public toCreateFleet() {\n    return this.to('CreateFleet');\n  }\n\n  /**\n   * Grants permission to delete an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DeleteFleet.html\n   */\n  public toDeleteFleet() {\n    return this.to('DeleteFleet');\n  }\n\n  /**\n   * Grants permission to describe the audit stream configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeAuditStreamConfiguration.html\n   */\n  public toDescribeAuditStreamConfiguration() {\n    return this.to('DescribeAuditStreamConfiguration');\n  }\n\n  /**\n   * Grants permission to describe the company network configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeCompanyNetworkConfiguration.html\n   */\n  public toDescribeCompanyNetworkConfiguration() {\n    return this.to('DescribeCompanyNetworkConfiguration');\n  }\n\n  /**\n   * Grants permission to describe details of a device associated with an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeDevice.html\n   */\n  public toDescribeDevice() {\n    return this.to('DescribeDevice');\n  }\n\n  /**\n   * Grants permission to describe the device policy configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeDevicePolicyConfiguration.html\n   */\n  public toDescribeDevicePolicyConfiguration() {\n    return this.to('DescribeDevicePolicyConfiguration');\n  }\n\n  /**\n   * Grants permission to describe details about a domain associated with an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeDomain.html\n   */\n  public toDescribeDomain() {\n    return this.to('DescribeDomain');\n  }\n\n  /**\n   * Grants permission to describe metadata of an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeFleetMetadata.html\n   */\n  public toDescribeFleetMetadata() {\n    return this.to('DescribeFleetMetadata');\n  }\n\n  /**\n   * Grants permission to describe the identity provider configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeIdentityProviderConfiguration.html\n   */\n  public toDescribeIdentityProviderConfiguration() {\n    return this.to('DescribeIdentityProviderConfiguration');\n  }\n\n  /**\n   * Grants permission to describe a website certificate authority associated with an Amazon WorkLink fleet\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DescribeWebsiteCertificateAuthority.html\n   */\n  public toDescribeWebsiteCertificateAuthority() {\n    return this.to('DescribeWebsiteCertificateAuthority');\n  }\n\n  /**\n   * Grants permission to disassociate a domain from an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DisassociateDomain.html\n   */\n  public toDisassociateDomain() {\n    return this.to('DisassociateDomain');\n  }\n\n  /**\n   * Grants permission to disassociate a website authorization provider from an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DisassociateWebsiteAuthorizationProvider.html\n   */\n  public toDisassociateWebsiteAuthorizationProvider() {\n    return this.to('DisassociateWebsiteAuthorizationProvider');\n  }\n\n  /**\n   * Grants permission to disassociate a website certificate authority from an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_DisassociateWebsiteCertificateAuthority.html\n   */\n  public toDisassociateWebsiteCertificateAuthority() {\n    return this.to('DisassociateWebsiteCertificateAuthority');\n  }\n\n  /**\n   * Grants permission to list the devices associated with an Amazon WorkLink fleet\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_ListDevices.html\n   */\n  public toListDevices() {\n    return this.to('ListDevices');\n  }\n\n  /**\n   * Grants permission to list the associated domains for an Amazon WorkLink fleet\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_ListDomains.html\n   */\n  public toListDomains() {\n    return this.to('ListDomains');\n  }\n\n  /**\n   * Grants permission to list the Amazon WorkLink fleets associated with the account\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_ListFleets.html\n   */\n  public toListFleets() {\n    return this.to('ListFleets');\n  }\n\n  /**\n   * Grants permission to list tags for a resource\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_ListTagsForResource.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to list the website authorization providers for an Amazon WorkLink fleet\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_ListWebsiteAuthorizationProviders.html\n   */\n  public toListWebsiteAuthorizationProviders() {\n    return this.to('ListWebsiteAuthorizationProviders');\n  }\n\n  /**\n   * Grants permission to list the website certificate authorities associated with an Amazon WorkLink fleet\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_ListWebsiteCertificateAuthorities.html\n   */\n  public toListWebsiteCertificateAuthorities() {\n    return this.to('ListWebsiteCertificateAuthorities');\n  }\n\n  /**\n   * Grants permission to restore access to a domain associated with an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_RestoreDomainAccess.html\n   */\n  public toRestoreDomainAccess() {\n    return this.to('RestoreDomainAccess');\n  }\n\n  /**\n   * Grants permission to revoke access to a domain associated with an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_RevokeDomainAccess.html\n   */\n  public toRevokeDomainAccess() {\n    return this.to('RevokeDomainAccess');\n  }\n\n  /**\n   * Grants permission to list devices for an Amazon WorkLink fleet\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/worklink/latest/ag/manage-devices.html\n   */\n  public toSearchEntity() {\n    return this.to('SearchEntity');\n  }\n\n  /**\n   * Grants permission to sign out a user from an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_SignOutUser.html\n   */\n  public toSignOutUser() {\n    return this.to('SignOutUser');\n  }\n\n  /**\n   * Grants permission to add one or more tags to a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsRequestTag()\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_TagResource.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to remove one or more tags from a resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_UntagResource.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update the audit stream configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateAuditStreamConfiguration.html\n   */\n  public toUpdateAuditStreamConfiguration() {\n    return this.to('UpdateAuditStreamConfiguration');\n  }\n\n  /**\n   * Grants permission to update the company network configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateCompanyNetworkConfiguration.html\n   */\n  public toUpdateCompanyNetworkConfiguration() {\n    return this.to('UpdateCompanyNetworkConfiguration');\n  }\n\n  /**\n   * Grants permission to update the device policy configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateDevicePolicyConfiguration.html\n   */\n  public toUpdateDevicePolicyConfiguration() {\n    return this.to('UpdateDevicePolicyConfiguration');\n  }\n\n  /**\n   * Grants permission to update the metadata for a domain associated with an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateDomainMetadata.html\n   */\n  public toUpdateDomainMetadata() {\n    return this.to('UpdateDomainMetadata');\n  }\n\n  /**\n   * Grants permission to update the metadata of an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateFleetMetadata.html\n   */\n  public toUpdateFleetMetadata() {\n    return this.to('UpdateFleetMetadata');\n  }\n\n  /**\n   * Grants permission to update the identity provider configuration for an Amazon WorkLink fleet\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_UpdateIdentityProviderConfiguration.html\n   */\n  public toUpdateIdentityProviderConfiguration() {\n    return this.to('UpdateIdentityProviderConfiguration');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AssociateDomain',\n      'AssociateWebsiteAuthorizationProvider',\n      'AssociateWebsiteCertificateAuthority',\n      'CreateFleet',\n      'DeleteFleet',\n      'DisassociateDomain',\n      'DisassociateWebsiteAuthorizationProvider',\n      'DisassociateWebsiteCertificateAuthority',\n      'RestoreDomainAccess',\n      'RevokeDomainAccess',\n      'SignOutUser',\n      'UpdateAuditStreamConfiguration',\n      'UpdateCompanyNetworkConfiguration',\n      'UpdateDevicePolicyConfiguration',\n      'UpdateDomainMetadata',\n      'UpdateFleetMetadata',\n      'UpdateIdentityProviderConfiguration'\n    ],\n    Read: [\n      'DescribeAuditStreamConfiguration',\n      'DescribeCompanyNetworkConfiguration',\n      'DescribeDevice',\n      'DescribeDevicePolicyConfiguration',\n      'DescribeDomain',\n      'DescribeFleetMetadata',\n      'DescribeIdentityProviderConfiguration',\n      'DescribeWebsiteCertificateAuthority',\n      'ListTagsForResource'\n    ],\n    List: [\n      'ListDevices',\n      'ListDomains',\n      'ListFleets',\n      'ListWebsiteAuthorizationProviders',\n      'ListWebsiteCertificateAuthorities',\n      'SearchEntity'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type fleet to the statement\n   *\n   * https://docs.aws.amazon.com/worklink/latest/api/API_CreateFleet.html\n   *\n   * @param fleetName - Identifier for the fleetName.\n   * @param account - Account of the resource; defaults to `*`, unless using the CDK, where the default is the current Stack's account.\n   * @param partition - Partition of the AWS account [aws, aws-cn, aws-us-gov]; defaults to `aws`, unless using the CDK, where the default is the current Stack's partition.\n   *\n   * Possible conditions:\n   * - .ifAwsResourceTag()\n   */\n  public onFleet(fleetName: string, account?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:worklink::${ account ?? this.defaultAccount }:fleet/${ fleetName }`);\n  }\n\n  /**\n   * Filters actions based on 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   * - .toCreateFleet()\n   * - .toDeleteFleet()\n   * - .toDescribeFleetMetadata()\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 based on 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   * - fleet\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 based on 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   * - .toCreateFleet()\n   * - .toDeleteFleet()\n   * - .toDescribeFleetMetadata()\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"]}