{-# 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.CreateTable -- 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 table definition in the Data Catalog. module Amazonka.Glue.CreateTable ( -- * Creating a Request CreateTable (..), newCreateTable, -- * Request Lenses createTable_catalogId, createTable_partitionIndexes, createTable_transactionId, createTable_databaseName, createTable_tableInput, -- * Destructuring the Response CreateTableResponse (..), newCreateTableResponse, -- * Response Lenses createTableResponse_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:/ 'newCreateTable' smart constructor. data CreateTable = CreateTable' { -- | The ID of the Data Catalog in which to create the @Table@. If none is -- supplied, the Amazon Web Services account ID is used by default. catalogId :: Prelude.Maybe Prelude.Text, -- | A list of partition indexes, @PartitionIndex@ structures, to create in -- the table. partitionIndexes :: Prelude.Maybe [PartitionIndex], -- | The ID of the transaction. transactionId :: Prelude.Maybe Prelude.Text, -- | The catalog database in which to create the new table. For Hive -- compatibility, this name is entirely lowercase. databaseName :: Prelude.Text, -- | The @TableInput@ object that defines the metadata table to create in the -- catalog. tableInput :: TableInput } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateTable' 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: -- -- 'catalogId', 'createTable_catalogId' - The ID of the Data Catalog in which to create the @Table@. If none is -- supplied, the Amazon Web Services account ID is used by default. -- -- 'partitionIndexes', 'createTable_partitionIndexes' - A list of partition indexes, @PartitionIndex@ structures, to create in -- the table. -- -- 'transactionId', 'createTable_transactionId' - The ID of the transaction. -- -- 'databaseName', 'createTable_databaseName' - The catalog database in which to create the new table. For Hive -- compatibility, this name is entirely lowercase. -- -- 'tableInput', 'createTable_tableInput' - The @TableInput@ object that defines the metadata table to create in the -- catalog. newCreateTable :: -- | 'databaseName' Prelude.Text -> -- | 'tableInput' TableInput -> CreateTable newCreateTable pDatabaseName_ pTableInput_ = CreateTable' { catalogId = Prelude.Nothing, partitionIndexes = Prelude.Nothing, transactionId = Prelude.Nothing, databaseName = pDatabaseName_, tableInput = pTableInput_ } -- | The ID of the Data Catalog in which to create the @Table@. If none is -- supplied, the Amazon Web Services account ID is used by default. createTable_catalogId :: Lens.Lens' CreateTable (Prelude.Maybe Prelude.Text) createTable_catalogId = Lens.lens (\CreateTable' {catalogId} -> catalogId) (\s@CreateTable' {} a -> s {catalogId = a} :: CreateTable) -- | A list of partition indexes, @PartitionIndex@ structures, to create in -- the table. createTable_partitionIndexes :: Lens.Lens' CreateTable (Prelude.Maybe [PartitionIndex]) createTable_partitionIndexes = Lens.lens (\CreateTable' {partitionIndexes} -> partitionIndexes) (\s@CreateTable' {} a -> s {partitionIndexes = a} :: CreateTable) Prelude.. Lens.mapping Lens.coerced -- | The ID of the transaction. createTable_transactionId :: Lens.Lens' CreateTable (Prelude.Maybe Prelude.Text) createTable_transactionId = Lens.lens (\CreateTable' {transactionId} -> transactionId) (\s@CreateTable' {} a -> s {transactionId = a} :: CreateTable) -- | The catalog database in which to create the new table. For Hive -- compatibility, this name is entirely lowercase. createTable_databaseName :: Lens.Lens' CreateTable Prelude.Text createTable_databaseName = Lens.lens (\CreateTable' {databaseName} -> databaseName) (\s@CreateTable' {} a -> s {databaseName = a} :: CreateTable) -- | The @TableInput@ object that defines the metadata table to create in the -- catalog. createTable_tableInput :: Lens.Lens' CreateTable TableInput createTable_tableInput = Lens.lens (\CreateTable' {tableInput} -> tableInput) (\s@CreateTable' {} a -> s {tableInput = a} :: CreateTable) instance Core.AWSRequest CreateTable where type AWSResponse CreateTable = CreateTableResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> CreateTableResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateTable where hashWithSalt _salt CreateTable' {..} = _salt `Prelude.hashWithSalt` catalogId `Prelude.hashWithSalt` partitionIndexes `Prelude.hashWithSalt` transactionId `Prelude.hashWithSalt` databaseName `Prelude.hashWithSalt` tableInput instance Prelude.NFData CreateTable where rnf CreateTable' {..} = Prelude.rnf catalogId `Prelude.seq` Prelude.rnf partitionIndexes `Prelude.seq` Prelude.rnf transactionId `Prelude.seq` Prelude.rnf databaseName `Prelude.seq` Prelude.rnf tableInput instance Data.ToHeaders CreateTable where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("AWSGlue.CreateTable" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON CreateTable where toJSON CreateTable' {..} = Data.object ( Prelude.catMaybes [ ("CatalogId" Data..=) Prelude.<$> catalogId, ("PartitionIndexes" Data..=) Prelude.<$> partitionIndexes, ("TransactionId" Data..=) Prelude.<$> transactionId, Prelude.Just ("DatabaseName" Data..= databaseName), Prelude.Just ("TableInput" Data..= tableInput) ] ) instance Data.ToPath CreateTable where toPath = Prelude.const "/" instance Data.ToQuery CreateTable where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateTableResponse' smart constructor. data CreateTableResponse = CreateTableResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateTableResponse' 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', 'createTableResponse_httpStatus' - The response's http status code. newCreateTableResponse :: -- | 'httpStatus' Prelude.Int -> CreateTableResponse newCreateTableResponse pHttpStatus_ = CreateTableResponse' {httpStatus = pHttpStatus_} -- | The response's http status code. createTableResponse_httpStatus :: Lens.Lens' CreateTableResponse Prelude.Int createTableResponse_httpStatus = Lens.lens (\CreateTableResponse' {httpStatus} -> httpStatus) (\s@CreateTableResponse' {} a -> s {httpStatus = a} :: CreateTableResponse) instance Prelude.NFData CreateTableResponse where rnf CreateTableResponse' {..} = Prelude.rnf httpStatus