{-# 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.SSM.UpdateAssociation
(
updateAssociation
, UpdateAssociation
, uaScheduleExpression
, uaOutputLocation
, uaParameters
, uaDocumentVersion
, uaAssociationId
, updateAssociationResponse
, UpdateAssociationResponse
, uarsAssociationDescription
, uarsResponseStatus
) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.SSM.Types
import Network.AWS.SSM.Types.Product
data UpdateAssociation = UpdateAssociation'
{ _uaScheduleExpression :: !(Maybe Text)
, _uaOutputLocation :: !(Maybe InstanceAssociationOutputLocation)
, _uaParameters :: !(Maybe (Map Text [Text]))
, _uaDocumentVersion :: !(Maybe Text)
, _uaAssociationId :: !Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
updateAssociation
:: Text
-> UpdateAssociation
updateAssociation pAssociationId_ =
UpdateAssociation'
{ _uaScheduleExpression = Nothing
, _uaOutputLocation = Nothing
, _uaParameters = Nothing
, _uaDocumentVersion = Nothing
, _uaAssociationId = pAssociationId_
}
uaScheduleExpression :: Lens' UpdateAssociation (Maybe Text)
uaScheduleExpression = lens _uaScheduleExpression (\ s a -> s{_uaScheduleExpression = a});
uaOutputLocation :: Lens' UpdateAssociation (Maybe InstanceAssociationOutputLocation)
uaOutputLocation = lens _uaOutputLocation (\ s a -> s{_uaOutputLocation = a});
uaParameters :: Lens' UpdateAssociation (HashMap Text [Text])
uaParameters = lens _uaParameters (\ s a -> s{_uaParameters = a}) . _Default . _Map;
uaDocumentVersion :: Lens' UpdateAssociation (Maybe Text)
uaDocumentVersion = lens _uaDocumentVersion (\ s a -> s{_uaDocumentVersion = a});
uaAssociationId :: Lens' UpdateAssociation Text
uaAssociationId = lens _uaAssociationId (\ s a -> s{_uaAssociationId = a});
instance AWSRequest UpdateAssociation where
type Rs UpdateAssociation = UpdateAssociationResponse
request = postJSON ssm
response
= receiveJSON
(\ s h x ->
UpdateAssociationResponse' <$>
(x .?> "AssociationDescription") <*>
(pure (fromEnum s)))
instance Hashable UpdateAssociation
instance NFData UpdateAssociation
instance ToHeaders UpdateAssociation where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AmazonSSM.UpdateAssociation" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON UpdateAssociation where
toJSON UpdateAssociation'{..}
= object
(catMaybes
[("ScheduleExpression" .=) <$> _uaScheduleExpression,
("OutputLocation" .=) <$> _uaOutputLocation,
("Parameters" .=) <$> _uaParameters,
("DocumentVersion" .=) <$> _uaDocumentVersion,
Just ("AssociationId" .= _uaAssociationId)])
instance ToPath UpdateAssociation where
toPath = const "/"
instance ToQuery UpdateAssociation where
toQuery = const mempty
data UpdateAssociationResponse = UpdateAssociationResponse'
{ _uarsAssociationDescription :: !(Maybe AssociationDescription)
, _uarsResponseStatus :: !Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
updateAssociationResponse
:: Int
-> UpdateAssociationResponse
updateAssociationResponse pResponseStatus_ =
UpdateAssociationResponse'
{ _uarsAssociationDescription = Nothing
, _uarsResponseStatus = pResponseStatus_
}
uarsAssociationDescription :: Lens' UpdateAssociationResponse (Maybe AssociationDescription)
uarsAssociationDescription = lens _uarsAssociationDescription (\ s a -> s{_uarsAssociationDescription = a});
uarsResponseStatus :: Lens' UpdateAssociationResponse Int
uarsResponseStatus = lens _uarsResponseStatus (\ s a -> s{_uarsResponseStatus = a});
instance NFData UpdateAssociationResponse