public sealed class AsymmetricDecryptResponse : IMessage<AsymmetricDecryptResponse>, IEquatable<AsymmetricDecryptResponse>, IDeepCloneable<AsymmetricDecryptResponse>, IBufferMessage, IMessage
Reference documentation and code samples for the Google Cloud Key Management Service v1 API class AsymmetricDecryptResponse.
Response message for
[KeyManagementService.AsymmetricDecrypt][google.cloud.kms.v1.KeyManagementService.AsymmetricDecrypt].
Integrity verification field. A CRC32C checksum of the returned
[AsymmetricDecryptResponse.plaintext][google.cloud.kms.v1.AsymmetricDecryptResponse.plaintext].
An integrity check of
[AsymmetricDecryptResponse.plaintext][google.cloud.kms.v1.AsymmetricDecryptResponse.plaintext]
can be performed by computing the CRC32C checksum of
[AsymmetricDecryptResponse.plaintext][google.cloud.kms.v1.AsymmetricDecryptResponse.plaintext]
and comparing your results to this field. Discard the response in case of
non-matching checksum values, and perform a limited number of retries. A
persistent mismatch may indicate an issue in your computation of the CRC32C
checksum. Note: This field is defined as int64 for reasons of compatibility
across different languages. However, it is a non-negative integer, which
will never exceed 2^32-1, and can be safely downconverted to uint32 in
languages that support this type.
Property Value
Type
Description
System.Int64
ProtectionLevel
public ProtectionLevel ProtectionLevel { get; set; }
The [ProtectionLevel][google.cloud.kms.v1.ProtectionLevel] of the
[CryptoKeyVersion][google.cloud.kms.v1.CryptoKeyVersion] used in
decryption.
public bool VerifiedCiphertextCrc32C { get; set; }
Integrity verification field. A flag indicating whether
[AsymmetricDecryptRequest.ciphertext_crc32c][google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext_crc32c]
was received by
[KeyManagementService][google.cloud.kms.v1.KeyManagementService] and used
for the integrity verification of the
[ciphertext][google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext]. A
false value of this field indicates either that
[AsymmetricDecryptRequest.ciphertext_crc32c][google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext_crc32c]
was left unset or that it was not delivered to
[KeyManagementService][google.cloud.kms.v1.KeyManagementService]. If you've
set
[AsymmetricDecryptRequest.ciphertext_crc32c][google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext_crc32c]
but this field is still false, discard the response and perform a limited
number of retries.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-07 UTC."],[[["\u003cp\u003eThis document provides reference information for the \u003ccode\u003eAsymmetricDecryptResponse\u003c/code\u003e class within the Google Cloud Key Management Service (KMS) v1 API for .NET, detailing its usage in asymmetric decryption.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003eAsymmetricDecryptResponse\u003c/code\u003e class is a response message for the \u003ccode\u003eKeyManagementService.AsymmetricDecrypt\u003c/code\u003e operation and implements multiple interfaces, including \u003ccode\u003eIMessage\u003c/code\u003e, \u003ccode\u003eIEquatable\u003c/code\u003e, and \u003ccode\u003eIDeepCloneable\u003c/code\u003e.\u003c/p\u003e\n"],["\u003cp\u003eThe class has properties to handle decrypted data (\u003ccode\u003ePlaintext\u003c/code\u003e), verify its integrity (\u003ccode\u003ePlaintextCrc32C\u003c/code\u003e, \u003ccode\u003eVerifiedCiphertextCrc32C\u003c/code\u003e), and to determine the \u003ccode\u003eProtectionLevel\u003c/code\u003e of the \u003ccode\u003eCryptoKeyVersion\u003c/code\u003e used.\u003c/p\u003e\n"],["\u003cp\u003eThere are 25 available versions, starting from version 2.2.0 and going all the way to the latest, 3.16.0, all versions pertaining to \u003ccode\u003eAsymmetricDecryptResponse\u003c/code\u003e within the \u003ccode\u003eGoogle.Cloud.Kms.V1\u003c/code\u003e namespace.\u003c/p\u003e\n"],["\u003cp\u003e\u003ccode\u003eAsymmetricDecryptResponse\u003c/code\u003e has two constructors one without parameters, and one that can clone another instance of itself.\u003c/p\u003e\n"]]],[],null,["# Google Cloud Key Management Service v1 API - Class AsymmetricDecryptResponse (3.18.0)\n\nVersion latestkeyboard_arrow_down\n\n- [3.18.0 (latest)](/dotnet/docs/reference/Google.Cloud.Kms.V1/latest/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.17.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.17.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.16.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.16.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.15.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.15.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.14.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.14.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.13.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.13.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.12.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.12.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.11.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.11.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.10.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.10.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.9.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.9.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.8.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.8.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.7.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.7.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.6.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.6.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.5.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.5.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.4.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.4.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.3.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.3.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.2.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.2.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.1.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.1.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [3.0.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/3.0.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.9.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.9.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.8.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.8.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.7.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.7.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.6.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.6.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.5.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.5.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.4.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.4.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.3.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.3.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse)\n- [2.2.0](/dotnet/docs/reference/Google.Cloud.Kms.V1/2.2.0/Google.Cloud.Kms.V1.AsymmetricDecryptResponse) \n\n public sealed class AsymmetricDecryptResponse : IMessage\u003cAsymmetricDecryptResponse\u003e, IEquatable\u003cAsymmetricDecryptResponse\u003e, IDeepCloneable\u003cAsymmetricDecryptResponse\u003e, IBufferMessage, IMessage\n\nReference documentation and code samples for the Google Cloud Key Management Service v1 API class AsymmetricDecryptResponse.\n\nResponse message for\n\\[KeyManagementService.AsymmetricDecrypt\\]\\[google.cloud.kms.v1.KeyManagementService.AsymmetricDecrypt\\]. \n\nInheritance\n-----------\n\n[object](https://learn.microsoft.com/dotnet/api/system.object) \\\u003e AsymmetricDecryptResponse \n\nImplements\n----------\n\n[IMessage](https://cloud.google.com/dotnet/docs/reference/Google.Protobuf/latest/Google.Protobuf.IMessage-1.html)[AsymmetricDecryptResponse](/dotnet/docs/reference/Google.Cloud.Kms.V1/latest/Google.Cloud.Kms.V1.AsymmetricDecryptResponse), [IEquatable](https://learn.microsoft.com/dotnet/api/system.iequatable-1)[AsymmetricDecryptResponse](/dotnet/docs/reference/Google.Cloud.Kms.V1/latest/Google.Cloud.Kms.V1.AsymmetricDecryptResponse), [IDeepCloneable](https://cloud.google.com/dotnet/docs/reference/Google.Protobuf/latest/Google.Protobuf.IDeepCloneable-1.html)[AsymmetricDecryptResponse](/dotnet/docs/reference/Google.Cloud.Kms.V1/latest/Google.Cloud.Kms.V1.AsymmetricDecryptResponse), [IBufferMessage](https://cloud.google.com/dotnet/docs/reference/Google.Protobuf/latest/Google.Protobuf.IBufferMessage.html), [IMessage](https://cloud.google.com/dotnet/docs/reference/Google.Protobuf/latest/Google.Protobuf.IMessage.html) \n\nInherited Members\n-----------------\n\n[object.GetHashCode()](https://learn.microsoft.com/dotnet/api/system.object.gethashcode) \n[object.GetType()](https://learn.microsoft.com/dotnet/api/system.object.gettype) \n[object.ToString()](https://learn.microsoft.com/dotnet/api/system.object.tostring)\n\nNamespace\n---------\n\n[Google.Cloud.Kms.V1](/dotnet/docs/reference/Google.Cloud.Kms.V1/latest/Google.Cloud.Kms.V1)\n\nAssembly\n--------\n\nGoogle.Cloud.Kms.V1.dll\n\nConstructors\n------------\n\n### AsymmetricDecryptResponse()\n\n public AsymmetricDecryptResponse()\n\n### AsymmetricDecryptResponse(AsymmetricDecryptResponse)\n\n public AsymmetricDecryptResponse(AsymmetricDecryptResponse other)\n\nProperties\n----------\n\n### Plaintext\n\n public ByteString Plaintext { get; set; }\n\nThe decrypted data originally encrypted with the matching public key.\n\n### PlaintextCrc32C\n\n public long? PlaintextCrc32C { get; set; }\n\nIntegrity verification field. A CRC32C checksum of the returned\n\\[AsymmetricDecryptResponse.plaintext\\]\\[google.cloud.kms.v1.AsymmetricDecryptResponse.plaintext\\].\nAn integrity check of\n\\[AsymmetricDecryptResponse.plaintext\\]\\[google.cloud.kms.v1.AsymmetricDecryptResponse.plaintext\\]\ncan be performed by computing the CRC32C checksum of\n\\[AsymmetricDecryptResponse.plaintext\\]\\[google.cloud.kms.v1.AsymmetricDecryptResponse.plaintext\\]\nand comparing your results to this field. Discard the response in case of\nnon-matching checksum values, and perform a limited number of retries. A\npersistent mismatch may indicate an issue in your computation of the CRC32C\nchecksum. Note: This field is defined as int64 for reasons of compatibility\nacross different languages. However, it is a non-negative integer, which\nwill never exceed 2\\^32-1, and can be safely downconverted to uint32 in\nlanguages that support this type.\n\n### ProtectionLevel\n\n public ProtectionLevel ProtectionLevel { get; set; }\n\nThe \\[ProtectionLevel\\]\\[google.cloud.kms.v1.ProtectionLevel\\] of the\n\\[CryptoKeyVersion\\]\\[google.cloud.kms.v1.CryptoKeyVersion\\] used in\ndecryption.\n\n### VerifiedCiphertextCrc32C\n\n public bool VerifiedCiphertextCrc32C { get; set; }\n\nIntegrity verification field. A flag indicating whether\n\\[AsymmetricDecryptRequest.ciphertext_crc32c\\]\\[google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext_crc32c\\]\nwas received by\n\\[KeyManagementService\\]\\[google.cloud.kms.v1.KeyManagementService\\] and used\nfor the integrity verification of the\n\\[ciphertext\\]\\[google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext\\]. A\nfalse value of this field indicates either that\n\\[AsymmetricDecryptRequest.ciphertext_crc32c\\]\\[google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext_crc32c\\]\nwas left unset or that it was not delivered to\n\\[KeyManagementService\\]\\[google.cloud.kms.v1.KeyManagementService\\]. If you've\nset\n\\[AsymmetricDecryptRequest.ciphertext_crc32c\\]\\[google.cloud.kms.v1.AsymmetricDecryptRequest.ciphertext_crc32c\\]\nbut this field is still false, discard the response and perform a limited\nnumber of retries."]]