{-# 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.FMS.ListDiscoveredResources
(
ListDiscoveredResources (..),
newListDiscoveredResources,
listDiscoveredResources_maxResults,
listDiscoveredResources_nextToken,
listDiscoveredResources_memberAccountIds,
listDiscoveredResources_resourceType,
ListDiscoveredResourcesResponse (..),
newListDiscoveredResourcesResponse,
listDiscoveredResourcesResponse_items,
listDiscoveredResourcesResponse_nextToken,
listDiscoveredResourcesResponse_httpStatus,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.FMS.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data ListDiscoveredResources = ListDiscoveredResources'
{
ListDiscoveredResources -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
ListDiscoveredResources -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
ListDiscoveredResources -> [Text]
memberAccountIds :: [Prelude.Text],
ListDiscoveredResources -> Text
resourceType :: Prelude.Text
}
deriving (ListDiscoveredResources -> ListDiscoveredResources -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListDiscoveredResources -> ListDiscoveredResources -> Bool
$c/= :: ListDiscoveredResources -> ListDiscoveredResources -> Bool
== :: ListDiscoveredResources -> ListDiscoveredResources -> Bool
$c== :: ListDiscoveredResources -> ListDiscoveredResources -> Bool
Prelude.Eq, ReadPrec [ListDiscoveredResources]
ReadPrec ListDiscoveredResources
Int -> ReadS ListDiscoveredResources
ReadS [ListDiscoveredResources]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListDiscoveredResources]
$creadListPrec :: ReadPrec [ListDiscoveredResources]
readPrec :: ReadPrec ListDiscoveredResources
$creadPrec :: ReadPrec ListDiscoveredResources
readList :: ReadS [ListDiscoveredResources]
$creadList :: ReadS [ListDiscoveredResources]
readsPrec :: Int -> ReadS ListDiscoveredResources
$creadsPrec :: Int -> ReadS ListDiscoveredResources
Prelude.Read, Int -> ListDiscoveredResources -> ShowS
[ListDiscoveredResources] -> ShowS
ListDiscoveredResources -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListDiscoveredResources] -> ShowS
$cshowList :: [ListDiscoveredResources] -> ShowS
show :: ListDiscoveredResources -> String
$cshow :: ListDiscoveredResources -> String
showsPrec :: Int -> ListDiscoveredResources -> ShowS
$cshowsPrec :: Int -> ListDiscoveredResources -> ShowS
Prelude.Show, forall x. Rep ListDiscoveredResources x -> ListDiscoveredResources
forall x. ListDiscoveredResources -> Rep ListDiscoveredResources x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListDiscoveredResources x -> ListDiscoveredResources
$cfrom :: forall x. ListDiscoveredResources -> Rep ListDiscoveredResources x
Prelude.Generic)
newListDiscoveredResources ::
Prelude.Text ->
ListDiscoveredResources
newListDiscoveredResources :: Text -> ListDiscoveredResources
newListDiscoveredResources Text
pResourceType_ =
ListDiscoveredResources'
{ $sel:maxResults:ListDiscoveredResources' :: Maybe Natural
maxResults =
forall a. Maybe a
Prelude.Nothing,
$sel:nextToken:ListDiscoveredResources' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
$sel:memberAccountIds:ListDiscoveredResources' :: [Text]
memberAccountIds = forall a. Monoid a => a
Prelude.mempty,
$sel:resourceType:ListDiscoveredResources' :: Text
resourceType = Text
pResourceType_
}
listDiscoveredResources_maxResults :: Lens.Lens' ListDiscoveredResources (Prelude.Maybe Prelude.Natural)
listDiscoveredResources_maxResults :: Lens' ListDiscoveredResources (Maybe Natural)
listDiscoveredResources_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListDiscoveredResources' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListDiscoveredResources' :: ListDiscoveredResources -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListDiscoveredResources
s@ListDiscoveredResources' {} Maybe Natural
a -> ListDiscoveredResources
s {$sel:maxResults:ListDiscoveredResources' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListDiscoveredResources)
listDiscoveredResources_nextToken :: Lens.Lens' ListDiscoveredResources (Prelude.Maybe Prelude.Text)
listDiscoveredResources_nextToken :: Lens' ListDiscoveredResources (Maybe Text)
listDiscoveredResources_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListDiscoveredResources' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListDiscoveredResources' :: ListDiscoveredResources -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListDiscoveredResources
s@ListDiscoveredResources' {} Maybe Text
a -> ListDiscoveredResources
s {$sel:nextToken:ListDiscoveredResources' :: Maybe Text
nextToken = Maybe Text
a} :: ListDiscoveredResources)
listDiscoveredResources_memberAccountIds :: Lens.Lens' ListDiscoveredResources [Prelude.Text]
listDiscoveredResources_memberAccountIds :: Lens' ListDiscoveredResources [Text]
listDiscoveredResources_memberAccountIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListDiscoveredResources' {[Text]
memberAccountIds :: [Text]
$sel:memberAccountIds:ListDiscoveredResources' :: ListDiscoveredResources -> [Text]
memberAccountIds} -> [Text]
memberAccountIds) (\s :: ListDiscoveredResources
s@ListDiscoveredResources' {} [Text]
a -> ListDiscoveredResources
s {$sel:memberAccountIds:ListDiscoveredResources' :: [Text]
memberAccountIds = [Text]
a} :: ListDiscoveredResources) 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
listDiscoveredResources_resourceType :: Lens.Lens' ListDiscoveredResources Prelude.Text
listDiscoveredResources_resourceType :: Lens' ListDiscoveredResources Text
listDiscoveredResources_resourceType = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListDiscoveredResources' {Text
resourceType :: Text
$sel:resourceType:ListDiscoveredResources' :: ListDiscoveredResources -> Text
resourceType} -> Text
resourceType) (\s :: ListDiscoveredResources
s@ListDiscoveredResources' {} Text
a -> ListDiscoveredResources
s {$sel:resourceType:ListDiscoveredResources' :: Text
resourceType = Text
a} :: ListDiscoveredResources)
instance Core.AWSRequest ListDiscoveredResources where
type
AWSResponse ListDiscoveredResources =
ListDiscoveredResourcesResponse
request :: (Service -> Service)
-> ListDiscoveredResources -> Request ListDiscoveredResources
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 ListDiscoveredResources
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse ListDiscoveredResources)))
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 [DiscoveredResource]
-> Maybe Text -> Int -> ListDiscoveredResourcesResponse
ListDiscoveredResourcesResponse'
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
"Items" 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.<*> (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))
)
instance Prelude.Hashable ListDiscoveredResources where
hashWithSalt :: Int -> ListDiscoveredResources -> Int
hashWithSalt Int
_salt ListDiscoveredResources' {[Text]
Maybe Natural
Maybe Text
Text
resourceType :: Text
memberAccountIds :: [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:resourceType:ListDiscoveredResources' :: ListDiscoveredResources -> Text
$sel:memberAccountIds:ListDiscoveredResources' :: ListDiscoveredResources -> [Text]
$sel:nextToken:ListDiscoveredResources' :: ListDiscoveredResources -> Maybe Text
$sel:maxResults:ListDiscoveredResources' :: ListDiscoveredResources -> 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]
memberAccountIds
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
resourceType
instance Prelude.NFData ListDiscoveredResources where
rnf :: ListDiscoveredResources -> ()
rnf ListDiscoveredResources' {[Text]
Maybe Natural
Maybe Text
Text
resourceType :: Text
memberAccountIds :: [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:resourceType:ListDiscoveredResources' :: ListDiscoveredResources -> Text
$sel:memberAccountIds:ListDiscoveredResources' :: ListDiscoveredResources -> [Text]
$sel:nextToken:ListDiscoveredResources' :: ListDiscoveredResources -> Maybe Text
$sel:maxResults:ListDiscoveredResources' :: ListDiscoveredResources -> 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]
memberAccountIds
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
resourceType
instance Data.ToHeaders ListDiscoveredResources where
toHeaders :: ListDiscoveredResources -> 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
"AWSFMS_20180101.ListDiscoveredResources" ::
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 ListDiscoveredResources where
toJSON :: ListDiscoveredResources -> Value
toJSON ListDiscoveredResources' {[Text]
Maybe Natural
Maybe Text
Text
resourceType :: Text
memberAccountIds :: [Text]
nextToken :: Maybe Text
maxResults :: Maybe Natural
$sel:resourceType:ListDiscoveredResources' :: ListDiscoveredResources -> Text
$sel:memberAccountIds:ListDiscoveredResources' :: ListDiscoveredResources -> [Text]
$sel:nextToken:ListDiscoveredResources' :: ListDiscoveredResources -> Maybe Text
$sel:maxResults:ListDiscoveredResources' :: ListDiscoveredResources -> 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
"MemberAccountIds" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [Text]
memberAccountIds),
forall a. a -> Maybe a
Prelude.Just (Key
"ResourceType" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
resourceType)
]
)
instance Data.ToPath ListDiscoveredResources where
toPath :: ListDiscoveredResources -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery ListDiscoveredResources where
toQuery :: ListDiscoveredResources -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data ListDiscoveredResourcesResponse = ListDiscoveredResourcesResponse'
{
ListDiscoveredResourcesResponse -> Maybe [DiscoveredResource]
items :: Prelude.Maybe [DiscoveredResource],
ListDiscoveredResourcesResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
ListDiscoveredResourcesResponse -> Int
httpStatus :: Prelude.Int
}
deriving (ListDiscoveredResourcesResponse
-> ListDiscoveredResourcesResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListDiscoveredResourcesResponse
-> ListDiscoveredResourcesResponse -> Bool
$c/= :: ListDiscoveredResourcesResponse
-> ListDiscoveredResourcesResponse -> Bool
== :: ListDiscoveredResourcesResponse
-> ListDiscoveredResourcesResponse -> Bool
$c== :: ListDiscoveredResourcesResponse
-> ListDiscoveredResourcesResponse -> Bool
Prelude.Eq, ReadPrec [ListDiscoveredResourcesResponse]
ReadPrec ListDiscoveredResourcesResponse
Int -> ReadS ListDiscoveredResourcesResponse
ReadS [ListDiscoveredResourcesResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListDiscoveredResourcesResponse]
$creadListPrec :: ReadPrec [ListDiscoveredResourcesResponse]
readPrec :: ReadPrec ListDiscoveredResourcesResponse
$creadPrec :: ReadPrec ListDiscoveredResourcesResponse
readList :: ReadS [ListDiscoveredResourcesResponse]
$creadList :: ReadS [ListDiscoveredResourcesResponse]
readsPrec :: Int -> ReadS ListDiscoveredResourcesResponse
$creadsPrec :: Int -> ReadS ListDiscoveredResourcesResponse
Prelude.Read, Int -> ListDiscoveredResourcesResponse -> ShowS
[ListDiscoveredResourcesResponse] -> ShowS
ListDiscoveredResourcesResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListDiscoveredResourcesResponse] -> ShowS
$cshowList :: [ListDiscoveredResourcesResponse] -> ShowS
show :: ListDiscoveredResourcesResponse -> String
$cshow :: ListDiscoveredResourcesResponse -> String
showsPrec :: Int -> ListDiscoveredResourcesResponse -> ShowS
$cshowsPrec :: Int -> ListDiscoveredResourcesResponse -> ShowS
Prelude.Show, forall x.
Rep ListDiscoveredResourcesResponse x
-> ListDiscoveredResourcesResponse
forall x.
ListDiscoveredResourcesResponse
-> Rep ListDiscoveredResourcesResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListDiscoveredResourcesResponse x
-> ListDiscoveredResourcesResponse
$cfrom :: forall x.
ListDiscoveredResourcesResponse
-> Rep ListDiscoveredResourcesResponse x
Prelude.Generic)
newListDiscoveredResourcesResponse ::
Prelude.Int ->
ListDiscoveredResourcesResponse
newListDiscoveredResourcesResponse :: Int -> ListDiscoveredResourcesResponse
newListDiscoveredResourcesResponse Int
pHttpStatus_ =
ListDiscoveredResourcesResponse'
{ $sel:items:ListDiscoveredResourcesResponse' :: Maybe [DiscoveredResource]
items =
forall a. Maybe a
Prelude.Nothing,
$sel:nextToken:ListDiscoveredResourcesResponse' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:ListDiscoveredResourcesResponse' :: Int
httpStatus = Int
pHttpStatus_
}
listDiscoveredResourcesResponse_items :: Lens.Lens' ListDiscoveredResourcesResponse (Prelude.Maybe [DiscoveredResource])
listDiscoveredResourcesResponse_items :: Lens' ListDiscoveredResourcesResponse (Maybe [DiscoveredResource])
listDiscoveredResourcesResponse_items = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListDiscoveredResourcesResponse' {Maybe [DiscoveredResource]
items :: Maybe [DiscoveredResource]
$sel:items:ListDiscoveredResourcesResponse' :: ListDiscoveredResourcesResponse -> Maybe [DiscoveredResource]
items} -> Maybe [DiscoveredResource]
items) (\s :: ListDiscoveredResourcesResponse
s@ListDiscoveredResourcesResponse' {} Maybe [DiscoveredResource]
a -> ListDiscoveredResourcesResponse
s {$sel:items:ListDiscoveredResourcesResponse' :: Maybe [DiscoveredResource]
items = Maybe [DiscoveredResource]
a} :: ListDiscoveredResourcesResponse) 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
listDiscoveredResourcesResponse_nextToken :: Lens.Lens' ListDiscoveredResourcesResponse (Prelude.Maybe Prelude.Text)
listDiscoveredResourcesResponse_nextToken :: Lens' ListDiscoveredResourcesResponse (Maybe Text)
listDiscoveredResourcesResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListDiscoveredResourcesResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListDiscoveredResourcesResponse' :: ListDiscoveredResourcesResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListDiscoveredResourcesResponse
s@ListDiscoveredResourcesResponse' {} Maybe Text
a -> ListDiscoveredResourcesResponse
s {$sel:nextToken:ListDiscoveredResourcesResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListDiscoveredResourcesResponse)
listDiscoveredResourcesResponse_httpStatus :: Lens.Lens' ListDiscoveredResourcesResponse Prelude.Int
listDiscoveredResourcesResponse_httpStatus :: Lens' ListDiscoveredResourcesResponse Int
listDiscoveredResourcesResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListDiscoveredResourcesResponse' {Int
httpStatus :: Int
$sel:httpStatus:ListDiscoveredResourcesResponse' :: ListDiscoveredResourcesResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ListDiscoveredResourcesResponse
s@ListDiscoveredResourcesResponse' {} Int
a -> ListDiscoveredResourcesResponse
s {$sel:httpStatus:ListDiscoveredResourcesResponse' :: Int
httpStatus = Int
a} :: ListDiscoveredResourcesResponse)
instance
Prelude.NFData
ListDiscoveredResourcesResponse
where
rnf :: ListDiscoveredResourcesResponse -> ()
rnf ListDiscoveredResourcesResponse' {Int
Maybe [DiscoveredResource]
Maybe Text
httpStatus :: Int
nextToken :: Maybe Text
items :: Maybe [DiscoveredResource]
$sel:httpStatus:ListDiscoveredResourcesResponse' :: ListDiscoveredResourcesResponse -> Int
$sel:nextToken:ListDiscoveredResourcesResponse' :: ListDiscoveredResourcesResponse -> Maybe Text
$sel:items:ListDiscoveredResourcesResponse' :: ListDiscoveredResourcesResponse -> Maybe [DiscoveredResource]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [DiscoveredResource]
items
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 Int
httpStatus