{-# 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.CloudWatchEvents.DescribeEventBus
(
describeEventBus
, DescribeEventBus
, describeEventBusResponse
, DescribeEventBusResponse
, debrsARN
, debrsName
, debrsPolicy
, debrsResponseStatus
) where
import Network.AWS.CloudWatchEvents.Types
import Network.AWS.CloudWatchEvents.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data DescribeEventBus =
DescribeEventBus'
deriving (Eq, Read, Show, Data, Typeable, Generic)
describeEventBus
:: DescribeEventBus
describeEventBus = DescribeEventBus'
instance AWSRequest DescribeEventBus where
type Rs DescribeEventBus = DescribeEventBusResponse
request = postJSON cloudWatchEvents
response
= receiveJSON
(\ s h x ->
DescribeEventBusResponse' <$>
(x .?> "Arn") <*> (x .?> "Name") <*> (x .?> "Policy")
<*> (pure (fromEnum s)))
instance Hashable DescribeEventBus where
instance NFData DescribeEventBus where
instance ToHeaders DescribeEventBus where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AWSEvents.DescribeEventBus" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DescribeEventBus where
toJSON = const (Object mempty)
instance ToPath DescribeEventBus where
toPath = const "/"
instance ToQuery DescribeEventBus where
toQuery = const mempty
data DescribeEventBusResponse = DescribeEventBusResponse'
{ _debrsARN :: !(Maybe Text)
, _debrsName :: !(Maybe Text)
, _debrsPolicy :: !(Maybe Text)
, _debrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeEventBusResponse
:: Int
-> DescribeEventBusResponse
describeEventBusResponse pResponseStatus_ =
DescribeEventBusResponse'
{ _debrsARN = Nothing
, _debrsName = Nothing
, _debrsPolicy = Nothing
, _debrsResponseStatus = pResponseStatus_
}
debrsARN :: Lens' DescribeEventBusResponse (Maybe Text)
debrsARN = lens _debrsARN (\ s a -> s{_debrsARN = a})
debrsName :: Lens' DescribeEventBusResponse (Maybe Text)
debrsName = lens _debrsName (\ s a -> s{_debrsName = a})
debrsPolicy :: Lens' DescribeEventBusResponse (Maybe Text)
debrsPolicy = lens _debrsPolicy (\ s a -> s{_debrsPolicy = a})
debrsResponseStatus :: Lens' DescribeEventBusResponse Int
debrsResponseStatus = lens _debrsResponseStatus (\ s a -> s{_debrsResponseStatus = a})
instance NFData DescribeEventBusResponse where