{-# 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.CloudWatchEvents.ListPartnerEventSourceAccounts -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- An SaaS partner can use this operation to display the Amazon Web -- Services account ID that a particular partner event source name is -- associated with. This operation is not used by Amazon Web Services -- customers. module Amazonka.CloudWatchEvents.ListPartnerEventSourceAccounts ( -- * Creating a Request ListPartnerEventSourceAccounts (..), newListPartnerEventSourceAccounts, -- * Request Lenses listPartnerEventSourceAccounts_limit, listPartnerEventSourceAccounts_nextToken, listPartnerEventSourceAccounts_eventSourceName, -- * Destructuring the Response ListPartnerEventSourceAccountsResponse (..), newListPartnerEventSourceAccountsResponse, -- * Response Lenses listPartnerEventSourceAccountsResponse_nextToken, listPartnerEventSourceAccountsResponse_partnerEventSourceAccounts, listPartnerEventSourceAccountsResponse_httpStatus, ) where import Amazonka.CloudWatchEvents.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 -- | /See:/ 'newListPartnerEventSourceAccounts' smart constructor. data ListPartnerEventSourceAccounts = ListPartnerEventSourceAccounts' { -- | Specifying this limits the number of results returned by this operation. -- The operation also returns a NextToken which you can use in a subsequent -- operation to retrieve the next set of results. limit :: Prelude.Maybe Prelude.Natural, -- | The token returned by a previous call to this operation. Specifying this -- retrieves the next set of results. nextToken :: Prelude.Maybe Prelude.Text, -- | The name of the partner event source to display account information -- about. eventSourceName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListPartnerEventSourceAccounts' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'limit', 'listPartnerEventSourceAccounts_limit' - Specifying this limits the number of results returned by this operation. -- The operation also returns a NextToken which you can use in a subsequent -- operation to retrieve the next set of results. -- -- 'nextToken', 'listPartnerEventSourceAccounts_nextToken' - The token returned by a previous call to this operation. Specifying this -- retrieves the next set of results. -- -- 'eventSourceName', 'listPartnerEventSourceAccounts_eventSourceName' - The name of the partner event source to display account information -- about. newListPartnerEventSourceAccounts :: -- | 'eventSourceName' Prelude.Text -> ListPartnerEventSourceAccounts newListPartnerEventSourceAccounts pEventSourceName_ = ListPartnerEventSourceAccounts' { limit = Prelude.Nothing, nextToken = Prelude.Nothing, eventSourceName = pEventSourceName_ } -- | Specifying this limits the number of results returned by this operation. -- The operation also returns a NextToken which you can use in a subsequent -- operation to retrieve the next set of results. listPartnerEventSourceAccounts_limit :: Lens.Lens' ListPartnerEventSourceAccounts (Prelude.Maybe Prelude.Natural) listPartnerEventSourceAccounts_limit = Lens.lens (\ListPartnerEventSourceAccounts' {limit} -> limit) (\s@ListPartnerEventSourceAccounts' {} a -> s {limit = a} :: ListPartnerEventSourceAccounts) -- | The token returned by a previous call to this operation. Specifying this -- retrieves the next set of results. listPartnerEventSourceAccounts_nextToken :: Lens.Lens' ListPartnerEventSourceAccounts (Prelude.Maybe Prelude.Text) listPartnerEventSourceAccounts_nextToken = Lens.lens (\ListPartnerEventSourceAccounts' {nextToken} -> nextToken) (\s@ListPartnerEventSourceAccounts' {} a -> s {nextToken = a} :: ListPartnerEventSourceAccounts) -- | The name of the partner event source to display account information -- about. listPartnerEventSourceAccounts_eventSourceName :: Lens.Lens' ListPartnerEventSourceAccounts Prelude.Text listPartnerEventSourceAccounts_eventSourceName = Lens.lens (\ListPartnerEventSourceAccounts' {eventSourceName} -> eventSourceName) (\s@ListPartnerEventSourceAccounts' {} a -> s {eventSourceName = a} :: ListPartnerEventSourceAccounts) instance Core.AWSRequest ListPartnerEventSourceAccounts where type AWSResponse ListPartnerEventSourceAccounts = ListPartnerEventSourceAccountsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListPartnerEventSourceAccountsResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> ( x Data..?> "PartnerEventSourceAccounts" Core..!@ Prelude.mempty ) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListPartnerEventSourceAccounts where hashWithSalt _salt ListPartnerEventSourceAccounts' {..} = _salt `Prelude.hashWithSalt` limit `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` eventSourceName instance Prelude.NFData ListPartnerEventSourceAccounts where rnf ListPartnerEventSourceAccounts' {..} = Prelude.rnf limit `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf eventSourceName instance Data.ToHeaders ListPartnerEventSourceAccounts where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSEvents.ListPartnerEventSourceAccounts" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListPartnerEventSourceAccounts where toJSON ListPartnerEventSourceAccounts' {..} = Data.object ( Prelude.catMaybes [ ("Limit" Data..=) Prelude.<$> limit, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("EventSourceName" Data..= eventSourceName) ] ) instance Data.ToPath ListPartnerEventSourceAccounts where toPath = Prelude.const "/" instance Data.ToQuery ListPartnerEventSourceAccounts where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListPartnerEventSourceAccountsResponse' smart constructor. data ListPartnerEventSourceAccountsResponse = ListPartnerEventSourceAccountsResponse' { -- | A token you can use in a subsequent operation to retrieve the next set -- of results. nextToken :: Prelude.Maybe Prelude.Text, -- | The list of partner event sources returned by the operation. partnerEventSourceAccounts :: Prelude.Maybe [PartnerEventSourceAccount], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListPartnerEventSourceAccountsResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'nextToken', 'listPartnerEventSourceAccountsResponse_nextToken' - A token you can use in a subsequent operation to retrieve the next set -- of results. -- -- 'partnerEventSourceAccounts', 'listPartnerEventSourceAccountsResponse_partnerEventSourceAccounts' - The list of partner event sources returned by the operation. -- -- 'httpStatus', 'listPartnerEventSourceAccountsResponse_httpStatus' - The response's http status code. newListPartnerEventSourceAccountsResponse :: -- | 'httpStatus' Prelude.Int -> ListPartnerEventSourceAccountsResponse newListPartnerEventSourceAccountsResponse pHttpStatus_ = ListPartnerEventSourceAccountsResponse' { nextToken = Prelude.Nothing, partnerEventSourceAccounts = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A token you can use in a subsequent operation to retrieve the next set -- of results. listPartnerEventSourceAccountsResponse_nextToken :: Lens.Lens' ListPartnerEventSourceAccountsResponse (Prelude.Maybe Prelude.Text) listPartnerEventSourceAccountsResponse_nextToken = Lens.lens (\ListPartnerEventSourceAccountsResponse' {nextToken} -> nextToken) (\s@ListPartnerEventSourceAccountsResponse' {} a -> s {nextToken = a} :: ListPartnerEventSourceAccountsResponse) -- | The list of partner event sources returned by the operation. listPartnerEventSourceAccountsResponse_partnerEventSourceAccounts :: Lens.Lens' ListPartnerEventSourceAccountsResponse (Prelude.Maybe [PartnerEventSourceAccount]) listPartnerEventSourceAccountsResponse_partnerEventSourceAccounts = Lens.lens (\ListPartnerEventSourceAccountsResponse' {partnerEventSourceAccounts} -> partnerEventSourceAccounts) (\s@ListPartnerEventSourceAccountsResponse' {} a -> s {partnerEventSourceAccounts = a} :: ListPartnerEventSourceAccountsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. listPartnerEventSourceAccountsResponse_httpStatus :: Lens.Lens' ListPartnerEventSourceAccountsResponse Prelude.Int listPartnerEventSourceAccountsResponse_httpStatus = Lens.lens (\ListPartnerEventSourceAccountsResponse' {httpStatus} -> httpStatus) (\s@ListPartnerEventSourceAccountsResponse' {} a -> s {httpStatus = a} :: ListPartnerEventSourceAccountsResponse) instance Prelude.NFData ListPartnerEventSourceAccountsResponse where rnf ListPartnerEventSourceAccountsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf partnerEventSourceAccounts `Prelude.seq` Prelude.rnf httpStatus