module Network.AWS.CloudFormation.DescribeStackEvents
(
DescribeStackEvents
, describeStackEvents
, dseNextToken
, dseStackName
, DescribeStackEventsResponse
, describeStackEventsResponse
, dserNextToken
, dserStackEvents
) where
import Network.AWS.Prelude
import Network.AWS.Request.Query
import Network.AWS.CloudFormation.Types
import qualified GHC.Exts
data DescribeStackEvents = DescribeStackEvents
{ _dseNextToken :: Maybe Text
, _dseStackName :: Maybe Text
} deriving (Eq, Ord, Show)
describeStackEvents :: DescribeStackEvents
describeStackEvents = DescribeStackEvents
{ _dseStackName = Nothing
, _dseNextToken = Nothing
}
dseNextToken :: Lens' DescribeStackEvents (Maybe Text)
dseNextToken = lens _dseNextToken (\s a -> s { _dseNextToken = a })
dseStackName :: Lens' DescribeStackEvents (Maybe Text)
dseStackName = lens _dseStackName (\s a -> s { _dseStackName = a })
data DescribeStackEventsResponse = DescribeStackEventsResponse
{ _dserNextToken :: Maybe Text
, _dserStackEvents :: List "StackEvents" StackEvent
} deriving (Eq, Show)
describeStackEventsResponse :: DescribeStackEventsResponse
describeStackEventsResponse = DescribeStackEventsResponse
{ _dserStackEvents = mempty
, _dserNextToken = Nothing
}
dserNextToken :: Lens' DescribeStackEventsResponse (Maybe Text)
dserNextToken = lens _dserNextToken (\s a -> s { _dserNextToken = a })
dserStackEvents :: Lens' DescribeStackEventsResponse [StackEvent]
dserStackEvents = lens _dserStackEvents (\s a -> s { _dserStackEvents = a }) . _List
instance ToPath DescribeStackEvents where
toPath = const "/"
instance ToQuery DescribeStackEvents where
toQuery DescribeStackEvents{..} = mconcat
[ "NextToken" =? _dseNextToken
, "StackName" =? _dseStackName
]
instance ToHeaders DescribeStackEvents
instance AWSRequest DescribeStackEvents where
type Sv DescribeStackEvents = CloudFormation
type Rs DescribeStackEvents = DescribeStackEventsResponse
request = post "DescribeStackEvents"
response = xmlResponse
instance FromXML DescribeStackEventsResponse where
parseXML = withElement "DescribeStackEventsResult" $ \x -> DescribeStackEventsResponse
<$> x .@? "NextToken"
<*> x .@ "StackEvents"
instance AWSPager DescribeStackEvents where
page rq rs
| stop (rq ^. dseNextToken) = Nothing
| otherwise = (\x -> rq & dseNextToken ?~ x)
<$> (rs ^. dserNextToken)