{-# 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.WorkSpaces.DescribeWorkspacesConnectionStatus
-- 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 the connection status of the specified WorkSpaces.
--
-- This operation returns paginated results.
module Amazonka.WorkSpaces.DescribeWorkspacesConnectionStatus
  ( -- * Creating a Request
    DescribeWorkspacesConnectionStatus (..),
    newDescribeWorkspacesConnectionStatus,

    -- * Request Lenses
    describeWorkspacesConnectionStatus_nextToken,
    describeWorkspacesConnectionStatus_workspaceIds,

    -- * Destructuring the Response
    DescribeWorkspacesConnectionStatusResponse (..),
    newDescribeWorkspacesConnectionStatusResponse,

    -- * Response Lenses
    describeWorkspacesConnectionStatusResponse_nextToken,
    describeWorkspacesConnectionStatusResponse_workspacesConnectionStatus,
    describeWorkspacesConnectionStatusResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
import Amazonka.WorkSpaces.Types

-- | /See:/ 'newDescribeWorkspacesConnectionStatus' smart constructor.
data DescribeWorkspacesConnectionStatus = DescribeWorkspacesConnectionStatus'
  { -- | If you received a @NextToken@ from a previous call that was paginated,
    -- provide this token to receive the next set of results.
    DescribeWorkspacesConnectionStatus -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The identifiers of the WorkSpaces. You can specify up to 25 WorkSpaces.
    DescribeWorkspacesConnectionStatus -> Maybe (NonEmpty Text)
workspaceIds :: Prelude.Maybe (Prelude.NonEmpty Prelude.Text)
  }
  deriving (DescribeWorkspacesConnectionStatus
-> DescribeWorkspacesConnectionStatus -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeWorkspacesConnectionStatus
-> DescribeWorkspacesConnectionStatus -> Bool
$c/= :: DescribeWorkspacesConnectionStatus
-> DescribeWorkspacesConnectionStatus -> Bool
== :: DescribeWorkspacesConnectionStatus
-> DescribeWorkspacesConnectionStatus -> Bool
$c== :: DescribeWorkspacesConnectionStatus
-> DescribeWorkspacesConnectionStatus -> Bool
Prelude.Eq, ReadPrec [DescribeWorkspacesConnectionStatus]
ReadPrec DescribeWorkspacesConnectionStatus
Int -> ReadS DescribeWorkspacesConnectionStatus
ReadS [DescribeWorkspacesConnectionStatus]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeWorkspacesConnectionStatus]
$creadListPrec :: ReadPrec [DescribeWorkspacesConnectionStatus]
readPrec :: ReadPrec DescribeWorkspacesConnectionStatus
$creadPrec :: ReadPrec DescribeWorkspacesConnectionStatus
readList :: ReadS [DescribeWorkspacesConnectionStatus]
$creadList :: ReadS [DescribeWorkspacesConnectionStatus]
readsPrec :: Int -> ReadS DescribeWorkspacesConnectionStatus
$creadsPrec :: Int -> ReadS DescribeWorkspacesConnectionStatus
Prelude.Read, Int -> DescribeWorkspacesConnectionStatus -> ShowS
[DescribeWorkspacesConnectionStatus] -> ShowS
DescribeWorkspacesConnectionStatus -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeWorkspacesConnectionStatus] -> ShowS
$cshowList :: [DescribeWorkspacesConnectionStatus] -> ShowS
show :: DescribeWorkspacesConnectionStatus -> String
$cshow :: DescribeWorkspacesConnectionStatus -> String
showsPrec :: Int -> DescribeWorkspacesConnectionStatus -> ShowS
$cshowsPrec :: Int -> DescribeWorkspacesConnectionStatus -> ShowS
Prelude.Show, forall x.
Rep DescribeWorkspacesConnectionStatus x
-> DescribeWorkspacesConnectionStatus
forall x.
DescribeWorkspacesConnectionStatus
-> Rep DescribeWorkspacesConnectionStatus x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeWorkspacesConnectionStatus x
-> DescribeWorkspacesConnectionStatus
$cfrom :: forall x.
DescribeWorkspacesConnectionStatus
-> Rep DescribeWorkspacesConnectionStatus x
Prelude.Generic)

-- |
-- Create a value of 'DescribeWorkspacesConnectionStatus' 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', 'describeWorkspacesConnectionStatus_nextToken' - If you received a @NextToken@ from a previous call that was paginated,
-- provide this token to receive the next set of results.
--
-- 'workspaceIds', 'describeWorkspacesConnectionStatus_workspaceIds' - The identifiers of the WorkSpaces. You can specify up to 25 WorkSpaces.
newDescribeWorkspacesConnectionStatus ::
  DescribeWorkspacesConnectionStatus
newDescribeWorkspacesConnectionStatus :: DescribeWorkspacesConnectionStatus
newDescribeWorkspacesConnectionStatus =
  DescribeWorkspacesConnectionStatus'
    { $sel:nextToken:DescribeWorkspacesConnectionStatus' :: Maybe Text
nextToken =
        forall a. Maybe a
Prelude.Nothing,
      $sel:workspaceIds:DescribeWorkspacesConnectionStatus' :: Maybe (NonEmpty Text)
workspaceIds = forall a. Maybe a
Prelude.Nothing
    }

-- | If you received a @NextToken@ from a previous call that was paginated,
-- provide this token to receive the next set of results.
describeWorkspacesConnectionStatus_nextToken :: Lens.Lens' DescribeWorkspacesConnectionStatus (Prelude.Maybe Prelude.Text)
describeWorkspacesConnectionStatus_nextToken :: Lens' DescribeWorkspacesConnectionStatus (Maybe Text)
describeWorkspacesConnectionStatus_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeWorkspacesConnectionStatus' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeWorkspacesConnectionStatus
s@DescribeWorkspacesConnectionStatus' {} Maybe Text
a -> DescribeWorkspacesConnectionStatus
s {$sel:nextToken:DescribeWorkspacesConnectionStatus' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeWorkspacesConnectionStatus)

-- | The identifiers of the WorkSpaces. You can specify up to 25 WorkSpaces.
describeWorkspacesConnectionStatus_workspaceIds :: Lens.Lens' DescribeWorkspacesConnectionStatus (Prelude.Maybe (Prelude.NonEmpty Prelude.Text))
describeWorkspacesConnectionStatus_workspaceIds :: Lens' DescribeWorkspacesConnectionStatus (Maybe (NonEmpty Text))
describeWorkspacesConnectionStatus_workspaceIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeWorkspacesConnectionStatus' {Maybe (NonEmpty Text)
workspaceIds :: Maybe (NonEmpty Text)
$sel:workspaceIds:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> Maybe (NonEmpty Text)
workspaceIds} -> Maybe (NonEmpty Text)
workspaceIds) (\s :: DescribeWorkspacesConnectionStatus
s@DescribeWorkspacesConnectionStatus' {} Maybe (NonEmpty Text)
a -> DescribeWorkspacesConnectionStatus
s {$sel:workspaceIds:DescribeWorkspacesConnectionStatus' :: Maybe (NonEmpty Text)
workspaceIds = Maybe (NonEmpty Text)
a} :: DescribeWorkspacesConnectionStatus) 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
    DescribeWorkspacesConnectionStatus
  where
  page :: DescribeWorkspacesConnectionStatus
-> AWSResponse DescribeWorkspacesConnectionStatus
-> Maybe DescribeWorkspacesConnectionStatus
page DescribeWorkspacesConnectionStatus
rq AWSResponse DescribeWorkspacesConnectionStatus
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse DescribeWorkspacesConnectionStatus
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeWorkspacesConnectionStatusResponse (Maybe Text)
describeWorkspacesConnectionStatusResponse_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 DescribeWorkspacesConnectionStatus
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens'
  DescribeWorkspacesConnectionStatusResponse
  (Maybe [WorkspaceConnectionStatus])
describeWorkspacesConnectionStatusResponse_workspacesConnectionStatus
            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.$ DescribeWorkspacesConnectionStatus
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' DescribeWorkspacesConnectionStatus (Maybe Text)
describeWorkspacesConnectionStatus_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse DescribeWorkspacesConnectionStatus
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' DescribeWorkspacesConnectionStatusResponse (Maybe Text)
describeWorkspacesConnectionStatusResponse_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
    DescribeWorkspacesConnectionStatus
  where
  type
    AWSResponse DescribeWorkspacesConnectionStatus =
      DescribeWorkspacesConnectionStatusResponse
  request :: (Service -> Service)
