{-# 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.CloudFormation.DescribeStackEvents -- Copyright : (c) 2013-2014 Brendan Hay <brendan.g.hay@gmail.com> -- 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 <brendan.g.hay@gmail.com> -- Stability : experimental -- Portability : non-portable (GHC extensions) -- -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | Returns all stack related events for a specified stack. For more information -- about a stack's event history, go to <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/concept-stack.html Stacks> in the AWS CloudFormation User -- Guide. -- -- You can list events for stacks that have failed to create or have been -- deleted by specifying the unique stack identifier (stack ID). -- -- <http://docs.aws.amazon.com/AWSCloudFormation/latest/APIReference/API_DescribeStackEvents.html> module Network.AWS.CloudFormation.DescribeStackEvents ( -- * Request DescribeStackEvents -- ** Request constructor , describeStackEvents -- ** Request lenses , dseNextToken , dseStackName -- * Response , DescribeStackEventsResponse -- ** Response constructor , describeStackEventsResponse -- ** Response lenses , 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, Read, Show) -- | 'DescribeStackEvents' constructor. -- -- The fields accessible through corresponding lenses are: -- -- * 'dseNextToken' @::@ 'Maybe' 'Text' -- -- * 'dseStackName' @::@ 'Maybe' 'Text' -- describeStackEvents :: DescribeStackEvents describeStackEvents = DescribeStackEvents { _dseStackName = Nothing , _dseNextToken = Nothing } -- | String that identifies the start of the next list of events, if there is one. -- -- Default: There is no default value. dseNextToken :: Lens' DescribeStackEvents (Maybe Text) dseNextToken = lens _dseNextToken (\s a -> s { _dseNextToken = a }) -- | The name or the unique stack ID that is associated with the stack, which are -- not always interchangeable: -- -- Running stacks: You can specify either the stack's name or its unique stack -- ID. Deleted stacks: You must specify the unique stack ID. Default: There is -- no default value. dseStackName :: Lens' DescribeStackEvents (Maybe Text) dseStackName = lens _dseStackName (\s a -> s { _dseStackName = a }) data DescribeStackEventsResponse = DescribeStackEventsResponse { _dserNextToken :: Maybe Text , _dserStackEvents :: List "member" StackEvent } deriving (Eq, Read, Show) -- | 'DescribeStackEventsResponse' constructor. -- -- The fields accessible through corresponding lenses are: -- -- * 'dserNextToken' @::@ 'Maybe' 'Text' -- -- * 'dserStackEvents' @::@ ['StackEvent'] -- describeStackEventsResponse :: DescribeStackEventsResponse describeStackEventsResponse = DescribeStackEventsResponse { _dserStackEvents = mempty , _dserNextToken = Nothing } -- | String that identifies the start of the next list of events, if there is one. dserNextToken :: Lens' DescribeStackEventsResponse (Maybe Text) dserNextToken = lens _dserNextToken (\s a -> s { _dserNextToken = a }) -- | A list of 'StackEvents' structures. 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" .!@ mempty instance AWSPager DescribeStackEvents where page rq rs | stop (rs ^. dserNextToken) = Nothing | otherwise = (\x -> rq & dseNextToken ?~ x) <$> (rs ^. dserNextToken)