{-# 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.ImageBuilder.ListContainerRecipes -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns a list of container recipes. module Amazonka.ImageBuilder.ListContainerRecipes ( -- * Creating a Request ListContainerRecipes (..), newListContainerRecipes, -- * Request Lenses listContainerRecipes_filters, listContainerRecipes_maxResults, listContainerRecipes_nextToken, listContainerRecipes_owner, -- * Destructuring the Response ListContainerRecipesResponse (..), newListContainerRecipesResponse, -- * Response Lenses listContainerRecipesResponse_containerRecipeSummaryList, listContainerRecipesResponse_nextToken, listContainerRecipesResponse_requestId, listContainerRecipesResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.ImageBuilder.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListContainerRecipes' smart constructor. data ListContainerRecipes = ListContainerRecipes' { -- | Use the following filters to streamline results: -- -- - @containerType@ -- -- - @name@ -- -- - @parentImage@ -- -- - @platform@ filters :: Prelude.Maybe (Prelude.NonEmpty Filter), -- | The maximum number of results to return in the list. maxResults :: Prelude.Maybe Prelude.Natural, -- | Provides a token for pagination, which determines where to begin the -- next set of results when the current set reaches the maximum for one -- request. nextToken :: Prelude.Maybe Prelude.Text, -- | Returns container recipes belonging to the specified owner, that have -- been shared with you. You can omit this field to return container -- recipes belonging to your account. owner :: Prelude.Maybe Ownership } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListContainerRecipes' 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: -- -- 'filters', 'listContainerRecipes_filters' - Use the following filters to streamline results: -- -- - @containerType@ -- -- - @name@ -- -- - @parentImage@ -- -- - @platform@ -- -- 'maxResults', 'listContainerRecipes_maxResults' - The maximum number of results to return in the list. -- -- 'nextToken', 'listContainerRecipes_nextToken' - Provides a token for pagination, which determines where to begin the -- next set of results when the current set reaches the maximum for one -- request. -- -- 'owner', 'listContainerRecipes_owner' - Returns container recipes belonging to the specified owner, that have -- been shared with you. You can omit this field to return container -- recipes belonging to your account. newListContainerRecipes :: ListContainerRecipes newListContainerRecipes = ListContainerRecipes' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, owner = Prelude.Nothing } -- | Use the following filters to streamline results: -- -- - @containerType@ -- -- - @name@ -- -- - @parentImage@ -- -- - @platform@ listContainerRecipes_filters :: Lens.Lens' ListContainerRecipes (Prelude.Maybe (Prelude.NonEmpty Filter)) listContainerRecipes_filters = Lens.lens (\ListContainerRecipes' {filters} -> filters) (\s@ListContainerRecipes' {} a -> s {filters = a} :: ListContainerRecipes) Prelude.. Lens.mapping Lens.coerced -- | The maximum number of results to return in the list. listContainerRecipes_maxResults :: Lens.Lens' ListContainerRecipes (Prelude.Maybe Prelude.Natural) listContainerRecipes_maxResults = Lens.lens (\ListContainerRecipes' {maxResults} -> maxResults) (\s@ListContainerRecipes' {} a -> s {maxResults = a} :: ListContainerRecipes) -- | Provides a token for pagination, which determines where to begin the -- next set of results when the current set reaches the maximum for one -- request. listContainerRecipes_nextToken :: Lens.Lens' ListContainerRecipes (Prelude.Maybe Prelude.Text) listContainerRecipes_nextToken = Lens.lens (\ListContainerRecipes' {nextToken} -> nextToken) (\s@ListContainerRecipes' {} a -> s {nextToken = a} :: ListContainerRecipes) -- | Returns container recipes belonging to the specified owner, that have -- been shared with you. You can omit this field to return container -- recipes belonging to your account. listContainerRecipes_owner :: Lens.Lens' ListContainerRecipes (Prelude.Maybe Ownership) listContainerRecipes_owner = Lens.lens (\ListContainerRecipes' {owner} -> owner) (\s@ListContainerRecipes' {} a -> s {owner = a} :: ListContainerRecipes) instance Core.AWSRequest ListContainerRecipes where type AWSResponse ListContainerRecipes = ListContainerRecipesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListContainerRecipesResponse' Prelude.<$> ( x Data..?> "containerRecipeSummaryList" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (x Data..?> "requestId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListContainerRecipes where hashWithSalt _salt ListContainerRecipes' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` owner instance Prelude.NFData ListContainerRecipes where rnf ListContainerRecipes' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf owner instance Data.ToHeaders ListContainerRecipes where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListContainerRecipes where toJSON ListContainerRecipes' {..} = Data.object ( Prelude.catMaybes [ ("filters" Data..=) Prelude.<$> filters, ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken, ("owner" Data..=) Prelude.<$> owner ] ) instance Data.ToPath ListContainerRecipes where toPath = Prelude.const "/ListContainerRecipes" instance Data.ToQuery ListContainerRecipes where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListContainerRecipesResponse' smart constructor. data ListContainerRecipesResponse = ListContainerRecipesResponse' { -- | The list of container recipes returned for the request. containerRecipeSummaryList :: Prelude.Maybe [ContainerRecipeSummary], -- | The next token field is used for paginated responses. When this is not -- empty, there are additional container recipes that the service has not -- included in this response. Use this token with the next request to -- retrieve additional list items. nextToken :: Prelude.Maybe Prelude.Text, -- | The request ID that uniquely identifies this request. requestId :: 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 'ListContainerRecipesResponse' 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: -- -- 'containerRecipeSummaryList', 'listContainerRecipesResponse_containerRecipeSummaryList' - The list of container recipes returned for the request. -- -- 'nextToken', 'listContainerRecipesResponse_nextToken' - The next token field is used for paginated responses. When this is not -- empty, there are additional container recipes that the service has not -- included in this response. Use this token with the next request to -- retrieve additional list items. -- -- 'requestId', 'listContainerRecipesResponse_requestId' - The request ID that uniquely identifies this request. -- -- 'httpStatus', 'listContainerRecipesResponse_httpStatus' - The response's http status code. newListContainerRecipesResponse :: -- | 'httpStatus' Prelude.Int -> ListContainerRecipesResponse newListContainerRecipesResponse pHttpStatus_ = ListContainerRecipesResponse' { containerRecipeSummaryList = Prelude.Nothing, nextToken = Prelude.Nothing, requestId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of container recipes returned for the request. listContainerRecipesResponse_containerRecipeSummaryList :: Lens.Lens' ListContainerRecipesResponse (Prelude.Maybe [ContainerRecipeSummary]) listContainerRecipesResponse_containerRecipeSummaryList = Lens.lens (\ListContainerRecipesResponse' {containerRecipeSummaryList} -> containerRecipeSummaryList) (\s@ListContainerRecipesResponse' {} a -> s {containerRecipeSummaryList = a} :: ListContainerRecipesResponse) Prelude.. Lens.mapping Lens.coerced -- | The next token field is used for paginated responses. When this is not -- empty, there are additional container recipes that the service has not -- included in this response. Use this token with the next request to -- retrieve additional list items. listContainerRecipesResponse_nextToken :: Lens.Lens' ListContainerRecipesResponse (Prelude.Maybe Prelude.Text) listContainerRecipesResponse_nextToken = Lens.lens (\ListContainerRecipesResponse' {nextToken} -> nextToken) (\s@ListContainerRecipesResponse' {} a -> s {nextToken = a} :: ListContainerRecipesResponse) -- | The request ID that uniquely identifies this request. listContainerRecipesResponse_requestId :: Lens.Lens' ListContainerRecipesResponse (Prelude.Maybe Prelude.Text) listContainerRecipesResponse_requestId = Lens.lens (\ListContainerRecipesResponse' {requestId} -> requestId) (\s@ListContainerRecipesResponse' {} a -> s {requestId = a} :: ListContainerRecipesResponse) -- | The response's http status code. listContainerRecipesResponse_httpStatus :: Lens.Lens' ListContainerRecipesResponse Prelude.Int listContainerRecipesResponse_httpStatus = Lens.lens (\ListContainerRecipesResponse' {httpStatus} -> httpStatus) (\s@ListContainerRecipesResponse' {} a -> s {httpStatus = a} :: ListContainerRecipesResponse) instance Prelude.NFData ListContainerRecipesResponse where rnf ListContainerRecipesResponse' {..} = Prelude.rnf containerRecipeSummaryList `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf requestId `Prelude.seq` Prelude.rnf httpStatus