UNPKG

iam-floyd

Version:

AWS IAM policy statement generator with fluent interface

369 lines 35.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Payments = void 0; const shared_1 = require("../../shared"); /** * Statement provider for service [payments](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awspayments.html). * * @param sid [SID](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html) of the statement */ class Payments extends shared_1.PolicyStatement { /** * Statement provider for service [payments](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awspayments.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 = 'payments'; this.accessLevelList = { Write: [ 'AcceptFinancingApplicationTerms', 'CreateFinancingApplication', 'CreatePaymentInstrument', 'DeletePaymentInstrument', 'MakePayment', 'UpdateFinancingApplication', 'UpdatePaymentInstrument', 'UpdatePaymentPreferences' ], Read: [ 'GetFinancingApplication', 'GetFinancingLine', 'GetFinancingLineWithdrawal', 'GetFinancingOption', 'GetPaymentStatus' ], List: [ 'GetPaymentInstrument', 'ListFinancingApplications', 'ListFinancingLineWithdrawals', 'ListFinancingLines', 'ListPaymentInstruments', 'ListPaymentPreferences', 'ListPaymentProgramOptions', 'ListPaymentProgramStatus', 'ListTagsForResource' ], Tagging: [ 'TagResource', 'UntagResource' ] }; } /** * Grants permission to accept financing application terms provided by a lender * * Access Level: Write * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toAcceptFinancingApplicationTerms() { return this.to('AcceptFinancingApplicationTerms'); } /** * Grants permission to create a financing application * * Access Level: Write * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toCreateFinancingApplication() { return this.to('CreateFinancingApplication'); } /** * Grants permission to create a payment instrument * * Access Level: Write * * Possible conditions: * - .ifAwsTagKeys() * - .ifAwsRequestTag() * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toCreatePaymentInstrument() { return this.to('CreatePaymentInstrument'); } /** * Grants permission to delete a payment instrument * * Access Level: Write * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toDeletePaymentInstrument() { return this.to('DeletePaymentInstrument'); } /** * Grants permission to get information about a financing application * * Access Level: Read * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toGetFinancingApplication() { return this.to('GetFinancingApplication'); } /** * Grants permission to get information about a financing line * * Access Level: Read * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toGetFinancingLine() { return this.to('GetFinancingLine'); } /** * Grants permission to get information about a financing line withdrawal * * Access Level: Read * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toGetFinancingLineWithdrawal() { return this.to('GetFinancingLineWithdrawal'); } /** * Grants permission to get information about a financing option * * Access Level: Read * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toGetFinancingOption() { return this.to('GetFinancingOption'); } /** * Grants permission to get information about a payment instrument * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toGetPaymentInstrument() { return this.to('GetPaymentInstrument'); } /** * Grants permission to get payment status of invoices * * Access Level: Read * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toGetPaymentStatus() { return this.to('GetPaymentStatus'); } /** * Grants permission to list financing application metadata * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toListFinancingApplications() { return this.to('ListFinancingApplications'); } /** * Grants permission to list financing line withdrawals metadata * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toListFinancingLineWithdrawals() { return this.to('ListFinancingLineWithdrawals'); } /** * Grants permission to list financing line metadata * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toListFinancingLines() { return this.to('ListFinancingLines'); } /** * Grants permission to list payment instrument metadata * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toListPaymentInstruments() { return this.to('ListPaymentInstruments'); } /** * Grants permission to get payment preferences (preferred payment currency, preferred payment method, etc.) * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toListPaymentPreferences() { return this.to('ListPaymentPreferences'); } /** * Grants permission to list information about payment options * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toListPaymentProgramOptions() { return this.to('ListPaymentProgramOptions'); } /** * Grants permission to list information about payment program eligibility and enrolment status * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toListPaymentProgramStatus() { return this.to('ListPaymentProgramStatus'); } /** * Grants permission to list tags on a payment resource * * Access Level: List * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toListTagsForResource() { return this.to('ListTagsForResource'); } /** * Grants permission to make a payment, authenticate a payment, verify a payment method, and generate a funding request document for Advance Pay * * Access Level: Write * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toMakePayment() { return this.to('MakePayment'); } /** * Grants permission to tag a payment resource * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * - .ifAwsRequestTag() * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toTagResource() { return this.to('TagResource'); } /** * Grants permission to untag a payment resource * * Access Level: Tagging * * Possible conditions: * - .ifAwsTagKeys() * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toUntagResource() { return this.to('UntagResource'); } /** * Grants permission to update a financing application * * Access Level: Write * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref */ toUpdateFinancingApplication() { return this.to('UpdateFinancingApplication'); } /** * Grants permission to update a payment instrument * * Access Level: Write * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toUpdatePaymentInstrument() { return this.to('UpdatePaymentInstrument'); } /** * Grants permission to update payment preferences (preferred payment currency, preferred payment method, etc.) * * Access Level: Write * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html */ toUpdatePaymentPreferences() { return this.to('UpdatePaymentPreferences'); } /** * Adds a resource of type payment-instrument to the statement * * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html#user-permissions * * @param resourceId - Identifier for the resourceId. * @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() */ onPaymentInstrument(resourceId, account, partition) { return this.on(`arn:${partition ?? this.defaultPartition}:payments::${account ?? this.defaultAccount}:payment-instrument:${resourceId}`); } /** * Filters access by the tags that are passed in the request * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag * * Applies to actions: * - .toCreatePaymentInstrument() * - .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 access by the tags associated with the resource * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-resourcetag * * Applies to resource types: * - payment-instrument * * @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 access by the tag keys that are passed in the request * * https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys * * Applies to actions: * - .toCreatePaymentInstrument() * - .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.Payments = Payments; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"payments.js","sourceRoot":"","sources":["payments.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 [payments](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awspayments.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 Payments extends PolicyStatement {\n  public servicePrefix = 'payments';\n\n  /**\n   * Statement provider for service [payments](https://docs.aws.amazon.com/service-authorization/latest/reference/list_awspayments.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 accept financing application terms provided by a lender\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toAcceptFinancingApplicationTerms() {\n    return this.to('AcceptFinancingApplicationTerms');\n  }\n\n  /**\n   * Grants permission to create a financing application\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toCreateFinancingApplication() {\n    return this.to('CreateFinancingApplication');\n  }\n\n  /**\n   * Grants permission to create a payment instrument\n   *\n   * Access Level: Write\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toCreatePaymentInstrument() {\n    return this.to('CreatePaymentInstrument');\n  }\n\n  /**\n   * Grants permission to delete a payment instrument\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toDeletePaymentInstrument() {\n    return this.to('DeletePaymentInstrument');\n  }\n\n  /**\n   * Grants permission to get information about a financing application\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toGetFinancingApplication() {\n    return this.to('GetFinancingApplication');\n  }\n\n  /**\n   * Grants permission to get information about a financing line\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toGetFinancingLine() {\n    return this.to('GetFinancingLine');\n  }\n\n  /**\n   * Grants permission to get information about a financing line withdrawal\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toGetFinancingLineWithdrawal() {\n    return this.to('GetFinancingLineWithdrawal');\n  }\n\n  /**\n   * Grants permission to get information about a financing option\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toGetFinancingOption() {\n    return this.to('GetFinancingOption');\n  }\n\n  /**\n   * Grants permission to get information about a payment instrument\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toGetPaymentInstrument() {\n    return this.to('GetPaymentInstrument');\n  }\n\n  /**\n   * Grants permission to get payment status of invoices\n   *\n   * Access Level: Read\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toGetPaymentStatus() {\n    return this.to('GetPaymentStatus');\n  }\n\n  /**\n   * Grants permission to list financing application metadata\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toListFinancingApplications() {\n    return this.to('ListFinancingApplications');\n  }\n\n  /**\n   * Grants permission to list financing line withdrawals metadata\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toListFinancingLineWithdrawals() {\n    return this.to('ListFinancingLineWithdrawals');\n  }\n\n  /**\n   * Grants permission to list financing line metadata\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toListFinancingLines() {\n    return this.to('ListFinancingLines');\n  }\n\n  /**\n   * Grants permission to list payment instrument metadata\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toListPaymentInstruments() {\n    return this.to('ListPaymentInstruments');\n  }\n\n  /**\n   * Grants permission to get payment preferences (preferred payment currency, preferred payment method, etc.)\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toListPaymentPreferences() {\n    return this.to('ListPaymentPreferences');\n  }\n\n  /**\n   * Grants permission to list information about payment options\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toListPaymentProgramOptions() {\n    return this.to('ListPaymentProgramOptions');\n  }\n\n  /**\n   * Grants permission to list information about payment program eligibility and enrolment status\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toListPaymentProgramStatus() {\n    return this.to('ListPaymentProgramStatus');\n  }\n\n  /**\n   * Grants permission to list tags on a payment resource\n   *\n   * Access Level: List\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toListTagsForResource() {\n    return this.to('ListTagsForResource');\n  }\n\n  /**\n   * Grants permission to make a payment, authenticate a payment, verify a payment method, and generate a funding request document for Advance Pay\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toMakePayment() {\n    return this.to('MakePayment');\n  }\n\n  /**\n   * Grants permission to tag a payment resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   * - .ifAwsRequestTag()\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toTagResource() {\n    return this.to('TagResource');\n  }\n\n  /**\n   * Grants permission to untag a payment resource\n   *\n   * Access Level: Tagging\n   *\n   * Possible conditions:\n   * - .ifAwsTagKeys()\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toUntagResource() {\n    return this.to('UntagResource');\n  }\n\n  /**\n   * Grants permission to update a financing application\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/security_iam_id-based-policy-examples.html#billing-permissions-ref\n   */\n  public toUpdateFinancingApplication() {\n    return this.to('UpdateFinancingApplication');\n  }\n\n  /**\n   * Grants permission to update a payment instrument\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toUpdatePaymentInstrument() {\n    return this.to('UpdatePaymentInstrument');\n  }\n\n  /**\n   * Grants permission to update payment preferences (preferred payment currency, preferred payment method, etc.)\n   *\n   * Access Level: Write\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html\n   */\n  public toUpdatePaymentPreferences() {\n    return this.to('UpdatePaymentPreferences');\n  }\n\n  protected accessLevelList: AccessLevelList = {\n    Write: [\n      'AcceptFinancingApplicationTerms',\n      'CreateFinancingApplication',\n      'CreatePaymentInstrument',\n      'DeletePaymentInstrument',\n      'MakePayment',\n      'UpdateFinancingApplication',\n      'UpdatePaymentInstrument',\n      'UpdatePaymentPreferences'\n    ],\n    Read: [\n      'GetFinancingApplication',\n      'GetFinancingLine',\n      'GetFinancingLineWithdrawal',\n      'GetFinancingOption',\n      'GetPaymentStatus'\n    ],\n    List: [\n      'GetPaymentInstrument',\n      'ListFinancingApplications',\n      'ListFinancingLineWithdrawals',\n      'ListFinancingLines',\n      'ListPaymentInstruments',\n      'ListPaymentPreferences',\n      'ListPaymentProgramOptions',\n      'ListPaymentProgramStatus',\n      'ListTagsForResource'\n    ],\n    Tagging: [\n      'TagResource',\n      'UntagResource'\n    ]\n  };\n\n  /**\n   * Adds a resource of type payment-instrument to the statement\n   *\n   * https://docs.aws.amazon.com/awsaccountbilling/latest/aboutv2/billing-permissions-ref.html#user-permissions\n   *\n   * @param resourceId - Identifier for the resourceId.\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 onPaymentInstrument(resourceId: string, account?: string, partition?: string) {\n    return this.on(`arn:${ partition ?? this.defaultPartition }:payments::${ account ?? this.defaultAccount }:payment-instrument:${ resourceId }`);\n  }\n\n  /**\n   * Filters access by the tags that are passed 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   * - .toCreatePaymentInstrument()\n   * - .toTagResource()\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsRequestTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:RequestTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the tags associated with 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   * - payment-instrument\n   *\n   * @param tagKey The tag key to check\n   * @param value The value(s) to check\n   * @param operator Works with [string operators](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html#Conditions_String). **Default:** `StringLike`\n   */\n  public ifAwsResourceTag(tagKey: string, value: string | string[], operator?: Operator | string) {\n    return this.if(`aws:ResourceTag/${ tagKey }`, value, operator ?? 'StringLike');\n  }\n\n  /**\n   * Filters access by the tag keys that are passed 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   * - .toCreatePaymentInstrument()\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"]}