module Network.AWS.Glue.UpdatePartition
(
updatePartition
, UpdatePartition
, upCatalogId
, upDatabaseName
, upTableName
, upPartitionValueList
, upPartitionInput
, updatePartitionResponse
, UpdatePartitionResponse
, uprsResponseStatus
) where
import Network.AWS.Glue.Types
import Network.AWS.Glue.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data UpdatePartition = UpdatePartition'
{ _upCatalogId :: !(Maybe Text)
, _upDatabaseName :: !Text
, _upTableName :: !Text
, _upPartitionValueList :: ![Text]
, _upPartitionInput :: !PartitionInput
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updatePartition
:: Text
-> Text
-> PartitionInput
-> UpdatePartition
updatePartition pDatabaseName_ pTableName_ pPartitionInput_ =
UpdatePartition'
{ _upCatalogId = Nothing
, _upDatabaseName = pDatabaseName_
, _upTableName = pTableName_
, _upPartitionValueList = mempty
, _upPartitionInput = pPartitionInput_
}
upCatalogId :: Lens' UpdatePartition (Maybe Text)
upCatalogId = lens _upCatalogId (\ s a -> s{_upCatalogId = a});
upDatabaseName :: Lens' UpdatePartition Text
upDatabaseName = lens _upDatabaseName (\ s a -> s{_upDatabaseName = a});
upTableName :: Lens' UpdatePartition Text
upTableName = lens _upTableName (\ s a -> s{_upTableName = a});
upPartitionValueList :: Lens' UpdatePartition [Text]
upPartitionValueList = lens _upPartitionValueList (\ s a -> s{_upPartitionValueList = a}) . _Coerce;
upPartitionInput :: Lens' UpdatePartition PartitionInput
upPartitionInput = lens _upPartitionInput (\ s a -> s{_upPartitionInput = a});
instance AWSRequest UpdatePartition where
type Rs UpdatePartition = UpdatePartitionResponse
request = postJSON glue
response
= receiveEmpty
(\ s h x ->
UpdatePartitionResponse' <$> (pure (fromEnum s)))
instance Hashable UpdatePartition where
instance NFData UpdatePartition where
instance ToHeaders UpdatePartition where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AWSGlue.UpdatePartition" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON UpdatePartition where
toJSON UpdatePartition'{..}
= object
(catMaybes
[("CatalogId" .=) <$> _upCatalogId,
Just ("DatabaseName" .= _upDatabaseName),
Just ("TableName" .= _upTableName),
Just ("PartitionValueList" .= _upPartitionValueList),
Just ("PartitionInput" .= _upPartitionInput)])
instance ToPath UpdatePartition where
toPath = const "/"
instance ToQuery UpdatePartition where
toQuery = const mempty
newtype UpdatePartitionResponse = UpdatePartitionResponse'
{ _uprsResponseStatus :: Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updatePartitionResponse
:: Int
-> UpdatePartitionResponse
updatePartitionResponse pResponseStatus_ =
UpdatePartitionResponse' {_uprsResponseStatus = pResponseStatus_}
uprsResponseStatus :: Lens' UpdatePartitionResponse Int
uprsResponseStatus = lens _uprsResponseStatus (\ s a -> s{_uprsResponseStatus = a});
instance NFData UpdatePartitionResponse where