/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include namespace Aws { namespace EC2 { namespace Model { /** */ class AWS_EC2_API ModifyEbsDefaultKmsKeyIdRequest : public EC2Request { public: ModifyEbsDefaultKmsKeyIdRequest(); // Service request name is the Operation name which will send this request out, // each operation should has unique request name, so that we can get operation's name from this request. // Note: this is not true for response, multiple operations may have the same response name, // so we can not get operation's name from response. inline virtual const char* GetServiceRequestName() const override { return "ModifyEbsDefaultKmsKeyId"; } Aws::String SerializePayload() const override; protected: void DumpBodyToUrl(Aws::Http::URI& uri ) const override; public: /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline const Aws::String& GetKmsKeyId() const{ return m_kmsKeyId; } /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline bool KmsKeyIdHasBeenSet() const { return m_kmsKeyIdHasBeenSet; } /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline void SetKmsKeyId(const Aws::String& value) { m_kmsKeyIdHasBeenSet = true; m_kmsKeyId = value; } /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline void SetKmsKeyId(Aws::String&& value) { m_kmsKeyIdHasBeenSet = true; m_kmsKeyId = std::move(value); } /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline void SetKmsKeyId(const char* value) { m_kmsKeyIdHasBeenSet = true; m_kmsKeyId.assign(value); } /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline ModifyEbsDefaultKmsKeyIdRequest& WithKmsKeyId(const Aws::String& value) { SetKmsKeyId(value); return *this;} /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline ModifyEbsDefaultKmsKeyIdRequest& WithKmsKeyId(Aws::String&& value) { SetKmsKeyId(std::move(value)); return *this;} /** *

The identifier of the AWS Key Management Service (AWS KMS) customer master * key (CMK) to use for Amazon EBS encryption. If this parameter is not specified, * your AWS managed CMK for EBS is used. If KmsKeyId is specified, the * encrypted state must be true.

You can specify the CMK using * any of the following:

  • Key ID. For example, * key/1234abcd-12ab-34cd-56ef-1234567890ab.

  • Key alias. For * example, alias/ExampleAlias.

  • Key ARN. For example, * arn:aws:kms:us-east-1:012345678910:key/abcd1234-a123-456a-a12b-a123b4cd56ef.

    *
  • Alias ARN. For example, * arn:aws:kms:us-east-1:012345678910:alias/ExampleAlias.

    *

AWS authenticates the CMK asynchronously. Therefore, if you * specify an ID, alias, or ARN that is not valid, the action can appear to * complete, but eventually fails.

Amazon EBS does not support asymmetric * CMKs.

*/ inline ModifyEbsDefaultKmsKeyIdRequest& WithKmsKeyId(const char* value) { SetKmsKeyId(value); return *this;} /** *

Checks whether you have the required permissions for the action, without * actually making the request, and provides an error response. If you have the * required permissions, the error response is DryRunOperation. * Otherwise, it is UnauthorizedOperation.

*/ inline bool GetDryRun() const{ return m_dryRun; } /** *

Checks whether you have the required permissions for the action, without * actually making the request, and provides an error response. If you have the * required permissions, the error response is DryRunOperation. * Otherwise, it is UnauthorizedOperation.

*/ inline bool DryRunHasBeenSet() const { return m_dryRunHasBeenSet; } /** *

Checks whether you have the required permissions for the action, without * actually making the request, and provides an error response. If you have the * required permissions, the error response is DryRunOperation. * Otherwise, it is UnauthorizedOperation.

*/ inline void SetDryRun(bool value) { m_dryRunHasBeenSet = true; m_dryRun = value; } /** *

Checks whether you have the required permissions for the action, without * actually making the request, and provides an error response. If you have the * required permissions, the error response is DryRunOperation. * Otherwise, it is UnauthorizedOperation.

*/ inline ModifyEbsDefaultKmsKeyIdRequest& WithDryRun(bool value) { SetDryRun(value); return *this;} private: Aws::String m_kmsKeyId; bool m_kmsKeyIdHasBeenSet; bool m_dryRun; bool m_dryRunHasBeenSet; }; } // namespace Model } // namespace EC2 } // namespace Aws