{-# 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 #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.OpsWorks.DescribeVolumes
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Describes an instance\'s Amazon EBS volumes.
--
-- This call accepts only one resource-identifying parameter.
--
-- __Required Permissions__: To use this action, an IAM user must have a
-- Show, Deploy, or Manage permissions level for the stack, or an attached
-- policy that explicitly grants permissions. For more information about
-- user permissions, see
-- <https://docs.aws.amazon.com/opsworks/latest/userguide/opsworks-security-users.html Managing User Permissions>.
module Amazonka.OpsWorks.DescribeVolumes
  ( -- * Creating a Request
    DescribeVolumes (..),
    newDescribeVolumes,

    -- * Request Lenses
    describeVolumes_instanceId,
    describeVolumes_raidArrayId,
    describeVolumes_stackId,
    describeVolumes_volumeIds,

    -- * Destructuring the Response
    DescribeVolumesResponse (..),
    newDescribeVolumesResponse,

    -- * Response Lenses
    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

-- | /See:/ 'newDescribeVolumes' smart constructor.
data DescribeVolumes = DescribeVolumes'
  { -- | The instance ID. If you use this parameter, @DescribeVolumes@ returns
    -- descriptions of the volumes associated with the specified instance.
    DescribeVolumes -> Maybe Text
instanceId :: Prelude.Maybe Prelude.Text,
    -- | The RAID array ID. If you use this parameter, @DescribeVolumes@ returns
    -- descriptions of the volumes associated with the specified RAID array.
    DescribeVolumes -> Maybe Text
raidArrayId :: Prelude.Maybe Prelude.Text,
    -- | A stack ID. The action describes the stack\'s registered Amazon EBS
    -- volumes.
    DescribeVolumes -> Maybe Text
stackId :: Prelude.Maybe Prelude.Text,
    -- | Am array of volume IDs. If you use this parameter, @DescribeVolumes@
    -- returns descriptions of the specified volumes. Otherwise, it returns a
    -- description of every volume.
    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)

-- |
-- Create a value of 'DescribeVolumes' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'instanceId', 'describeVolumes_instanceId' - The instance ID. If you use this parameter, @DescribeVolumes@ returns
-- descriptions of the volumes associated with the specified instance.
--
-- 'raidArrayId', 'describeVolumes_raidArrayId' - The RAID array ID. If you use this parameter, @DescribeVolumes@ returns
-- descriptions of the volumes associated with the specified RAID array.
--
-- 'stackId', 'describeVolumes_stackId' - A stack ID. The action describes the stack\'s registered Amazon EBS
-- volumes.
--
-- 'volumeIds', 'describeVolumes_volumeIds' - Am array of volume IDs. If you use this parameter, @DescribeVolumes@
-- returns descriptions of the specified volumes. Otherwise, it returns a
-- description of every volume.
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
    }

-- | The instance ID. If you use this parameter, @DescribeVolumes@ returns
-- descriptions of the volumes associated with the specified instance.
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)

-- | The RAID array ID. If you use this parameter, @DescribeVolumes@ returns
-- descriptions of the volumes associated with the specified RAID array.
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)

-- | A stack ID. The action describes the stack\'s registered Amazon EBS
-- volumes.
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)

-- | Am array of volume IDs. If you use this parameter, @DescribeVolumes@
-- returns descriptions of the specified volumes. Otherwise, it returns a
-- description of every volume.
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

-- | Contains the response to a @DescribeVolumes@ request.
--
-- /See:/ 'newDescribeVolumesResponse' smart constructor.
data DescribeVolumesResponse = DescribeVolumesResponse'
  { -- | An array of volume IDs.
    DescribeVolumesResponse -> Maybe [Volume]
volumes :: Prelude.Maybe [Volume],
    -- | The response's http status code.
    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)

-- |
-- Create a value of 'DescribeVolumesResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'volumes', 'describeVolumesResponse_volumes' - An array of volume IDs.
--
-- 'httpStatus', 'describeVolumesResponse_httpStatus' - The response's http status code.
newDescribeVolumesResponse ::
  -- | 'httpStatus'
  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_
    }

-- | An array of volume IDs.
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

-- | The response's http status code.
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