{-# 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.MacieV2.UpdateOrganizationConfiguration -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Updates the Amazon Macie configuration settings for an organization in -- Organizations. module Amazonka.MacieV2.UpdateOrganizationConfiguration ( -- * Creating a Request UpdateOrganizationConfiguration (..), newUpdateOrganizationConfiguration, -- * Request Lenses updateOrganizationConfiguration_autoEnable, -- * Destructuring the Response UpdateOrganizationConfigurationResponse (..), newUpdateOrganizationConfigurationResponse, -- * Response Lenses updateOrganizationConfigurationResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.MacieV2.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateOrganizationConfiguration' smart constructor. data UpdateOrganizationConfiguration = UpdateOrganizationConfiguration' { -- | Specifies whether to enable Amazon Macie automatically for an account -- when the account is added to the organization in Organizations. autoEnable :: Prelude.Bool } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateOrganizationConfiguration' 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: -- -- 'autoEnable', 'updateOrganizationConfiguration_autoEnable' - Specifies whether to enable Amazon Macie automatically for an account -- when the account is added to the organization in Organizations. newUpdateOrganizationConfiguration :: -- | 'autoEnable' Prelude.Bool -> UpdateOrganizationConfiguration newUpdateOrganizationConfiguration pAutoEnable_ = UpdateOrganizationConfiguration' { autoEnable = pAutoEnable_ } -- | Specifies whether to enable Amazon Macie automatically for an account -- when the account is added to the organization in Organizations. updateOrganizationConfiguration_autoEnable :: Lens.Lens' UpdateOrganizationConfiguration Prelude.Bool updateOrganizationConfiguration_autoEnable = Lens.lens (\UpdateOrganizationConfiguration' {autoEnable} -> autoEnable) (\s@UpdateOrganizationConfiguration' {} a -> s {autoEnable = a} :: UpdateOrganizationConfiguration) instance Core.AWSRequest UpdateOrganizationConfiguration where type AWSResponse UpdateOrganizationConfiguration = UpdateOrganizationConfigurationResponse request overrides = Request.patchJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> UpdateOrganizationConfigurationResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateOrganizationConfiguration where hashWithSalt _salt UpdateOrganizationConfiguration' {..} = _salt `Prelude.hashWithSalt` autoEnable instance Prelude.NFData UpdateOrganizationConfiguration where rnf UpdateOrganizationConfiguration' {..} = Prelude.rnf autoEnable instance Data.ToHeaders UpdateOrganizationConfiguration where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateOrganizationConfiguration where toJSON UpdateOrganizationConfiguration' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("autoEnable" Data..= autoEnable)] ) instance Data.ToPath UpdateOrganizationConfiguration where toPath = Prelude.const "/admin/configuration" instance Data.ToQuery UpdateOrganizationConfiguration where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateOrganizationConfigurationResponse' smart constructor. data UpdateOrganizationConfigurationResponse = UpdateOrganizationConfigurationResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateOrganizationConfigurationResponse' 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: -- -- 'httpStatus', 'updateOrganizationConfigurationResponse_httpStatus' - The response's http status code. newUpdateOrganizationConfigurationResponse :: -- | 'httpStatus' Prelude.Int -> UpdateOrganizationConfigurationResponse newUpdateOrganizationConfigurationResponse pHttpStatus_ = UpdateOrganizationConfigurationResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. updateOrganizationConfigurationResponse_httpStatus :: Lens.Lens' UpdateOrganizationConfigurationResponse Prelude.Int updateOrganizationConfigurationResponse_httpStatus = Lens.lens (\UpdateOrganizationConfigurationResponse' {httpStatus} -> httpStatus) (\s@UpdateOrganizationConfigurationResponse' {} a -> s {httpStatus = a} :: UpdateOrganizationConfigurationResponse) instance Prelude.NFData UpdateOrganizationConfigurationResponse where rnf UpdateOrganizationConfigurationResponse' {..} = Prelude.rnf httpStatus