module Network.AWS.DeviceFarm.CreateRemoteAccessSession
(
createRemoteAccessSession
, CreateRemoteAccessSession
, crasClientId
, crasSshPublicKey
, crasName
, crasRemoteDebugEnabled
, 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'
{ _crasClientId :: !(Maybe Text)
, _crasSshPublicKey :: !(Maybe Text)
, _crasName :: !(Maybe Text)
, _crasRemoteDebugEnabled :: !(Maybe Bool)
, _crasConfiguration :: !(Maybe CreateRemoteAccessSessionConfiguration)
, _crasProjectARN :: !Text
, _crasDeviceARN :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
createRemoteAccessSession
:: Text
-> Text
-> CreateRemoteAccessSession
createRemoteAccessSession pProjectARN_ pDeviceARN_ =
CreateRemoteAccessSession'
{ _crasClientId = Nothing
, _crasSshPublicKey = Nothing
, _crasName = Nothing
, _crasRemoteDebugEnabled = Nothing
, _crasConfiguration = Nothing
, _crasProjectARN = pProjectARN_
, _crasDeviceARN = pDeviceARN_
}
crasClientId :: Lens' CreateRemoteAccessSession (Maybe Text)
crasClientId = lens _crasClientId (\ s a -> s{_crasClientId = a});
crasSshPublicKey :: Lens' CreateRemoteAccessSession (Maybe Text)
crasSshPublicKey = lens _crasSshPublicKey (\ s a -> s{_crasSshPublicKey = a});
crasName :: Lens' CreateRemoteAccessSession (Maybe Text)
crasName = lens _crasName (\ s a -> s{_crasName = a});
crasRemoteDebugEnabled :: Lens' CreateRemoteAccessSession (Maybe Bool)
crasRemoteDebugEnabled = lens _crasRemoteDebugEnabled (\ s a -> s{_crasRemoteDebugEnabled = 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 where
instance NFData CreateRemoteAccessSession where
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
[("clientId" .=) <$> _crasClientId,
("sshPublicKey" .=) <$> _crasSshPublicKey,
("name" .=) <$> _crasName,
("remoteDebugEnabled" .=) <$>
_crasRemoteDebugEnabled,
("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
where