-> DescribeWorkspacesConnectionStatus
-> Request DescribeWorkspacesConnectionStatus
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 DescribeWorkspacesConnectionStatus
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse (AWSResponse DescribeWorkspacesConnectionStatus)))
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 [WorkspaceConnectionStatus]
-> Int
-> DescribeWorkspacesConnectionStatusResponse
DescribeWorkspacesConnectionStatusResponse'
            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
"WorkspacesConnectionStatus"
                            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
    DescribeWorkspacesConnectionStatus
  where
  hashWithSalt :: Int -> DescribeWorkspacesConnectionStatus -> Int
hashWithSalt
    Int
_salt
    DescribeWorkspacesConnectionStatus' {Maybe (NonEmpty Text)
Maybe Text
workspaceIds :: Maybe (NonEmpty Text)
nextToken :: Maybe Text
$sel:workspaceIds:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> Maybe (NonEmpty Text)
$sel:nextToken:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> Maybe Text
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe (NonEmpty Text)
workspaceIds

instance
  Prelude.NFData
    DescribeWorkspacesConnectionStatus
  where
  rnf :: DescribeWorkspacesConnectionStatus -> ()
rnf DescribeWorkspacesConnectionStatus' {Maybe (NonEmpty Text)
Maybe Text
workspaceIds :: Maybe (NonEmpty Text)
nextToken :: Maybe Text
$sel:workspaceIds:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> Maybe (NonEmpty Text)
$sel:nextToken:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> 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 (NonEmpty Text)
workspaceIds

instance
  Data.ToHeaders
    DescribeWorkspacesConnectionStatus
  where
  toHeaders :: DescribeWorkspacesConnectionStatus -> 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
"WorkspacesService.DescribeWorkspacesConnectionStatus" ::
                          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
    DescribeWorkspacesConnectionStatus
  where
  toJSON :: DescribeWorkspacesConnectionStatus -> Value
toJSON DescribeWorkspacesConnectionStatus' {Maybe (NonEmpty Text)
Maybe Text
workspaceIds :: Maybe (NonEmpty Text)
nextToken :: Maybe Text
$sel:workspaceIds:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> Maybe (NonEmpty Text)
$sel:nextToken:DescribeWorkspacesConnectionStatus' :: DescribeWorkspacesConnectionStatus -> Maybe Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (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
"WorkspaceIds" 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 (NonEmpty Text)
workspaceIds
          ]
      )

instance
  Data.ToPath
    DescribeWorkspacesConnectionStatus
  where
  toPath :: DescribeWorkspacesConnectionStatus -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance
  Data.ToQuery
    DescribeWorkspacesConnectionStatus
  where
  toQuery :: DescribeWorkspacesConnectionStatus -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newDescribeWorkspacesConnectionStatusResponse' smart constructor.
data DescribeWorkspacesConnectionStatusResponse = DescribeWorkspacesConnectionStatusResponse'
  { -- | The token to use to retrieve the next page of results. This value is
    -- null when there are no more results to return.
    DescribeWorkspacesConnectionStatusResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | Information about the connection status of the WorkSpace.
    DescribeWorkspacesConnectionStatusResponse
-> Maybe [WorkspaceConnectionStatus]
workspacesConnectionStatus :: Prelude.Maybe [WorkspaceConnectionStatus],
    -- | The response's http status code.
    DescribeWorkspacesConnectionStatusResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (DescribeWorkspacesConnectionStatusResponse
-> DescribeWorkspacesConnectionStatusResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: DescribeWorkspacesConnectionStatusResponse
-> DescribeWorkspacesConnectionStatusResponse -> Bool
$c/= :: DescribeWorkspacesConnectionStatusResponse
-> DescribeWorkspacesConnectionStatusResponse -> Bool
== :: DescribeWorkspacesConnectionStatusResponse
-> DescribeWorkspacesConnectionStatusResponse -> Bool
$c== :: DescribeWorkspacesConnectionStatusResponse
-> DescribeWorkspacesConnectionStatusResponse -> Bool
Prelude.Eq, ReadPrec [DescribeWorkspacesConnectionStatusResponse]
ReadPrec DescribeWorkspacesConnectionStatusResponse
Int -> ReadS DescribeWorkspacesConnectionStatusResponse
ReadS [DescribeWorkspacesConnectionStatusResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [DescribeWorkspacesConnectionStatusResponse]
$creadListPrec :: ReadPrec [DescribeWorkspacesConnectionStatusResponse]
readPrec :: ReadPrec DescribeWorkspacesConnectionStatusResponse
$creadPrec :: ReadPrec DescribeWorkspacesConnectionStatusResponse
readList :: ReadS [DescribeWorkspacesConnectionStatusResponse]
$creadList :: ReadS [DescribeWorkspacesConnectionStatusResponse]
readsPrec :: Int -> ReadS DescribeWorkspacesConnectionStatusResponse
$creadsPrec :: Int -> ReadS DescribeWorkspacesConnectionStatusResponse
Prelude.Read, Int -> DescribeWorkspacesConnectionStatusResponse -> ShowS
[DescribeWorkspacesConnectionStatusResponse] -> ShowS
DescribeWorkspacesConnectionStatusResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [DescribeWorkspacesConnectionStatusResponse] -> ShowS
$cshowList :: [DescribeWorkspacesConnectionStatusResponse] -> ShowS
show :: DescribeWorkspacesConnectionStatusResponse -> String
$cshow :: DescribeWorkspacesConnectionStatusResponse -> String
showsPrec :: Int -> DescribeWorkspacesConnectionStatusResponse -> ShowS
$cshowsPrec :: Int -> DescribeWorkspacesConnectionStatusResponse -> ShowS
Prelude.Show, forall x.
Rep DescribeWorkspacesConnectionStatusResponse x
-> DescribeWorkspacesConnectionStatusResponse
forall x.
DescribeWorkspacesConnectionStatusResponse
-> Rep DescribeWorkspacesConnectionStatusResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep DescribeWorkspacesConnectionStatusResponse x
-> DescribeWorkspacesConnectionStatusResponse
$cfrom :: forall x.
DescribeWorkspacesConnectionStatusResponse
-> Rep DescribeWorkspacesConnectionStatusResponse x
Prelude.Generic)

-- |
-- Create a value of 'DescribeWorkspacesConnectionStatusResponse' 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', 'describeWorkspacesConnectionStatusResponse_nextToken' - The token to use to retrieve the next page of results. This value is
-- null when there are no more results to return.
--
-- 'workspacesConnectionStatus', 'describeWorkspacesConnectionStatusResponse_workspacesConnectionStatus' - Information about the connection status of the WorkSpace.
--
-- 'httpStatus', 'describeWorkspacesConnectionStatusResponse_httpStatus' - The response's http status code.
newDescribeWorkspacesConnectionStatusResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  DescribeWorkspacesConnectionStatusResponse
newDescribeWorkspacesConnectionStatusResponse :: Int -> DescribeWorkspacesConnectionStatusResponse
newDescribeWorkspacesConnectionStatusResponse
  Int
pHttpStatus_ =
    DescribeWorkspacesConnectionStatusResponse'
      { $sel:nextToken:DescribeWorkspacesConnectionStatusResponse' :: Maybe Text
nextToken =
          forall a. Maybe a
Prelude.Nothing,
        $sel:workspacesConnectionStatus:DescribeWorkspacesConnectionStatusResponse' :: Maybe [WorkspaceConnectionStatus]
workspacesConnectionStatus =
          forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:DescribeWorkspacesConnectionStatusResponse' :: Int
httpStatus = Int
pHttpStatus_
      }

-- | The token to use to retrieve the next page of results. This value is
-- null when there are no more results to return.
describeWorkspacesConnectionStatusResponse_nextToken :: Lens.Lens' DescribeWorkspacesConnectionStatusResponse (Prelude.Maybe Prelude.Text)
describeWorkspacesConnectionStatusResponse_nextToken :: Lens' DescribeWorkspacesConnectionStatusResponse (Maybe Text)
describeWorkspacesConnectionStatusResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeWorkspacesConnectionStatusResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:DescribeWorkspacesConnectionStatusResponse' :: DescribeWorkspacesConnectionStatusResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: DescribeWorkspacesConnectionStatusResponse
s@DescribeWorkspacesConnectionStatusResponse' {} Maybe Text
a -> DescribeWorkspacesConnectionStatusResponse
s {$sel:nextToken:DescribeWorkspacesConnectionStatusResponse' :: Maybe Text
nextToken = Maybe Text
a} :: DescribeWorkspacesConnectionStatusResponse)

-- | Information about the connection status of the WorkSpace.
describeWorkspacesConnectionStatusResponse_workspacesConnectionStatus :: Lens.Lens' DescribeWorkspacesConnectionStatusResponse (Prelude.Maybe [WorkspaceConnectionStatus])
describeWorkspacesConnectionStatusResponse_workspacesConnectionStatus :: Lens'
  DescribeWorkspacesConnectionStatusResponse
  (Maybe [WorkspaceConnectionStatus])
describeWorkspacesConnectionStatusResponse_workspacesConnectionStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeWorkspacesConnectionStatusResponse' {Maybe [WorkspaceConnectionStatus]
workspacesConnectionStatus :: Maybe [WorkspaceConnectionStatus]
$sel:workspacesConnectionStatus:DescribeWorkspacesConnectionStatusResponse' :: DescribeWorkspacesConnectionStatusResponse
-> Maybe [WorkspaceConnectionStatus]
workspacesConnectionStatus} -> Maybe [WorkspaceConnectionStatus]
workspacesConnectionStatus) (\s :: DescribeWorkspacesConnectionStatusResponse
s@DescribeWorkspacesConnectionStatusResponse' {} Maybe [WorkspaceConnectionStatus]
a -> DescribeWorkspacesConnectionStatusResponse
s {$sel:workspacesConnectionStatus:DescribeWorkspacesConnectionStatusResponse' :: Maybe [WorkspaceConnectionStatus]
workspacesConnectionStatus = Maybe [WorkspaceConnectionStatus]
a} :: DescribeWorkspacesConnectionStatusResponse) 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.
describeWorkspacesConnectionStatusResponse_httpStatus :: Lens.Lens' DescribeWorkspacesConnectionStatusResponse Prelude.Int
describeWorkspacesConnectionStatusResponse_httpStatus :: Lens' DescribeWorkspacesConnectionStatusResponse Int
describeWorkspacesConnectionStatusResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\DescribeWorkspacesConnectionStatusResponse' {Int
httpStatus :: Int
$sel:httpStatus:DescribeWorkspacesConnectionStatusResponse' :: DescribeWorkspacesConnectionStatusResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: DescribeWorkspacesConnectionStatusResponse
s@DescribeWorkspacesConnectionStatusResponse' {} Int
a -> DescribeWorkspacesConnectionStatusResponse
s {$sel:httpStatus:DescribeWorkspacesConnectionStatusResponse' :: Int
httpStatus = Int
a} :: DescribeWorkspacesConnectionStatusResponse)

instance
  Prelude.NFData
    DescribeWorkspacesConnectionStatusResponse
  where
  rnf :: DescribeWorkspacesConnectionStatusResponse -> ()
rnf DescribeWorkspacesConnectionStatusResponse' {Int
Maybe [WorkspaceConnectionStatus]
Maybe Text
httpStatus :: Int
workspacesConnectionStatus :: Maybe [WorkspaceConnectionStatus]
nextToken :: Maybe Text
$sel:httpStatus:DescribeWorkspacesConnectionStatusResponse' :: DescribeWorkspacesConnectionStatusResponse -> Int
$sel:workspacesConnectionStatus:DescribeWorkspacesConnectionStatusResponse' :: DescribeWorkspacesConnectionStatusResponse
-> Maybe [WorkspaceConnectionStatus]
$sel:nextToken:DescribeWorkspacesConnectionStatusResponse' :: DescribeWorkspacesConnectionStatusResponse -> 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 [WorkspaceConnectionStatus]
workspacesConnectionStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus