{-# 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.SecurityHub.EnableSecurityHub -- 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 Security Hub for your account in the current Region or the -- Region you specify in the request. -- -- When you enable Security Hub, you grant to Security Hub the permissions -- necessary to gather findings from other services that are integrated -- with Security Hub. -- -- When you use the @EnableSecurityHub@ operation to enable Security Hub, -- you also automatically enable the following standards. -- -- - CIS Amazon Web Services Foundations -- -- - Amazon Web Services Foundational Security Best Practices -- -- You do not enable the Payment Card Industry Data Security Standard (PCI -- DSS) standard. -- -- To not enable the automatically enabled standards, set -- @EnableDefaultStandards@ to @false@. -- -- After you enable Security Hub, to enable a standard, use the -- @BatchEnableStandards@ operation. To disable a standard, use the -- @BatchDisableStandards@ operation. -- -- To learn more, see the -- -- in the /Security Hub User Guide/. module Amazonka.SecurityHub.EnableSecurityHub ( -- * Creating a Request EnableSecurityHub (..), newEnableSecurityHub, -- * Request Lenses enableSecurityHub_enableDefaultStandards, enableSecurityHub_tags, -- * Destructuring the Response EnableSecurityHubResponse (..), newEnableSecurityHubResponse, -- * Response Lenses enableSecurityHubResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.SecurityHub.Types -- | /See:/ 'newEnableSecurityHub' smart constructor. data EnableSecurityHub = EnableSecurityHub' { -- | Whether to enable the security standards that Security Hub has -- designated as automatically enabled. If you do not provide a value for -- @EnableDefaultStandards@, it is set to @true@. To not enable the -- automatically enabled standards, set @EnableDefaultStandards@ to -- @false@. enableDefaultStandards :: Prelude.Maybe Prelude.Bool, -- | The tags to add to the hub resource when you enable Security Hub. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text) } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'EnableSecurityHub' 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: -- -- 'enableDefaultStandards', 'enableSecurityHub_enableDefaultStandards' - Whether to enable the security standards that Security Hub has -- designated as automatically enabled. If you do not provide a value for -- @EnableDefaultStandards@, it is set to @true@. To not enable the -- automatically enabled standards, set @EnableDefaultStandards@ to -- @false@. -- -- 'tags', 'enableSecurityHub_tags' - The tags to add to the hub resource when you enable Security Hub. newEnableSecurityHub :: EnableSecurityHub newEnableSecurityHub = EnableSecurityHub' { enableDefaultStandards = Prelude.Nothing, tags = Prelude.Nothing } -- | Whether to enable the security standards that Security Hub has -- designated as automatically enabled. If you do not provide a value for -- @EnableDefaultStandards@, it is set to @true@. To not enable the -- automatically enabled standards, set @EnableDefaultStandards@ to -- @false@. enableSecurityHub_enableDefaultStandards :: Lens.Lens' EnableSecurityHub (Prelude.Maybe Prelude.Bool) enableSecurityHub_enableDefaultStandards = Lens.lens (\EnableSecurityHub' {enableDefaultStandards} -> enableDefaultStandards) (\s@EnableSecurityHub' {} a -> s {enableDefaultStandards = a} :: EnableSecurityHub) -- | The tags to add to the hub resource when you enable Security Hub. enableSecurityHub_tags :: Lens.Lens' EnableSecurityHub (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) enableSecurityHub_tags = Lens.lens (\EnableSecurityHub' {tags} -> tags) (\s@EnableSecurityHub' {} a -> s {tags = a} :: EnableSecurityHub) Prelude.. Lens.mapping Lens.coerced instance Core.AWSRequest EnableSecurityHub where type AWSResponse EnableSecurityHub = EnableSecurityHubResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> EnableSecurityHubResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable EnableSecurityHub where hashWithSalt _salt EnableSecurityHub' {..} = _salt `Prelude.hashWithSalt` enableDefaultStandards `Prelude.hashWithSalt` tags instance Prelude.NFData EnableSecurityHub where rnf EnableSecurityHub' {..} = Prelude.rnf enableDefaultStandards `Prelude.seq` Prelude.rnf tags instance Data.ToHeaders EnableSecurityHub where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON EnableSecurityHub where toJSON EnableSecurityHub' {..} = Data.object ( Prelude.catMaybes [ ("EnableDefaultStandards" Data..=) Prelude.<$> enableDefaultStandards, ("Tags" Data..=) Prelude.<$> tags ] ) instance Data.ToPath EnableSecurityHub where toPath = Prelude.const "/accounts" instance Data.ToQuery EnableSecurityHub where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newEnableSecurityHubResponse' smart constructor. data EnableSecurityHubResponse = EnableSecurityHubResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'EnableSecurityHubResponse' 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', 'enableSecurityHubResponse_httpStatus' - The response's http status code. newEnableSecurityHubResponse :: -- | 'httpStatus' Prelude.Int -> EnableSecurityHubResponse newEnableSecurityHubResponse pHttpStatus_ = EnableSecurityHubResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. enableSecurityHubResponse_httpStatus :: Lens.Lens' EnableSecurityHubResponse Prelude.Int enableSecurityHubResponse_httpStatus = Lens.lens (\EnableSecurityHubResponse' {httpStatus} -> httpStatus) (\s@EnableSecurityHubResponse' {} a -> s {httpStatus = a} :: EnableSecurityHubResponse) instance Prelude.NFData EnableSecurityHubResponse where rnf EnableSecurityHubResponse' {..} = Prelude.rnf httpStatus