public enum CryptoKeyVersionAlgorithm
The algorithm of the [CryptoKeyVersion][google.cloud.kms.v1.CryptoKeyVersion], indicating what parameters must be used for each cryptographic operation.
The [GOOGLE_SYMMETRIC_ENCRYPTION][google.cloud.kms.v1.CryptoKeyVersion.CryptoKeyVersionAlgorithm.GOOGLE_SYMMETRIC_ENCRYPTION] algorithm is usable with [CryptoKey.purpose][google.cloud.kms.v1.CryptoKey.purpose] [ENCRYPT_DECRYPT][google.cloud.kms.v1.CryptoKey.CryptoKeyPurpose.ENCRYPT_DECRYPT].
Algorithms beginning with "RSA_SIGN_" are usable with [CryptoKey.purpose][google.cloud.kms.v1.CryptoKey.purpose] [ASYMMETRIC_SIGN][google.cloud.kms.v1.CryptoKey.CryptoKeyPurpose.ASYMMETRIC_SIGN].
The fields in the name after "RSA_SIGN_" correspond to the following parameters: padding algorithm, modulus bit length, and digest algorithm.
For PSS, the salt length used is equal to the length of digest algorithm. For example, [RSA_SIGN_PSS_2048_SHA256][google.cloud.kms.v1.CryptoKeyVersion.CryptoKeyVersionAlgorithm.RSA_SIGN_PSS_2048_SHA256] will use PSS with a salt length of 256 bits or 32 bytes.
Algorithms beginning with "RSA_DECRYPT_" are usable with [CryptoKey.purpose][google.cloud.kms.v1.CryptoKey.purpose] [ASYMMETRIC_DECRYPT][google.cloud.kms.v1.CryptoKey.CryptoKeyPurpose.ASYMMETRIC_DECRYPT].
The fields in the name after "RSA_DECRYPT_" correspond to the following parameters: padding algorithm, modulus bit length, and digest algorithm.
Algorithms beginning with "EC_SIGN_" are usable with [CryptoKey.purpose][google.cloud.kms.v1.CryptoKey.purpose] [ASYMMETRIC_SIGN][google.cloud.kms.v1.CryptoKey.CryptoKeyPurpose.ASYMMETRIC_SIGN].
The fields in the name after "EC_SIGN_" correspond to the following parameters: elliptic curve, digest algorithm.
Algorithms beginning with "HMAC_" are usable with [CryptoKey.purpose][google.cloud.kms.v1.CryptoKey.purpose] [MAC][google.cloud.kms.v1.CryptoKey.CryptoKeyPurpose.MAC].
The suffix following "HMAC_" corresponds to the hash algorithm being used (eg. SHA256).
For more information, see Key purposes and algorithms.
Namespace
Google.Cloud.Kms.V1Assembly
Google.Cloud.Kms.V1.dll
Fields | |
---|---|
Name | Description |
EcSignP256Sha256 | ECDSA on the NIST P-256 curve with a SHA256 digest. |
EcSignP384Sha384 | ECDSA on the NIST P-384 curve with a SHA384 digest. |
EcSignSecp256K1Sha256 | ECDSA on the non-NIST secp256k1 curve. This curve is only supported for HSM protection level. |
ExternalSymmetricEncryption | Algorithm representing symmetric encryption by an external key manager. |
GoogleSymmetricEncryption | Creates symmetric encryption keys. |
HmacSha256 | HMAC-SHA256 signing with a 256 bit key. |
RsaDecryptOaep2048Sha256 | RSAES-OAEP 2048 bit key with a SHA256 digest. |
RsaDecryptOaep3072Sha256 | RSAES-OAEP 3072 bit key with a SHA256 digest. |
RsaDecryptOaep4096Sha256 | RSAES-OAEP 4096 bit key with a SHA256 digest. |
RsaDecryptOaep4096Sha512 | RSAES-OAEP 4096 bit key with a SHA512 digest. |
RsaSignPkcs12048Sha256 | RSASSA-PKCS1-v1_5 with a 2048 bit key and a SHA256 digest. |
RsaSignPkcs13072Sha256 | RSASSA-PKCS1-v1_5 with a 3072 bit key and a SHA256 digest. |
RsaSignPkcs14096Sha256 | RSASSA-PKCS1-v1_5 with a 4096 bit key and a SHA256 digest. |
RsaSignPkcs14096Sha512 | RSASSA-PKCS1-v1_5 with a 4096 bit key and a SHA512 digest. |
RsaSignPss2048Sha256 | RSASSA-PSS 2048 bit key with a SHA256 digest. |
RsaSignPss3072Sha256 | RSASSA-PSS 3072 bit key with a SHA256 digest. |
RsaSignPss4096Sha256 | RSASSA-PSS 4096 bit key with a SHA256 digest. |
RsaSignPss4096Sha512 | RSASSA-PSS 4096 bit key with a SHA512 digest. |
Unspecified | Not specified. |