{-# 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.Schemas.ListRegistries -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- List the registries. -- -- This operation returns paginated results. module Amazonka.Schemas.ListRegistries ( -- * Creating a Request ListRegistries (..), newListRegistries, -- * Request Lenses listRegistries_limit, listRegistries_nextToken, listRegistries_registryNamePrefix, listRegistries_scope, -- * Destructuring the Response ListRegistriesResponse (..), newListRegistriesResponse, -- * Response Lenses listRegistriesResponse_nextToken, listRegistriesResponse_registries, listRegistriesResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.Schemas.Types -- | /See:/ 'newListRegistries' smart constructor. data ListRegistries = ListRegistries' { limit :: Prelude.Maybe Prelude.Int, -- | The token that specifies the next page of results to return. To request -- the first page, leave NextToken empty. The token will expire in 24 -- hours, and cannot be shared with other accounts. nextToken :: Prelude.Maybe Prelude.Text, -- | Specifying this limits the results to only those registry names that -- start with the specified prefix. registryNamePrefix :: Prelude.Maybe Prelude.Text, -- | Can be set to Local or AWS to limit responses to your custom registries, -- or the ones provided by AWS. scope :: Prelude.Maybe Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListRegistries' 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: -- -- 'limit', 'listRegistries_limit' - Undocumented member. -- -- 'nextToken', 'listRegistries_nextToken' - The token that specifies the next page of results to return. To request -- the first page, leave NextToken empty. The token will expire in 24 -- hours, and cannot be shared with other accounts. -- -- 'registryNamePrefix', 'listRegistries_registryNamePrefix' - Specifying this limits the results to only those registry names that -- start with the specified prefix. -- -- 'scope', 'listRegistries_scope' - Can be set to Local or AWS to limit responses to your custom registries, -- or the ones provided by AWS. newListRegistries :: ListRegistries newListRegistries = ListRegistries' { limit = Prelude.Nothing, nextToken = Prelude.Nothing, registryNamePrefix = Prelude.Nothing, scope = Prelude.Nothing } -- | Undocumented member. listRegistries_limit :: Lens.Lens' ListRegistries (Prelude.Maybe Prelude.Int) listRegistries_limit = Lens.lens (\ListRegistries' {limit} -> limit) (\s@ListRegistries' {} a -> s {limit = a} :: ListRegistries) -- | The token that specifies the next page of results to return. To request -- the first page, leave NextToken empty. The token will expire in 24 -- hours, and cannot be shared with other accounts. listRegistries_nextToken :: Lens.Lens' ListRegistries (Prelude.Maybe Prelude.Text) listRegistries_nextToken = Lens.lens (\ListRegistries' {nextToken} -> nextToken) (\s@ListRegistries' {} a -> s {nextToken = a} :: ListRegistries) -- | Specifying this limits the results to only those registry names that -- start with the specified prefix. listRegistries_registryNamePrefix :: Lens.Lens' ListRegistries (Prelude.Maybe Prelude.Text) listRegistries_registryNamePrefix = Lens.lens (\ListRegistries' {registryNamePrefix} -> registryNamePrefix) (\s@ListRegistries' {} a -> s {registryNamePrefix = a} :: ListRegistries) -- | Can be set to Local or AWS to limit responses to your custom registries, -- or the ones provided by AWS. listRegistries_scope :: Lens.Lens' ListRegistries (Prelude.Maybe Prelude.Text) listRegistries_scope = Lens.lens (\ListRegistries' {scope} -> scope) (\s@ListRegistries' {} a -> s {scope = a} :: ListRegistries) instance Core.AWSPager ListRegistries where page rq rs | Core.stop ( rs Lens.^? listRegistriesResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listRegistriesResponse_registries Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listRegistries_nextToken Lens..~ rs Lens.^? listRegistriesResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListRegistries where type AWSResponse ListRegistries = ListRegistriesResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListRegistriesResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> (x Data..?> "Registries" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListRegistries where hashWithSalt _salt ListRegistries' {..} = _salt `Prelude.hashWithSalt` limit `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` registryNamePrefix `Prelude.hashWithSalt` scope instance Prelude.NFData ListRegistries where rnf ListRegistries' {..} = Prelude.rnf limit `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf registryNamePrefix `Prelude.seq` Prelude.rnf scope instance Data.ToHeaders ListRegistries where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath ListRegistries where toPath = Prelude.const "/v1/registries" instance Data.ToQuery ListRegistries where toQuery ListRegistries' {..} = Prelude.mconcat [ "limit" Data.=: limit, "nextToken" Data.=: nextToken, "registryNamePrefix" Data.=: registryNamePrefix, "scope" Data.=: scope ] -- | /See:/ 'newListRegistriesResponse' smart constructor. data ListRegistriesResponse = ListRegistriesResponse' { -- | The token that specifies the next page of results to return. To request -- the first page, leave NextToken empty. The token will expire in 24 -- hours, and cannot be shared with other accounts. nextToken :: Prelude.Maybe Prelude.Text, -- | An array of registry summaries. registries :: Prelude.Maybe [RegistrySummary], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListRegistriesResponse' 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', 'listRegistriesResponse_nextToken' - The token that specifies the next page of results to return. To request -- the first page, leave NextToken empty. The token will expire in 24 -- hours, and cannot be shared with other accounts. -- -- 'registries', 'listRegistriesResponse_registries' - An array of registry summaries. -- -- 'httpStatus', 'listRegistriesResponse_httpStatus' - The response's http status code. newListRegistriesResponse :: -- | 'httpStatus' Prelude.Int -> ListRegistriesResponse newListRegistriesResponse pHttpStatus_ = ListRegistriesResponse' { nextToken = Prelude.Nothing, registries = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The token that specifies the next page of results to return. To request -- the first page, leave NextToken empty. The token will expire in 24 -- hours, and cannot be shared with other accounts. listRegistriesResponse_nextToken :: Lens.Lens' ListRegistriesResponse (Prelude.Maybe Prelude.Text) listRegistriesResponse_nextToken = Lens.lens (\ListRegistriesResponse' {nextToken} -> nextToken) (\s@ListRegistriesResponse' {} a -> s {nextToken = a} :: ListRegistriesResponse) -- | An array of registry summaries. listRegistriesResponse_registries :: Lens.Lens' ListRegistriesResponse (Prelude.Maybe [RegistrySummary]) listRegistriesResponse_registries = Lens.lens (\ListRegistriesResponse' {registries} -> registries) (\s@ListRegistriesResponse' {} a -> s {registries = a} :: ListRegistriesResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. listRegistriesResponse_httpStatus :: Lens.Lens' ListRegistriesResponse Prelude.Int listRegistriesResponse_httpStatus = Lens.lens (\ListRegistriesResponse' {httpStatus} -> httpStatus) (\s@ListRegistriesResponse' {} a -> s {httpStatus = a} :: ListRegistriesResponse) instance Prelude.NFData ListRegistriesResponse where rnf ListRegistriesResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf registries `Prelude.seq` Prelude.rnf httpStatus