{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.DeviceFarm.GetTestGridProject
(
GetTestGridProject (..),
newGetTestGridProject,
getTestGridProject_projectArn,
GetTestGridProjectResponse (..),
newGetTestGridProjectResponse,
getTestGridProjectResponse_testGridProject,
getTestGridProjectResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.DeviceFarm.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data GetTestGridProject = GetTestGridProject'
{
GetTestGridProject -> Text
projectArn :: Prelude.Text
}
deriving (GetTestGridProject -> GetTestGridProject -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetTestGridProject -> GetTestGridProject -> Bool
$c/= :: GetTestGridProject -> GetTestGridProject -> Bool
== :: GetTestGridProject -> GetTestGridProject -> Bool
$c== :: GetTestGridProject -> GetTestGridProject -> Bool
Prelude.Eq, ReadPrec [GetTestGridProject]
ReadPrec GetTestGridProject
Int -> ReadS GetTestGridProject
ReadS [GetTestGridProject]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetTestGridProject]
$creadListPrec :: ReadPrec [GetTestGridProject]
readPrec :: ReadPrec GetTestGridProject
$creadPrec :: ReadPrec GetTestGridProject
readList :: ReadS [GetTestGridProject]
$creadList :: ReadS [GetTestGridProject]
readsPrec :: Int -> ReadS GetTestGridProject
$creadsPrec :: Int -> ReadS GetTestGridProject
Prelude.Read, Int -> GetTestGridProject -> ShowS
[GetTestGridProject] -> ShowS
GetTestGridProject -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetTestGridProject] -> ShowS
$cshowList :: [GetTestGridProject] -> ShowS
show :: GetTestGridProject -> String
$cshow :: GetTestGridProject -> String
showsPrec :: Int -> GetTestGridProject -> ShowS
$cshowsPrec :: Int -> GetTestGridProject -> ShowS
Prelude.Show, forall x. Rep GetTestGridProject x -> GetTestGridProject
forall x. GetTestGridProject -> Rep GetTestGridProject x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GetTestGridProject x -> GetTestGridProject
$cfrom :: forall x. GetTestGridProject -> Rep GetTestGridProject x
Prelude.Generic)
newGetTestGridProject ::
Prelude.Text ->
GetTestGridProject
newGetTestGridProject :: Text -> GetTestGridProject
newGetTestGridProject Text
pProjectArn_ =
GetTestGridProject' {$sel:projectArn:GetTestGridProject' :: Text
projectArn = Text
pProjectArn_}
getTestGridProject_projectArn :: Lens.Lens' GetTestGridProject Prelude.Text
getTestGridProject_projectArn :: Lens' GetTestGridProject Text
getTestGridProject_projectArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetTestGridProject' {Text
projectArn :: Text
$sel:projectArn:GetTestGridProject' :: GetTestGridProject -> Text
projectArn} -> Text
projectArn) (\s :: GetTestGridProject
s@GetTestGridProject' {} Text
a -> GetTestGridProject
s {$sel:projectArn:GetTestGridProject' :: Text
projectArn = Text
a} :: GetTestGridProject)
instance Core.AWSRequest GetTestGridProject where
type
AWSResponse GetTestGridProject =
GetTestGridProjectResponse
request :: (Service -> Service)
-> GetTestGridProject -> Request GetTestGridProject
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetTestGridProject
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse GetTestGridProject)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
( \Int
s ResponseHeaders
h Object
x ->
Maybe TestGridProject -> Int -> GetTestGridProjectResponse
GetTestGridProjectResponse'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"testGridProject")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
)
instance Prelude.Hashable GetTestGridProject where
hashWithSalt :: Int -> GetTestGridProject -> Int
hashWithSalt Int
_salt GetTestGridProject' {Text
projectArn :: Text
$sel:projectArn:GetTestGridProject' :: GetTestGridProject -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
projectArn
instance Prelude.NFData GetTestGridProject where
rnf :: GetTestGridProject -> ()
rnf GetTestGridProject' {Text
projectArn :: Text
$sel:projectArn:GetTestGridProject' :: GetTestGridProject -> Text
..} = forall a. NFData a => a -> ()
Prelude.rnf Text
projectArn
instance Data.ToHeaders GetTestGridProject where
toHeaders :: GetTestGridProject -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"X-Amz-Target"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"DeviceFarm_20150623.GetTestGridProject" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON GetTestGridProject where
toJSON :: GetTestGridProject -> Value
toJSON GetTestGridProject' {Text
projectArn :: Text
$sel:projectArn:GetTestGridProject' :: GetTestGridProject -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[forall a. a -> Maybe a
Prelude.Just (Key
"projectArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
projectArn)]
)
instance Data.ToPath GetTestGridProject where
toPath :: GetTestGridProject -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery GetTestGridProject where
toQuery :: GetTestGridProject -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data GetTestGridProjectResponse = GetTestGridProjectResponse'
{
GetTestGridProjectResponse -> Maybe TestGridProject
testGridProject :: Prelude.Maybe TestGridProject,
GetTestGridProjectResponse -> Int
httpStatus :: Prelude.Int
}
deriving (GetTestGridProjectResponse -> GetTestGridProjectResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetTestGridProjectResponse -> GetTestGridProjectResponse -> Bool
$c/= :: GetTestGridProjectResponse -> GetTestGridProjectResponse -> Bool
== :: GetTestGridProjectResponse -> GetTestGridProjectResponse -> Bool
$c== :: GetTestGridProjectResponse -> GetTestGridProjectResponse -> Bool
Prelude.Eq, ReadPrec [GetTestGridProjectResponse]
ReadPrec GetTestGridProjectResponse
Int -> ReadS GetTestGridProjectResponse
ReadS [GetTestGridProjectResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetTestGridProjectResponse]
$creadListPrec :: ReadPrec [GetTestGridProjectResponse]
readPrec :: ReadPrec GetTestGridProjectResponse
$creadPrec :: ReadPrec GetTestGridProjectResponse
readList :: ReadS [GetTestGridProjectResponse]
$creadList :: ReadS [GetTestGridProjectResponse]
readsPrec :: Int -> ReadS GetTestGridProjectResponse
$creadsPrec :: Int -> ReadS GetTestGridProjectResponse
Prelude.Read, Int -> GetTestGridProjectResponse -> ShowS
[GetTestGridProjectResponse] -> ShowS
GetTestGridProjectResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetTestGridProjectResponse] -> ShowS
$cshowList :: [GetTestGridProjectResponse] -> ShowS
show :: GetTestGridProjectResponse -> String
$cshow :: GetTestGridProjectResponse -> String
showsPrec :: Int -> GetTestGridProjectResponse -> ShowS
$cshowsPrec :: Int -> GetTestGridProjectResponse -> ShowS
Prelude.Show, forall x.
Rep GetTestGridProjectResponse x -> GetTestGridProjectResponse
forall x.
GetTestGridProjectResponse -> Rep GetTestGridProjectResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetTestGridProjectResponse x -> GetTestGridProjectResponse
$cfrom :: forall x.
GetTestGridProjectResponse -> Rep GetTestGridProjectResponse x
Prelude.Generic)
newGetTestGridProjectResponse ::
Prelude.Int ->
GetTestGridProjectResponse
newGetTestGridProjectResponse :: Int -> GetTestGridProjectResponse
newGetTestGridProjectResponse Int
pHttpStatus_ =
GetTestGridProjectResponse'
{ $sel:testGridProject:GetTestGridProjectResponse' :: Maybe TestGridProject
testGridProject =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:GetTestGridProjectResponse' :: Int
httpStatus = Int
pHttpStatus_
}
getTestGridProjectResponse_testGridProject :: Lens.Lens' GetTestGridProjectResponse (Prelude.Maybe TestGridProject)
getTestGridProjectResponse_testGridProject :: Lens' GetTestGridProjectResponse (Maybe TestGridProject)
getTestGridProjectResponse_testGridProject = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetTestGridProjectResponse' {Maybe TestGridProject
testGridProject :: Maybe TestGridProject
$sel:testGridProject:GetTestGridProjectResponse' :: GetTestGridProjectResponse -> Maybe TestGridProject
testGridProject} -> Maybe TestGridProject
testGridProject) (\s :: GetTestGridProjectResponse
s@GetTestGridProjectResponse' {} Maybe TestGridProject
a -> GetTestGridProjectResponse
s {$sel:testGridProject:GetTestGridProjectResponse' :: Maybe TestGridProject
testGridProject = Maybe TestGridProject
a} :: GetTestGridProjectResponse)
getTestGridProjectResponse_httpStatus :: Lens.Lens' GetTestGridProjectResponse Prelude.Int
getTestGridProjectResponse_httpStatus :: Lens' GetTestGridProjectResponse Int
getTestGridProjectResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetTestGridProjectResponse' {Int
httpStatus :: Int
$sel:httpStatus:GetTestGridProjectResponse' :: GetTestGridProjectResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: GetTestGridProjectResponse
s@GetTestGridProjectResponse' {} Int
a -> GetTestGridProjectResponse
s {$sel:httpStatus:GetTestGridProjectResponse' :: Int
httpStatus = Int
a} :: GetTestGridProjectResponse)
instance Prelude.NFData GetTestGridProjectResponse where
rnf :: GetTestGridProjectResponse -> ()
rnf GetTestGridProjectResponse' {Int
Maybe TestGridProject
httpStatus :: Int
testGridProject :: Maybe TestGridProject
$sel:httpStatus:GetTestGridProjectResponse' :: GetTestGridProjectResponse -> Int
$sel:testGridProject:GetTestGridProjectResponse' :: GetTestGridProjectResponse -> Maybe TestGridProject
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe TestGridProject
testGridProject
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus