{-# 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.MediaConnect.DescribeReservation
(
DescribeReservation (..),
newDescribeReservation,
describeReservation_reservationArn,
DescribeReservationResponse (..),
newDescribeReservationResponse,
describeReservationResponse_reservation,
describeReservationResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.MediaConnect.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DescribeReservation = DescribeReservation'
{
DescribeReservation -> Text
reservationArn :: Prelude.Text
}
deriving (DescribeReservation -> DescribeReservation -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservation -> DescribeReservation -> Bool
$c/= :: DescribeReservation -> DescribeReservation -> Bool
== :: DescribeReservation -> DescribeReservation -> Bool
$c== :: DescribeReservation -> DescribeReservation -> Bool
Prelude.Eq, ReadPrec [DescribeReservation]
ReadPrec DescribeReservation
Int -> ReadS DescribeReservation
ReadS [DescribeReservation]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservation]
$creadListPrec :: ReadPrec [DescribeReservation]
readPrec :: ReadPrec DescribeReservation
$creadPrec :: ReadPrec DescribeReservation
readList :: ReadS [DescribeReservation]
$creadList :: ReadS [DescribeReservation]
readsPrec :: Int -> ReadS DescribeReservation
$creadsPrec :: Int -> ReadS DescribeReservation
Prelude.Read, Int -> DescribeReservation -> ShowS
[DescribeReservation] -> ShowS
DescribeReservation -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservation] -> ShowS
$cshowList :: [DescribeReservation] -> ShowS
show :: DescribeReservation -> String
$cshow :: DescribeReservation -> String
showsPrec :: Int -> DescribeReservation -> ShowS
$cshowsPrec :: Int -> DescribeReservation -> ShowS
Prelude.Show, forall x. Rep DescribeReservation x -> DescribeReservation
forall x. DescribeReservation -> Rep DescribeReservation x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeReservation x -> DescribeReservation
$cfrom :: forall x. DescribeReservation -> Rep DescribeReservation x
Prelude.Generic)
newDescribeReservation ::
Prelude.Text ->
DescribeReservation
newDescribeReservation :: Text -> DescribeReservation
newDescribeReservation Text
pReservationArn_ =
DescribeReservation'
{ $sel:reservationArn:DescribeReservation' :: Text
reservationArn =
Text
pReservationArn_
}
describeReservation_reservationArn :: Lens.Lens' DescribeReservation Prelude.Text
describeReservation_reservationArn :: Lens' DescribeReservation Text
describeReservation_reservationArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservation' {Text
reservationArn :: Text
$sel:reservationArn:DescribeReservation' :: DescribeReservation -> Text
reservationArn} -> Text
reservationArn) (\s :: DescribeReservation
s@DescribeReservation' {} Text
a -> DescribeReservation
s {$sel:reservationArn:DescribeReservation' :: Text
reservationArn = Text
a} :: DescribeReservation)
instance Core.AWSRequest DescribeReservation where
type
AWSResponse DescribeReservation =
DescribeReservationResponse
request :: (Service -> Service)
-> DescribeReservation -> Request DescribeReservation
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 DescribeReservation
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse DescribeReservation)))
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 Reservation -> Int -> DescribeReservationResponse
DescribeReservationResponse'
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
"reservation")
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 DescribeReservation where
hashWithSalt :: Int -> DescribeReservation -> Int
hashWithSalt Int
_salt DescribeReservation' {Text
reservationArn :: Text
$sel:reservationArn:DescribeReservation' :: DescribeReservation -> Text
..} =
Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
reservationArn
instance Prelude.NFData DescribeReservation where
rnf :: DescribeReservation -> ()
rnf DescribeReservation' {Text
reservationArn :: Text
$sel:reservationArn:DescribeReservation' :: DescribeReservation -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
reservationArn
instance Data.ToHeaders DescribeReservation where
toHeaders :: DescribeReservation -> 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 DescribeReservation where
toPath :: DescribeReservation -> ByteString
toPath DescribeReservation' {Text
reservationArn :: Text
$sel:reservationArn:DescribeReservation' :: DescribeReservation -> Text
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ByteString
"/v1/reservations/", forall a. ToByteString a => a -> ByteString
Data.toBS Text
reservationArn]
instance Data.ToQuery DescribeReservation where
toQuery :: DescribeReservation -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DescribeReservationResponse = DescribeReservationResponse'
{ DescribeReservationResponse -> Maybe Reservation
reservation :: Prelude.Maybe Reservation,
DescribeReservationResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DescribeReservationResponse -> DescribeReservationResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeReservationResponse -> DescribeReservationResponse -> Bool
$c/= :: DescribeReservationResponse -> DescribeReservationResponse -> Bool
== :: DescribeReservationResponse -> DescribeReservationResponse -> Bool
$c== :: DescribeReservationResponse -> DescribeReservationResponse -> Bool
Prelude.Eq, ReadPrec [DescribeReservationResponse]
ReadPrec DescribeReservationResponse
Int -> ReadS DescribeReservationResponse
ReadS [DescribeReservationResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeReservationResponse]
$creadListPrec :: ReadPrec [DescribeReservationResponse]
readPrec :: ReadPrec DescribeReservationResponse
$creadPrec :: ReadPrec DescribeReservationResponse
readList :: ReadS [DescribeReservationResponse]
$creadList :: ReadS [DescribeReservationResponse]
readsPrec :: Int -> ReadS DescribeReservationResponse
$creadsPrec :: Int -> ReadS DescribeReservationResponse
Prelude.Read, Int -> DescribeReservationResponse -> ShowS
[DescribeReservationResponse] -> ShowS
DescribeReservationResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeReservationResponse] -> ShowS
$cshowList :: [DescribeReservationResponse] -> ShowS
show :: DescribeReservationResponse -> String
$cshow :: DescribeReservationResponse -> String
showsPrec :: Int -> DescribeReservationResponse -> ShowS
$cshowsPrec :: Int -> DescribeReservationResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeReservationResponse x -> DescribeReservationResponse
forall x.
DescribeReservationResponse -> Rep DescribeReservationResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeReservationResponse x -> DescribeReservationResponse
$cfrom :: forall x.
DescribeReservationResponse -> Rep DescribeReservationResponse x
Prelude.Generic)
newDescribeReservationResponse ::
Prelude.Int ->
DescribeReservationResponse
newDescribeReservationResponse :: Int -> DescribeReservationResponse
newDescribeReservationResponse Int
pHttpStatus_ =
DescribeReservationResponse'
{ $sel:reservation:DescribeReservationResponse' :: Maybe Reservation
reservation =
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DescribeReservationResponse' :: Int
httpStatus = Int
pHttpStatus_
}
describeReservationResponse_reservation :: Lens.Lens' DescribeReservationResponse (Prelude.Maybe Reservation)
describeReservationResponse_reservation :: Lens' DescribeReservationResponse (Maybe Reservation)
describeReservationResponse_reservation = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservationResponse' {Maybe Reservation
reservation :: Maybe Reservation
$sel:reservation:DescribeReservationResponse' :: DescribeReservationResponse -> Maybe Reservation
reservation} -> Maybe Reservation
reservation) (\s :: DescribeReservationResponse
s@DescribeReservationResponse' {} Maybe Reservation
a -> DescribeReservationResponse
s {$sel:reservation:DescribeReservationResponse' :: Maybe Reservation
reservation = Maybe Reservation
a} :: DescribeReservationResponse)
describeReservationResponse_httpStatus :: Lens.Lens' DescribeReservationResponse Prelude.Int
describeReservationResponse_httpStatus :: Lens' DescribeReservationResponse Int
describeReservationResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeReservationResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeReservationResponse' :: DescribeReservationResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeReservationResponse
s@DescribeReservationResponse' {} Int
a -> DescribeReservationResponse
s {$sel:httpStatus:DescribeReservationResponse' :: Int
httpStatus = Int
a} :: DescribeReservationResponse)
instance Prelude.NFData DescribeReservationResponse where
rnf :: DescribeReservationResponse -> ()
rnf DescribeReservationResponse' {Int
Maybe Reservation
httpStatus :: Int
reservation :: Maybe Reservation
$sel:httpStatus:DescribeReservationResponse' :: DescribeReservationResponse -> Int
$sel:reservation:DescribeReservationResponse' :: DescribeReservationResponse -> Maybe Reservation
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Reservation
reservation
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus