{-# 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.Transfer.ListAccesses
(
ListAccesses (..),
newListAccesses,
listAccesses_maxResults,
listAccesses_nextToken,
listAccesses_serverId,
ListAccessesResponse (..),
newListAccessesResponse,
listAccessesResponse_nextToken,
listAccessesResponse_httpStatus,
listAccessesResponse_serverId,
listAccessesResponse_accesses,
)
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.Transfer.Types
data ListAccesses = ListAccesses'
{
ListAccesses -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
ListAccesses -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
ListAccesses -> Text
serverId :: Prelude.Text
}
deriving (ListAccesses -> ListAccesses -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListAccesses -> ListAccesses -> Bool
$c/= :: ListAccesses -> ListAccesses -> Bool
== :: ListAccesses -> ListAccesses -> Bool
$c== :: ListAccesses -> ListAccesses -> Bool
Prelude.Eq, ReadPrec [ListAccesses]
ReadPrec ListAccesses
Int -> ReadS ListAccesses
ReadS [ListAccesses]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListAccesses]
$creadListPrec :: ReadPrec [ListAccesses]
readPrec :: ReadPrec ListAccesses
$creadPrec :: ReadPrec ListAccesses
readList :: ReadS [ListAccesses]
$creadList :: ReadS [ListAccesses]
readsPrec :: Int -> ReadS ListAccesses
$creadsPrec :: Int -> ReadS ListAccesses
Prelude.Read, Int -> ListAccesses -> ShowS
[ListAccesses] -> ShowS
ListAccesses -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListAccesses] -> ShowS
$cshowList :: [ListAccesses] -> ShowS
show :: ListAccesses -> String
$cshow :: ListAccesses -> String
showsPrec :: Int -> ListAccesses -> ShowS
$cshowsPrec :: Int -> ListAccesses -> ShowS
Prelude.Show, forall x. Rep ListAccesses x -> ListAccesses
forall x. ListAccesses -> Rep ListAccesses x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListAccesses x -> ListAccesses
$cfrom :: forall x. ListAccesses -> Rep ListAccesses x
Prelude.Generic)
newListAccesses ::
Prelude.Text ->
ListAccesses
newListAccesses :: Text -> ListAccesses
newListAccesses Text
pServerId_ =
ListAccesses'
{ $sel:maxResults:ListAccesses' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
$sel:nextToken:ListAccesses' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
$sel:serverId:ListAccesses' :: Text
serverId = Text
pServerId_
}
listAccesses_maxResults :: Lens.Lens' ListAccesses (Prelude.Maybe Prelude.Natural)
listAccesses_maxResults :: Lens' ListAccesses (Maybe Natural)
listAccesses_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccesses' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListAccesses' :: ListAccesses -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListAccesses
s@ListAccesses' {} Maybe Natural
a -> ListAccesses
s {$sel:maxResults:ListAccesses' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListAccesses)
listAccesses_nextToken :: Lens.Lens' ListAccesses (Prelude.Maybe Prelude.Text)
listAccesses_nextToken :: Lens' ListAccesses (Maybe Text)
listAccesses_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccesses' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListAccesses
s@ListAccesses' {} Maybe Text
a -> ListAccesses
s {$sel:nextToken:ListAccesses' :: Maybe Text
nextToken = Maybe Text
a} :: ListAccesses)
listAccesses_serverId :: Lens.Lens' ListAccesses Prelude.Text
listAccesses_serverId :: Lens' ListAccesses Text
listAccesses_serverId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccesses' {Text
serverId :: Text
$sel:serverId:ListAccesses' :: ListAccesses -> Text
serverId} -> Text
serverId) (\s :: ListAccesses
s@ListAccesses' {} Text
a -> ListAccesses
s {$sel:serverId:ListAccesses' :: Text
serverId = Text
a} :: ListAccesses)
instance Core.AWSPager ListAccesses where
page :: ListAccesses -> AWSResponse ListAccesses -> Maybe ListAccesses
page ListAccesses
rq AWSResponse ListAccesses
rs
| forall a. AWSTruncated a => a -> Bool
Core.stop
( AWSResponse ListAccesses
rs
forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListAccessesResponse (Maybe Text)
listAccessesResponse_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 ListAccesses
rs forall s a. s -> Getting a s a -> a
Lens.^. Lens' ListAccessesResponse [ListedAccess]
listAccessesResponse_accesses) =
forall a. Maybe a
Prelude.Nothing
| Bool
Prelude.otherwise =
forall a. a -> Maybe a
Prelude.Just
forall a b. (a -> b) -> a -> b
Prelude.$ ListAccesses
rq
forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListAccesses (Maybe Text)
listAccesses_nextToken
forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListAccesses
rs
forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListAccessesResponse (Maybe Text)
listAccessesResponse_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 ListAccesses where
type AWSResponse ListAccesses = ListAccessesResponse
request :: (Service -> Service) -> ListAccesses -> Request ListAccesses
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 ListAccesses
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse ListAccesses)))
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 -> Int -> Text -> [ListedAccess] -> ListAccessesResponse
ListAccessesResponse'
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.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"ServerId")
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
"Accesses" forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty)
)
instance Prelude.Hashable ListAccesses where
hashWithSalt :: Int -> ListAccesses -> Int
hashWithSalt Int
_salt ListAccesses' {Maybe Natural
Maybe Text
Text
serverId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:serverId:ListAccesses' :: ListAccesses -> Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
$sel:maxResults:ListAccesses' :: ListAccesses -> 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
serverId
instance Prelude.NFData ListAccesses where
rnf :: ListAccesses -> ()
rnf ListAccesses' {Maybe Natural
Maybe Text
Text
serverId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:serverId:ListAccesses' :: ListAccesses -> Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
$sel:maxResults:ListAccesses' :: ListAccesses -> 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
serverId
instance Data.ToHeaders ListAccesses where
toHeaders :: ListAccesses -> 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
"TransferService.ListAccesses" ::
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 ListAccesses where
toJSON :: ListAccesses -> Value
toJSON ListAccesses' {Maybe Natural
Maybe Text
Text
serverId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:serverId:ListAccesses' :: ListAccesses -> Text
$sel:nextToken:ListAccesses' :: ListAccesses -> Maybe Text
$sel:maxResults:ListAccesses' :: ListAccesses -> Maybe Natural
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (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,
forall a. a -> Maybe a
Prelude.Just (Key
"ServerId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
serverId)
]
)
instance Data.ToPath ListAccesses where
toPath :: ListAccesses -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery ListAccesses where
toQuery :: ListAccesses -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data ListAccessesResponse = ListAccessesResponse'
{
ListAccessesResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
ListAccessesResponse -> Int
httpStatus :: Prelude.Int,
ListAccessesResponse -> Text
serverId :: Prelude.Text,
ListAccessesResponse -> [ListedAccess]
accesses :: [ListedAccess]
}
deriving (ListAccessesResponse -> ListAccessesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListAccessesResponse -> ListAccessesResponse -> Bool
$c/= :: ListAccessesResponse -> ListAccessesResponse -> Bool
== :: ListAccessesResponse -> ListAccessesResponse -> Bool
$c== :: ListAccessesResponse -> ListAccessesResponse -> Bool
Prelude.Eq, ReadPrec [ListAccessesResponse]
ReadPrec ListAccessesResponse
Int -> ReadS ListAccessesResponse
ReadS [ListAccessesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListAccessesResponse]
$creadListPrec :: ReadPrec [ListAccessesResponse]
readPrec :: ReadPrec ListAccessesResponse
$creadPrec :: ReadPrec ListAccessesResponse
readList :: ReadS [ListAccessesResponse]
$creadList :: ReadS [ListAccessesResponse]
readsPrec :: Int -> ReadS ListAccessesResponse
$creadsPrec :: Int -> ReadS ListAccessesResponse
Prelude.Read, Int -> ListAccessesResponse -> ShowS
[ListAccessesResponse] -> ShowS
ListAccessesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListAccessesResponse] -> ShowS
$cshowList :: [ListAccessesResponse] -> ShowS
show :: ListAccessesResponse -> String
$cshow :: ListAccessesResponse -> String
showsPrec :: Int -> ListAccessesResponse -> ShowS
$cshowsPrec :: Int -> ListAccessesResponse -> ShowS
Prelude.Show, forall x. Rep ListAccessesResponse x -> ListAccessesResponse
forall x. ListAccessesResponse -> Rep ListAccessesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListAccessesResponse x -> ListAccessesResponse
$cfrom :: forall x. ListAccessesResponse -> Rep ListAccessesResponse x
Prelude.Generic)
newListAccessesResponse ::
Prelude.Int ->
Prelude.Text ->
ListAccessesResponse
newListAccessesResponse :: Int -> Text -> ListAccessesResponse
newListAccessesResponse Int
pHttpStatus_ Text
pServerId_ =
ListAccessesResponse'
{ $sel:nextToken:ListAccessesResponse' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:ListAccessesResponse' :: Int
httpStatus = Int
pHttpStatus_,
$sel:serverId:ListAccessesResponse' :: Text
serverId = Text
pServerId_,
$sel:accesses:ListAccessesResponse' :: [ListedAccess]
accesses = forall a. Monoid a => a
Prelude.mempty
}
listAccessesResponse_nextToken :: Lens.Lens' ListAccessesResponse (Prelude.Maybe Prelude.Text)
listAccessesResponse_nextToken :: Lens' ListAccessesResponse (Maybe Text)
listAccessesResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListAccessesResponse' :: ListAccessesResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} Maybe Text
a -> ListAccessesResponse
s {$sel:nextToken:ListAccessesResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListAccessesResponse)
listAccessesResponse_httpStatus :: Lens.Lens' ListAccessesResponse Prelude.Int
listAccessesResponse_httpStatus :: Lens' ListAccessesResponse Int
listAccessesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {Int
httpStatus :: Int
$sel:httpStatus:ListAccessesResponse' :: ListAccessesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} Int
a -> ListAccessesResponse
s {$sel:httpStatus:ListAccessesResponse' :: Int
httpStatus = Int
a} :: ListAccessesResponse)
listAccessesResponse_serverId :: Lens.Lens' ListAccessesResponse Prelude.Text
listAccessesResponse_serverId :: Lens' ListAccessesResponse Text
listAccessesResponse_serverId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {Text
serverId :: Text
$sel:serverId:ListAccessesResponse' :: ListAccessesResponse -> Text
serverId} -> Text
serverId) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} Text
a -> ListAccessesResponse
s {$sel:serverId:ListAccessesResponse' :: Text
serverId = Text
a} :: ListAccessesResponse)
listAccessesResponse_accesses :: Lens.Lens' ListAccessesResponse [ListedAccess]
listAccessesResponse_accesses :: Lens' ListAccessesResponse [ListedAccess]
listAccessesResponse_accesses = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListAccessesResponse' {[ListedAccess]
accesses :: [ListedAccess]
$sel:accesses:ListAccessesResponse' :: ListAccessesResponse -> [ListedAccess]
accesses} -> [ListedAccess]
accesses) (\s :: ListAccessesResponse
s@ListAccessesResponse' {} [ListedAccess]
a -> ListAccessesResponse
s {$sel:accesses:ListAccessesResponse' :: [ListedAccess]
accesses = [ListedAccess]
a} :: ListAccessesResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
instance Prelude.NFData ListAccessesResponse where
rnf :: ListAccessesResponse -> ()
rnf ListAccessesResponse' {Int
[ListedAccess]
Maybe Text
Text
accesses :: [ListedAccess]
serverId :: Text
httpStatus :: Int
nextToken :: Maybe Text
$sel:accesses:ListAccessesResponse' :: ListAccessesResponse -> [ListedAccess]
$sel:serverId:ListAccessesResponse' :: ListAccessesResponse -> Text
$sel:httpStatus:ListAccessesResponse' :: ListAccessesResponse -> Int
$sel:nextToken:ListAccessesResponse' :: ListAccessesResponse -> 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 Int
httpStatus
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
serverId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [ListedAccess]
accesses