{-# 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.LexV2Models.ListBuiltInIntents -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Gets a list of built-in intents provided by Amazon Lex that you can use -- in your bot. -- -- To use a built-in intent as a the base for your own intent, include the -- built-in intent signature in the @parentIntentSignature@ parameter when -- you call the @CreateIntent@ operation. For more information, see -- . module Amazonka.LexV2Models.ListBuiltInIntents ( -- * Creating a Request ListBuiltInIntents (..), newListBuiltInIntents, -- * Request Lenses listBuiltInIntents_maxResults, listBuiltInIntents_nextToken, listBuiltInIntents_sortBy, listBuiltInIntents_localeId, -- * Destructuring the Response ListBuiltInIntentsResponse (..), newListBuiltInIntentsResponse, -- * Response Lenses listBuiltInIntentsResponse_builtInIntentSummaries, listBuiltInIntentsResponse_localeId, listBuiltInIntentsResponse_nextToken, listBuiltInIntentsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.LexV2Models.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListBuiltInIntents' smart constructor. data ListBuiltInIntents = ListBuiltInIntents' { -- | The maximum number of built-in intents to return in each page of -- results. If there are fewer results than the max page size, only the -- actual number of results are returned. maxResults :: Prelude.Maybe Prelude.Natural, -- | If the response from the @ListBuiltInIntents@ operation contains more -- results than specified in the @maxResults@ parameter, a token is -- returned in the response. Use that token in the @nextToken@ parameter to -- return the next page of results. nextToken :: Prelude.Maybe Prelude.Text, -- | Specifies sorting parameters for the list of built-in intents. You can -- specify that the list be sorted by the built-in intent signature in -- either ascending or descending order. sortBy :: Prelude.Maybe BuiltInIntentSortBy, -- | The identifier of the language and locale of the intents to list. The -- string must match one of the supported locales. For more information, -- see -- . localeId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListBuiltInIntents' 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', 'listBuiltInIntents_maxResults' - The maximum number of built-in intents to return in each page of -- results. If there are fewer results than the max page size, only the -- actual number of results are returned. -- -- 'nextToken', 'listBuiltInIntents_nextToken' - If the response from the @ListBuiltInIntents@ operation contains more -- results than specified in the @maxResults@ parameter, a token is -- returned in the response. Use that token in the @nextToken@ parameter to -- return the next page of results. -- -- 'sortBy', 'listBuiltInIntents_sortBy' - Specifies sorting parameters for the list of built-in intents. You can -- specify that the list be sorted by the built-in intent signature in -- either ascending or descending order. -- -- 'localeId', 'listBuiltInIntents_localeId' - The identifier of the language and locale of the intents to list. The -- string must match one of the supported locales. For more information, -- see -- . newListBuiltInIntents :: -- | 'localeId' Prelude.Text -> ListBuiltInIntents newListBuiltInIntents pLocaleId_ = ListBuiltInIntents' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, sortBy = Prelude.Nothing, localeId = pLocaleId_ } -- | The maximum number of built-in intents to return in each page of -- results. If there are fewer results than the max page size, only the -- actual number of results are returned. listBuiltInIntents_maxResults :: Lens.Lens' ListBuiltInIntents (Prelude.Maybe Prelude.Natural) listBuiltInIntents_maxResults = Lens.lens (\ListBuiltInIntents' {maxResults} -> maxResults) (\s@ListBuiltInIntents' {} a -> s {maxResults = a} :: ListBuiltInIntents) -- | If the response from the @ListBuiltInIntents@ operation contains more -- results than specified in the @maxResults@ parameter, a token is -- returned in the response. Use that token in the @nextToken@ parameter to -- return the next page of results. listBuiltInIntents_nextToken :: Lens.Lens' ListBuiltInIntents (Prelude.Maybe Prelude.Text) listBuiltInIntents_nextToken = Lens.lens (\ListBuiltInIntents' {nextToken} -> nextToken) (\s@ListBuiltInIntents' {} a -> s {nextToken = a} :: ListBuiltInIntents) -- | Specifies sorting parameters for the list of built-in intents. You can -- specify that the list be sorted by the built-in intent signature in -- either ascending or descending order. listBuiltInIntents_sortBy :: Lens.Lens' ListBuiltInIntents (Prelude.Maybe BuiltInIntentSortBy) listBuiltInIntents_sortBy = Lens.lens (\ListBuiltInIntents' {sortBy} -> sortBy) (\s@ListBuiltInIntents' {} a -> s {sortBy = a} :: ListBuiltInIntents) -- | The identifier of the language and locale of the intents to list. The -- string must match one of the supported locales. For more information, -- see -- . listBuiltInIntents_localeId :: Lens.Lens' ListBuiltInIntents Prelude.Text listBuiltInIntents_localeId = Lens.lens (\ListBuiltInIntents' {localeId} -> localeId) (\s@ListBuiltInIntents' {} a -> s {localeId = a} :: ListBuiltInIntents) instance Core.AWSRequest ListBuiltInIntents where type AWSResponse ListBuiltInIntents = ListBuiltInIntentsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListBuiltInIntentsResponse' Prelude.<$> ( x Data..?> "builtInIntentSummaries" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "localeId") Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListBuiltInIntents where hashWithSalt _salt ListBuiltInIntents' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` sortBy `Prelude.hashWithSalt` localeId instance Prelude.NFData ListBuiltInIntents where rnf ListBuiltInIntents' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf sortBy `Prelude.seq` Prelude.rnf localeId instance Data.ToHeaders ListBuiltInIntents where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListBuiltInIntents where toJSON ListBuiltInIntents' {..} = Data.object ( Prelude.catMaybes [ ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken, ("sortBy" Data..=) Prelude.<$> sortBy ] ) instance Data.ToPath ListBuiltInIntents where toPath ListBuiltInIntents' {..} = Prelude.mconcat [ "/builtins/locales/", Data.toBS localeId, "/intents/" ] instance Data.ToQuery ListBuiltInIntents where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListBuiltInIntentsResponse' smart constructor. data ListBuiltInIntentsResponse = ListBuiltInIntentsResponse' { -- | Summary information for the built-in intents that meet the filter -- criteria specified in the request. The length of the list is specified -- in the @maxResults@ parameter of the request. If there are more intents -- available, the @nextToken@ field contains a token to get the next page -- of results. builtInIntentSummaries :: Prelude.Maybe [BuiltInIntentSummary], -- | The language and locale of the intents in the list. localeId :: Prelude.Maybe Prelude.Text, -- | A token that indicates whether there are more results to return in a -- response to the @ListBuiltInIntents@ operation. If the @nextToken@ field -- is present, you send the contents as the @nextToken@ parameter of a -- @ListBotAliases@ operation request to get the next page 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 'ListBuiltInIntentsResponse' 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: -- -- 'builtInIntentSummaries', 'listBuiltInIntentsResponse_builtInIntentSummaries' - Summary information for the built-in intents that meet the filter -- criteria specified in the request. The length of the list is specified -- in the @maxResults@ parameter of the request. If there are more intents -- available, the @nextToken@ field contains a token to get the next page -- of results. -- -- 'localeId', 'listBuiltInIntentsResponse_localeId' - The language and locale of the intents in the list. -- -- 'nextToken', 'listBuiltInIntentsResponse_nextToken' - A token that indicates whether there are more results to return in a -- response to the @ListBuiltInIntents@ operation. If the @nextToken@ field -- is present, you send the contents as the @nextToken@ parameter of a -- @ListBotAliases@ operation request to get the next page of results. -- -- 'httpStatus', 'listBuiltInIntentsResponse_httpStatus' - The response's http status code. newListBuiltInIntentsResponse :: -- | 'httpStatus' Prelude.Int -> ListBuiltInIntentsResponse newListBuiltInIntentsResponse pHttpStatus_ = ListBuiltInIntentsResponse' { builtInIntentSummaries = Prelude.Nothing, localeId = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Summary information for the built-in intents that meet the filter -- criteria specified in the request. The length of the list is specified -- in the @maxResults@ parameter of the request. If there are more intents -- available, the @nextToken@ field contains a token to get the next page -- of results. listBuiltInIntentsResponse_builtInIntentSummaries :: Lens.Lens' ListBuiltInIntentsResponse (Prelude.Maybe [BuiltInIntentSummary]) listBuiltInIntentsResponse_builtInIntentSummaries = Lens.lens (\ListBuiltInIntentsResponse' {builtInIntentSummaries} -> builtInIntentSummaries) (\s@ListBuiltInIntentsResponse' {} a -> s {builtInIntentSummaries = a} :: ListBuiltInIntentsResponse) Prelude.. Lens.mapping Lens.coerced -- | The language and locale of the intents in the list. listBuiltInIntentsResponse_localeId :: Lens.Lens' ListBuiltInIntentsResponse (Prelude.Maybe Prelude.Text) listBuiltInIntentsResponse_localeId = Lens.lens (\ListBuiltInIntentsResponse' {localeId} -> localeId) (\s@ListBuiltInIntentsResponse' {} a -> s {localeId = a} :: ListBuiltInIntentsResponse) -- | A token that indicates whether there are more results to return in a -- response to the @ListBuiltInIntents@ operation. If the @nextToken@ field -- is present, you send the contents as the @nextToken@ parameter of a -- @ListBotAliases@ operation request to get the next page of results. listBuiltInIntentsResponse_nextToken :: Lens.Lens' ListBuiltInIntentsResponse (Prelude.Maybe Prelude.Text) listBuiltInIntentsResponse_nextToken = Lens.lens (\ListBuiltInIntentsResponse' {nextToken} -> nextToken) (\s@ListBuiltInIntentsResponse' {} a -> s {nextToken = a} :: ListBuiltInIntentsResponse) -- | The response's http status code. listBuiltInIntentsResponse_httpStatus :: Lens.Lens' ListBuiltInIntentsResponse Prelude.Int listBuiltInIntentsResponse_httpStatus = Lens.lens (\ListBuiltInIntentsResponse' {httpStatus} -> httpStatus) (\s@ListBuiltInIntentsResponse' {} a -> s {httpStatus = a} :: ListBuiltInIntentsResponse) instance Prelude.NFData ListBuiltInIntentsResponse where rnf ListBuiltInIntentsResponse' {..} = Prelude.rnf builtInIntentSummaries `Prelude.seq` Prelude.rnf localeId `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus