{-# 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.SSM.ListAssociationVersions -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Retrieves all versions of an association for a specific association ID. -- -- This operation returns paginated results. module Amazonka.SSM.ListAssociationVersions ( -- * Creating a Request ListAssociationVersions (..), newListAssociationVersions, -- * Request Lenses listAssociationVersions_maxResults, listAssociationVersions_nextToken, listAssociationVersions_associationId, -- * Destructuring the Response ListAssociationVersionsResponse (..), newListAssociationVersionsResponse, -- * Response Lenses listAssociationVersionsResponse_associationVersions, listAssociationVersionsResponse_nextToken, listAssociationVersionsResponse_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.SSM.Types -- | /See:/ 'newListAssociationVersions' smart constructor. data ListAssociationVersions = ListAssociationVersions' { -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. maxResults :: Prelude.Maybe Prelude.Natural, -- | A token to start the list. Use this token to get the next set of -- results. nextToken :: Prelude.Maybe Prelude.Text, -- | The association ID for which you want to view all versions. associationId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListAssociationVersions' 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: -- -- 'maxResults', 'listAssociationVersions_maxResults' - The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. -- -- 'nextToken', 'listAssociationVersions_nextToken' - A token to start the list. Use this token to get the next set of -- results. -- -- 'associationId', 'listAssociationVersions_associationId' - The association ID for which you want to view all versions. newListAssociationVersions :: -- | 'associationId' Prelude.Text -> ListAssociationVersions newListAssociationVersions pAssociationId_ = ListAssociationVersions' { maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, associationId = pAssociationId_ } -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. listAssociationVersions_maxResults :: Lens.Lens' ListAssociationVersions (Prelude.Maybe Prelude.Natural) listAssociationVersions_maxResults = Lens.lens (\ListAssociationVersions' {maxResults} -> maxResults) (\s@ListAssociationVersions' {} a -> s {maxResults = a} :: ListAssociationVersions) -- | A token to start the list. Use this token to get the next set of -- results. listAssociationVersions_nextToken :: Lens.Lens' ListAssociationVersions (Prelude.Maybe Prelude.Text) listAssociationVersions_nextToken = Lens.lens (\ListAssociationVersions' {nextToken} -> nextToken) (\s@ListAssociationVersions' {} a -> s {nextToken = a} :: ListAssociationVersions) -- | The association ID for which you want to view all versions. listAssociationVersions_associationId :: Lens.Lens' ListAssociationVersions Prelude.Text listAssociationVersions_associationId = Lens.lens (\ListAssociationVersions' {associationId} -> associationId) (\s@ListAssociationVersions' {} a -> s {associationId = a} :: ListAssociationVersions) instance Core.AWSPager ListAssociationVersions where page rq rs | Core.stop ( rs Lens.^? listAssociationVersionsResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? listAssociationVersionsResponse_associationVersions Prelude.. Lens._Just Prelude.. Lens.to Prelude.toList ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& listAssociationVersions_nextToken Lens..~ rs Lens.^? listAssociationVersionsResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest ListAssociationVersions where type AWSResponse ListAssociationVersions = ListAssociationVersionsResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListAssociationVersionsResponse' Prelude.<$> (x Data..?> "AssociationVersions") Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListAssociationVersions where hashWithSalt _salt ListAssociationVersions' {..} = _salt `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` associationId instance Prelude.NFData ListAssociationVersions where rnf ListAssociationVersions' {..} = Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf associationId instance Data.ToHeaders ListAssociationVersions where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.ListAssociationVersions" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListAssociationVersions where toJSON ListAssociationVersions' {..} = Data.object ( Prelude.catMaybes [ ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("AssociationId" Data..= associationId) ] ) instance Data.ToPath ListAssociationVersions where toPath = Prelude.const "/" instance Data.ToQuery ListAssociationVersions where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListAssociationVersionsResponse' smart constructor. data ListAssociationVersionsResponse = ListAssociationVersionsResponse' { -- | Information about all versions of the association for the specified -- association ID. associationVersions :: Prelude.Maybe (Prelude.NonEmpty AssociationVersionInfo), -- | The token for the next set of items to return. Use this token to get the -- next set of results. nextToken :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListAssociationVersionsResponse' 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: -- -- 'associationVersions', 'listAssociationVersionsResponse_associationVersions' - Information about all versions of the association for the specified -- association ID. -- -- 'nextToken', 'listAssociationVersionsResponse_nextToken' - The token for the next set of items to return. Use this token to get the -- next set of results. -- -- 'httpStatus', 'listAssociationVersionsResponse_httpStatus' - The response's http status code. newListAssociationVersionsResponse :: -- | 'httpStatus' Prelude.Int -> ListAssociationVersionsResponse newListAssociationVersionsResponse pHttpStatus_ = ListAssociationVersionsResponse' { associationVersions = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about all versions of the association for the specified -- association ID. listAssociationVersionsResponse_associationVersions :: Lens.Lens' ListAssociationVersionsResponse (Prelude.Maybe (Prelude.NonEmpty AssociationVersionInfo)) listAssociationVersionsResponse_associationVersions = Lens.lens (\ListAssociationVersionsResponse' {associationVersions} -> associationVersions) (\s@ListAssociationVersionsResponse' {} a -> s {associationVersions = a} :: ListAssociationVersionsResponse) Prelude.. Lens.mapping Lens.coerced -- | The token for the next set of items to return. Use this token to get the -- next set of results. listAssociationVersionsResponse_nextToken :: Lens.Lens' ListAssociationVersionsResponse (Prelude.Maybe Prelude.Text) listAssociationVersionsResponse_nextToken = Lens.lens (\ListAssociationVersionsResponse' {nextToken} -> nextToken) (\s@ListAssociationVersionsResponse' {} a -> s {nextToken = a} :: ListAssociationVersionsResponse) -- | The response's http status code. listAssociationVersionsResponse_httpStatus :: Lens.Lens' ListAssociationVersionsResponse Prelude.Int listAssociationVersionsResponse_httpStatus = Lens.lens (\ListAssociationVersionsResponse' {httpStatus} -> httpStatus) (\s@ListAssociationVersionsResponse' {} a -> s {httpStatus = a} :: ListAssociationVersionsResponse) instance Prelude.NFData ListAssociationVersionsResponse where rnf ListAssociationVersionsResponse' {..} = Prelude.rnf associationVersions `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus