{-# 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.CreateTestGridUrl
(
CreateTestGridUrl (..),
newCreateTestGridUrl,
createTestGridUrl_projectArn,
createTestGridUrl_expiresInSeconds,
CreateTestGridUrlResponse (..),
newCreateTestGridUrlResponse,
createTestGridUrlResponse_expires,
createTestGridUrlResponse_url,
createTestGridUrlResponse_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 CreateTestGridUrl = CreateTestGridUrl'
{
CreateTestGridUrl -> Text
projectArn :: Prelude.Text,
CreateTestGridUrl -> Natural
expiresInSeconds :: Prelude.Natural
}
deriving (CreateTestGridUrl -> CreateTestGridUrl -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateTestGridUrl -> CreateTestGridUrl -> Bool
$c/= :: CreateTestGridUrl -> CreateTestGridUrl -> Bool
== :: CreateTestGridUrl -> CreateTestGridUrl -> Bool
$c== :: CreateTestGridUrl -> CreateTestGridUrl -> Bool
Prelude.Eq, ReadPrec [CreateTestGridUrl]
ReadPrec CreateTestGridUrl
Int -> ReadS CreateTestGridUrl
ReadS [CreateTestGridUrl]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateTestGridUrl]
$creadListPrec :: ReadPrec [CreateTestGridUrl]
readPrec :: ReadPrec CreateTestGridUrl
$creadPrec :: ReadPrec CreateTestGridUrl
readList :: ReadS [CreateTestGridUrl]
$creadList :: ReadS [CreateTestGridUrl]
readsPrec :: Int -> ReadS CreateTestGridUrl
$creadsPrec :: Int -> ReadS CreateTestGridUrl
Prelude.Read, Int -> CreateTestGridUrl -> ShowS
[CreateTestGridUrl] -> ShowS
CreateTestGridUrl -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateTestGridUrl] -> ShowS
$cshowList :: [CreateTestGridUrl] -> ShowS
show :: CreateTestGridUrl -> String
$cshow :: CreateTestGridUrl -> String
showsPrec :: Int -> CreateTestGridUrl -> ShowS
$cshowsPrec :: Int -> CreateTestGridUrl -> ShowS
Prelude.Show, forall x. Rep CreateTestGridUrl x -> CreateTestGridUrl
forall x. CreateTestGridUrl -> Rep CreateTestGridUrl x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateTestGridUrl x -> CreateTestGridUrl
$cfrom :: forall x. CreateTestGridUrl -> Rep CreateTestGridUrl x
Prelude.Generic)
newCreateTestGridUrl ::
Prelude.Text ->
Prelude.Natural ->
CreateTestGridUrl
newCreateTestGridUrl :: Text -> Natural -> CreateTestGridUrl
newCreateTestGridUrl Text
pProjectArn_ Natural
pExpiresInSeconds_ =
CreateTestGridUrl'
{ $sel:projectArn:CreateTestGridUrl' :: Text
projectArn = Text
pProjectArn_,
$sel:expiresInSeconds:CreateTestGridUrl' :: Natural
expiresInSeconds = Natural
pExpiresInSeconds_
}
createTestGridUrl_projectArn :: Lens.Lens' CreateTestGridUrl Prelude.Text
createTestGridUrl_projectArn :: Lens' CreateTestGridUrl Text
createTestGridUrl_projectArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateTestGridUrl' {Text
projectArn :: Text
$sel:projectArn:CreateTestGridUrl' :: CreateTestGridUrl -> Text
projectArn} -> Text
projectArn) (\s :: CreateTestGridUrl
s@CreateTestGridUrl' {} Text
a -> CreateTestGridUrl
s {$sel:projectArn:CreateTestGridUrl' :: Text
projectArn = Text
a} :: CreateTestGridUrl)
createTestGridUrl_expiresInSeconds :: Lens.Lens' CreateTestGridUrl Prelude.Natural
createTestGridUrl_expiresInSeconds :: Lens' CreateTestGridUrl Natural
createTestGridUrl_expiresInSeconds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateTestGridUrl' {Natural
expiresInSeconds :: Natural
$sel:expiresInSeconds:CreateTestGridUrl' :: CreateTestGridUrl -> Natural
expiresInSeconds} -> Natural
expiresInSeconds) (\s :: CreateTestGridUrl
s@CreateTestGridUrl' {} Natural
a -> CreateTestGridUrl
s {$sel:expiresInSeconds:CreateTestGridUrl' :: Natural
expiresInSeconds = Natural
a} :: CreateTestGridUrl)
instance Core.AWSRequest CreateTestGridUrl where
type
AWSResponse CreateTestGridUrl =
CreateTestGridUrlResponse
request :: (Service -> Service)
-> CreateTestGridUrl -> Request CreateTestGridUrl
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 CreateTestGridUrl
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse CreateTestGridUrl)))
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 POSIX
-> Maybe (Sensitive Text) -> Int -> CreateTestGridUrlResponse
CreateTestGridUrlResponse'
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
"expires")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"url")
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 CreateTestGridUrl where
hashWithSalt :: Int -> CreateTestGridUrl -> Int
hashWithSalt Int
_salt CreateTestGridUrl' {Natural
Text
expiresInSeconds :: Natural
projectArn :: Text
$sel:expiresInSeconds:CreateTestGridUrl' :: CreateTestGridUrl -> Natural
$sel:projectArn:CreateTestGridUrl' :: CreateTestGridUrl -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
projectArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Natural
expiresInSeconds
instance Prelude.NFData CreateTestGridUrl where
rnf :: CreateTestGridUrl -> ()
rnf CreateTestGridUrl' {Natural
Text
expiresInSeconds :: Natural
projectArn :: Text
$sel:expiresInSeconds:CreateTestGridUrl' :: CreateTestGridUrl -> Natural
$sel:projectArn:CreateTestGridUrl' :: CreateTestGridUrl -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
projectArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Natural
expiresInSeconds
instance Data.ToHeaders CreateTestGridUrl where
toHeaders :: CreateTestGridUrl -> 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.CreateTestGridUrl" ::
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 CreateTestGridUrl where
toJSON :: CreateTestGridUrl -> Value
toJSON CreateTestGridUrl' {Natural
Text
expiresInSeconds :: Natural
projectArn :: Text
$sel:expiresInSeconds:CreateTestGridUrl' :: CreateTestGridUrl -> Natural
$sel:projectArn:CreateTestGridUrl' :: CreateTestGridUrl -> 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),
forall a. a -> Maybe a
Prelude.Just
(Key
"expiresInSeconds" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Natural
expiresInSeconds)
]
)
instance Data.ToPath CreateTestGridUrl where
toPath :: CreateTestGridUrl -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery CreateTestGridUrl where
toQuery :: CreateTestGridUrl -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data CreateTestGridUrlResponse = CreateTestGridUrlResponse'
{
CreateTestGridUrlResponse -> Maybe POSIX
expires :: Prelude.Maybe Data.POSIX,
CreateTestGridUrlResponse -> Maybe (Sensitive Text)
url :: Prelude.Maybe (Data.Sensitive Prelude.Text),
CreateTestGridUrlResponse -> Int
httpStatus :: Prelude.Int
}
deriving (CreateTestGridUrlResponse -> CreateTestGridUrlResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateTestGridUrlResponse -> CreateTestGridUrlResponse -> Bool
$c/= :: CreateTestGridUrlResponse -> CreateTestGridUrlResponse -> Bool
== :: CreateTestGridUrlResponse -> CreateTestGridUrlResponse -> Bool
$c== :: CreateTestGridUrlResponse -> CreateTestGridUrlResponse -> Bool
Prelude.Eq, Int -> CreateTestGridUrlResponse -> ShowS
[CreateTestGridUrlResponse] -> ShowS
CreateTestGridUrlResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateTestGridUrlResponse] -> ShowS
$cshowList :: [CreateTestGridUrlResponse] -> ShowS
show :: CreateTestGridUrlResponse -> String
$cshow :: CreateTestGridUrlResponse -> String
showsPrec :: Int -> CreateTestGridUrlResponse -> ShowS
$cshowsPrec :: Int -> CreateTestGridUrlResponse -> ShowS
Prelude.Show, forall x.
Rep CreateTestGridUrlResponse x -> CreateTestGridUrlResponse
forall x.
CreateTestGridUrlResponse -> Rep CreateTestGridUrlResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateTestGridUrlResponse x -> CreateTestGridUrlResponse
$cfrom :: forall x.
CreateTestGridUrlResponse -> Rep CreateTestGridUrlResponse x
Prelude.Generic)
newCreateTestGridUrlResponse ::
Prelude.Int ->
CreateTestGridUrlResponse
newCreateTestGridUrlResponse :: Int -> CreateTestGridUrlResponse
newCreateTestGridUrlResponse Int
pHttpStatus_ =
CreateTestGridUrlResponse'
{ $sel:expires:CreateTestGridUrlResponse' :: Maybe POSIX
expires =
forall a. Maybe a
Prelude.Nothing,
$sel:url:CreateTestGridUrlResponse' :: Maybe (Sensitive Text)
url = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:CreateTestGridUrlResponse' :: Int
httpStatus = Int
pHttpStatus_
}
createTestGridUrlResponse_expires :: Lens.Lens' CreateTestGridUrlResponse (Prelude.Maybe Prelude.UTCTime)
createTestGridUrlResponse_expires :: Lens' CreateTestGridUrlResponse (Maybe UTCTime)
createTestGridUrlResponse_expires = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateTestGridUrlResponse' {Maybe POSIX
expires :: Maybe POSIX
$sel:expires:CreateTestGridUrlResponse' :: CreateTestGridUrlResponse -> Maybe POSIX
expires} -> Maybe POSIX
expires) (\s :: CreateTestGridUrlResponse
s@CreateTestGridUrlResponse' {} Maybe POSIX
a -> CreateTestGridUrlResponse
s {$sel:expires:CreateTestGridUrlResponse' :: Maybe POSIX
expires = Maybe POSIX
a} :: CreateTestGridUrlResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall (a :: Format). Iso' (Time a) UTCTime
Data._Time
createTestGridUrlResponse_url :: Lens.Lens' CreateTestGridUrlResponse (Prelude.Maybe Prelude.Text)
createTestGridUrlResponse_url :: Lens' CreateTestGridUrlResponse (Maybe Text)
createTestGridUrlResponse_url = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateTestGridUrlResponse' {Maybe (Sensitive Text)
url :: Maybe (Sensitive Text)
$sel:url:CreateTestGridUrlResponse' :: CreateTestGridUrlResponse -> Maybe (Sensitive Text)
url} -> Maybe (Sensitive Text)
url) (\s :: CreateTestGridUrlResponse
s@CreateTestGridUrlResponse' {} Maybe (Sensitive Text)
a -> CreateTestGridUrlResponse
s {$sel:url:CreateTestGridUrlResponse' :: Maybe (Sensitive Text)
url = Maybe (Sensitive Text)
a} :: CreateTestGridUrlResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall a. Iso' (Sensitive a) a
Data._Sensitive
createTestGridUrlResponse_httpStatus :: Lens.Lens' CreateTestGridUrlResponse Prelude.Int
createTestGridUrlResponse_httpStatus :: Lens' CreateTestGridUrlResponse Int
createTestGridUrlResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateTestGridUrlResponse' {Int
httpStatus :: Int
$sel:httpStatus:CreateTestGridUrlResponse' :: CreateTestGridUrlResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: CreateTestGridUrlResponse
s@CreateTestGridUrlResponse' {} Int
a -> CreateTestGridUrlResponse
s {$sel:httpStatus:CreateTestGridUrlResponse' :: Int
httpStatus = Int
a} :: CreateTestGridUrlResponse)
instance Prelude.NFData CreateTestGridUrlResponse where
rnf :: CreateTestGridUrlResponse -> ()
rnf CreateTestGridUrlResponse' {Int
Maybe (Sensitive Text)
Maybe POSIX
httpStatus :: Int
url :: Maybe (Sensitive Text)
expires :: Maybe POSIX
$sel:httpStatus:CreateTestGridUrlResponse' :: CreateTestGridUrlResponse -> Int
$sel:url:CreateTestGridUrlResponse' :: CreateTestGridUrlResponse -> Maybe (Sensitive Text)
$sel:expires:CreateTestGridUrlResponse' :: CreateTestGridUrlResponse -> Maybe POSIX
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe POSIX
expires
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe (Sensitive Text)
url
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus