{-# 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.ListImagePipelines -- 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 image pipelines. module Amazonka.ImageBuilder.ListImagePipelines ( -- * Creating a Request ListImagePipelines (..), newListImagePipelines, -- * Request Lenses listImagePipelines_filters, listImagePipelines_maxResults, listImagePipelines_nextToken, -- * Destructuring the Response ListImagePipelinesResponse (..), newListImagePipelinesResponse, -- * Response Lenses listImagePipelinesResponse_imagePipelineList, listImagePipelinesResponse_nextToken, listImagePipelinesResponse_requestId, listImagePipelinesResponse_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:/ 'newListImagePipelines' smart constructor. data ListImagePipelines = ListImagePipelines' { -- | Use the following filters to streamline results: -- -- - @description@ -- -- - @distributionConfigurationArn@ -- -- - @imageRecipeArn@ -- -- - @infrastructureConfigurationArn@ -- -- - @name@ -- -- - @status@ filters :: Prelude.Maybe (Prelude.NonEmpty Filter), -- | The maximum items to return in a request. maxResults :: Prelude.Maybe Prelude.Natural, -- | A token to specify where to start paginating. This is the NextToken from -- a previously truncated response. nextToken :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListImagePipelines' 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', 'listImagePipelines_filters' - Use the following filters to streamline results: -- -- - @description@ -- -- - @distributionConfigurationArn@ -- -- - @imageRecipeArn@ -- -- - @infrastructureConfigurationArn@ -- -- - @name@ -- -- - @status@ -- -- 'maxResults', 'listImagePipelines_maxResults' - The maximum items to return in a request. -- -- 'nextToken', 'listImagePipelines_nextToken' - A token to specify where to start paginating. This is the NextToken from -- a previously truncated response. newListImagePipelines :: ListImagePipelines newListImagePipelines = ListImagePipelines' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing } -- | Use the following filters to streamline results: -- -- - @description@ -- -- - @distributionConfigurationArn@ -- -- - @imageRecipeArn@ -- -- - @infrastructureConfigurationArn@ -- -- - @name@ -- -- - @status@ listImagePipelines_filters :: Lens.Lens' ListImagePipelines (Prelude.Maybe (Prelude.NonEmpty Filter)) listImagePipelines_filters = Lens.lens (\ListImagePipelines' {filters} -> filters) (\s@ListImagePipelines' {} a -> s {filters = a} :: ListImagePipelines) Prelude.. Lens.mapping Lens.coerced -- | The maximum items to return in a request. listImagePipelines_maxResults :: Lens.Lens' ListImagePipelines (Prelude.Maybe Prelude.Natural) listImagePipelines_maxResults = Lens.lens (\ListImagePipelines' {maxResults} -> maxResults) (\s@ListImagePipelines' {} a -> s {maxResults = a} :: ListImagePipelines) -- | A token to specify where to start paginating. This is the NextToken from -- a previously truncated response. listImagePipelines_nextToken :: Lens.Lens' ListImagePipelines (Prelude.Maybe Prelude.Text) listImagePipelines_nextToken = Lens.lens (\ListImagePipelines' {nextToken} -> nextToken) (\s@ListImagePipelines' {} a -> s {nextToken = a} :: ListImagePipelines) instance Core.AWSRequest ListImagePipelines where type AWSResponse ListImagePipelines = ListImagePipelinesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListImagePipelinesResponse' Prelude.<$> ( x Data..?> "imagePipelineList" Core..!@ Prelude.mempty ) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (x Data..?> "requestId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListImagePipelines where hashWithSalt _salt ListImagePipelines' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken instance Prelude.NFData ListImagePipelines where rnf ListImagePipelines' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken instance Data.ToHeaders ListImagePipelines where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListImagePipelines where toJSON ListImagePipelines' {..} = Data.object ( Prelude.catMaybes [ ("filters" Data..=) Prelude.<$> filters, ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken ] ) instance Data.ToPath ListImagePipelines where toPath = Prelude.const "/ListImagePipelines" instance Data.ToQuery ListImagePipelines where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListImagePipelinesResponse' smart constructor. data ListImagePipelinesResponse = ListImagePipelinesResponse' { -- | The list of image pipelines. imagePipelineList :: Prelude.Maybe [ImagePipeline], -- | The next token used for paginated responses. When this is not empty, -- there are additional elements that the service has not included in this -- request. Use this token with the next request to retrieve additional -- objects. 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 'ListImagePipelinesResponse' 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: -- -- 'imagePipelineList', 'listImagePipelinesResponse_imagePipelineList' - The list of image pipelines. -- -- 'nextToken', 'listImagePipelinesResponse_nextToken' - The next token used for paginated responses. When this is not empty, -- there are additional elements that the service has not included in this -- request. Use this token with the next request to retrieve additional -- objects. -- -- 'requestId', 'listImagePipelinesResponse_requestId' - The request ID that uniquely identifies this request. -- -- 'httpStatus', 'listImagePipelinesResponse_httpStatus' - The response's http status code. newListImagePipelinesResponse :: -- | 'httpStatus' Prelude.Int -> ListImagePipelinesResponse newListImagePipelinesResponse pHttpStatus_ = ListImagePipelinesResponse' { imagePipelineList = Prelude.Nothing, nextToken = Prelude.Nothing, requestId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of image pipelines. listImagePipelinesResponse_imagePipelineList :: Lens.Lens' ListImagePipelinesResponse (Prelude.Maybe [ImagePipeline]) listImagePipelinesResponse_imagePipelineList = Lens.lens (\ListImagePipelinesResponse' {imagePipelineList} -> imagePipelineList) (\s@ListImagePipelinesResponse' {} a -> s {imagePipelineList = a} :: ListImagePipelinesResponse) Prelude.. Lens.mapping Lens.coerced -- | The next token used for paginated responses. When this is not empty, -- there are additional elements that the service has not included in this -- request. Use this token with the next request to retrieve additional -- objects. listImagePipelinesResponse_nextToken :: Lens.Lens' ListImagePipelinesResponse (Prelude.Maybe Prelude.Text) listImagePipelinesResponse_nextToken = Lens.lens (\ListImagePipelinesResponse' {nextToken} -> nextToken) (\s@ListImagePipelinesResponse' {} a -> s {nextToken = a} :: ListImagePipelinesResponse) -- | The request ID that uniquely identifies this request. listImagePipelinesResponse_requestId :: Lens.Lens' ListImagePipelinesResponse (Prelude.Maybe Prelude.Text) listImagePipelinesResponse_requestId = Lens.lens (\ListImagePipelinesResponse' {requestId} -> requestId) (\s@ListImagePipelinesResponse' {} a -> s {requestId = a} :: ListImagePipelinesResponse) -- | The response's http status code. listImagePipelinesResponse_httpStatus :: Lens.Lens' ListImagePipelinesResponse Prelude.Int listImagePipelinesResponse_httpStatus = Lens.lens (\ListImagePipelinesResponse' {httpStatus} -> httpStatus) (\s@ListImagePipelinesResponse' {} a -> s {httpStatus = a} :: ListImagePipelinesResponse) instance Prelude.NFData ListImagePipelinesResponse where rnf ListImagePipelinesResponse' {..} = Prelude.rnf imagePipelineList `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf requestId `Prelude.seq` Prelude.rnf httpStatus