{-# 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.IoTAnalytics.UpdatePipeline
(
updatePipeline
, UpdatePipeline
, upPipelineName
, upPipelineActivities
, updatePipelineResponse
, UpdatePipelineResponse
) where
import Network.AWS.IoTAnalytics.Types
import Network.AWS.IoTAnalytics.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data UpdatePipeline = UpdatePipeline'
{ _upPipelineName :: !Text
, _upPipelineActivities :: !(List1 PipelineActivity)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updatePipeline
:: Text
-> NonEmpty PipelineActivity
-> UpdatePipeline
updatePipeline pPipelineName_ pPipelineActivities_ =
UpdatePipeline'
{ _upPipelineName = pPipelineName_
, _upPipelineActivities = _List1 # pPipelineActivities_
}
upPipelineName :: Lens' UpdatePipeline Text
upPipelineName = lens _upPipelineName (\ s a -> s{_upPipelineName = a})
upPipelineActivities :: Lens' UpdatePipeline (NonEmpty PipelineActivity)
upPipelineActivities = lens _upPipelineActivities (\ s a -> s{_upPipelineActivities = a}) . _List1
instance AWSRequest UpdatePipeline where
type Rs UpdatePipeline = UpdatePipelineResponse
request = putJSON ioTAnalytics
response = receiveNull UpdatePipelineResponse'
instance Hashable UpdatePipeline where
instance NFData UpdatePipeline where
instance ToHeaders UpdatePipeline where
toHeaders = const mempty
instance ToJSON UpdatePipeline where
toJSON UpdatePipeline'{..}
= object
(catMaybes
[Just
("pipelineActivities" .= _upPipelineActivities)])
instance ToPath UpdatePipeline where
toPath UpdatePipeline'{..}
= mconcat ["/pipelines/", toBS _upPipelineName]
instance ToQuery UpdatePipeline where
toQuery = const mempty
data UpdatePipelineResponse =
UpdatePipelineResponse'
deriving (Eq, Read, Show, Data, Typeable, Generic)
updatePipelineResponse
:: UpdatePipelineResponse
updatePipelineResponse = UpdatePipelineResponse'
instance NFData UpdatePipelineResponse where