{-# 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.FSx.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 one or more Amazon FSx for NetApp ONTAP or Amazon FSx for
-- OpenZFS volumes.
--
-- This operation returns paginated results.
module Amazonka.FSx.DescribeVolumes
  ( -- * Creating a Request
    DescribeVolumes (..),
    newDescribeVolumes,

    -- * Request Lenses
    describeVolumes_filters,
    describeVolumes_maxResults,
    describeVolumes_nextToken,
    describeVolumes_volumeIds,

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

    -- * Response Lenses
    describeVolumesResponse_nextToken,
    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.FSx.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'
  { -- | Enter a filter @Name@ and @Values@ pair to view a select set of volumes.
    DescribeVolumes -> Maybe [VolumeFilter]
filters :: Prelude.Maybe [VolumeFilter],
    DescribeVolumes -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    DescribeVolumes -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The IDs of the volumes whose descriptions you want to retrieve.
    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:
--
-- 'filters', 'describeVolumes_filters' - Enter a filter @Name@ and @Values@ pair to view a select set of volumes.
--
-- 'maxResults', 'describeVolumes_maxResults' - Undocumented member.
--
-- 'nextToken', 'describeVolumes_nextToken' - Undocumented member.
--
-- 'volumeIds', 'describeVolumes_volumeIds' - The IDs of the volumes whose descriptions you want to retrieve.
newDescribeVolumes ::
  DescribeVolumes
newDescribeVolumes :: DescribeVolumes
newDescribeVolumes =
  DescribeVolumes'
    { $sel:filters:DescribeVolumes' :: Maybe [VolumeFilter]
filters = forall a. Maybe a
Prelude.Nothing,
      $sel:maxResults:DescribeVolumes' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:DescribeVolumes' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:volumeIds:DescribeVolumes' :: Maybe [Text]
volumeIds = forall a. Maybe a
Prelude.Nothing
    }

-- | Enter a filter @Name@ and @Values@ pair to view a select set of volumes.
describeVolumes_filters :: Lens.Lens' DescribeVolumes (Prelude.Maybe [VolumeFilter])
describeVolumes_filters :: Lens' DescribeVolumes (Maybe [VolumeFilter])
describeVolumes_filters = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumes' {Maybe [VolumeFilter]
filters :: Maybe [VolumeFilter]
$sel:filters:DescribeVolumes' :: DescribeVolumes -> Maybe [VolumeFilter]
filters} -> Maybe [VolumeFilter]
filters) (\s :: DescribeVolumes
s@DescribeVolumes' {} Maybe [VolumeFilter]
a -> DescribeVolumes
s {$sel:filters:DescribeVolumes' :: Maybe [VolumeFilter]
filters = Maybe [VolumeFilter]
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

-- | Undocumented member.
describeVolumes_maxResults :: Lens.Lens' DescribeVolumes (Prelude.Maybe Prelude.Natural)
describeVolumes_maxResults :: Lens' DescribeVolumes (Maybe Natural)
describeVolumes_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumes' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:DescribeVolumes' :: DescribeVolumes -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: DescribeVolumes
s@DescribeVolumes' {} Maybe Natural
a -> DescribeVolumes
s {$sel:maxResults:DescribeVolumes' :: Maybe Natural
maxResults = Maybe Natural
a} :: DescribeVolumes)

-- | Undocumented member.
describeVolumes_nextToken :: Lens.Lens' DescribeVolumes (Prelude.Maybe Prelude.Text)
describeVolumes_nextToken :: Lens' DescribeVolumes (Maybe Text)
describeVolumes_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumes' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeVolumes' :: DescribeVolumes -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeVolumes
s@DescribeVolumes' {} Maybe Text
a -> DescribeVolumes
s {$sel:nextToken:DescribeVolumes' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeVolumes)

-- | The IDs of the volumes whose descriptions you want to retrieve.
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.AWSPager DescribeVolumes where
  page :: DescribeVolumes
-> AWSResponse DescribeVolumes -> Maybe DescribeVolumes
page DescribeVolumes
rq AWSResponse DescribeVolumes
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeVolumes
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeVolumesResponse (Maybe Text)
describeVolumesResponse_nextToken
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeVolumes
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeVolumesResponse (Maybe [Volume])
describeVolumesResponse_volumes
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ DescribeVolumes
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' DescribeVolumes (Maybe Text)
describeVolumes_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse DescribeVolumes
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeVolumesResponse (Maybe Text)
describeVolumesResponse_nextToken
          forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just

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 Text -> 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
"NextToken")
            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
"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 Natural
Maybe [Text]
Maybe [VolumeFilter]
Maybe Text
volumeIds :: Maybe [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [VolumeFilter]
$sel:volumeIds:DescribeVolumes' :: DescribeVolumes -> Maybe [Text]
$sel:nextToken:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:maxResults:DescribeVolumes' :: DescribeVolumes -> Maybe Natural
$sel:filters:DescribeVolumes' :: DescribeVolumes -> Maybe [VolumeFilter]
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [VolumeFilter]
filters
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
maxResults
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
volumeIds

instance Prelude.NFData DescribeVolumes where
  rnf :: DescribeVolumes -> ()
rnf DescribeVolumes' {Maybe Natural
Maybe [Text]
Maybe [VolumeFilter]
Maybe Text
volumeIds :: Maybe [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [VolumeFilter]
$sel:volumeIds:DescribeVolumes' :: DescribeVolumes -> Maybe [Text]
$sel:nextToken:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:maxResults:DescribeVolumes' :: DescribeVolumes -> Maybe Natural
$sel:filters:DescribeVolumes' :: DescribeVolumes -> Maybe [VolumeFilter]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [VolumeFilter]
filters
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
maxResults
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      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
"AWSSimbaAPIService_v20180301.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 Natural
Maybe [Text]
Maybe [VolumeFilter]
Maybe Text
volumeIds :: Maybe [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
filters :: Maybe [VolumeFilter]
$sel:volumeIds:DescribeVolumes' :: DescribeVolumes -> Maybe [Text]
$sel:nextToken:DescribeVolumes' :: DescribeVolumes -> Maybe Text
$sel:maxResults:DescribeVolumes' :: DescribeVolumes -> Maybe Natural
$sel:filters:DescribeVolumes' :: DescribeVolumes -> Maybe [VolumeFilter]
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"Filters" 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 [VolumeFilter]
filters,
            (Key
"MaxResults" 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 Natural
maxResults,
            (Key
"NextToken" 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
nextToken,
            (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

-- | /See:/ 'newDescribeVolumesResponse' smart constructor.
data DescribeVolumesResponse = DescribeVolumesResponse'
  { DescribeVolumesResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | Returned after a successful @DescribeVolumes@ operation, describing each
    -- volume.
    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:
--
-- 'nextToken', 'describeVolumesResponse_nextToken' - Undocumented member.
--
-- 'volumes', 'describeVolumesResponse_volumes' - Returned after a successful @DescribeVolumes@ operation, describing each
-- volume.
--
-- 'httpStatus', 'describeVolumesResponse_httpStatus' - The response's http status code.
newDescribeVolumesResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeVolumesResponse
newDescribeVolumesResponse :: Int -> DescribeVolumesResponse
newDescribeVolumesResponse Int
pHttpStatus_ =
  DescribeVolumesResponse'
    { $sel:nextToken:DescribeVolumesResponse' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:volumes:DescribeVolumesResponse' :: Maybe [Volume]
volumes = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:DescribeVolumesResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | Undocumented member.
describeVolumesResponse_nextToken :: Lens.Lens' DescribeVolumesResponse (Prelude.Maybe Prelude.Text)
describeVolumesResponse_nextToken :: Lens' DescribeVolumesResponse (Maybe Text)
describeVolumesResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeVolumesResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeVolumesResponse' :: DescribeVolumesResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeVolumesResponse
s@DescribeVolumesResponse' {} Maybe Text
a -> DescribeVolumesResponse
s {$sel:nextToken:DescribeVolumesResponse' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeVolumesResponse)

-- | Returned after a successful @DescribeVolumes@ operation, describing each
-- volume.
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]
Maybe Text
httpStatus :: Int
volumes :: Maybe [Volume]
nextToken :: Maybe Text
$sel:httpStatus:DescribeVolumesResponse' :: DescribeVolumesResponse -> Int
$sel:volumes:DescribeVolumesResponse' :: DescribeVolumesResponse -> Maybe [Volume]
$sel:nextToken:DescribeVolumesResponse' :: DescribeVolumesResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` 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