{-# 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.EMRContainers.DescribeJobRun
(
DescribeJobRun (..),
newDescribeJobRun,
describeJobRun_id,
describeJobRun_virtualClusterId,
DescribeJobRunResponse (..),
newDescribeJobRunResponse,
describeJobRunResponse_jobRun,
describeJobRunResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EMRContainers.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DescribeJobRun = DescribeJobRun'
{
DescribeJobRun -> Text
id :: Prelude.Text,
DescribeJobRun -> Text
virtualClusterId :: Prelude.Text
}
deriving (DescribeJobRun -> DescribeJobRun -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeJobRun -> DescribeJobRun -> Bool
$c/= :: DescribeJobRun -> DescribeJobRun -> Bool
== :: DescribeJobRun -> DescribeJobRun -> Bool
$c== :: DescribeJobRun -> DescribeJobRun -> Bool
Prelude.Eq, ReadPrec [DescribeJobRun]
ReadPrec DescribeJobRun
Int -> ReadS DescribeJobRun
ReadS [DescribeJobRun]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeJobRun]
$creadListPrec :: ReadPrec [DescribeJobRun]
readPrec :: ReadPrec DescribeJobRun
$creadPrec :: ReadPrec DescribeJobRun
readList :: ReadS [DescribeJobRun]
$creadList :: ReadS [DescribeJobRun]
readsPrec :: Int -> ReadS DescribeJobRun
$creadsPrec :: Int -> ReadS DescribeJobRun
Prelude.Read, Int -> DescribeJobRun -> ShowS
[DescribeJobRun] -> ShowS
DescribeJobRun -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeJobRun] -> ShowS
$cshowList :: [DescribeJobRun] -> ShowS
show :: DescribeJobRun -> String
$cshow :: DescribeJobRun -> String
showsPrec :: Int -> DescribeJobRun -> ShowS
$cshowsPrec :: Int -> DescribeJobRun -> ShowS
Prelude.Show, forall x. Rep DescribeJobRun x -> DescribeJobRun
forall x. DescribeJobRun -> Rep DescribeJobRun x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeJobRun x -> DescribeJobRun
$cfrom :: forall x. DescribeJobRun -> Rep DescribeJobRun x
Prelude.Generic)
newDescribeJobRun ::
Prelude.Text ->
Prelude.Text ->
DescribeJobRun
newDescribeJobRun :: Text -> Text -> DescribeJobRun
newDescribeJobRun Text
pId_ Text
pVirtualClusterId_ =
DescribeJobRun'
{ $sel:id:DescribeJobRun' :: Text
id = Text
pId_,
$sel:virtualClusterId:DescribeJobRun' :: Text
virtualClusterId = Text
pVirtualClusterId_
}
describeJobRun_id :: Lens.Lens' DescribeJobRun Prelude.Text
describeJobRun_id :: Lens' DescribeJobRun Text
describeJobRun_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeJobRun' {Text
id :: Text
$sel:id:DescribeJobRun' :: DescribeJobRun -> Text
id} -> Text
id) (\s :: DescribeJobRun
s@DescribeJobRun' {} Text
a -> DescribeJobRun
s {$sel:id:DescribeJobRun' :: Text
id = Text
a} :: DescribeJobRun)
describeJobRun_virtualClusterId :: Lens.Lens' DescribeJobRun Prelude.Text
describeJobRun_virtualClusterId :: Lens' DescribeJobRun Text
describeJobRun_virtualClusterId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeJobRun' {Text
virtualClusterId :: Text
$sel:virtualClusterId:DescribeJobRun' :: DescribeJobRun -> Text
virtualClusterId} -> Text
virtualClusterId) (\s :: DescribeJobRun
s@DescribeJobRun' {} Text
a -> DescribeJobRun
s {$sel:virtualClusterId:DescribeJobRun' :: Text
virtualClusterId = Text
a} :: DescribeJobRun)
instance Core.AWSRequest DescribeJobRun where
type
AWSResponse DescribeJobRun =
DescribeJobRunResponse
request :: (Service -> Service) -> DescribeJobRun -> Request DescribeJobRun
request Service -> Service
overrides =
forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy DescribeJobRun
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeJobRun)))
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 JobRun -> Int -> DescribeJobRunResponse
DescribeJobRunResponse'
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
"jobRun")
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 DescribeJobRun where
hashWithSalt :: Int -> DescribeJobRun -> Int
hashWithSalt Int
_salt DescribeJobRun' {Text
virtualClusterId :: Text
id :: Text
$sel:virtualClusterId:DescribeJobRun' :: DescribeJobRun -> Text
$sel:id:DescribeJobRun' :: DescribeJobRun -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
id
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
virtualClusterId
instance Prelude.NFData DescribeJobRun where
rnf :: DescribeJobRun -> ()
rnf DescribeJobRun' {Text
virtualClusterId :: Text
id :: Text
$sel:virtualClusterId:DescribeJobRun' :: DescribeJobRun -> Text
$sel:id:DescribeJobRun' :: DescribeJobRun -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
id
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
virtualClusterId
instance Data.ToHeaders DescribeJobRun where
toHeaders :: DescribeJobRun -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToPath DescribeJobRun where
toPath :: DescribeJobRun -> ByteString
toPath DescribeJobRun' {Text
virtualClusterId :: Text
id :: Text
$sel:virtualClusterId:DescribeJobRun' :: DescribeJobRun -> Text
$sel:id:DescribeJobRun' :: DescribeJobRun -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/virtualclusters/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
virtualClusterId,
ByteString
"/jobruns/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
id
]
instance Data.ToQuery DescribeJobRun where
toQuery :: DescribeJobRun -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DescribeJobRunResponse = DescribeJobRunResponse'
{
DescribeJobRunResponse -> Maybe JobRun
jobRun :: Prelude.Maybe JobRun,
DescribeJobRunResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DescribeJobRunResponse -> DescribeJobRunResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeJobRunResponse -> DescribeJobRunResponse -> Bool
$c/= :: DescribeJobRunResponse -> DescribeJobRunResponse -> Bool
== :: DescribeJobRunResponse -> DescribeJobRunResponse -> Bool
$c== :: DescribeJobRunResponse -> DescribeJobRunResponse -> Bool
Prelude.Eq, Int -> DescribeJobRunResponse -> ShowS
[DescribeJobRunResponse] -> ShowS
DescribeJobRunResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeJobRunResponse] -> ShowS
$cshowList :: [DescribeJobRunResponse] -> ShowS
show :: DescribeJobRunResponse -> String
$cshow :: DescribeJobRunResponse -> String
showsPrec :: Int -> DescribeJobRunResponse -> ShowS
$cshowsPrec :: Int -> DescribeJobRunResponse -> ShowS
Prelude.Show, forall x. Rep DescribeJobRunResponse x -> DescribeJobRunResponse
forall x. DescribeJobRunResponse -> Rep DescribeJobRunResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeJobRunResponse x -> DescribeJobRunResponse
$cfrom :: forall x. DescribeJobRunResponse -> Rep DescribeJobRunResponse x
Prelude.Generic)
newDescribeJobRunResponse ::
Prelude.Int ->
DescribeJobRunResponse
newDescribeJobRunResponse :: Int -> DescribeJobRunResponse
newDescribeJobRunResponse Int
pHttpStatus_ =
DescribeJobRunResponse'
{ $sel:jobRun:DescribeJobRunResponse' :: Maybe JobRun
jobRun = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DescribeJobRunResponse' :: Int
httpStatus = Int
pHttpStatus_
}
describeJobRunResponse_jobRun :: Lens.Lens' DescribeJobRunResponse (Prelude.Maybe JobRun)
describeJobRunResponse_jobRun :: Lens' DescribeJobRunResponse (Maybe JobRun)
describeJobRunResponse_jobRun = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeJobRunResponse' {Maybe JobRun
jobRun :: Maybe JobRun
$sel:jobRun:DescribeJobRunResponse' :: DescribeJobRunResponse -> Maybe JobRun
jobRun} -> Maybe JobRun
jobRun) (\s :: DescribeJobRunResponse
s@DescribeJobRunResponse' {} Maybe JobRun
a -> DescribeJobRunResponse
s {$sel:jobRun:DescribeJobRunResponse' :: Maybe JobRun
jobRun = Maybe JobRun
a} :: DescribeJobRunResponse)
describeJobRunResponse_httpStatus :: Lens.Lens' DescribeJobRunResponse Prelude.Int
describeJobRunResponse_httpStatus :: Lens' DescribeJobRunResponse Int
describeJobRunResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeJobRunResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeJobRunResponse' :: DescribeJobRunResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeJobRunResponse
s@DescribeJobRunResponse' {} Int
a -> DescribeJobRunResponse
s {$sel:httpStatus:DescribeJobRunResponse' :: Int
httpStatus = Int
a} :: DescribeJobRunResponse)
instance Prelude.NFData DescribeJobRunResponse where
rnf :: DescribeJobRunResponse -> ()
rnf DescribeJobRunResponse' {Int
Maybe JobRun
httpStatus :: Int
jobRun :: Maybe JobRun
$sel:httpStatus:DescribeJobRunResponse' :: DescribeJobRunResponse -> Int
$sel:jobRun:DescribeJobRunResponse' :: DescribeJobRunResponse -> Maybe JobRun
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe JobRun
jobRun
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus