{-# 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.AppSync.ListDomainNames -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Lists multiple custom domain names. module Amazonka.AppSync.ListDomainNames ( -- * Creating a Request ListDomainNames (..), newListDomainNames, -- * Request Lenses listDomainNames_maxResults, listDomainNames_nextToken, -- * Destructuring the Response ListDomainNamesResponse (..), newListDomainNamesResponse, -- * Response Lenses listDomainNamesResponse_domainNameConfigs, listDomainNamesResponse_nextToken, listDomainNamesResponse_httpStatus, ) where import Amazonka.AppSync.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:/ 'newListDomainNames' smart constructor. data ListDomainNames = ListDomainNames' { -- | The maximum number of results that you want the request to return. maxResults :: Prelude.Maybe Prelude.Natural, -- | The API token. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListDomainNames' 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: -- -- 'maxResults', 'listDomainNames_maxResults' - The maximum number of results that you want the request to return. -- -- 'nextToken', 'listDomainNames_nextToken' - The API token. newListDomainNames :: ListDomainNames newListDomainNames = ListDomainNames' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | The maximum number of results that you want the request to return. listDomainNames_maxResults :: Lens.Lens' ListDomainNames (Prelude.Maybe Prelude.Natural) listDomainNames_maxResults = Lens.lens (\ListDomainNames' {maxResults} -> maxResults) (\s@ListDomainNames' {} a -> s {maxResults = a} :: ListDomainNames) -- | The API token. listDomainNames_nextToken :: Lens.Lens' ListDomainNames (Prelude.Maybe Prelude.Text) listDomainNames_nextToken = Lens.lens (\ListDomainNames' {nextToken} -> nextToken) (\s@ListDomainNames' {} a -> s {nextToken = a} :: ListDomainNames) instance Core.AWSRequest ListDomainNames where type AWSResponse ListDomainNames = ListDomainNamesResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListDomainNamesResponse' Prelude.<$> ( x Data..?> "domainNameConfigs" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListDomainNames where hashWithSalt _salt ListDomainNames' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListDomainNames where rnf ListDomainNames' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListDomainNames where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath ListDomainNames where toPath = Prelude.const "/v1/domainnames" instance Data.ToQuery ListDomainNames where toQuery ListDomainNames' {..} = Prelude.mconcat [ "maxResults" Data.=: maxResults, "nextToken" Data.=: nextToken ] -- | /See:/ 'newListDomainNamesResponse' smart constructor. data ListDomainNamesResponse = ListDomainNamesResponse' { -- | Lists configurations for multiple domain names. domainNameConfigs :: Prelude.Maybe [DomainNameConfig], -- | The API token. 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 'ListDomainNamesResponse' 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: -- -- 'domainNameConfigs', 'listDomainNamesResponse_domainNameConfigs' - Lists configurations for multiple domain names. -- -- 'nextToken', 'listDomainNamesResponse_nextToken' - The API token. -- -- 'httpStatus', 'listDomainNamesResponse_httpStatus' - The response's http status code. newListDomainNamesResponse :: -- | 'httpStatus' Prelude.Int -> ListDomainNamesResponse newListDomainNamesResponse pHttpStatus_ = ListDomainNamesResponse' { domainNameConfigs = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Lists configurations for multiple domain names. listDomainNamesResponse_domainNameConfigs :: Lens.Lens' ListDomainNamesResponse (Prelude.Maybe [DomainNameConfig]) listDomainNamesResponse_domainNameConfigs = Lens.lens (\ListDomainNamesResponse' {domainNameConfigs} -> domainNameConfigs) (\s@ListDomainNamesResponse' {} a -> s {domainNameConfigs = a} :: ListDomainNamesResponse) Prelude.. Lens.mapping Lens.coerced -- | The API token. listDomainNamesResponse_nextToken :: Lens.Lens' ListDomainNamesResponse (Prelude.Maybe Prelude.Text) listDomainNamesResponse_nextToken = Lens.lens (\ListDomainNamesResponse' {nextToken} -> nextToken) (\s@ListDomainNamesResponse' {} a -> s {nextToken = a} :: ListDomainNamesResponse) -- | The response's http status code. listDomainNamesResponse_httpStatus :: Lens.Lens' ListDomainNamesResponse Prelude.Int listDomainNamesResponse_httpStatus = Lens.lens (\ListDomainNamesResponse' {httpStatus} -> httpStatus) (\s@ListDomainNamesResponse' {} a -> s {httpStatus = a} :: ListDomainNamesResponse) instance Prelude.NFData ListDomainNamesResponse where rnf ListDomainNamesResponse' {..} = Prelude.rnf domainNameConfigs `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus