{
  "url": "https://docs.aws.amazon.com/service-authorization/latest/reference/list_awskeymanagementservice.html",
  "name": "AWS Key Management Service",
  "prefix": "kms",
  "timestamp": "1778371206",
  "actions": [
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_CancelKeyDeletion.html",
      "name": "CancelKeyDeletion",
      "description": "Controls permission to cancel the scheduled deletion of an AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ConnectCustomKeyStore.html",
      "name": "ConnectCustomKeyStore",
      "description": "Controls permission to connect or reconnect a custom key store to its associated AWS CloudHSM cluster or external key manager outside of AWS",
      "access": "Write",
      "resources": [],
      "conditions": [
        "kms:CallerAccount"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_CreateAlias.html",
      "name": "CreateAlias",
      "description": "Controls permission to create an alias for an AWS KMS key. Aliases are optional friendly names that you can associate with KMS keys",
      "access": "Write",
      "resources": [
        {
          "name": "alias",
          "is_required": true
        },
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_CreateCustomKeyStore.html",
      "name": "CreateCustomKeyStore",
      "description": "Controls permission to create a custom key store that is backed by an AWS CloudHSM cluster or an external key manager outside of AWS",
      "access": "Write",
      "resources": [],
      "conditions": [
        "kms:CallerAccount"
      ],
      "dependents": [
        "cloudhsm:DescribeClusters",
        "ec2:DescribeVpcEndpointServices",
        "iam:CreateServiceLinkedRole"
      ]
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_CreateGrant.html",
      "name": "CreateGrant",
      "description": "Controls permission to add a grant to an AWS KMS key. You can use grants to add permissions without changing the key policy or IAM policy",
      "access": "Permissions management",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:GrantConstraintType",
        "kms:GranteePrincipal",
        "kms:GrantIsForAWSResource",
        "kms:GrantOperations",
        "kms:RetiringPrincipal",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_CreateKey.html",
      "name": "CreateKey",
      "description": "Controls permission to create an AWS KMS key that can be used to protect data keys and other sensitive information",
      "access": "Write",
      "resources": [],
      "conditions": [
        "aws:ResourceTag/${TagKey}",
        "aws:RequestTag/${TagKey}",
        "aws:TagKeys",
        "kms:BypassPolicyLockoutSafetyCheck",
        "kms:CallerAccount",
        "kms:KeySpec",
        "kms:KeyUsage",
        "kms:KeyOrigin",
        "kms:MultiRegion",
        "kms:MultiRegionKeyType",
        "kms:ViaService"
      ],
      "dependents": [
        "iam:CreateServiceLinkedRole",
        "kms:PutKeyPolicy",
        "kms:TagResource"
      ]
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_Decrypt.html",
      "name": "Decrypt",
      "description": "Controls permission to decrypt ciphertext that was encrypted under an AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:RecipientAttestation:ImageSha384",
        "kms:RecipientAttestation:NitroTPMPCR0",
        "kms:RecipientAttestation:NitroTPMPCR1",
        "kms:RecipientAttestation:NitroTPMPCR2",
        "kms:RecipientAttestation:NitroTPMPCR3",
        "kms:RecipientAttestation:NitroTPMPCR4",
        "kms:RecipientAttestation:NitroTPMPCR5",
        "kms:RecipientAttestation:NitroTPMPCR6",
        "kms:RecipientAttestation:NitroTPMPCR7",
        "kms:RecipientAttestation:NitroTPMPCR8",
        "kms:RecipientAttestation:NitroTPMPCR9",
        "kms:RecipientAttestation:NitroTPMPCR10",
        "kms:RecipientAttestation:NitroTPMPCR11",
        "kms:RecipientAttestation:NitroTPMPCR12",
        "kms:RecipientAttestation:NitroTPMPCR13",
        "kms:RecipientAttestation:NitroTPMPCR14",
        "kms:RecipientAttestation:NitroTPMPCR15",
        "kms:RecipientAttestation:NitroTPMPCR16",
        "kms:RecipientAttestation:NitroTPMPCR17",
        "kms:RecipientAttestation:NitroTPMPCR18",
        "kms:RecipientAttestation:NitroTPMPCR19",
        "kms:RecipientAttestation:NitroTPMPCR20",
        "kms:RecipientAttestation:NitroTPMPCR21",
        "kms:RecipientAttestation:NitroTPMPCR22",
        "kms:RecipientAttestation:NitroTPMPCR23",
        "kms:RecipientAttestation:PCR0",
        "kms:RecipientAttestation:PCR1",
        "kms:RecipientAttestation:PCR2",
        "kms:RecipientAttestation:PCR3",
        "kms:RecipientAttestation:PCR4",
        "kms:RecipientAttestation:PCR5",
        "kms:RecipientAttestation:PCR6",
        "kms:RecipientAttestation:PCR7",
        "kms:RecipientAttestation:PCR8",
        "kms:RecipientAttestation:PCR9",
        "kms:RecipientAttestation:PCR10",
        "kms:RecipientAttestation:PCR11",
        "kms:RecipientAttestation:PCR12",
        "kms:RecipientAttestation:PCR13",
        "kms:RecipientAttestation:PCR14",
        "kms:RecipientAttestation:PCR15",
        "kms:RecipientAttestation:PCR16",
        "kms:RecipientAttestation:PCR17",
        "kms:RecipientAttestation:PCR18",
        "kms:RecipientAttestation:PCR19",
        "kms:RecipientAttestation:PCR20",
        "kms:RecipientAttestation:PCR21",
        "kms:RecipientAttestation:PCR22",
        "kms:RecipientAttestation:PCR23",
        "kms:RecipientAttestation:PCR24",
        "kms:RecipientAttestation:PCR25",
        "kms:RecipientAttestation:PCR26",
        "kms:RecipientAttestation:PCR27",
        "kms:RecipientAttestation:PCR28",
        "kms:RecipientAttestation:PCR29",
        "kms:RecipientAttestation:PCR30",
        "kms:RecipientAttestation:PCR31",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DeleteAlias.html",
      "name": "DeleteAlias",
      "description": "Controls permission to delete an alias. Aliases are optional friendly names that you can associate with AWS KMS keys",
      "access": "Write",
      "resources": [
        {
          "name": "alias",
          "is_required": true
        },
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DeleteCustomKeyStore.html",
      "name": "DeleteCustomKeyStore",
      "description": "Controls permission to delete a custom key store",
      "access": "Write",
      "resources": [],
      "conditions": [
        "kms:CallerAccount"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DeleteImportedKeyMaterial.html",
      "name": "DeleteImportedKeyMaterial",
      "description": "Controls permission to delete cryptographic material that you imported into an AWS KMS key. This action makes the key unusable",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DeriveSharedSecret.html",
      "name": "DeriveSharedSecret",
      "description": "Controls permission to use the specified AWS KMS key to derive shared secrets",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:KeyAgreementAlgorithm",
        "kms:RecipientAttestation:ImageSha384",
        "kms:RecipientAttestation:NitroTPMPCR0",
        "kms:RecipientAttestation:NitroTPMPCR1",
        "kms:RecipientAttestation:NitroTPMPCR2",
        "kms:RecipientAttestation:NitroTPMPCR3",
        "kms:RecipientAttestation:NitroTPMPCR4",
        "kms:RecipientAttestation:NitroTPMPCR5",
        "kms:RecipientAttestation:NitroTPMPCR6",
        "kms:RecipientAttestation:NitroTPMPCR7",
        "kms:RecipientAttestation:NitroTPMPCR8",
        "kms:RecipientAttestation:NitroTPMPCR9",
        "kms:RecipientAttestation:NitroTPMPCR10",
        "kms:RecipientAttestation:NitroTPMPCR11",
        "kms:RecipientAttestation:NitroTPMPCR12",
        "kms:RecipientAttestation:NitroTPMPCR13",
        "kms:RecipientAttestation:NitroTPMPCR14",
        "kms:RecipientAttestation:NitroTPMPCR15",
        "kms:RecipientAttestation:NitroTPMPCR16",
        "kms:RecipientAttestation:NitroTPMPCR17",
        "kms:RecipientAttestation:NitroTPMPCR18",
        "kms:RecipientAttestation:NitroTPMPCR19",
        "kms:RecipientAttestation:NitroTPMPCR20",
        "kms:RecipientAttestation:NitroTPMPCR21",
        "kms:RecipientAttestation:NitroTPMPCR22",
        "kms:RecipientAttestation:NitroTPMPCR23",
        "kms:RecipientAttestation:PCR0",
        "kms:RecipientAttestation:PCR1",
        "kms:RecipientAttestation:PCR2",
        "kms:RecipientAttestation:PCR3",
        "kms:RecipientAttestation:PCR4",
        "kms:RecipientAttestation:PCR5",
        "kms:RecipientAttestation:PCR6",
        "kms:RecipientAttestation:PCR7",
        "kms:RecipientAttestation:PCR8",
        "kms:RecipientAttestation:PCR9",
        "kms:RecipientAttestation:PCR10",
        "kms:RecipientAttestation:PCR11",
        "kms:RecipientAttestation:PCR12",
        "kms:RecipientAttestation:PCR13",
        "kms:RecipientAttestation:PCR14",
        "kms:RecipientAttestation:PCR15",
        "kms:RecipientAttestation:PCR16",
        "kms:RecipientAttestation:PCR17",
        "kms:RecipientAttestation:PCR18",
        "kms:RecipientAttestation:PCR19",
        "kms:RecipientAttestation:PCR20",
        "kms:RecipientAttestation:PCR21",
        "kms:RecipientAttestation:PCR22",
        "kms:RecipientAttestation:PCR23",
        "kms:RecipientAttestation:PCR24",
        "kms:RecipientAttestation:PCR25",
        "kms:RecipientAttestation:PCR26",
        "kms:RecipientAttestation:PCR27",
        "kms:RecipientAttestation:PCR28",
        "kms:RecipientAttestation:PCR29",
        "kms:RecipientAttestation:PCR30",
        "kms:RecipientAttestation:PCR31",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DescribeCustomKeyStores.html",
      "name": "DescribeCustomKeyStores",
      "description": "Controls permission to view detailed information about custom key stores in the account and region",
      "access": "Read",
      "resources": [],
      "conditions": [
        "kms:CallerAccount"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DescribeKey.html",
      "name": "DescribeKey",
      "description": "Controls permission to view detailed information about an AWS KMS key",
      "access": "Read",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DisableKey.html",
      "name": "DisableKey",
      "description": "Controls permission to disable an AWS KMS key, which prevents it from being used in cryptographic operations",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:TrailingDaysWithoutKeyUsage",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DisableKeyRotation.html",
      "name": "DisableKeyRotation",
      "description": "Controls permission to disable automatic rotation of a customer managed AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_DisconnectCustomKeyStore.html",
      "name": "DisconnectCustomKeyStore",
      "description": "Controls permission to disconnect the custom key store from its associated AWS CloudHSM cluster or external key manager outside of AWS",
      "access": "Write",
      "resources": [],
      "conditions": [
        "kms:CallerAccount"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_EnableKey.html",
      "name": "EnableKey",
      "description": "Controls permission to change the state of an AWS KMS key to enabled. This allows the KMS key to be used in cryptographic operations",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_EnableKeyRotation.html",
      "name": "EnableKeyRotation",
      "description": "Controls permission to enable automatic rotation of the cryptographic material in an AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:RotationPeriodInDays",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_Encrypt.html",
      "name": "Encrypt",
      "description": "Controls permission to use the specified AWS KMS key to encrypt data and data keys",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GenerateDataKey.html",
      "name": "GenerateDataKey",
      "description": "Controls permission to use the AWS KMS key to generate data keys. You can use the data keys to encrypt data outside of AWS KMS",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:RecipientAttestation:ImageSha384",
        "kms:RecipientAttestation:NitroTPMPCR0",
        "kms:RecipientAttestation:NitroTPMPCR1",
        "kms:RecipientAttestation:NitroTPMPCR2",
        "kms:RecipientAttestation:NitroTPMPCR3",
        "kms:RecipientAttestation:NitroTPMPCR4",
        "kms:RecipientAttestation:NitroTPMPCR5",
        "kms:RecipientAttestation:NitroTPMPCR6",
        "kms:RecipientAttestation:NitroTPMPCR7",
        "kms:RecipientAttestation:NitroTPMPCR8",
        "kms:RecipientAttestation:NitroTPMPCR9",
        "kms:RecipientAttestation:NitroTPMPCR10",
        "kms:RecipientAttestation:NitroTPMPCR11",
        "kms:RecipientAttestation:NitroTPMPCR12",
        "kms:RecipientAttestation:NitroTPMPCR13",
        "kms:RecipientAttestation:NitroTPMPCR14",
        "kms:RecipientAttestation:NitroTPMPCR15",
        "kms:RecipientAttestation:NitroTPMPCR16",
        "kms:RecipientAttestation:NitroTPMPCR17",
        "kms:RecipientAttestation:NitroTPMPCR18",
        "kms:RecipientAttestation:NitroTPMPCR19",
        "kms:RecipientAttestation:NitroTPMPCR20",
        "kms:RecipientAttestation:NitroTPMPCR21",
        "kms:RecipientAttestation:NitroTPMPCR22",
        "kms:RecipientAttestation:NitroTPMPCR23",
        "kms:RecipientAttestation:PCR0",
        "kms:RecipientAttestation:PCR1",
        "kms:RecipientAttestation:PCR2",
        "kms:RecipientAttestation:PCR3",
        "kms:RecipientAttestation:PCR4",
        "kms:RecipientAttestation:PCR5",
        "kms:RecipientAttestation:PCR6",
        "kms:RecipientAttestation:PCR7",
        "kms:RecipientAttestation:PCR8",
        "kms:RecipientAttestation:PCR9",
        "kms:RecipientAttestation:PCR10",
        "kms:RecipientAttestation:PCR11",
        "kms:RecipientAttestation:PCR12",
        "kms:RecipientAttestation:PCR13",
        "kms:RecipientAttestation:PCR14",
        "kms:RecipientAttestation:PCR15",
        "kms:RecipientAttestation:PCR16",
        "kms:RecipientAttestation:PCR17",
        "kms:RecipientAttestation:PCR18",
        "kms:RecipientAttestation:PCR19",
        "kms:RecipientAttestation:PCR20",
        "kms:RecipientAttestation:PCR21",
        "kms:RecipientAttestation:PCR22",
        "kms:RecipientAttestation:PCR23",
        "kms:RecipientAttestation:PCR24",
        "kms:RecipientAttestation:PCR25",
        "kms:RecipientAttestation:PCR26",
        "kms:RecipientAttestation:PCR27",
        "kms:RecipientAttestation:PCR28",
        "kms:RecipientAttestation:PCR29",
        "kms:RecipientAttestation:PCR30",
        "kms:RecipientAttestation:PCR31",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GenerateDataKeyPair.html",
      "name": "GenerateDataKeyPair",
      "description": "Controls permission to use the AWS KMS key to generate data key pairs",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:DataKeyPairSpec",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:RecipientAttestation:ImageSha384",
        "kms:RecipientAttestation:NitroTPMPCR0",
        "kms:RecipientAttestation:NitroTPMPCR1",
        "kms:RecipientAttestation:NitroTPMPCR2",
        "kms:RecipientAttestation:NitroTPMPCR3",
        "kms:RecipientAttestation:NitroTPMPCR4",
        "kms:RecipientAttestation:NitroTPMPCR5",
        "kms:RecipientAttestation:NitroTPMPCR6",
        "kms:RecipientAttestation:NitroTPMPCR7",
        "kms:RecipientAttestation:NitroTPMPCR8",
        "kms:RecipientAttestation:NitroTPMPCR9",
        "kms:RecipientAttestation:NitroTPMPCR10",
        "kms:RecipientAttestation:NitroTPMPCR11",
        "kms:RecipientAttestation:NitroTPMPCR12",
        "kms:RecipientAttestation:NitroTPMPCR13",
        "kms:RecipientAttestation:NitroTPMPCR14",
        "kms:RecipientAttestation:NitroTPMPCR15",
        "kms:RecipientAttestation:NitroTPMPCR16",
        "kms:RecipientAttestation:NitroTPMPCR17",
        "kms:RecipientAttestation:NitroTPMPCR18",
        "kms:RecipientAttestation:NitroTPMPCR19",
        "kms:RecipientAttestation:NitroTPMPCR20",
        "kms:RecipientAttestation:NitroTPMPCR21",
        "kms:RecipientAttestation:NitroTPMPCR22",
        "kms:RecipientAttestation:NitroTPMPCR23",
        "kms:RecipientAttestation:PCR0",
        "kms:RecipientAttestation:PCR1",
        "kms:RecipientAttestation:PCR2",
        "kms:RecipientAttestation:PCR3",
        "kms:RecipientAttestation:PCR4",
        "kms:RecipientAttestation:PCR5",
        "kms:RecipientAttestation:PCR6",
        "kms:RecipientAttestation:PCR7",
        "kms:RecipientAttestation:PCR8",
        "kms:RecipientAttestation:PCR9",
        "kms:RecipientAttestation:PCR10",
        "kms:RecipientAttestation:PCR11",
        "kms:RecipientAttestation:PCR12",
        "kms:RecipientAttestation:PCR13",
        "kms:RecipientAttestation:PCR14",
        "kms:RecipientAttestation:PCR15",
        "kms:RecipientAttestation:PCR16",
        "kms:RecipientAttestation:PCR17",
        "kms:RecipientAttestation:PCR18",
        "kms:RecipientAttestation:PCR19",
        "kms:RecipientAttestation:PCR20",
        "kms:RecipientAttestation:PCR21",
        "kms:RecipientAttestation:PCR22",
        "kms:RecipientAttestation:PCR23",
        "kms:RecipientAttestation:PCR24",
        "kms:RecipientAttestation:PCR25",
        "kms:RecipientAttestation:PCR26",
        "kms:RecipientAttestation:PCR27",
        "kms:RecipientAttestation:PCR28",
        "kms:RecipientAttestation:PCR29",
        "kms:RecipientAttestation:PCR30",
        "kms:RecipientAttestation:PCR31",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GenerateDataKeyPairWithoutPlaintext.html",
      "name": "GenerateDataKeyPairWithoutPlaintext",
      "description": "Controls permission to use the AWS KMS key to generate data key pairs. Unlike the GenerateDataKeyPair operation, this operation returns an encrypted private key without a plaintext copy",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:DataKeyPairSpec",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GenerateDataKeyWithoutPlaintext.html",
      "name": "GenerateDataKeyWithoutPlaintext",
      "description": "Controls permission to use the AWS KMS key to generate a data key. Unlike the GenerateDataKey operation, this operation returns an encrypted data key without a plaintext version of the data key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GenerateMac.html",
      "name": "GenerateMac",
      "description": "Controls permission to use the AWS KMS key to generate message authentication codes",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:MacAlgorithm",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GenerateRandom.html",
      "name": "GenerateRandom",
      "description": "Controls permission to get a cryptographically secure random byte string from AWS KMS",
      "access": "Write",
      "resources": [],
      "conditions": [
        "kms:RecipientAttestation:ImageSha384",
        "kms:RecipientAttestation:NitroTPMPCR0",
        "kms:RecipientAttestation:NitroTPMPCR1",
        "kms:RecipientAttestation:NitroTPMPCR2",
        "kms:RecipientAttestation:NitroTPMPCR3",
        "kms:RecipientAttestation:NitroTPMPCR4",
        "kms:RecipientAttestation:NitroTPMPCR5",
        "kms:RecipientAttestation:NitroTPMPCR6",
        "kms:RecipientAttestation:NitroTPMPCR7",
        "kms:RecipientAttestation:NitroTPMPCR8",
        "kms:RecipientAttestation:NitroTPMPCR9",
        "kms:RecipientAttestation:NitroTPMPCR10",
        "kms:RecipientAttestation:NitroTPMPCR11",
        "kms:RecipientAttestation:NitroTPMPCR12",
        "kms:RecipientAttestation:NitroTPMPCR13",
        "kms:RecipientAttestation:NitroTPMPCR14",
        "kms:RecipientAttestation:NitroTPMPCR15",
        "kms:RecipientAttestation:NitroTPMPCR16",
        "kms:RecipientAttestation:NitroTPMPCR17",
        "kms:RecipientAttestation:NitroTPMPCR18",
        "kms:RecipientAttestation:NitroTPMPCR19",
        "kms:RecipientAttestation:NitroTPMPCR20",
        "kms:RecipientAttestation:NitroTPMPCR21",
        "kms:RecipientAttestation:NitroTPMPCR22",
        "kms:RecipientAttestation:NitroTPMPCR23",
        "kms:RecipientAttestation:PCR0",
        "kms:RecipientAttestation:PCR1",
        "kms:RecipientAttestation:PCR2",
        "kms:RecipientAttestation:PCR3",
        "kms:RecipientAttestation:PCR4",
        "kms:RecipientAttestation:PCR5",
        "kms:RecipientAttestation:PCR6",
        "kms:RecipientAttestation:PCR7",
        "kms:RecipientAttestation:PCR8",
        "kms:RecipientAttestation:PCR9",
        "kms:RecipientAttestation:PCR10",
        "kms:RecipientAttestation:PCR11",
        "kms:RecipientAttestation:PCR12",
        "kms:RecipientAttestation:PCR13",
        "kms:RecipientAttestation:PCR14",
        "kms:RecipientAttestation:PCR15",
        "kms:RecipientAttestation:PCR16",
        "kms:RecipientAttestation:PCR17",
        "kms:RecipientAttestation:PCR18",
        "kms:RecipientAttestation:PCR19",
        "kms:RecipientAttestation:PCR20",
        "kms:RecipientAttestation:PCR21",
        "kms:RecipientAttestation:PCR22",
        "kms:RecipientAttestation:PCR23",
        "kms:RecipientAttestation:PCR24",
        "kms:RecipientAttestation:PCR25",
        "kms:RecipientAttestation:PCR26",
        "kms:RecipientAttestation:PCR27",
        "kms:RecipientAttestation:PCR28",
        "kms:RecipientAttestation:PCR29",
        "kms:RecipientAttestation:PCR30",
        "kms:RecipientAttestation:PCR31"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GetKeyLastUsage.html",
      "name": "GetKeyLastUsage",
      "description": "Controls permission to view the last usage of an AWS KMS key",
      "access": "Read",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GetKeyPolicy.html",
      "name": "GetKeyPolicy",
      "description": "Controls permission to view the key policy for the specified AWS KMS key",
      "access": "Read",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GetKeyRotationStatus.html",
      "name": "GetKeyRotationStatus",
      "description": "Controls permission to view the key rotation status for an AWS KMS key",
      "access": "Read",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GetParametersForImport.html",
      "name": "GetParametersForImport",
      "description": "Controls permission to get data that is required to import cryptographic material into a customer managed key, including a public key and import token",
      "access": "Read",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService",
        "kms:WrappingAlgorithm",
        "kms:WrappingKeySpec"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_GetPublicKey.html",
      "name": "GetPublicKey",
      "description": "Controls permission to download the public key of an asymmetric AWS KMS key",
      "access": "Read",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ImportKeyMaterial.html",
      "name": "ImportKeyMaterial",
      "description": "Controls permission to import cryptographic material into an AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ExpirationModel",
        "kms:ValidTo",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ListAliases.html",
      "name": "ListAliases",
      "description": "Controls permission to view the aliases that are defined in the account. Aliases are optional friendly names that you can associate with AWS KMS keys",
      "access": "List",
      "resources": [],
      "conditions": [],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ListGrants.html",
      "name": "ListGrants",
      "description": "Controls permission to view all grants for an AWS KMS key",
      "access": "List",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:GrantIsForAWSResource",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ListKeyPolicies.html",
      "name": "ListKeyPolicies",
      "description": "Controls permission to view the names of key policies for an AWS KMS key",
      "access": "List",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ListKeyRotations.html",
      "name": "ListKeyRotations",
      "description": "Controls permission to view the list of key materials for an AWS KMS key",
      "access": "List",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ListKeys.html",
      "name": "ListKeys",
      "description": "Controls permission to view the key ID and Amazon Resource Name (ARN) of all AWS KMS keys in the account",
      "access": "List",
      "resources": [],
      "conditions": [],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ListResourceTags.html",
      "name": "ListResourceTags",
      "description": "Controls permission to view all tags that are attached to an AWS KMS key",
      "access": "List",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ListRetirableGrants.html",
      "name": "ListRetirableGrants",
      "description": "Controls permission to view grants in which the specified principal is the retiring principal. Other principals might be able to retire the grant and this principal might be able to retire other grants",
      "access": "List",
      "resources": [],
      "conditions": [],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_PutKeyPolicy.html",
      "name": "PutKeyPolicy",
      "description": "Controls permission to replace the key policy for the specified AWS KMS key",
      "access": "Permissions management",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:BypassPolicyLockoutSafetyCheck",
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ReEncrypt.html",
      "name": "ReEncryptFrom",
      "description": "Controls permission to decrypt data as part of the process that decrypts and reencrypts the data within AWS KMS",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:ReEncryptOnSameKey",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ReEncrypt.html",
      "name": "ReEncryptTo",
      "description": "Controls permission to encrypt data as part of the process that decrypts and reencrypts the data within AWS KMS",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionAlgorithm",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:ReEncryptOnSameKey",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ReplicateKey.html",
      "name": "ReplicateKey",
      "description": "Controls permission to replicate a multi-Region primary key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ReplicaRegion",
        "kms:ViaService"
      ],
      "dependents": [
        "iam:CreateServiceLinkedRole",
        "kms:CreateKey",
        "kms:PutKeyPolicy",
        "kms:TagResource"
      ]
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_RetireGrant.html",
      "name": "RetireGrant",
      "description": "Controls permission to retire a grant. The RetireGrant operation is typically called by the grant user after they complete the tasks that the grant allowed them to perform",
      "access": "Permissions management",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:EncryptionContext:${EncryptionContextKey}",
        "kms:EncryptionContextKeys",
        "kms:GrantConstraintType",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_RevokeGrant.html",
      "name": "RevokeGrant",
      "description": "Controls permission to revoke a grant, which denies permission for all operations that depend on the grant",
      "access": "Permissions management",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:GrantIsForAWSResource",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_RotateKeyOnDemand.html",
      "name": "RotateKeyOnDemand",
      "description": "Controls permission to invoke on-demand rotation of the cryptographic material in an AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_ScheduleKeyDeletion.html",
      "name": "ScheduleKeyDeletion",
      "description": "Controls permission to schedule deletion of an AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ScheduleKeyDeletionPendingWindowInDays",
        "kms:TrailingDaysWithoutKeyUsage",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_Sign.html",
      "name": "Sign",
      "description": "Controls permission to produce a digital signature for a message",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:MessageType",
        "kms:RequestAlias",
        "kms:SigningAlgorithm",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/multi-region-keys-auth.html#multi-region-auth-slr",
      "name": "SynchronizeMultiRegionKey",
      "description": "Controls access to internal APIs that synchronize multi-Region keys",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_TagResource.html",
      "name": "TagResource",
      "description": "Controls permission to create or update tags that are attached to an AWS KMS key",
      "access": "Tagging",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "aws:RequestTag/${TagKey}",
        "aws:TagKeys",
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_UntagResource.html",
      "name": "UntagResource",
      "description": "Controls permission to delete tags that are attached to an AWS KMS key",
      "access": "Tagging",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "aws:TagKeys",
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_UpdateAlias.html",
      "name": "UpdateAlias",
      "description": "Controls permission to associate an alias with a different AWS KMS key. An alias is an optional friendly name that you can associate with a KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "alias",
          "is_required": true
        },
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_UpdateCustomKeyStore.html",
      "name": "UpdateCustomKeyStore",
      "description": "Controls permission to change the properties of a custom key store",
      "access": "Write",
      "resources": [],
      "conditions": [
        "kms:CallerAccount"
      ],
      "dependents": [
        "ec2:DescribeVpcEndpointServices"
      ]
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_UpdateKeyDescription.html",
      "name": "UpdateKeyDescription",
      "description": "Controls permission to delete or change the description of an AWS KMS key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_UpdatePrimaryRegion.html",
      "name": "UpdatePrimaryRegion",
      "description": "Controls permission to update the primary Region of a multi-Region primary key",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:PrimaryRegion",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_Verify.html",
      "name": "Verify",
      "description": "Controls permission to use the specified AWS KMS key to verify digital signatures",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:MessageType",
        "kms:RequestAlias",
        "kms:SigningAlgorithm",
        "kms:ViaService"
      ],
      "dependents": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/APIReference/API_VerifyMac.html",
      "name": "VerifyMac",
      "description": "Controls permission to use the AWS KMS key to verify message authentication codes",
      "access": "Write",
      "resources": [
        {
          "name": "key",
          "is_required": true
        }
      ],
      "conditions": [
        "kms:CallerAccount",
        "kms:MacAlgorithm",
        "kms:RequestAlias",
        "kms:ViaService"
      ],
      "dependents": []
    }
  ],
  "resources": [
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#alias-concept",
      "name": "alias",
      "arn": "arn:${Partition}:kms:${Region}:${Account}:alias/${Alias}",
      "conditions": []
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#kms_keys",
      "name": "key",
      "arn": "arn:${Partition}:kms:${Region}:${Account}:key/${KeyId}",
      "conditions": [
        "aws:ResourceTag/${TagKey}",
        "kms:KeyOrigin",
        "kms:KeySpec",
        "kms:KeyUsage",
        "kms:MultiRegion",
        "kms:MultiRegionKeyType",
        "kms:ResourceAliases"
      ]
    }
  ],
  "conditions": [
    {
      "url": "https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-requesttag",
      "name": "aws:RequestTag/${TagKey}",
      "description": "Filters access to the specified AWS KMS operations based on both the key and value of the tag in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/tag-authorization.html",
      "name": "aws:ResourceTag/${TagKey}",
      "description": "Filters access to the specified AWS KMS operations based on tags assigned to the AWS KMS key",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-tagkeys",
      "name": "aws:TagKeys",
      "description": "Filters access to the specified AWS KMS operations based on tag keys in the request",
      "type": "ArrayOfString"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-bypass-policy-lockout-safety-check",
      "name": "kms:BypassPolicyLockoutSafetyCheck",
      "description": "Filters access to the CreateKey and PutKeyPolicy operations based on the value of the BypassPolicyLockoutSafetyCheck parameter in the request",
      "type": "Bool"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-caller-account",
      "name": "kms:CallerAccount",
      "description": "Filters access to specified AWS KMS operations based on the AWS account ID of the caller. You can use this condition key to allow or deny access to all IAM users and roles in an AWS account in a single policy statement",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-key-spec-replaced",
      "name": "kms:CustomerMasterKeySpec",
      "description": "The kms:CustomerMasterKeySpec condition key is deprecated. Instead, use the kms:KeySpec condition key",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-key-usage-replaced",
      "name": "kms:CustomerMasterKeyUsage",
      "description": "The kms:CustomerMasterKeyUsage condition key is deprecated. Instead, use the kms:KeyUsage condition key",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-data-key-pair-spec",
      "name": "kms:DataKeyPairSpec",
      "description": "Filters access to GenerateDataKeyPair and GenerateDataKeyPairWithoutPlaintext operations based on the value of the KeyPairSpec parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-encryption-algorithm",
      "name": "kms:EncryptionAlgorithm",
      "description": "Filters access to encryption operations based on the value of the encryption algorithm in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-encryption-context",
      "name": "kms:EncryptionContext:${EncryptionContextKey}",
      "description": "Filters access to a symmetric AWS KMS key based on the encryption context in a cryptographic operation. This condition evaluates the key and value in each key-value encryption context pair",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-encryption-context-keys",
      "name": "kms:EncryptionContextKeys",
      "description": "Filters access to a symmetric AWS KMS key based on the encryption context in a cryptographic operation. This condition key evaluates only the key in each key-value encryption context pair",
      "type": "ArrayOfString"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-expiration-model",
      "name": "kms:ExpirationModel",
      "description": "Filters access to the ImportKeyMaterial operation based on the value of the ExpirationModel parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-grant-constraint-type",
      "name": "kms:GrantConstraintType",
      "description": "Filters access to the CreateGrant operation based on the grant constraint in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-grant-is-for-aws-resource",
      "name": "kms:GrantIsForAWSResource",
      "description": "Filters access to the CreateGrant operation when the request comes from a specified AWS service",
      "type": "Bool"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-grant-operations",
      "name": "kms:GrantOperations",
      "description": "Filters access to the CreateGrant operation based on the operations in the grant",
      "type": "ArrayOfString"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-grantee-principal",
      "name": "kms:GranteePrincipal",
      "description": "Filters access to the CreateGrant operation based on the grantee principal in the grant",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-key-agreement-algorithm",
      "name": "kms:KeyAgreementAlgorithm",
      "description": "Filters access to the DeriveSharedSecret operation based on the value of the KeyAgreementAlgorithm parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-key-origin",
      "name": "kms:KeyOrigin",
      "description": "Filters access to an API operation based on the Origin property of the AWS KMS key created by or used in the operation. Use it to qualify authorization of the CreateKey operation or any operation that is authorized for a KMS key",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-key-spec",
      "name": "kms:KeySpec",
      "description": "Filters access to an API operation based on the KeySpec property of the AWS KMS key that is created by or used in the operation. Use it to qualify authorization of the CreateKey operation or any operation that is authorized for a KMS key resource",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-key-usage",
      "name": "kms:KeyUsage",
      "description": "Filters access to an API operation based on the KeyUsage property of the AWS KMS key created by or used in the operation. Use it to qualify authorization of the CreateKey operation or any operation that is authorized for a KMS key resource",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-mac-algorithm",
      "name": "kms:MacAlgorithm",
      "description": "Filters access to the GenerateMac and VerifyMac operations based on the MacAlgorithm parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-message-type",
      "name": "kms:MessageType",
      "description": "Filters access to the Sign and Verify operations based on the value of the MessageType parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-multi-region",
      "name": "kms:MultiRegion",
      "description": "Filters access to an API operation based on the MultiRegion property of the AWS KMS key created by or used in the operation. Use it to qualify authorization of the CreateKey operation or any operation that is authorized for a KMS key resource",
      "type": "Bool"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-multi-region-key-type",
      "name": "kms:MultiRegionKeyType",
      "description": "Filters access to an API operation based on the MultiRegionKeyType property of the AWS KMS key created by or used in the operation. Use it to qualify authorization of the CreateKey operation or any operation that is authorized for a KMS key resource",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-primary-region",
      "name": "kms:PrimaryRegion",
      "description": "Filters access to the UpdatePrimaryRegion operation based on the value of the PrimaryRegion parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-reencrypt-on-same-key",
      "name": "kms:ReEncryptOnSameKey",
      "description": "Filters access to the ReEncrypt operation when it uses the same AWS KMS key that was used for the Encrypt operation",
      "type": "Bool"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-image-sha",
      "name": "kms:RecipientAttestation:ImageSha384",
      "description": "Filters access to the API operations based on the image hash in the attestation document in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR0",
      "description": "Filters access by the platform configuration register (PCR) 0 in the attestation document in the request. PCR0 is a contiguous measure of core system firmware executable code",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR1",
      "description": "Filters access by the platform configuration register (PCR) 1 in the attestation document in the request. PCR1 is a contiguous measure of core system firmware data/host platform configuration, typically including serial and model numbers",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR10",
      "description": "Filters access by the platform configuration register (PCR) 10 in the attestation document in the request. PCR10 is a contiguous measure of protection of the IMA measurement log",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR11",
      "description": "Filters access by the platform configuration register (PCR) 11 in the attestation document in the request. PCR11 is a contiguous measure of all components of unified kernel images (UKIs)",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR12",
      "description": "Filters access by the platform configuration register (PCR) 12 in the attestation document in the request. PCR12 is a contiguous measure of kernel command line, system credentials and system configuration images",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR13",
      "description": "Filters access by the platform configuration register (PCR) 13 in the attestation document in the request. PCR13 is a contiguous measure of all system extension images for the initrd",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR14",
      "description": "Filters access by the platform configuration register (PCR) 14 in the attestation document in the request. PCR14 is a contiguous measure of \"MOK\" certificates and hashes",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR15",
      "description": "Filters access by the platform configuration register (PCR) 15 in the attestation document in the request. PCR15 is a contiguous measure of root file system volume encryption key",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR16",
      "description": "Filters access by the platform configuration register (PCR) 16 in the attestation document in the request. PCR16 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR17",
      "description": "Filters access by the platform configuration register (PCR) 17 in the attestation document in the request. PCR17 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR18",
      "description": "Filters access by the platform configuration register (PCR) 18 in the attestation document in the request. PCR18 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR19",
      "description": "Filters access by the platform configuration register (PCR) 19 in the attestation document in the request. PCR19 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR2",
      "description": "Filters access by the platform configuration register (PCR) 2 in the attestation document in the request. PCR2 is a contiguous measure of extended or pluggable executable code, including option ROMs on pluggable hardware",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR20",
      "description": "Filters access by the platform configuration register (PCR) 20 in the attestation document in the request. PCR20 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR21",
      "description": "Filters access by the platform configuration register (PCR) 21 in the attestation document in the request. PCR21 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR22",
      "description": "Filters access by the platform configuration register (PCR) 22 in the attestation document in the request. PCR22 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR23",
      "description": "Filters access by the platform configuration register (PCR) 23 in the attestation document in the request. PCR23 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR3",
      "description": "Filters access by the platform configuration register (PCR) 3 in the attestation document in the request. PCR3 is a contiguous measure of extended or pluggable firmware data, including information about pluggable hardware",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR4",
      "description": "Filters access by the platform configuration register (PCR) 4 in the attestation document in the request. PCR4 is a contiguous measure of boot loader and additional drivers, including binaries and extensions loaded by the boot loader",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR5",
      "description": "Filters access by the platform configuration register (PCR) 5 in the attestation document in the request. PCR5 is a contiguous measure of GPT/Partition table",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR6",
      "description": "Filters access by the platform configuration register (PCR) 6 in the attestation document in the request. PCR6 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR7",
      "description": "Filters access by the platform configuration register (PCR) 7 in the attestation document in the request. PCR7 is a contiguous measure of SecureBoot state",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR8",
      "description": "Filters access by the platform configuration register (PCR) 8 in the attestation document in the request. PCR8 is a contiguous measure of commands and kernel command line",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-tpm.html#conditions-kms-recipient-nitro-tpm-pcrs",
      "name": "kms:RecipientAttestation:NitroTPMPCR9",
      "description": "Filters access by the platform configuration register (PCR) 9 in the attestation document in the request. PCR9 is a contiguous measure of all files read (including kernel image)",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR0",
      "description": "Filters access by the platform configuration register (PCR) 0 in the attestation document in the request. PCR0 is a contiguous measure of the contents of the enclave image file, without the section data",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR1",
      "description": "Filters access by the platform configuration register (PCR) 1 in the attestation document in the request. PCR1 is a contiguous measurement of the Linux kernel and bootstrap data",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR10",
      "description": "Filters access by the platform configuration register (PCR) 10 in the attestation document in the request. PCR10 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR11",
      "description": "Filters access by the platform configuration register (PCR) 11 in the attestation document in the request. PCR11 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR12",
      "description": "Filters access by the platform configuration register (PCR) 12 in the attestation document in the request. PCR12 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR13",
      "description": "Filters access by the platform configuration register (PCR) 13 in the attestation document in the request. PCR13 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR14",
      "description": "Filters access by the platform configuration register (PCR) 14 in the attestation document in the request. PCR14 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR15",
      "description": "Filters access by the platform configuration register (PCR) 15 in the attestation document in the request. PCR15 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR16",
      "description": "Filters access by the platform configuration register (PCR) 16 in the attestation document in the request. PCR16 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR17",
      "description": "Filters access by the platform configuration register (PCR) 17 in the attestation document in the request. PCR17 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR18",
      "description": "Filters access by the platform configuration register (PCR) 18 in the attestation document in the request. PCR18 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR19",
      "description": "Filters access by the platform configuration register (PCR) 19 in the attestation document in the request. PCR19 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR2",
      "description": "Filters access by the platform configuration register (PCR) 2 in the attestation document in the request. PCR2 is a contiguous, in-order measurement of the user applications, without the boot ramfs",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR20",
      "description": "Filters access by the platform configuration register (PCR) 20 in the attestation document in the request. PCR20 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR21",
      "description": "Filters access by the platform configuration register (PCR) 21 in the attestation document in the request. PCR21 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR22",
      "description": "Filters access by the platform configuration register (PCR) 22 in the attestation document in the request. PCR22 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR23",
      "description": "Filters access by the platform configuration register (PCR) 23 in the attestation document in the request. PCR23 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR24",
      "description": "Filters access by the platform configuration register (PCR) 24 in the attestation document in the request. PCR24 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR25",
      "description": "Filters access by the platform configuration register (PCR) 25 in the attestation document in the request. PCR25 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR26",
      "description": "Filters access by the platform configuration register (PCR) 26 in the attestation document in the request. PCR26 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR27",
      "description": "Filters access by the platform configuration register (PCR) 27 in the attestation document in the request. PCR27 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR28",
      "description": "Filters access by the platform configuration register (PCR) 28 in the attestation document in the request. PCR28 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR29",
      "description": "Filters access by the platform configuration register (PCR) 29 in the attestation document in the request. PCR29 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR3",
      "description": "Filters access by the platform configuration register (PCR) 3 in the attestation document in the request. PCR3 is a contiguous measurement of the IAM role assigned to the parent instance",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR30",
      "description": "Filters access by the platform configuration register (PCR) 30 in the attestation document in the request. PCR30 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR31",
      "description": "Filters access by the platform configuration register (PCR) 31 in the attestation document in the request. PCR31 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR4",
      "description": "Filters access by the platform configuration register (PCR) 4 in the attestation document in the request. PCR4 is a contiguous measurement of the ID of the parent instance",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR5",
      "description": "Filters access by the platform configuration register (PCR) 5 in the attestation document in the request. PCR5 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR6",
      "description": "Filters access by the platform configuration register (PCR) 6 in the attestation document in the request. PCR6 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR7",
      "description": "Filters access by the platform configuration register (PCR) 7 in the attestation document in the request. PCR7 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR8",
      "description": "Filters access by the platform configuration register (PCR) 8 in the attestation document in the request. PCR8 is a measure of the signing certificate specified for the enclave image file",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-nitro-enclaves.html#conditions-kms-recipient-pcrs",
      "name": "kms:RecipientAttestation:PCR9",
      "description": "Filters access by the platform configuration register (PCR) 9 in the attestation document in the request. PCR9 is a custom PCR that can be defined by the user for specific use cases",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-replica-region",
      "name": "kms:ReplicaRegion",
      "description": "Filters access to the ReplicateKey operation based on the value of the ReplicaRegion parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-request-alias",
      "name": "kms:RequestAlias",
      "description": "Filters access to cryptographic operations, DescribeKey, and GetPublicKey based on the alias in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-resource-aliases",
      "name": "kms:ResourceAliases",
      "description": "Filters access to specified AWS KMS operations based on aliases associated with the AWS KMS key",
      "type": "ArrayOfString"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-retiring-principal",
      "name": "kms:RetiringPrincipal",
      "description": "Filters access to the CreateGrant operation based on the retiring principal in the grant",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-rotation-period-in-days",
      "name": "kms:RotationPeriodInDays",
      "description": "Filters access to the EnableKeyRotation operation based on the value of the RotationPeriodInDays parameter in the request",
      "type": "Numeric"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-schedule-key-deletion-pending-window-in-days",
      "name": "kms:ScheduleKeyDeletionPendingWindowInDays",
      "description": "Filters access to the ScheduleKeyDeletion operation based on the value of the PendingWindowInDays parameter in the request",
      "type": "Numeric"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-signing-algorithm",
      "name": "kms:SigningAlgorithm",
      "description": "Filters access to the Sign and Verify operations based on the signing algorithm in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-trailing-days-without-key-usage",
      "name": "kms:TrailingDaysWithoutKeyUsage",
      "description": "Filters access to the ScheduleKeyDeletion and DisableKey operations based on the number of days since the AWS KMS key was last used",
      "type": "Numeric"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-valid-to",
      "name": "kms:ValidTo",
      "description": "Filters access to the ImportKeyMaterial operation based on the value of the ValidTo parameter in the request. You can use this condition key to allow users to import key material only when it expires by the specified date",
      "type": "Date"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-via-service",
      "name": "kms:ViaService",
      "description": "Filters access when a request made on the principal's behalf comes from a specified AWS service",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-wrapping-algorithm",
      "name": "kms:WrappingAlgorithm",
      "description": "Filters access to the GetParametersForImport operation based on the value of the WrappingAlgorithm parameter in the request",
      "type": "String"
    },
    {
      "url": "https://docs.aws.amazon.com/kms/latest/developerguide/conditions-kms.html#conditions-kms-wrapping-key-spec",
      "name": "kms:WrappingKeySpec",
      "description": "Filters access to the GetParametersForImport operation based on the value of the WrappingKeySpec parameter in the request",
      "type": "String"
    }
  ]
}