{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Network.AWS.Glue.GetClassifier
(
getClassifier
, GetClassifier
, getName
, getClassifierResponse
, GetClassifierResponse
, gcrsClassifier
, gcrsResponseStatus
) 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
newtype GetClassifier = GetClassifier'
{ _getName :: Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
getClassifier
:: Text
-> GetClassifier
getClassifier pName_ = GetClassifier' {_getName = pName_}
getName :: Lens' GetClassifier Text
getName = lens _getName (\ s a -> s{_getName = a})
instance AWSRequest GetClassifier where
type Rs GetClassifier = GetClassifierResponse
request = postJSON glue
response
= receiveJSON
(\ s h x ->
GetClassifierResponse' <$>
(x .?> "Classifier") <*> (pure (fromEnum s)))
instance Hashable GetClassifier where
instance NFData GetClassifier where
instance ToHeaders GetClassifier where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AWSGlue.GetClassifier" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON GetClassifier where
toJSON GetClassifier'{..}
= object (catMaybes [Just ("Name" .= _getName)])
instance ToPath GetClassifier where
toPath = const "/"
instance ToQuery GetClassifier where
toQuery = const mempty
data GetClassifierResponse = GetClassifierResponse'
{ _gcrsClassifier :: !(Maybe Classifier)
, _gcrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
getClassifierResponse
:: Int
-> GetClassifierResponse
getClassifierResponse pResponseStatus_ =
GetClassifierResponse'
{_gcrsClassifier = Nothing, _gcrsResponseStatus = pResponseStatus_}
gcrsClassifier :: Lens' GetClassifierResponse (Maybe Classifier)
gcrsClassifier = lens _gcrsClassifier (\ s a -> s{_gcrsClassifier = a})
gcrsResponseStatus :: Lens' GetClassifierResponse Int
gcrsResponseStatus = lens _gcrsResponseStatus (\ s a -> s{_gcrsResponseStatus = a})
instance NFData GetClassifierResponse where