This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
pxz-hos-client-cpp-module/support/aws-sdk-cpp-master/aws-cpp-sdk-kms/source/model/ReEncryptRequest.cpp

108 lines
3.2 KiB
C++

/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#include <aws/kms/model/ReEncryptRequest.h>
#include <aws/core/utils/json/JsonSerializer.h>
#include <aws/core/utils/HashingUtils.h>
#include <utility>
using namespace Aws::KMS::Model;
using namespace Aws::Utils::Json;
using namespace Aws::Utils;
ReEncryptRequest::ReEncryptRequest() :
m_ciphertextBlobHasBeenSet(false),
m_sourceEncryptionContextHasBeenSet(false),
m_sourceKeyIdHasBeenSet(false),
m_destinationKeyIdHasBeenSet(false),
m_destinationEncryptionContextHasBeenSet(false),
m_sourceEncryptionAlgorithm(EncryptionAlgorithmSpec::NOT_SET),
m_sourceEncryptionAlgorithmHasBeenSet(false),
m_destinationEncryptionAlgorithm(EncryptionAlgorithmSpec::NOT_SET),
m_destinationEncryptionAlgorithmHasBeenSet(false),
m_grantTokensHasBeenSet(false)
{
}
Aws::String ReEncryptRequest::SerializePayload() const
{
JsonValue payload;
if(m_ciphertextBlobHasBeenSet)
{
payload.WithString("CiphertextBlob", HashingUtils::Base64Encode(m_ciphertextBlob));
}
if(m_sourceEncryptionContextHasBeenSet)
{
JsonValue sourceEncryptionContextJsonMap;
for(auto& sourceEncryptionContextItem : m_sourceEncryptionContext)
{
sourceEncryptionContextJsonMap.WithString(sourceEncryptionContextItem.first, sourceEncryptionContextItem.second);
}
payload.WithObject("SourceEncryptionContext", std::move(sourceEncryptionContextJsonMap));
}
if(m_sourceKeyIdHasBeenSet)
{
payload.WithString("SourceKeyId", m_sourceKeyId);
}
if(m_destinationKeyIdHasBeenSet)
{
payload.WithString("DestinationKeyId", m_destinationKeyId);
}
if(m_destinationEncryptionContextHasBeenSet)
{
JsonValue destinationEncryptionContextJsonMap;
for(auto& destinationEncryptionContextItem : m_destinationEncryptionContext)
{
destinationEncryptionContextJsonMap.WithString(destinationEncryptionContextItem.first, destinationEncryptionContextItem.second);
}
payload.WithObject("DestinationEncryptionContext", std::move(destinationEncryptionContextJsonMap));
}
if(m_sourceEncryptionAlgorithmHasBeenSet)
{
payload.WithString("SourceEncryptionAlgorithm", EncryptionAlgorithmSpecMapper::GetNameForEncryptionAlgorithmSpec(m_sourceEncryptionAlgorithm));
}
if(m_destinationEncryptionAlgorithmHasBeenSet)
{
payload.WithString("DestinationEncryptionAlgorithm", EncryptionAlgorithmSpecMapper::GetNameForEncryptionAlgorithmSpec(m_destinationEncryptionAlgorithm));
}
if(m_grantTokensHasBeenSet)
{
Array<JsonValue> grantTokensJsonList(m_grantTokens.size());
for(unsigned grantTokensIndex = 0; grantTokensIndex < grantTokensJsonList.GetLength(); ++grantTokensIndex)
{
grantTokensJsonList[grantTokensIndex].AsString(m_grantTokens[grantTokensIndex]);
}
payload.WithArray("GrantTokens", std::move(grantTokensJsonList));
}
return payload.View().WriteReadable();
}
Aws::Http::HeaderValueCollection ReEncryptRequest::GetRequestSpecificHeaders() const
{
Aws::Http::HeaderValueCollection headers;
headers.insert(Aws::Http::HeaderValuePair("X-Amz-Target", "TrentService.ReEncrypt"));
return headers;
}