{-# 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.Connect.ListIntegrationAssociations -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Provides summary information about the Amazon Web Services resource -- associations for the specified Amazon Connect instance. -- -- This operation returns paginated results. module Amazonka.Connect.ListIntegrationAssociations ( -- * Creating a Request ListIntegrationAssociations (..), newListIntegrationAssociations, -- * Request Lenses listIntegrationAssociations_integrationType, listIntegrationAssociations_maxResults, listIntegrationAssociations_nextToken, listIntegrationAssociations_instanceId, -- * Destructuring the Response ListIntegrationAssociationsResponse (..), newListIntegrationAssociationsResponse, -- * Response Lenses listIntegrationAssociationsResponse_integrationAssociationSummaryList, listIntegrationAssociationsResponse_nextToken, listIntegrationAssociationsResponse_httpStatus, ) where import Amazonka.Connect.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:/ 'newListIntegrationAssociations' smart constructor. data ListIntegrationAssociations = ListIntegrationAssociations' { -- | The integration type. integrationType :: Prelude.Maybe IntegrationType, -- | The maximum number of results to return per page. maxResults :: Prelude.Maybe Prelude.Natural, -- | The token for the next set of results. Use the value returned in the -- previous response in the next request to retrieve the next set of -- results. nextToken :: Prelude.Maybe Prelude.Text, -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. instanceId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListIntegrationAssociations' 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: -- -- 'integrationType', 'listIntegrationAssociations_integrationType' - The integration type. -- -- 'maxResults', 'listIntegrationAssociations_maxResults' - The maximum number of results to return per page. -- -- 'nextToken', 'listIntegrationAssociations_nextToken' - The token for the next set of results. Use the value returned in the -- previous response in the next request to retrieve the next set of -- results. -- -- 'instanceId', 'listIntegrationAssociations_instanceId' - The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. newListIntegrationAssociations :: -- | 'instanceId' Prelude.Text -> ListIntegrationAssociations newListIntegrationAssociations pInstanceId_ = ListIntegrationAssociations' { integrationType = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, instanceId = pInstanceId_ } -- | The integration type. listIntegrationAssociations_integrationType :: Lens.Lens' ListIntegrationAssociations (Prelude.Maybe IntegrationType) listIntegrationAssociations_integrationType = Lens.lens (\ListIntegrationAssociations' {integrationType} -> integrationType) (\s@ListIntegrationAssociations' {} a -> s {integrationType = a} :: ListIntegrationAssociations) -- | The maximum number of results to return per page. listIntegrationAssociations_maxResults :: Lens.Lens' ListIntegrationAssociations (Prelude.Maybe Prelude.Natural) listIntegrationAssociations_maxResults = Lens.lens (\ListIntegrationAssociations' {maxResults} -> maxResults) (\s@ListIntegrationAssociations' {} a -> s {maxResults = a} :: ListIntegrationAssociations) -- | The token for the next set of results. Use the value returned in the -- previous response in the next request to retrieve the next set of -- results. listIntegrationAssociations_nextToken :: Lens.Lens' ListIntegrationAssociations (Prelude.Maybe Prelude.Text) listIntegrationAssociations_nextToken = Lens.lens (\ListIntegrationAssociations' {nextToken} -> nextToken) (\s@ListIntegrationAssociations' {} a -> s {nextToken = a} :: ListIntegrationAssociations) -- | The identifier of the Amazon Connect instance. You can find the -- instanceId in the ARN of the instance. listIntegrationAssociations_instanceId :: Lens.Lens' ListIntegrationAssociations Prelude.Text listIntegrationAssociations_instanceId = Lens.lens (\ListIntegrationAssociations' {instanceId} -> instanceId) (\s@ListIntegrationAssociations' {} a -> s {instanceId = a} :: ListIntegrationAssociations) instance Core.AWSPager ListIntegrationAssociations where page rq rs | Core.stop ( rs Lens.^? listIntegrationAssociationsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listIntegrationAssociationsResponse_integrationAssociationSummaryList Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listIntegrationAssociations_nextToken Lens..~ rs Lens.^? listIntegrationAssociationsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListIntegrationAssociations where type AWSResponse ListIntegrationAssociations = ListIntegrationAssociationsResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListIntegrationAssociationsResponse' Prelude.<$> ( x Data..?> "IntegrationAssociationSummaryList" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListIntegrationAssociations where hashWithSalt _salt ListIntegrationAssociations' {..} = _salt `Prelude.hashWithSalt` integrationType `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` instanceId instance Prelude.NFData ListIntegrationAssociations where rnf ListIntegrationAssociations' {..} = Prelude.rnf integrationType `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf instanceId instance Data.ToHeaders ListIntegrationAssociations where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath ListIntegrationAssociations where toPath ListIntegrationAssociations' {..} = Prelude.mconcat [ "/instance/", Data.toBS instanceId, "/integration-associations" ] instance Data.ToQuery ListIntegrationAssociations where toQuery ListIntegrationAssociations' {..} = Prelude.mconcat [ "integrationType" Data.=: integrationType, "maxResults" Data.=: maxResults, "nextToken" Data.=: nextToken ] -- | /See:/ 'newListIntegrationAssociationsResponse' smart constructor. data ListIntegrationAssociationsResponse = ListIntegrationAssociationsResponse' { -- | The associations. integrationAssociationSummaryList :: Prelude.Maybe [IntegrationAssociationSummary], -- | If there are additional results, this is the token for the next set of -- results. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListIntegrationAssociationsResponse' 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: -- -- 'integrationAssociationSummaryList', 'listIntegrationAssociationsResponse_integrationAssociationSummaryList' - The associations. -- -- 'nextToken', 'listIntegrationAssociationsResponse_nextToken' - If there are additional results, this is the token for the next set of -- results. -- -- 'httpStatus', 'listIntegrationAssociationsResponse_httpStatus' - The response's http status code. newListIntegrationAssociationsResponse :: -- | 'httpStatus' Prelude.Int -> ListIntegrationAssociationsResponse newListIntegrationAssociationsResponse pHttpStatus_ = ListIntegrationAssociationsResponse' { integrationAssociationSummaryList = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The associations. listIntegrationAssociationsResponse_integrationAssociationSummaryList :: Lens.Lens' ListIntegrationAssociationsResponse (Prelude.Maybe [IntegrationAssociationSummary]) listIntegrationAssociationsResponse_integrationAssociationSummaryList = Lens.lens (\ListIntegrationAssociationsResponse' {integrationAssociationSummaryList} -> integrationAssociationSummaryList) (\s@ListIntegrationAssociationsResponse' {} a -> s {integrationAssociationSummaryList = a} :: ListIntegrationAssociationsResponse) Prelude.. Lens.mapping Lens.coerced -- | If there are additional results, this is the token for the next set of -- results. listIntegrationAssociationsResponse_nextToken :: Lens.Lens' ListIntegrationAssociationsResponse (Prelude.Maybe Prelude.Text) listIntegrationAssociationsResponse_nextToken = Lens.lens (\ListIntegrationAssociationsResponse' {nextToken} -> nextToken) (\s@ListIntegrationAssociationsResponse' {} a -> s {nextToken = a} :: ListIntegrationAssociationsResponse) -- | The response's http status code. listIntegrationAssociationsResponse_httpStatus :: Lens.Lens' ListIntegrationAssociationsResponse Prelude.Int listIntegrationAssociationsResponse_httpStatus = Lens.lens (\ListIntegrationAssociationsResponse' {httpStatus} -> httpStatus) (\s@ListIntegrationAssociationsResponse' {} a -> s {httpStatus = a} :: ListIntegrationAssociationsResponse) instance Prelude.NFData ListIntegrationAssociationsResponse where rnf ListIntegrationAssociationsResponse' {..} = Prelude.rnf integrationAssociationSummaryList `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus