{-# LANGUAGE DataKinds #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE GeneralizedNewtypeDeriving #-} {-# LANGUAGE LambdaCase #-} {-# LANGUAGE NoImplicitPrelude #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE TypeFamilies #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} -- Module : Network.AWS.DynamoDB.DeleteTable -- Copyright : (c) 2013-2014 Brendan Hay -- License : This Source Code Form is subject to the terms of -- the Mozilla Public License, v. 2.0. -- A copy of the MPL can be found in the LICENSE file or -- you can obtain it at http://mozilla.org/MPL/2.0/. -- Maintainer : Brendan Hay -- Stability : experimental -- Portability : non-portable (GHC extensions) -- -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | The /DeleteTable/ operation deletes a table and all of its items. After a /DeleteTable/ request, the specified table is in the 'DELETING' state until DynamoDB -- completes the deletion. If the table is in the 'ACTIVE' state, you can delete -- it. If a table is in 'CREATING' or 'UPDATING' states, then DynamoDB returns a /ResourceInUseException/. If the specified table does not exist, DynamoDB returns a /ResourceNotFoundException/. If table is already in the 'DELETING' state, no error is returned. -- -- DynamoDB might continue to accept data read and write operations, such as /GetItem/ and /PutItem/, on a table in the 'DELETING' state until the table deletion is -- complete. -- -- When you delete a table, any indexes on that table are also deleted. -- -- Use the /DescribeTable/ API to check the status of the table. -- -- module Network.AWS.DynamoDB.DeleteTable ( -- * Request DeleteTable -- ** Request constructor , deleteTable -- ** Request lenses , dtTableName -- * Response , DeleteTableResponse -- ** Response constructor , deleteTableResponse -- ** Response lenses , dtrTableDescription ) where import Network.AWS.Data (Object) import Network.AWS.Prelude import Network.AWS.Request.JSON import Network.AWS.DynamoDB.Types import qualified GHC.Exts newtype DeleteTable = DeleteTable { _dtTableName :: Text } deriving (Eq, Ord, Read, Show, Monoid, IsString) -- | 'DeleteTable' constructor. -- -- The fields accessible through corresponding lenses are: -- -- * 'dtTableName' @::@ 'Text' -- deleteTable :: Text -- ^ 'dtTableName' -> DeleteTable deleteTable p1 = DeleteTable { _dtTableName = p1 } -- | The name of the table to delete. dtTableName :: Lens' DeleteTable Text dtTableName = lens _dtTableName (\s a -> s { _dtTableName = a }) newtype DeleteTableResponse = DeleteTableResponse { _dtrTableDescription :: Maybe TableDescription } deriving (Eq, Read, Show) -- | 'DeleteTableResponse' constructor. -- -- The fields accessible through corresponding lenses are: -- -- * 'dtrTableDescription' @::@ 'Maybe' 'TableDescription' -- deleteTableResponse :: DeleteTableResponse deleteTableResponse = DeleteTableResponse { _dtrTableDescription = Nothing } dtrTableDescription :: Lens' DeleteTableResponse (Maybe TableDescription) dtrTableDescription = lens _dtrTableDescription (\s a -> s { _dtrTableDescription = a }) instance ToPath DeleteTable where toPath = const "/" instance ToQuery DeleteTable where toQuery = const mempty instance ToHeaders DeleteTable instance ToJSON DeleteTable where toJSON DeleteTable{..} = object [ "TableName" .= _dtTableName ] instance AWSRequest DeleteTable where type Sv DeleteTable = DynamoDB type Rs DeleteTable = DeleteTableResponse request = post "DeleteTable" response = jsonResponse instance FromJSON DeleteTableResponse where parseJSON = withObject "DeleteTableResponse" $ \o -> DeleteTableResponse <$> o .:? "TableDescription"