{-# 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.DeviceFarm.CreateRemoteAccessSession
(
createRemoteAccessSession
, CreateRemoteAccessSession
, crasName
, crasConfiguration
, crasProjectARN
, crasDeviceARN
, createRemoteAccessSessionResponse
, CreateRemoteAccessSessionResponse
, crasrsRemoteAccessSession
, crasrsResponseStatus
) where
import Network.AWS.DeviceFarm.Types
import Network.AWS.DeviceFarm.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data CreateRemoteAccessSession = CreateRemoteAccessSession'
{ _crasName :: !(Maybe Text)
, _crasConfiguration :: !(Maybe CreateRemoteAccessSessionConfiguration)
, _crasProjectARN :: !Text
, _crasDeviceARN :: !Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
createRemoteAccessSession
:: Text
-> Text
-> CreateRemoteAccessSession
createRemoteAccessSession pProjectARN_ pDeviceARN_ =
CreateRemoteAccessSession'
{ _crasName = Nothing
, _crasConfiguration = Nothing
, _crasProjectARN = pProjectARN_
, _crasDeviceARN = pDeviceARN_
}
crasName :: Lens' CreateRemoteAccessSession (Maybe Text)
crasName = lens _crasName (\ s a -> s{_crasName = a});
crasConfiguration :: Lens' CreateRemoteAccessSession (Maybe CreateRemoteAccessSessionConfiguration)
crasConfiguration = lens _crasConfiguration (\ s a -> s{_crasConfiguration = a});
crasProjectARN :: Lens' CreateRemoteAccessSession Text
crasProjectARN = lens _crasProjectARN (\ s a -> s{_crasProjectARN = a});
crasDeviceARN :: Lens' CreateRemoteAccessSession Text
crasDeviceARN = lens _crasDeviceARN (\ s a -> s{_crasDeviceARN = a});
instance AWSRequest CreateRemoteAccessSession where
type Rs CreateRemoteAccessSession =
CreateRemoteAccessSessionResponse
request = postJSON deviceFarm
response
= receiveJSON
(\ s h x ->
CreateRemoteAccessSessionResponse' <$>
(x .?> "remoteAccessSession") <*>
(pure (fromEnum s)))
instance Hashable CreateRemoteAccessSession
instance NFData CreateRemoteAccessSession
instance ToHeaders CreateRemoteAccessSession where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("DeviceFarm_20150623.CreateRemoteAccessSession" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON CreateRemoteAccessSession where
toJSON CreateRemoteAccessSession'{..}
= object
(catMaybes
[("name" .=) <$> _crasName,
("configuration" .=) <$> _crasConfiguration,
Just ("projectArn" .= _crasProjectARN),
Just ("deviceArn" .= _crasDeviceARN)])
instance ToPath CreateRemoteAccessSession where
toPath = const "/"
instance ToQuery CreateRemoteAccessSession where
toQuery = const mempty
data CreateRemoteAccessSessionResponse = CreateRemoteAccessSessionResponse'
{ _crasrsRemoteAccessSession :: !(Maybe RemoteAccessSession)
, _crasrsResponseStatus :: !Int
} deriving (Eq,Read,Show,Data,Typeable,Generic)
createRemoteAccessSessionResponse
:: Int
-> CreateRemoteAccessSessionResponse
createRemoteAccessSessionResponse pResponseStatus_ =
CreateRemoteAccessSessionResponse'
{ _crasrsRemoteAccessSession = Nothing
, _crasrsResponseStatus = pResponseStatus_
}
crasrsRemoteAccessSession :: Lens' CreateRemoteAccessSessionResponse (Maybe RemoteAccessSession)
crasrsRemoteAccessSession = lens _crasrsRemoteAccessSession (\ s a -> s{_crasrsRemoteAccessSession = a});
crasrsResponseStatus :: Lens' CreateRemoteAccessSessionResponse Int
crasrsResponseStatus = lens _crasrsResponseStatus (\ s a -> s{_crasrsResponseStatus = a});
instance NFData CreateRemoteAccessSessionResponse