{-# 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.Glacier.GetDataRetrievalPolicy
(
getDataRetrievalPolicy
, GetDataRetrievalPolicy
, gdrpAccountId
, getDataRetrievalPolicyResponse
, GetDataRetrievalPolicyResponse
, gdrprsPolicy
, gdrprsResponseStatus
) where
import Network.AWS.Glacier.Types
import Network.AWS.Glacier.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
newtype GetDataRetrievalPolicy = GetDataRetrievalPolicy'
{ _gdrpAccountId :: Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
getDataRetrievalPolicy
:: Text
-> GetDataRetrievalPolicy
getDataRetrievalPolicy pAccountId_ =
GetDataRetrievalPolicy'
{ _gdrpAccountId = pAccountId_
}
gdrpAccountId :: Lens' GetDataRetrievalPolicy Text
gdrpAccountId = lens _gdrpAccountId (\ s a -> s{_gdrpAccountId = a});
instance AWSRequest GetDataRetrievalPolicy where
type Rs GetDataRetrievalPolicy =
GetDataRetrievalPolicyResponse
request = get glacier
response
= receiveJSON
(\ s h x ->
GetDataRetrievalPolicyResponse' <$>
(x .?> "Policy") <*> (pure (fromEnum s)))
instance Hashable GetDataRetrievalPolicy
instance NFData GetDataRetrievalPolicy
instance ToHeaders GetDataRetrievalPolicy where
toHeaders = const mempty
instance ToPath GetDataRetrievalPolicy where
toPath GetDataRetrievalPolicy'{..}
= mconcat
["/", toBS _gdrpAccountId,
"/policies/data-retrieval"]
instance ToQuery GetDataRetrievalPolicy where
toQuery = const mempty
data GetDataRetrievalPolicyResponse = GetDataRetrievalPolicyResponse'
{ _gdrprsPolicy :: !(Maybe DataRetrievalPolicy)
, _gdrprsResponseStatus :: !Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
getDataRetrievalPolicyResponse
:: Int
-> GetDataRetrievalPolicyResponse
getDataRetrievalPolicyResponse pResponseStatus_ =
GetDataRetrievalPolicyResponse'
{ _gdrprsPolicy = Nothing
, _gdrprsResponseStatus = pResponseStatus_
}
gdrprsPolicy :: Lens' GetDataRetrievalPolicyResponse (Maybe DataRetrievalPolicy)
gdrprsPolicy = lens _gdrprsPolicy (\ s a -> s{_gdrprsPolicy = a});
gdrprsResponseStatus :: Lens' GetDataRetrievalPolicyResponse Int
gdrprsResponseStatus = lens _gdrprsResponseStatus (\ s a -> s{_gdrprsResponseStatus = a});
instance NFData GetDataRetrievalPolicyResponse