{-# 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.ECR.ListImages -- 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 all the image IDs for the specified repository. -- -- You can filter images based on whether or not they are tagged by using -- the @tagStatus@ filter and specifying either @TAGGED@, @UNTAGGED@ or -- @ANY@. For example, you can filter your results to return only -- @UNTAGGED@ images and then pipe that result to a BatchDeleteImage -- operation to delete them. Or, you can filter your results to return only -- @TAGGED@ images to list all of the tags in your repository. -- -- This operation returns paginated results. module Amazonka.ECR.ListImages ( -- * Creating a Request ListImages (..), newListImages, -- * Request Lenses listImages_filter, listImages_maxResults, listImages_nextToken, listImages_registryId, listImages_repositoryName, -- * Destructuring the Response ListImagesResponse (..), newListImagesResponse, -- * Response Lenses listImagesResponse_imageIds, listImagesResponse_nextToken, listImagesResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.ECR.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newListImages' smart constructor. data ListImages = ListImages' { -- | The filter key and value with which to filter your @ListImages@ results. filter' :: Prelude.Maybe ListImagesFilter, -- | The maximum number of image results returned by @ListImages@ in -- paginated output. When this parameter is used, @ListImages@ only returns -- @maxResults@ results in a single page along with a @nextToken@ response -- element. The remaining results of the initial request can be seen by -- sending another @ListImages@ request with the returned @nextToken@ -- value. This value can be between 1 and 1000. If this parameter is not -- used, then @ListImages@ returns up to 100 results and a @nextToken@ -- value, if applicable. maxResults :: Prelude.Maybe Prelude.Natural, -- | The @nextToken@ value returned from a previous paginated @ListImages@ -- request where @maxResults@ was used and the results exceeded the value -- of that parameter. Pagination continues from the end of the previous -- results that returned the @nextToken@ value. This value is @null@ when -- there are no more results to return. -- -- This token should be treated as an opaque identifier that is only used -- to retrieve the next items in a list and not for other programmatic -- purposes. nextToken :: Prelude.Maybe Prelude.Text, -- | The Amazon Web Services account ID associated with the registry that -- contains the repository in which to list images. If you do not specify a -- registry, the default registry is assumed. registryId :: Prelude.Maybe Prelude.Text, -- | The repository with image IDs to be listed. repositoryName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListImages' 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: -- -- 'filter'', 'listImages_filter' - The filter key and value with which to filter your @ListImages@ results. -- -- 'maxResults', 'listImages_maxResults' - The maximum number of image results returned by @ListImages@ in -- paginated output. When this parameter is used, @ListImages@ only returns -- @maxResults@ results in a single page along with a @nextToken@ response -- element. The remaining results of the initial request can be seen by -- sending another @ListImages@ request with the returned @nextToken@ -- value. This value can be between 1 and 1000. If this parameter is not -- used, then @ListImages@ returns up to 100 results and a @nextToken@ -- value, if applicable. -- -- 'nextToken', 'listImages_nextToken' - The @nextToken@ value returned from a previous paginated @ListImages@ -- request where @maxResults@ was used and the results exceeded the value -- of that parameter. Pagination continues from the end of the previous -- results that returned the @nextToken@ value. This value is @null@ when -- there are no more results to return. -- -- This token should be treated as an opaque identifier that is only used -- to retrieve the next items in a list and not for other programmatic -- purposes. -- -- 'registryId', 'listImages_registryId' - The Amazon Web Services account ID associated with the registry that -- contains the repository in which to list images. If you do not specify a -- registry, the default registry is assumed. -- -- 'repositoryName', 'listImages_repositoryName' - The repository with image IDs to be listed. newListImages :: -- | 'repositoryName' Prelude.Text -> ListImages newListImages pRepositoryName_ = ListImages' { filter' = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, registryId = Prelude.Nothing, repositoryName = pRepositoryName_ } -- | The filter key and value with which to filter your @ListImages@ results. listImages_filter :: Lens.Lens' ListImages (Prelude.Maybe ListImagesFilter) listImages_filter = Lens.lens (\ListImages' {filter'} -> filter') (\s@ListImages' {} a -> s {filter' = a} :: ListImages) -- | The maximum number of image results returned by @ListImages@ in -- paginated output. When this parameter is used, @ListImages@ only returns -- @maxResults@ results in a single page along with a @nextToken@ response -- element. The remaining results of the initial request can be seen by -- sending another @ListImages@ request with the returned @nextToken@ -- value. This value can be between 1 and 1000. If this parameter is not -- used, then @ListImages@ returns up to 100 results and a @nextToken@ -- value, if applicable. listImages_maxResults :: Lens.Lens' ListImages (Prelude.Maybe Prelude.Natural) listImages_maxResults = Lens.lens (\ListImages' {maxResults} -> maxResults) (\s@ListImages' {} a -> s {maxResults = a} :: ListImages) -- | The @nextToken@ value returned from a previous paginated @ListImages@ -- request where @maxResults@ was used and the results exceeded the value -- of that parameter. Pagination continues from the end of the previous -- results that returned the @nextToken@ value. This value is @null@ when -- there are no more results to return. -- -- This token should be treated as an opaque identifier that is only used -- to retrieve the next items in a list and not for other programmatic -- purposes. listImages_nextToken :: Lens.Lens' ListImages (Prelude.Maybe Prelude.Text) listImages_nextToken = Lens.lens (\ListImages' {nextToken} -> nextToken) (\s@ListImages' {} a -> s {nextToken = a} :: ListImages) -- | The Amazon Web Services account ID associated with the registry that -- contains the repository in which to list images. If you do not specify a -- registry, the default registry is assumed. listImages_registryId :: Lens.Lens' ListImages (Prelude.Maybe Prelude.Text) listImages_registryId = Lens.lens (\ListImages' {registryId} -> registryId) (\s@ListImages' {} a -> s {registryId = a} :: ListImages) -- | The repository with image IDs to be listed. listImages_repositoryName :: Lens.Lens' ListImages Prelude.Text listImages_repositoryName = Lens.lens (\ListImages' {repositoryName} -> repositoryName) (\s@ListImages' {} a -> s {repositoryName = a} :: ListImages) instance Core.AWSPager ListImages where page rq rs | Core.stop ( rs Lens.^? listImagesResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listImagesResponse_imageIds Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listImages_nextToken Lens..~ rs Lens.^? listImagesResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListImages where type AWSResponse ListImages = ListImagesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListImagesResponse' Prelude.<$> (x Data..?> "imageIds" Core..!@ Prelude.mempty) Prelude.<*> (x Data..?> "nextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListImages where hashWithSalt _salt ListImages' {..} = _salt `Prelude.hashWithSalt` filter' `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` registryId `Prelude.hashWithSalt` repositoryName instance Prelude.NFData ListImages where rnf ListImages' {..} = Prelude.rnf filter' `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf registryId `Prelude.seq` Prelude.rnf repositoryName instance Data.ToHeaders ListImages where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonEC2ContainerRegistry_V20150921.ListImages" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListImages where toJSON ListImages' {..} = Data.object ( Prelude.catMaybes [ ("filter" Data..=) Prelude.<$> filter', ("maxResults" Data..=) Prelude.<$> maxResults, ("nextToken" Data..=) Prelude.<$> nextToken, ("registryId" Data..=) Prelude.<$> registryId, Prelude.Just ("repositoryName" Data..= repositoryName) ] ) instance Data.ToPath ListImages where toPath = Prelude.const "/" instance Data.ToQuery ListImages where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListImagesResponse' smart constructor. data ListImagesResponse = ListImagesResponse' { -- | The list of image IDs for the requested repository. imageIds :: Prelude.Maybe [ImageIdentifier], -- | The @nextToken@ value to include in a future @ListImages@ request. When -- the results of a @ListImages@ request exceed @maxResults@, this value -- can be used to retrieve the next page of results. This value is @null@ -- when there are no more results to return. 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 'ListImagesResponse' 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: -- -- 'imageIds', 'listImagesResponse_imageIds' - The list of image IDs for the requested repository. -- -- 'nextToken', 'listImagesResponse_nextToken' - The @nextToken@ value to include in a future @ListImages@ request. When -- the results of a @ListImages@ request exceed @maxResults@, this value -- can be used to retrieve the next page of results. This value is @null@ -- when there are no more results to return. -- -- 'httpStatus', 'listImagesResponse_httpStatus' - The response's http status code. newListImagesResponse :: -- | 'httpStatus' Prelude.Int -> ListImagesResponse newListImagesResponse pHttpStatus_ = ListImagesResponse' { imageIds = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of image IDs for the requested repository. listImagesResponse_imageIds :: Lens.Lens' ListImagesResponse (Prelude.Maybe [ImageIdentifier]) listImagesResponse_imageIds = Lens.lens (\ListImagesResponse' {imageIds} -> imageIds) (\s@ListImagesResponse' {} a -> s {imageIds = a} :: ListImagesResponse) Prelude.. Lens.mapping Lens.coerced -- | The @nextToken@ value to include in a future @ListImages@ request. When -- the results of a @ListImages@ request exceed @maxResults@, this value -- can be used to retrieve the next page of results. This value is @null@ -- when there are no more results to return. listImagesResponse_nextToken :: Lens.Lens' ListImagesResponse (Prelude.Maybe Prelude.Text) listImagesResponse_nextToken = Lens.lens (\ListImagesResponse' {nextToken} -> nextToken) (\s@ListImagesResponse' {} a -> s {nextToken = a} :: ListImagesResponse) -- | The response's http status code. listImagesResponse_httpStatus :: Lens.Lens' ListImagesResponse Prelude.Int listImagesResponse_httpStatus = Lens.lens (\ListImagesResponse' {httpStatus} -> httpStatus) (\s@ListImagesResponse' {} a -> s {httpStatus = a} :: ListImagesResponse) instance Prelude.NFData ListImagesResponse where rnf ListImagesResponse' {..} = Prelude.rnf imageIds `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus