{-# 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.OpsWorks.DescribeVolumes
(
DescribeVolumes (..),
newDescribeVolumes,
describeVolumes_instanceId,
describeVolumes_raidArrayId,
describeVolumes_stackId,
describeVolumes_volumeIds,
DescribeVolumesResponse (..),
newDescribeVolumesResponse,
describeVolumesResponse_volumes,
describeVolumesResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.OpsWorks.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data DescribeVolumes = DescribeVolumes'
{
DescribeVolumes -> Maybe Text
instanceId :: Prelude.Maybe Prelude.Text,
DescribeVolumes -> Maybe Text
raidArrayId :: Prelude.Maybe Prelude.Text,
DescribeVolumes -> Maybe Text
stackId :: Prelude.Maybe Prelude.Text,
DescribeVolumes -> Maybe [Text]
volumeIds :: Prelude.Maybe [Prelude.Text]
}
deriving (DescribeVolumes -> DescribeVolumes -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeVolumes -> DescribeVolumes -> Bool
$c/= :: DescribeVolumes -> DescribeVolumes -> Bool
== :: DescribeVolumes -> DescribeVolumes -> Bool
$c== :: DescribeVolumes -> DescribeVolumes -> Bool
Prelude.Eq, ReadPrec [DescribeVolumes]
ReadPrec DescribeVolumes
Int -> ReadS DescribeVolumes
ReadS [DescribeVolumes]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeVolumes]
$creadListPrec :: ReadPrec [DescribeVolumes]
readPrec :: ReadPrec DescribeVolumes
$creadPrec :: ReadPrec DescribeVolumes
readList :: ReadS [DescribeVolumes]
$creadList :: ReadS [DescribeVolumes]
readsPrec :: Int -> ReadS DescribeVolumes
$creadsPrec :: Int -> ReadS DescribeVolumes
Prelude.Read, Int -> DescribeVolumes -> ShowS
[DescribeVolumes] -> ShowS
DescribeVolumes -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeVolumes] -> ShowS
$cshowList :: [DescribeVolumes] -> ShowS
show :: DescribeVolumes -> String
$cshow :: DescribeVolumes -> String
showsPrec :: Int -> DescribeVolumes -> ShowS
$cshowsPrec :: Int -> DescribeVolumes -> ShowS
Prelude.Show, forall x. Rep DescribeVolumes x -> DescribeVolumes
forall x. DescribeVolumes -> Rep DescribeVolumes x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeVolumes x -> DescribeVolumes
$cfrom :: forall x. DescribeVolumes -> Rep DescribeVolumes x
Prelude.Generic)
newDescribeVolumes ::
DescribeVolumes
newDescribeVolumes :: DescribeVolumes
newDescribeVolumes =
DescribeVolumes'
{ $sel:instanceId:DescribeVolumes' :: Maybe Text
instanceId = forall a. Maybe a
Prelude.Nothing,
$sel:raidArrayId:DescribeVolumes' :: Maybe Text
raidArrayId = forall a. Maybe a
Prelude.Nothing,
$sel:stackId:DescribeVolumes' :: Maybe Text
stackId = forall a. Maybe a
Prelude.Nothing,
$sel:volumeIds:DescribeVolumes' :: Maybe [Text]
volumeIds = forall a. Maybe a
Prelude.Nothing
}
describeVolumes_instanceId :: Lens.Lens' DescribeVolumes (Prelude.Maybe Prelude.Text)
describeVolumes_instanceId :: Lens' DescribeVolumes (Maybe Text)
describeVolumes_instanceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumes' {Maybe Text
instanceId :: Maybe Text
$sel:instanceId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
instanceId} -> Maybe Text
instanceId) (\s :: DescribeVolumes
s@DescribeVolumes' {} Maybe Text
a -> DescribeVolumes
s {$sel:instanceId:DescribeVolumes' :: Maybe Text
instanceId = Maybe Text
a} :: DescribeVolumes)
describeVolumes_raidArrayId :: Lens.Lens' DescribeVolumes (Prelude.Maybe Prelude.Text)
describeVolumes_raidArrayId :: Lens' DescribeVolumes (Maybe Text)
describeVolumes_raidArrayId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumes' {Maybe Text
raidArrayId :: Maybe Text
$sel:raidArrayId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
raidArrayId} -> Maybe Text
raidArrayId) (\s :: DescribeVolumes
s@DescribeVolumes' {} Maybe Text
a -> DescribeVolumes
s {$sel:raidArrayId:DescribeVolumes' :: Maybe Text
raidArrayId = Maybe Text
a} :: DescribeVolumes)
describeVolumes_stackId :: Lens.Lens' DescribeVolumes (Prelude.Maybe Prelude.Text)
describeVolumes_stackId :: Lens' DescribeVolumes (Maybe Text)
describeVolumes_stackId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumes' {Maybe Text
stackId :: Maybe Text
$sel:stackId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
stackId} -> Maybe Text
stackId) (\s :: DescribeVolumes
s@DescribeVolumes' {} Maybe Text
a -> DescribeVolumes
s {$sel:stackId:DescribeVolumes' :: Maybe Text
stackId = Maybe Text
a} :: DescribeVolumes)
describeVolumes_volumeIds :: Lens.Lens' DescribeVolumes (Prelude.Maybe [Prelude.Text])
describeVolumes_volumeIds :: Lens' DescribeVolumes (Maybe [Text])
describeVolumes_volumeIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumes' {Maybe [Text]
volumeIds :: Maybe [Text]
$sel:volumeIds:DescribeVolumes' :: DescribeVolumes -> Maybe [Text]
volumeIds} -> Maybe [Text]
volumeIds) (\s :: DescribeVolumes
s@DescribeVolumes' {} Maybe [Text]
a -> DescribeVolumes
s {$sel:volumeIds:DescribeVolumes' :: Maybe [Text]
volumeIds = Maybe [Text]
a} :: DescribeVolumes) 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 s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
instance Core.AWSRequest DescribeVolumes where
type
AWSResponse DescribeVolumes =
DescribeVolumesResponse
request :: (Service -> Service) -> DescribeVolumes -> Request DescribeVolumes
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 DescribeVolumes
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse DescribeVolumes)))
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 [Volume] -> Int -> DescribeVolumesResponse
DescribeVolumesResponse'
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
"Volumes" forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty)
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 DescribeVolumes where
hashWithSalt :: Int -> DescribeVolumes -> Int
hashWithSalt Int
_salt DescribeVolumes' {Maybe [Text]
Maybe Text
volumeIds :: Maybe [Text]
stackId :: Maybe Text
raidArrayId :: Maybe Text
instanceId :: Maybe Text
$sel:volumeIds:DescribeVolumes' :: DescribeVolumes -> Maybe [Text]
$sel:stackId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:raidArrayId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:instanceId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
instanceId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
raidArrayId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
stackId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
volumeIds
instance Prelude.NFData DescribeVolumes where
rnf :: DescribeVolumes -> ()
rnf DescribeVolumes' {Maybe [Text]
Maybe Text
volumeIds :: Maybe [Text]
stackId :: Maybe Text
raidArrayId :: Maybe Text
instanceId :: Maybe Text
$sel:volumeIds:DescribeVolumes' :: DescribeVolumes -> Maybe [Text]
$sel:stackId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:raidArrayId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:instanceId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
instanceId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
raidArrayId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
stackId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
volumeIds
instance Data.ToHeaders DescribeVolumes where
toHeaders :: DescribeVolumes -> 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
"OpsWorks_20130218.DescribeVolumes" ::
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 DescribeVolumes where
toJSON :: DescribeVolumes -> Value
toJSON DescribeVolumes' {Maybe [Text]
Maybe Text
volumeIds :: Maybe [Text]
stackId :: Maybe Text
raidArrayId :: Maybe Text
instanceId :: Maybe Text
$sel:volumeIds:DescribeVolumes' :: DescribeVolumes -> Maybe [Text]
$sel:stackId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:raidArrayId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:instanceId:DescribeVolumes' :: DescribeVolumes -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"InstanceId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
instanceId,
(Key
"RaidArrayId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
raidArrayId,
(Key
"StackId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
stackId,
(Key
"VolumeIds" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
volumeIds
]
)
instance Data.ToPath DescribeVolumes where
toPath :: DescribeVolumes -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery DescribeVolumes where
toQuery :: DescribeVolumes -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data DescribeVolumesResponse = DescribeVolumesResponse'
{
DescribeVolumesResponse -> Maybe [Volume]
volumes :: Prelude.Maybe [Volume],
DescribeVolumesResponse -> Int
httpStatus :: Prelude.Int
}
deriving (DescribeVolumesResponse -> DescribeVolumesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeVolumesResponse -> DescribeVolumesResponse -> Bool
$c/= :: DescribeVolumesResponse -> DescribeVolumesResponse -> Bool
== :: DescribeVolumesResponse -> DescribeVolumesResponse -> Bool
$c== :: DescribeVolumesResponse -> DescribeVolumesResponse -> Bool
Prelude.Eq, ReadPrec [DescribeVolumesResponse]
ReadPrec DescribeVolumesResponse
Int -> ReadS DescribeVolumesResponse
ReadS [DescribeVolumesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeVolumesResponse]
$creadListPrec :: ReadPrec [DescribeVolumesResponse]
readPrec :: ReadPrec DescribeVolumesResponse
$creadPrec :: ReadPrec DescribeVolumesResponse
readList :: ReadS [DescribeVolumesResponse]
$creadList :: ReadS [DescribeVolumesResponse]
readsPrec :: Int -> ReadS DescribeVolumesResponse
$creadsPrec :: Int -> ReadS DescribeVolumesResponse
Prelude.Read, Int -> DescribeVolumesResponse -> ShowS
[DescribeVolumesResponse] -> ShowS
DescribeVolumesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeVolumesResponse] -> ShowS
$cshowList :: [DescribeVolumesResponse] -> ShowS
show :: DescribeVolumesResponse -> String
$cshow :: DescribeVolumesResponse -> String
showsPrec :: Int -> DescribeVolumesResponse -> ShowS
$cshowsPrec :: Int -> DescribeVolumesResponse -> ShowS
Prelude.Show, forall x. Rep DescribeVolumesResponse x -> DescribeVolumesResponse
forall x. DescribeVolumesResponse -> Rep DescribeVolumesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep DescribeVolumesResponse x -> DescribeVolumesResponse
$cfrom :: forall x. DescribeVolumesResponse -> Rep DescribeVolumesResponse x
Prelude.Generic)
newDescribeVolumesResponse ::
Prelude.Int ->
DescribeVolumesResponse
newDescribeVolumesResponse :: Int -> DescribeVolumesResponse
newDescribeVolumesResponse Int
pHttpStatus_ =
DescribeVolumesResponse'
{ $sel:volumes:DescribeVolumesResponse' :: Maybe [Volume]
volumes = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:DescribeVolumesResponse' :: Int
httpStatus = Int
pHttpStatus_
}
describeVolumesResponse_volumes :: Lens.Lens' DescribeVolumesResponse (Prelude.Maybe [Volume])
describeVolumesResponse_volumes :: Lens' DescribeVolumesResponse (Maybe [Volume])
describeVolumesResponse_volumes = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumesResponse' {Maybe [Volume]
volumes :: Maybe [Volume]
$sel:volumes:DescribeVolumesResponse' :: DescribeVolumesResponse -> Maybe [Volume]
volumes} -> Maybe [Volume]
volumes) (\s :: DescribeVolumesResponse
s@DescribeVolumesResponse' {} Maybe [Volume]
a -> DescribeVolumesResponse
s {$sel:volumes:DescribeVolumesResponse' :: Maybe [Volume]
volumes = Maybe [Volume]
a} :: DescribeVolumesResponse) 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 s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
describeVolumesResponse_httpStatus :: Lens.Lens' DescribeVolumesResponse Prelude.Int
describeVolumesResponse_httpStatus :: Lens' DescribeVolumesResponse Int
describeVolumesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumesResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeVolumesResponse' :: DescribeVolumesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeVolumesResponse
s@DescribeVolumesResponse' {} Int
a -> DescribeVolumesResponse
s {$sel:httpStatus:DescribeVolumesResponse' :: Int
httpStatus = Int
a} :: DescribeVolumesResponse)
instance Prelude.NFData DescribeVolumesResponse where
rnf :: DescribeVolumesResponse -> ()
rnf DescribeVolumesResponse' {Int
Maybe [Volume]
httpStatus :: Int
volumes :: Maybe [Volume]
$sel:httpStatus:DescribeVolumesResponse' :: DescribeVolumesResponse -> Int
$sel:volumes:DescribeVolumesResponse' :: DescribeVolumesResponse -> Maybe [Volume]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [Volume]
volumes
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus