{-# 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.Chime.ListRoomMemberships
(
ListRoomMemberships (..),
newListRoomMemberships,
listRoomMemberships_maxResults,
listRoomMemberships_nextToken,
listRoomMemberships_accountId,
listRoomMemberships_roomId,
ListRoomMembershipsResponse (..),
newListRoomMembershipsResponse,
listRoomMembershipsResponse_nextToken,
listRoomMembershipsResponse_roomMemberships,
listRoomMembershipsResponse_httpStatus,
)
where
import Amazonka.Chime.Types
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
data ListRoomMemberships = ListRoomMemberships'
{
ListRoomMemberships -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
ListRoomMemberships -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
ListRoomMemberships -> Text
accountId :: Prelude.Text,
ListRoomMemberships -> Text
roomId :: Prelude.Text
}
deriving (ListRoomMemberships -> ListRoomMemberships -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListRoomMemberships -> ListRoomMemberships -> Bool
$c/= :: ListRoomMemberships -> ListRoomMemberships -> Bool
== :: ListRoomMemberships -> ListRoomMemberships -> Bool
$c== :: ListRoomMemberships -> ListRoomMemberships -> Bool
Prelude.Eq, ReadPrec [ListRoomMemberships]
ReadPrec ListRoomMemberships
Int -> ReadS ListRoomMemberships
ReadS [ListRoomMemberships]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListRoomMemberships]
$creadListPrec :: ReadPrec [ListRoomMemberships]
readPrec :: ReadPrec ListRoomMemberships
$creadPrec :: ReadPrec ListRoomMemberships
readList :: ReadS [ListRoomMemberships]
$creadList :: ReadS [ListRoomMemberships]
readsPrec :: Int -> ReadS ListRoomMemberships
$creadsPrec :: Int -> ReadS ListRoomMemberships
Prelude.Read, Int -> ListRoomMemberships -> ShowS
[ListRoomMemberships] -> ShowS
ListRoomMemberships -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListRoomMemberships] -> ShowS
$cshowList :: [ListRoomMemberships] -> ShowS
show :: ListRoomMemberships -> String
$cshow :: ListRoomMemberships -> String
showsPrec :: Int -> ListRoomMemberships -> ShowS
$cshowsPrec :: Int -> ListRoomMemberships -> ShowS
Prelude.Show, forall x. Rep ListRoomMemberships x -> ListRoomMemberships
forall x. ListRoomMemberships -> Rep ListRoomMemberships x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListRoomMemberships x -> ListRoomMemberships
$cfrom :: forall x. ListRoomMemberships -> Rep ListRoomMemberships x
Prelude.Generic)
newListRoomMemberships ::
Prelude.Text ->
Prelude.Text ->
ListRoomMemberships
newListRoomMemberships :: Text -> Text -> ListRoomMemberships
newListRoomMemberships Text
pAccountId_ Text
pRoomId_ =
ListRoomMemberships'
{ $sel:maxResults:ListRoomMemberships' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
$sel:nextToken:ListRoomMemberships' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
$sel:accountId:ListRoomMemberships' :: Text
accountId = Text
pAccountId_,
$sel:roomId:ListRoomMemberships' :: Text
roomId = Text
pRoomId_
}
listRoomMemberships_maxResults :: Lens.Lens' ListRoomMemberships (Prelude.Maybe Prelude.Natural)
listRoomMemberships_maxResults :: Lens' ListRoomMemberships (Maybe Natural)
listRoomMemberships_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListRoomMemberships' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListRoomMemberships' :: ListRoomMemberships -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListRoomMemberships
s@ListRoomMemberships' {} Maybe Natural
a -> ListRoomMemberships
s {$sel:maxResults:ListRoomMemberships' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListRoomMemberships)
listRoomMemberships_nextToken :: Lens.Lens' ListRoomMemberships (Prelude.Maybe Prelude.Text)
listRoomMemberships_nextToken :: Lens' ListRoomMemberships (Maybe Text)
listRoomMemberships_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListRoomMemberships' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListRoomMemberships' :: ListRoomMemberships -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListRoomMemberships
s@ListRoomMemberships' {} Maybe Text
a -> ListRoomMemberships
s {$sel:nextToken:ListRoomMemberships' :: Maybe Text
nextToken = Maybe Text
a} :: ListRoomMemberships)
listRoomMemberships_accountId :: Lens.Lens' ListRoomMemberships Prelude.Text
listRoomMemberships_accountId :: Lens' ListRoomMemberships Text
listRoomMemberships_accountId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListRoomMemberships' {Text
accountId :: Text
$sel:accountId:ListRoomMemberships' :: ListRoomMemberships -> Text
accountId} -> Text
accountId) (\s :: ListRoomMemberships
s@ListRoomMemberships' {} Text
a -> ListRoomMemberships
s {$sel:accountId:ListRoomMemberships' :: Text
accountId = Text
a} :: ListRoomMemberships)
listRoomMemberships_roomId :: Lens.Lens' ListRoomMemberships Prelude.Text
listRoomMemberships_roomId :: Lens' ListRoomMemberships Text
listRoomMemberships_roomId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListRoomMemberships' {Text
roomId :: Text
$sel:roomId:ListRoomMemberships' :: ListRoomMemberships -> Text
roomId} -> Text
roomId) (\s :: ListRoomMemberships
s@ListRoomMemberships' {} Text
a -> ListRoomMemberships
s {$sel:roomId:ListRoomMemberships' :: Text
roomId = Text
a} :: ListRoomMemberships)
instance Core.AWSRequest ListRoomMemberships where
type
AWSResponse ListRoomMemberships =
ListRoomMembershipsResponse
request :: (Service -> Service)
-> ListRoomMemberships -> Request ListRoomMemberships
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 ListRoomMemberships
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse ListRoomMemberships)))
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 [RoomMembership] -> Int -> ListRoomMembershipsResponse
ListRoomMembershipsResponse'
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
"RoomMemberships"
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 ListRoomMemberships where
hashWithSalt :: Int -> ListRoomMemberships -> Int
hashWithSalt Int
_salt ListRoomMemberships' {Maybe Natural
Maybe Text
Text
roomId :: Text
accountId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:roomId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:accountId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:nextToken:ListRoomMemberships' :: ListRoomMemberships -> Maybe Text
$sel:maxResults:ListRoomMemberships' :: ListRoomMemberships -> Maybe Natural
..} =
Int
_salt
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` Text
accountId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
roomId
instance Prelude.NFData ListRoomMemberships where
rnf :: ListRoomMemberships -> ()
rnf ListRoomMemberships' {Maybe Natural
Maybe Text
Text
roomId :: Text
accountId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:roomId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:accountId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:nextToken:ListRoomMemberships' :: ListRoomMemberships -> Maybe Text
$sel:maxResults:ListRoomMemberships' :: ListRoomMemberships -> Maybe Natural
..} =
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 Text
accountId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
roomId
instance Data.ToHeaders ListRoomMemberships where
toHeaders :: ListRoomMemberships -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
instance Data.ToPath ListRoomMemberships where
toPath :: ListRoomMemberships -> ByteString
toPath ListRoomMemberships' {Maybe Natural
Maybe Text
Text
roomId :: Text
accountId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:roomId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:accountId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:nextToken:ListRoomMemberships' :: ListRoomMemberships -> Maybe Text
$sel:maxResults:ListRoomMemberships' :: ListRoomMemberships -> Maybe Natural
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"/accounts/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
accountId,
ByteString
"/rooms/",
forall a. ToByteString a => a -> ByteString
Data.toBS Text
roomId,
ByteString
"/memberships"
]
instance Data.ToQuery ListRoomMemberships where
toQuery :: ListRoomMemberships -> QueryString
toQuery ListRoomMemberships' {Maybe Natural
Maybe Text
Text
roomId :: Text
accountId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:roomId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:accountId:ListRoomMemberships' :: ListRoomMemberships -> Text
$sel:nextToken:ListRoomMemberships' :: ListRoomMemberships -> Maybe Text
$sel:maxResults:ListRoomMemberships' :: ListRoomMemberships -> Maybe Natural
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"max-results" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Natural
maxResults,
ByteString
"next-token" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
nextToken
]
data ListRoomMembershipsResponse = ListRoomMembershipsResponse'
{
ListRoomMembershipsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
ListRoomMembershipsResponse -> Maybe [RoomMembership]
roomMemberships :: Prelude.Maybe [RoomMembership],
ListRoomMembershipsResponse -> Int
httpStatus :: Prelude.Int
}
deriving (ListRoomMembershipsResponse -> ListRoomMembershipsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListRoomMembershipsResponse -> ListRoomMembershipsResponse -> Bool
$c/= :: ListRoomMembershipsResponse -> ListRoomMembershipsResponse -> Bool
== :: ListRoomMembershipsResponse -> ListRoomMembershipsResponse -> Bool
$c== :: ListRoomMembershipsResponse -> ListRoomMembershipsResponse -> Bool
Prelude.Eq, Int -> ListRoomMembershipsResponse -> ShowS
[ListRoomMembershipsResponse] -> ShowS
ListRoomMembershipsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListRoomMembershipsResponse] -> ShowS
$cshowList :: [ListRoomMembershipsResponse] -> ShowS
show :: ListRoomMembershipsResponse -> String
$cshow :: ListRoomMembershipsResponse -> String
showsPrec :: Int -> ListRoomMembershipsResponse -> ShowS
$cshowsPrec :: Int -> ListRoomMembershipsResponse -> ShowS
Prelude.Show, forall x.
Rep ListRoomMembershipsResponse x -> ListRoomMembershipsResponse
forall x.
ListRoomMembershipsResponse -> Rep ListRoomMembershipsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListRoomMembershipsResponse x -> ListRoomMembershipsResponse
$cfrom :: forall x.
ListRoomMembershipsResponse -> Rep ListRoomMembershipsResponse x
Prelude.Generic)
newListRoomMembershipsResponse ::
Prelude.Int ->
ListRoomMembershipsResponse
newListRoomMembershipsResponse :: Int -> ListRoomMembershipsResponse
newListRoomMembershipsResponse Int
pHttpStatus_ =
ListRoomMembershipsResponse'
{ $sel:nextToken:ListRoomMembershipsResponse' :: Maybe Text
nextToken =
forall a. Maybe a
Prelude.Nothing,
$sel:roomMemberships:ListRoomMembershipsResponse' :: Maybe [RoomMembership]
roomMemberships = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:ListRoomMembershipsResponse' :: Int
httpStatus = Int
pHttpStatus_
}
listRoomMembershipsResponse_nextToken :: Lens.Lens' ListRoomMembershipsResponse (Prelude.Maybe Prelude.Text)
listRoomMembershipsResponse_nextToken :: Lens' ListRoomMembershipsResponse (Maybe Text)
listRoomMembershipsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListRoomMembershipsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListRoomMembershipsResponse' :: ListRoomMembershipsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListRoomMembershipsResponse
s@ListRoomMembershipsResponse' {} Maybe Text
a -> ListRoomMembershipsResponse
s {$sel:nextToken:ListRoomMembershipsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListRoomMembershipsResponse)
listRoomMembershipsResponse_roomMemberships :: Lens.Lens' ListRoomMembershipsResponse (Prelude.Maybe [RoomMembership])
listRoomMembershipsResponse_roomMemberships :: Lens' ListRoomMembershipsResponse (Maybe [RoomMembership])
listRoomMembershipsResponse_roomMemberships = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListRoomMembershipsResponse' {Maybe [RoomMembership]
roomMemberships :: Maybe [RoomMembership]
$sel:roomMemberships:ListRoomMembershipsResponse' :: ListRoomMembershipsResponse -> Maybe [RoomMembership]
roomMemberships} -> Maybe [RoomMembership]
roomMemberships) (\s :: ListRoomMembershipsResponse
s@ListRoomMembershipsResponse' {} Maybe [RoomMembership]
a -> ListRoomMembershipsResponse
s {$sel:roomMemberships:ListRoomMembershipsResponse' :: Maybe [RoomMembership]
roomMemberships = Maybe [RoomMembership]
a} :: ListRoomMembershipsResponse) 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
listRoomMembershipsResponse_httpStatus :: Lens.Lens' ListRoomMembershipsResponse Prelude.Int
listRoomMembershipsResponse_httpStatus :: Lens' ListRoomMembershipsResponse Int
listRoomMembershipsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListRoomMembershipsResponse' {Int
httpStatus :: Int
$sel:httpStatus:ListRoomMembershipsResponse' :: ListRoomMembershipsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ListRoomMembershipsResponse
s@ListRoomMembershipsResponse' {} Int
a -> ListRoomMembershipsResponse
s {$sel:httpStatus:ListRoomMembershipsResponse' :: Int
httpStatus = Int
a} :: ListRoomMembershipsResponse)
instance Prelude.NFData ListRoomMembershipsResponse where
rnf :: ListRoomMembershipsResponse -> ()
rnf ListRoomMembershipsResponse' {Int
Maybe [RoomMembership]
Maybe Text
httpStatus :: Int
roomMemberships :: Maybe [RoomMembership]
nextToken :: Maybe Text
$sel:httpStatus:ListRoomMembershipsResponse' :: ListRoomMembershipsResponse -> Int
$sel:roomMemberships:ListRoomMembershipsResponse' :: ListRoomMembershipsResponse -> Maybe [RoomMembership]
$sel:nextToken:ListRoomMembershipsResponse' :: ListRoomMembershipsResponse -> 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 [RoomMembership]
roomMemberships
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus