{-# 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.MediaConvert.ListPresets -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retrieve a JSON array of up to twenty of your presets. This will return -- the presets themselves, not just a list of them. To retrieve the next -- twenty presets, use the nextToken string returned with the array. -- -- This operation returns paginated results. module Amazonka.MediaConvert.ListPresets ( -- * Creating a Request ListPresets (..), newListPresets, -- * Request Lenses listPresets_category, listPresets_listBy, listPresets_maxResults, listPresets_nextToken, listPresets_order, -- * Destructuring the Response ListPresetsResponse (..), newListPresetsResponse, -- * Response Lenses listPresetsResponse_nextToken, listPresetsResponse_presets, listPresetsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.MediaConvert.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListPresets' smart constructor. data ListPresets = ListPresets' { -- | Optionally, specify a preset category to limit responses to only presets -- from that category. category :: Prelude.Maybe Prelude.Text, -- | Optional. When you request a list of presets, you can choose to list -- them alphabetically by NAME or chronologically by CREATION_DATE. If you -- don\'t specify, the service will list them by name. listBy :: Prelude.Maybe PresetListBy, -- | Optional. Number of presets, up to twenty, that will be returned at one -- time maxResults :: Prelude.Maybe Prelude.Natural, -- | Use this string, provided with the response to a previous request, to -- request the next batch of presets. nextToken :: Prelude.Maybe Prelude.Text, -- | Optional. When you request lists of resources, you can specify whether -- they are sorted in ASCENDING or DESCENDING order. Default varies by -- resource. order :: Prelude.Maybe Order } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListPresets' 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: -- -- 'category', 'listPresets_category' - Optionally, specify a preset category to limit responses to only presets -- from that category. -- -- 'listBy', 'listPresets_listBy' - Optional. When you request a list of presets, you can choose to list -- them alphabetically by NAME or chronologically by CREATION_DATE. If you -- don\'t specify, the service will list them by name. -- -- 'maxResults', 'listPresets_maxResults' - Optional. Number of presets, up to twenty, that will be returned at one -- time -- -- 'nextToken', 'listPresets_nextToken' - Use this string, provided with the response to a previous request, to -- request the next batch of presets. -- -- 'order', 'listPresets_order' - Optional. When you request lists of resources, you can specify whether -- they are sorted in ASCENDING or DESCENDING order. Default varies by -- resource. newListPresets :: ListPresets newListPresets = ListPresets' { category = Prelude.Nothing, listBy = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, order = Prelude.Nothing } -- | Optionally, specify a preset category to limit responses to only presets -- from that category. listPresets_category :: Lens.Lens' ListPresets (Prelude.Maybe Prelude.Text) listPresets_category = Lens.lens (\ListPresets' {category} -> category) (\s@ListPresets' {} a -> s {category = a} :: ListPresets) -- | Optional. When you request a list of presets, you can choose to list -- them alphabetically by NAME or chronologically by CREATION_DATE. If you -- don\'t specify, the service will list them by name. listPresets_listBy :: Lens.Lens' ListPresets (Prelude.Maybe PresetListBy) listPresets_listBy = Lens.lens (\ListPresets' {listBy} -> listBy) (\s@ListPresets' {} a -> s {listBy = a} :: ListPresets) -- | Optional. Number of presets, up to twenty, that will be returned at one -- time listPresets_maxResults :: Lens.Lens' ListPresets (Prelude.Maybe Prelude.Natural) listPresets_maxResults = Lens.lens (\ListPresets' {maxResults} -> maxResults) (\s@ListPresets' {} a -> s {maxResults = a} :: ListPresets) -- | Use this string, provided with the response to a previous request, to -- request the next batch of presets. listPresets_nextToken :: Lens.Lens' ListPresets (Prelude.Maybe Prelude.Text) listPresets_nextToken = Lens.lens (\ListPresets' {nextToken} -> nextToken) (\s@ListPresets' {} a -> s {nextToken = a} :: ListPresets) -- | Optional. When you request lists of resources, you can specify whether -- they are sorted in ASCENDING or DESCENDING order. Default varies by -- resource. listPresets_order :: Lens.Lens' ListPresets (Prelude.Maybe Order) listPresets_order = Lens.lens (\ListPresets' {order} -> order) (\s@ListPresets' {} a -> s {order = a} :: ListPresets) instance Core.AWSPager ListPresets where page rq rs | Core.stop ( rs Lens.^? listPresetsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listPresetsResponse_presets Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listPresets_nextToken Lens..~ rs Lens.^? listPresetsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListPresets where type AWSResponse ListPresets = ListPresetsResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListPresetsResponse' Prelude.<$> (x Data..?> "nextToken") Prelude.<*> (x Data..?> "presets" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListPresets where hashWithSalt _salt ListPresets' {..} = _salt `Prelude.hashWithSalt` category `Prelude.hashWithSalt` listBy `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` order instance Prelude.NFData ListPresets where rnf ListPresets' {..} = Prelude.rnf category `Prelude.seq` Prelude.rnf listBy `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf order instance Data.ToHeaders ListPresets where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath ListPresets where toPath = Prelude.const "/2017-08-29/presets" instance Data.ToQuery ListPresets where toQuery ListPresets' {..} = Prelude.mconcat [ "category" Data.=: category, "listBy" Data.=: listBy, "maxResults" Data.=: maxResults, "nextToken" Data.=: nextToken, "order" Data.=: order ] -- | /See:/ 'newListPresetsResponse' smart constructor. data ListPresetsResponse = ListPresetsResponse' { -- | Use this string to request the next batch of presets. nextToken :: Prelude.Maybe Prelude.Text, -- | List of presets presets :: Prelude.Maybe [Preset], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListPresetsResponse' 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', 'listPresetsResponse_nextToken' - Use this string to request the next batch of presets. -- -- 'presets', 'listPresetsResponse_presets' - List of presets -- -- 'httpStatus', 'listPresetsResponse_httpStatus' - The response's http status code. newListPresetsResponse :: -- | 'httpStatus' Prelude.Int -> ListPresetsResponse newListPresetsResponse pHttpStatus_ = ListPresetsResponse' { nextToken = Prelude.Nothing, presets = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Use this string to request the next batch of presets. listPresetsResponse_nextToken :: Lens.Lens' ListPresetsResponse (Prelude.Maybe Prelude.Text) listPresetsResponse_nextToken = Lens.lens (\ListPresetsResponse' {nextToken} -> nextToken) (\s@ListPresetsResponse' {} a -> s {nextToken = a} :: ListPresetsResponse) -- | List of presets listPresetsResponse_presets :: Lens.Lens' ListPresetsResponse (Prelude.Maybe [Preset]) listPresetsResponse_presets = Lens.lens (\ListPresetsResponse' {presets} -> presets) (\s@ListPresetsResponse' {} a -> s {presets = a} :: ListPresetsResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. listPresetsResponse_httpStatus :: Lens.Lens' ListPresetsResponse Prelude.Int listPresetsResponse_httpStatus = Lens.lens (\ListPresetsResponse' {httpStatus} -> httpStatus) (\s@ListPresetsResponse' {} a -> s {httpStatus = a} :: ListPresetsResponse) instance Prelude.NFData ListPresetsResponse where rnf ListPresetsResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf presets `Prelude.seq` Prelude.rnf httpStatus