200 lines
8.8 KiB
C++
200 lines
8.8 KiB
C++
/**
|
||
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
||
* SPDX-License-Identifier: Apache-2.0.
|
||
*/
|
||
|
||
#pragma once
|
||
#include <aws/kms/KMS_EXPORTS.h>
|
||
#include <aws/core/utils/memory/stl/AWSString.h>
|
||
#include <aws/core/utils/Array.h>
|
||
#include <aws/kms/model/SigningAlgorithmSpec.h>
|
||
#include <utility>
|
||
|
||
namespace Aws
|
||
{
|
||
template<typename RESULT_TYPE>
|
||
class AmazonWebServiceResult;
|
||
|
||
namespace Utils
|
||
{
|
||
namespace Json
|
||
{
|
||
class JsonValue;
|
||
} // namespace Json
|
||
} // namespace Utils
|
||
namespace KMS
|
||
{
|
||
namespace Model
|
||
{
|
||
class AWS_KMS_API SignResult
|
||
{
|
||
public:
|
||
SignResult();
|
||
SignResult(const Aws::AmazonWebServiceResult<Aws::Utils::Json::JsonValue>& result);
|
||
SignResult& operator=(const Aws::AmazonWebServiceResult<Aws::Utils::Json::JsonValue>& result);
|
||
|
||
|
||
/**
|
||
* <p>The Amazon Resource Name (<a
|
||
* href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id-key-ARN">key
|
||
* ARN</a>) of the asymmetric CMK that was used to sign the message.</p>
|
||
*/
|
||
inline const Aws::String& GetKeyId() const{ return m_keyId; }
|
||
|
||
/**
|
||
* <p>The Amazon Resource Name (<a
|
||
* href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id-key-ARN">key
|
||
* ARN</a>) of the asymmetric CMK that was used to sign the message.</p>
|
||
*/
|
||
inline void SetKeyId(const Aws::String& value) { m_keyId = value; }
|
||
|
||
/**
|
||
* <p>The Amazon Resource Name (<a
|
||
* href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id-key-ARN">key
|
||
* ARN</a>) of the asymmetric CMK that was used to sign the message.</p>
|
||
*/
|
||
inline void SetKeyId(Aws::String&& value) { m_keyId = std::move(value); }
|
||
|
||
/**
|
||
* <p>The Amazon Resource Name (<a
|
||
* href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id-key-ARN">key
|
||
* ARN</a>) of the asymmetric CMK that was used to sign the message.</p>
|
||
*/
|
||
inline void SetKeyId(const char* value) { m_keyId.assign(value); }
|
||
|
||
/**
|
||
* <p>The Amazon Resource Name (<a
|
||
* href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id-key-ARN">key
|
||
* ARN</a>) of the asymmetric CMK that was used to sign the message.</p>
|
||
*/
|
||
inline SignResult& WithKeyId(const Aws::String& value) { SetKeyId(value); return *this;}
|
||
|
||
/**
|
||
* <p>The Amazon Resource Name (<a
|
||
* href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id-key-ARN">key
|
||
* ARN</a>) of the asymmetric CMK that was used to sign the message.</p>
|
||
*/
|
||
inline SignResult& WithKeyId(Aws::String&& value) { SetKeyId(std::move(value)); return *this;}
|
||
|
||
/**
|
||
* <p>The Amazon Resource Name (<a
|
||
* href="https://docs.aws.amazon.com/kms/latest/developerguide/concepts.html#key-id-key-ARN">key
|
||
* ARN</a>) of the asymmetric CMK that was used to sign the message.</p>
|
||
*/
|
||
inline SignResult& WithKeyId(const char* value) { SetKeyId(value); return *this;}
|
||
|
||
|
||
/**
|
||
* <p>The cryptographic signature that was generated for the message. </p> <ul>
|
||
* <li> <p>When used with the supported RSA signing algorithms, the encoding of
|
||
* this value is defined by <a href="https://tools.ietf.org/html/rfc8017">PKCS #1
|
||
* in RFC 8017</a>.</p> </li> <li> <p>When used with the
|
||
* <code>ECDSA_SHA_256</code>, <code>ECDSA_SHA_384</code>, or
|
||
* <code>ECDSA_SHA_512</code> signing algorithms, this value is a DER-encoded
|
||
* object as defined by ANS X9.62–2005 and <a
|
||
* href="https://tools.ietf.org/html/rfc3279#section-2.2.3">RFC 3279 Section
|
||
* 2.2.3</a>. This is the most commonly used signature format and is appropriate
|
||
* for most uses. </p> </li> </ul> <p>When you use the HTTP API or the AWS CLI, the
|
||
* value is Base64-encoded. Otherwise, it is not Base64-encoded.</p>
|
||
*/
|
||
inline const Aws::Utils::ByteBuffer& GetSignature() const{ return m_signature; }
|
||
|
||
/**
|
||
* <p>The cryptographic signature that was generated for the message. </p> <ul>
|
||
* <li> <p>When used with the supported RSA signing algorithms, the encoding of
|
||
* this value is defined by <a href="https://tools.ietf.org/html/rfc8017">PKCS #1
|
||
* in RFC 8017</a>.</p> </li> <li> <p>When used with the
|
||
* <code>ECDSA_SHA_256</code>, <code>ECDSA_SHA_384</code>, or
|
||
* <code>ECDSA_SHA_512</code> signing algorithms, this value is a DER-encoded
|
||
* object as defined by ANS X9.62–2005 and <a
|
||
* href="https://tools.ietf.org/html/rfc3279#section-2.2.3">RFC 3279 Section
|
||
* 2.2.3</a>. This is the most commonly used signature format and is appropriate
|
||
* for most uses. </p> </li> </ul> <p>When you use the HTTP API or the AWS CLI, the
|
||
* value is Base64-encoded. Otherwise, it is not Base64-encoded.</p>
|
||
*/
|
||
inline void SetSignature(const Aws::Utils::ByteBuffer& value) { m_signature = value; }
|
||
|
||
/**
|
||
* <p>The cryptographic signature that was generated for the message. </p> <ul>
|
||
* <li> <p>When used with the supported RSA signing algorithms, the encoding of
|
||
* this value is defined by <a href="https://tools.ietf.org/html/rfc8017">PKCS #1
|
||
* in RFC 8017</a>.</p> </li> <li> <p>When used with the
|
||
* <code>ECDSA_SHA_256</code>, <code>ECDSA_SHA_384</code>, or
|
||
* <code>ECDSA_SHA_512</code> signing algorithms, this value is a DER-encoded
|
||
* object as defined by ANS X9.62–2005 and <a
|
||
* href="https://tools.ietf.org/html/rfc3279#section-2.2.3">RFC 3279 Section
|
||
* 2.2.3</a>. This is the most commonly used signature format and is appropriate
|
||
* for most uses. </p> </li> </ul> <p>When you use the HTTP API or the AWS CLI, the
|
||
* value is Base64-encoded. Otherwise, it is not Base64-encoded.</p>
|
||
*/
|
||
inline void SetSignature(Aws::Utils::ByteBuffer&& value) { m_signature = std::move(value); }
|
||
|
||
/**
|
||
* <p>The cryptographic signature that was generated for the message. </p> <ul>
|
||
* <li> <p>When used with the supported RSA signing algorithms, the encoding of
|
||
* this value is defined by <a href="https://tools.ietf.org/html/rfc8017">PKCS #1
|
||
* in RFC 8017</a>.</p> </li> <li> <p>When used with the
|
||
* <code>ECDSA_SHA_256</code>, <code>ECDSA_SHA_384</code>, or
|
||
* <code>ECDSA_SHA_512</code> signing algorithms, this value is a DER-encoded
|
||
* object as defined by ANS X9.62–2005 and <a
|
||
* href="https://tools.ietf.org/html/rfc3279#section-2.2.3">RFC 3279 Section
|
||
* 2.2.3</a>. This is the most commonly used signature format and is appropriate
|
||
* for most uses. </p> </li> </ul> <p>When you use the HTTP API or the AWS CLI, the
|
||
* value is Base64-encoded. Otherwise, it is not Base64-encoded.</p>
|
||
*/
|
||
inline SignResult& WithSignature(const Aws::Utils::ByteBuffer& value) { SetSignature(value); return *this;}
|
||
|
||
/**
|
||
* <p>The cryptographic signature that was generated for the message. </p> <ul>
|
||
* <li> <p>When used with the supported RSA signing algorithms, the encoding of
|
||
* this value is defined by <a href="https://tools.ietf.org/html/rfc8017">PKCS #1
|
||
* in RFC 8017</a>.</p> </li> <li> <p>When used with the
|
||
* <code>ECDSA_SHA_256</code>, <code>ECDSA_SHA_384</code>, or
|
||
* <code>ECDSA_SHA_512</code> signing algorithms, this value is a DER-encoded
|
||
* object as defined by ANS X9.62–2005 and <a
|
||
* href="https://tools.ietf.org/html/rfc3279#section-2.2.3">RFC 3279 Section
|
||
* 2.2.3</a>. This is the most commonly used signature format and is appropriate
|
||
* for most uses. </p> </li> </ul> <p>When you use the HTTP API or the AWS CLI, the
|
||
* value is Base64-encoded. Otherwise, it is not Base64-encoded.</p>
|
||
*/
|
||
inline SignResult& WithSignature(Aws::Utils::ByteBuffer&& value) { SetSignature(std::move(value)); return *this;}
|
||
|
||
|
||
/**
|
||
* <p>The signing algorithm that was used to sign the message.</p>
|
||
*/
|
||
inline const SigningAlgorithmSpec& GetSigningAlgorithm() const{ return m_signingAlgorithm; }
|
||
|
||
/**
|
||
* <p>The signing algorithm that was used to sign the message.</p>
|
||
*/
|
||
inline void SetSigningAlgorithm(const SigningAlgorithmSpec& value) { m_signingAlgorithm = value; }
|
||
|
||
/**
|
||
* <p>The signing algorithm that was used to sign the message.</p>
|
||
*/
|
||
inline void SetSigningAlgorithm(SigningAlgorithmSpec&& value) { m_signingAlgorithm = std::move(value); }
|
||
|
||
/**
|
||
* <p>The signing algorithm that was used to sign the message.</p>
|
||
*/
|
||
inline SignResult& WithSigningAlgorithm(const SigningAlgorithmSpec& value) { SetSigningAlgorithm(value); return *this;}
|
||
|
||
/**
|
||
* <p>The signing algorithm that was used to sign the message.</p>
|
||
*/
|
||
inline SignResult& WithSigningAlgorithm(SigningAlgorithmSpec&& value) { SetSigningAlgorithm(std::move(value)); return *this;}
|
||
|
||
private:
|
||
|
||
Aws::String m_keyId;
|
||
|
||
Aws::Utils::ByteBuffer m_signature;
|
||
|
||
SigningAlgorithmSpec m_signingAlgorithm;
|
||
};
|
||
|
||
} // namespace Model
|
||
} // namespace KMS
|
||
} // namespace Aws
|