{-# 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.Glue.CreateSecurityConfiguration -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates a new security configuration. A security configuration is a set -- of security properties that can be used by Glue. You can use a security -- configuration to encrypt data at rest. For information about using -- security configurations in Glue, see -- . module Amazonka.Glue.CreateSecurityConfiguration ( -- * Creating a Request CreateSecurityConfiguration (..), newCreateSecurityConfiguration, -- * Request Lenses createSecurityConfiguration_name, createSecurityConfiguration_encryptionConfiguration, -- * Destructuring the Response CreateSecurityConfigurationResponse (..), newCreateSecurityConfigurationResponse, -- * Response Lenses createSecurityConfigurationResponse_createdTimestamp, createSecurityConfigurationResponse_name, createSecurityConfigurationResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.Glue.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newCreateSecurityConfiguration' smart constructor. data CreateSecurityConfiguration = CreateSecurityConfiguration' { -- | The name for the new security configuration. name :: Prelude.Text, -- | The encryption configuration for the new security configuration. encryptionConfiguration :: EncryptionConfiguration } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateSecurityConfiguration' 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: -- -- 'name', 'createSecurityConfiguration_name' - The name for the new security configuration. -- -- 'encryptionConfiguration', 'createSecurityConfiguration_encryptionConfiguration' - The encryption configuration for the new security configuration. newCreateSecurityConfiguration :: -- | 'name' Prelude.Text -> -- | 'encryptionConfiguration' EncryptionConfiguration -> CreateSecurityConfiguration newCreateSecurityConfiguration pName_ pEncryptionConfiguration_ = CreateSecurityConfiguration' { name = pName_, encryptionConfiguration = pEncryptionConfiguration_ } -- | The name for the new security configuration. createSecurityConfiguration_name :: Lens.Lens' CreateSecurityConfiguration Prelude.Text createSecurityConfiguration_name = Lens.lens (\CreateSecurityConfiguration' {name} -> name) (\s@CreateSecurityConfiguration' {} a -> s {name = a} :: CreateSecurityConfiguration) -- | The encryption configuration for the new security configuration. createSecurityConfiguration_encryptionConfiguration :: Lens.Lens' CreateSecurityConfiguration EncryptionConfiguration createSecurityConfiguration_encryptionConfiguration = Lens.lens (\CreateSecurityConfiguration' {encryptionConfiguration} -> encryptionConfiguration) (\s@CreateSecurityConfiguration' {} a -> s {encryptionConfiguration = a} :: CreateSecurityConfiguration) instance Core.AWSRequest CreateSecurityConfiguration where type AWSResponse CreateSecurityConfiguration = CreateSecurityConfigurationResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateSecurityConfigurationResponse' Prelude.<$> (x Data..?> "CreatedTimestamp") Prelude.<*> (x Data..?> "Name") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateSecurityConfiguration where hashWithSalt _salt CreateSecurityConfiguration' {..} = _salt `Prelude.hashWithSalt` name `Prelude.hashWithSalt` encryptionConfiguration instance Prelude.NFData CreateSecurityConfiguration where rnf CreateSecurityConfiguration' {..} = Prelude.rnf name `Prelude.seq` Prelude.rnf encryptionConfiguration instance Data.ToHeaders CreateSecurityConfiguration where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSGlue.CreateSecurityConfiguration" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON CreateSecurityConfiguration where toJSON CreateSecurityConfiguration' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("Name" Data..= name), Prelude.Just ( "EncryptionConfiguration" Data..= encryptionConfiguration ) ] ) instance Data.ToPath CreateSecurityConfiguration where toPath = Prelude.const "/" instance Data.ToQuery CreateSecurityConfiguration where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateSecurityConfigurationResponse' smart constructor. data CreateSecurityConfigurationResponse = CreateSecurityConfigurationResponse' { -- | The time at which the new security configuration was created. createdTimestamp :: Prelude.Maybe Data.POSIX, -- | The name assigned to the new security configuration. name :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateSecurityConfigurationResponse' 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: -- -- 'createdTimestamp', 'createSecurityConfigurationResponse_createdTimestamp' - The time at which the new security configuration was created. -- -- 'name', 'createSecurityConfigurationResponse_name' - The name assigned to the new security configuration. -- -- 'httpStatus', 'createSecurityConfigurationResponse_httpStatus' - The response's http status code. newCreateSecurityConfigurationResponse :: -- | 'httpStatus' Prelude.Int -> CreateSecurityConfigurationResponse newCreateSecurityConfigurationResponse pHttpStatus_ = CreateSecurityConfigurationResponse' { createdTimestamp = Prelude.Nothing, name = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The time at which the new security configuration was created. createSecurityConfigurationResponse_createdTimestamp :: Lens.Lens' CreateSecurityConfigurationResponse (Prelude.Maybe Prelude.UTCTime) createSecurityConfigurationResponse_createdTimestamp = Lens.lens (\CreateSecurityConfigurationResponse' {createdTimestamp} -> createdTimestamp) (\s@CreateSecurityConfigurationResponse' {} a -> s {createdTimestamp = a} :: CreateSecurityConfigurationResponse) Prelude.. Lens.mapping Data._Time -- | The name assigned to the new security configuration. createSecurityConfigurationResponse_name :: Lens.Lens' CreateSecurityConfigurationResponse (Prelude.Maybe Prelude.Text) createSecurityConfigurationResponse_name = Lens.lens (\CreateSecurityConfigurationResponse' {name} -> name) (\s@CreateSecurityConfigurationResponse' {} a -> s {name = a} :: CreateSecurityConfigurationResponse) -- | The response's http status code. createSecurityConfigurationResponse_httpStatus :: Lens.Lens' CreateSecurityConfigurationResponse Prelude.Int createSecurityConfigurationResponse_httpStatus = Lens.lens (\CreateSecurityConfigurationResponse' {httpStatus} -> httpStatus) (\s@CreateSecurityConfigurationResponse' {} a -> s {httpStatus = a} :: CreateSecurityConfigurationResponse) instance Prelude.NFData CreateSecurityConfigurationResponse where rnf CreateSecurityConfigurationResponse' {..} = Prelude.rnf createdTimestamp `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf httpStatus