{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.EC2.EnableEbsEncryptionByDefault -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Enables EBS encryption by default for your account in the current -- Region. -- -- After you enable encryption by default, the EBS volumes that you create -- are always encrypted, either using the default KMS key or the KMS key -- that you specified when you created each volume. For more information, -- see -- -- in the /Amazon Elastic Compute Cloud User Guide/. -- -- You can specify the default KMS key for encryption by default using -- ModifyEbsDefaultKmsKeyId or ResetEbsDefaultKmsKeyId. -- -- Enabling encryption by default has no effect on the encryption status of -- your existing volumes. -- -- After you enable encryption by default, you can no longer launch -- instances using instance types that do not support encryption. For more -- information, see -- . module Amazonka.EC2.EnableEbsEncryptionByDefault ( -- * Creating a Request EnableEbsEncryptionByDefault (..), newEnableEbsEncryptionByDefault, -- * Request Lenses enableEbsEncryptionByDefault_dryRun, -- * Destructuring the Response EnableEbsEncryptionByDefaultResponse (..), newEnableEbsEncryptionByDefaultResponse, -- * Response Lenses enableEbsEncryptionByDefaultResponse_ebsEncryptionByDefault, enableEbsEncryptionByDefaultResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.EC2.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newEnableEbsEncryptionByDefault' smart constructor. data EnableEbsEncryptionByDefault = EnableEbsEncryptionByDefault' { -- | 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@. dryRun :: Prelude.Maybe Prelude.Bool } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'EnableEbsEncryptionByDefault' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'dryRun', 'enableEbsEncryptionByDefault_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@. newEnableEbsEncryptionByDefault :: EnableEbsEncryptionByDefault newEnableEbsEncryptionByDefault = EnableEbsEncryptionByDefault' { dryRun = Prelude.Nothing } -- | 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@. enableEbsEncryptionByDefault_dryRun :: Lens.Lens' EnableEbsEncryptionByDefault (Prelude.Maybe Prelude.Bool) enableEbsEncryptionByDefault_dryRun = Lens.lens (\EnableEbsEncryptionByDefault' {dryRun} -> dryRun) (\s@EnableEbsEncryptionByDefault' {} a -> s {dryRun = a} :: EnableEbsEncryptionByDefault) instance Core.AWSRequest EnableEbsEncryptionByDefault where type AWSResponse EnableEbsEncryptionByDefault = EnableEbsEncryptionByDefaultResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXML ( \s h x -> EnableEbsEncryptionByDefaultResponse' Prelude.<$> (x Data..@? "ebsEncryptionByDefault") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable EnableEbsEncryptionByDefault where hashWithSalt _salt EnableEbsEncryptionByDefault' {..} = _salt `Prelude.hashWithSalt` dryRun instance Prelude.NFData EnableEbsEncryptionByDefault where rnf EnableEbsEncryptionByDefault' {..} = Prelude.rnf dryRun instance Data.ToHeaders EnableEbsEncryptionByDefault where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath EnableEbsEncryptionByDefault where toPath = Prelude.const "/" instance Data.ToQuery EnableEbsEncryptionByDefault where toQuery EnableEbsEncryptionByDefault' {..} = Prelude.mconcat [ "Action" Data.=: ( "EnableEbsEncryptionByDefault" :: Prelude.ByteString ), "Version" Data.=: ("2016-11-15" :: Prelude.ByteString), "DryRun" Data.=: dryRun ] -- | /See:/ 'newEnableEbsEncryptionByDefaultResponse' smart constructor. data EnableEbsEncryptionByDefaultResponse = EnableEbsEncryptionByDefaultResponse' { -- | The updated status of encryption by default. ebsEncryptionByDefault :: Prelude.Maybe Prelude.Bool, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'EnableEbsEncryptionByDefaultResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'ebsEncryptionByDefault', 'enableEbsEncryptionByDefaultResponse_ebsEncryptionByDefault' - The updated status of encryption by default. -- -- 'httpStatus', 'enableEbsEncryptionByDefaultResponse_httpStatus' - The response's http status code. newEnableEbsEncryptionByDefaultResponse :: -- | 'httpStatus' Prelude.Int -> EnableEbsEncryptionByDefaultResponse newEnableEbsEncryptionByDefaultResponse pHttpStatus_ = EnableEbsEncryptionByDefaultResponse' { ebsEncryptionByDefault = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The updated status of encryption by default. enableEbsEncryptionByDefaultResponse_ebsEncryptionByDefault :: Lens.Lens' EnableEbsEncryptionByDefaultResponse (Prelude.Maybe Prelude.Bool) enableEbsEncryptionByDefaultResponse_ebsEncryptionByDefault = Lens.lens (\EnableEbsEncryptionByDefaultResponse' {ebsEncryptionByDefault} -> ebsEncryptionByDefault) (\s@EnableEbsEncryptionByDefaultResponse' {} a -> s {ebsEncryptionByDefault = a} :: EnableEbsEncryptionByDefaultResponse) -- | The response's http status code. enableEbsEncryptionByDefaultResponse_httpStatus :: Lens.Lens' EnableEbsEncryptionByDefaultResponse Prelude.Int enableEbsEncryptionByDefaultResponse_httpStatus = Lens.lens (\EnableEbsEncryptionByDefaultResponse' {httpStatus} -> httpStatus) (\s@EnableEbsEncryptionByDefaultResponse' {} a -> s {httpStatus = a} :: EnableEbsEncryptionByDefaultResponse) instance Prelude.NFData EnableEbsEncryptionByDefaultResponse where rnf EnableEbsEncryptionByDefaultResponse' {..} = Prelude.rnf ebsEncryptionByDefault `Prelude.seq` Prelude.rnf httpStatus