{-# 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.CodeDeploy.RegisterOnPremisesInstance
(
registerOnPremisesInstance
, RegisterOnPremisesInstance
, ropiIamUserARN
, ropiIamSessionARN
, ropiInstanceName
, registerOnPremisesInstanceResponse
, RegisterOnPremisesInstanceResponse
) where
import Network.AWS.CodeDeploy.Types
import Network.AWS.CodeDeploy.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data RegisterOnPremisesInstance = RegisterOnPremisesInstance'
{ _ropiIamUserARN :: !(Maybe Text)
, _ropiIamSessionARN :: !(Maybe Text)
, _ropiInstanceName :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
registerOnPremisesInstance
:: Text
-> RegisterOnPremisesInstance
registerOnPremisesInstance pInstanceName_ =
RegisterOnPremisesInstance'
{ _ropiIamUserARN = Nothing
, _ropiIamSessionARN = Nothing
, _ropiInstanceName = pInstanceName_
}
ropiIamUserARN :: Lens' RegisterOnPremisesInstance (Maybe Text)
ropiIamUserARN = lens _ropiIamUserARN (\ s a -> s{_ropiIamUserARN = a})
ropiIamSessionARN :: Lens' RegisterOnPremisesInstance (Maybe Text)
ropiIamSessionARN = lens _ropiIamSessionARN (\ s a -> s{_ropiIamSessionARN = a})
ropiInstanceName :: Lens' RegisterOnPremisesInstance Text
ropiInstanceName = lens _ropiInstanceName (\ s a -> s{_ropiInstanceName = a})
instance AWSRequest RegisterOnPremisesInstance where
type Rs RegisterOnPremisesInstance =
RegisterOnPremisesInstanceResponse
request = postJSON codeDeploy
response
= receiveNull RegisterOnPremisesInstanceResponse'
instance Hashable RegisterOnPremisesInstance where
instance NFData RegisterOnPremisesInstance where
instance ToHeaders RegisterOnPremisesInstance where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("CodeDeploy_20141006.RegisterOnPremisesInstance" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON RegisterOnPremisesInstance where
toJSON RegisterOnPremisesInstance'{..}
= object
(catMaybes
[("iamUserArn" .=) <$> _ropiIamUserARN,
("iamSessionArn" .=) <$> _ropiIamSessionARN,
Just ("instanceName" .= _ropiInstanceName)])
instance ToPath RegisterOnPremisesInstance where
toPath = const "/"
instance ToQuery RegisterOnPremisesInstance where
toQuery = const mempty
data RegisterOnPremisesInstanceResponse =
RegisterOnPremisesInstanceResponse'
deriving (Eq, Read, Show, Data, Typeable, Generic)
registerOnPremisesInstanceResponse
:: RegisterOnPremisesInstanceResponse
registerOnPremisesInstanceResponse = RegisterOnPremisesInstanceResponse'
instance NFData RegisterOnPremisesInstanceResponse
where