{-# 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.ListDocumentMetadataHistory -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Information about approval reviews for a version of a change template in -- Change Manager. module Amazonka.SSM.ListDocumentMetadataHistory ( -- * Creating a Request ListDocumentMetadataHistory (..), newListDocumentMetadataHistory, -- * Request Lenses listDocumentMetadataHistory_documentVersion, listDocumentMetadataHistory_maxResults, listDocumentMetadataHistory_nextToken, listDocumentMetadataHistory_name, listDocumentMetadataHistory_metadata, -- * Destructuring the Response ListDocumentMetadataHistoryResponse (..), newListDocumentMetadataHistoryResponse, -- * Response Lenses listDocumentMetadataHistoryResponse_author, listDocumentMetadataHistoryResponse_documentVersion, listDocumentMetadataHistoryResponse_metadata, listDocumentMetadataHistoryResponse_name, listDocumentMetadataHistoryResponse_nextToken, listDocumentMetadataHistoryResponse_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:/ 'newListDocumentMetadataHistory' smart constructor. data ListDocumentMetadataHistory = ListDocumentMetadataHistory' { -- | The version of the change template. documentVersion :: Prelude.Maybe Prelude.Text, -- | 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, -- | The token for the next set of items to return. (You received this token -- from a previous call.) nextToken :: Prelude.Maybe Prelude.Text, -- | The name of the change template. name :: Prelude.Text, -- | The type of data for which details are being requested. Currently, the -- only supported value is @DocumentReviews@. metadata :: DocumentMetadataEnum } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ListDocumentMetadataHistory' 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: -- -- 'documentVersion', 'listDocumentMetadataHistory_documentVersion' - The version of the change template. -- -- 'maxResults', 'listDocumentMetadataHistory_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', 'listDocumentMetadataHistory_nextToken' - The token for the next set of items to return. (You received this token -- from a previous call.) -- -- 'name', 'listDocumentMetadataHistory_name' - The name of the change template. -- -- 'metadata', 'listDocumentMetadataHistory_metadata' - The type of data for which details are being requested. Currently, the -- only supported value is @DocumentReviews@. newListDocumentMetadataHistory :: -- | 'name' Prelude.Text -> -- | 'metadata' DocumentMetadataEnum -> ListDocumentMetadataHistory newListDocumentMetadataHistory pName_ pMetadata_ = ListDocumentMetadataHistory' { documentVersion = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, name = pName_, metadata = pMetadata_ } -- | The version of the change template. listDocumentMetadataHistory_documentVersion :: Lens.Lens' ListDocumentMetadataHistory (Prelude.Maybe Prelude.Text) listDocumentMetadataHistory_documentVersion = Lens.lens (\ListDocumentMetadataHistory' {documentVersion} -> documentVersion) (\s@ListDocumentMetadataHistory' {} a -> s {documentVersion = a} :: ListDocumentMetadataHistory) -- | 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. listDocumentMetadataHistory_maxResults :: Lens.Lens' ListDocumentMetadataHistory (Prelude.Maybe Prelude.Natural) listDocumentMetadataHistory_maxResults = Lens.lens (\ListDocumentMetadataHistory' {maxResults} -> maxResults) (\s@ListDocumentMetadataHistory' {} a -> s {maxResults = a} :: ListDocumentMetadataHistory) -- | The token for the next set of items to return. (You received this token -- from a previous call.) listDocumentMetadataHistory_nextToken :: Lens.Lens' ListDocumentMetadataHistory (Prelude.Maybe Prelude.Text) listDocumentMetadataHistory_nextToken = Lens.lens (\ListDocumentMetadataHistory' {nextToken} -> nextToken) (\s@ListDocumentMetadataHistory' {} a -> s {nextToken = a} :: ListDocumentMetadataHistory) -- | The name of the change template. listDocumentMetadataHistory_name :: Lens.Lens' ListDocumentMetadataHistory Prelude.Text listDocumentMetadataHistory_name = Lens.lens (\ListDocumentMetadataHistory' {name} -> name) (\s@ListDocumentMetadataHistory' {} a -> s {name = a} :: ListDocumentMetadataHistory) -- | The type of data for which details are being requested. Currently, the -- only supported value is @DocumentReviews@. listDocumentMetadataHistory_metadata :: Lens.Lens' ListDocumentMetadataHistory DocumentMetadataEnum listDocumentMetadataHistory_metadata = Lens.lens (\ListDocumentMetadataHistory' {metadata} -> metadata) (\s@ListDocumentMetadataHistory' {} a -> s {metadata = a} :: ListDocumentMetadataHistory) instance Core.AWSRequest ListDocumentMetadataHistory where type AWSResponse ListDocumentMetadataHistory = ListDocumentMetadataHistoryResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ListDocumentMetadataHistoryResponse' Prelude.<$> (x Data..?> "Author") Prelude.<*> (x Data..?> "DocumentVersion") Prelude.<*> (x Data..?> "Metadata") Prelude.<*> (x Data..?> "Name") Prelude.<*> (x Data..?> "NextToken") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ListDocumentMetadataHistory where hashWithSalt _salt ListDocumentMetadataHistory' {..} = _salt `Prelude.hashWithSalt` documentVersion `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` name `Prelude.hashWithSalt` metadata instance Prelude.NFData ListDocumentMetadataHistory where rnf ListDocumentMetadataHistory' {..} = Prelude.rnf documentVersion `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf metadata instance Data.ToHeaders ListDocumentMetadataHistory where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.ListDocumentMetadataHistory" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ListDocumentMetadataHistory where toJSON ListDocumentMetadataHistory' {..} = Data.object ( Prelude.catMaybes [ ("DocumentVersion" Data..=) Prelude.<$> documentVersion, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, Prelude.Just ("Name" Data..= name), Prelude.Just ("Metadata" Data..= metadata) ] ) instance Data.ToPath ListDocumentMetadataHistory where toPath = Prelude.const "/" instance Data.ToQuery ListDocumentMetadataHistory where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newListDocumentMetadataHistoryResponse' smart constructor. data ListDocumentMetadataHistoryResponse = ListDocumentMetadataHistoryResponse' { -- | The user ID of the person in the organization who requested the review -- of the change template. author :: Prelude.Maybe Prelude.Text, -- | The version of the change template. documentVersion :: Prelude.Maybe Prelude.Text, -- | Information about the response to the change template approval request. metadata :: Prelude.Maybe DocumentMetadataResponseInfo, -- | The name of the change template. name :: Prelude.Maybe Prelude.Text, -- | 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 :: 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 'ListDocumentMetadataHistoryResponse' 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: -- -- 'author', 'listDocumentMetadataHistoryResponse_author' - The user ID of the person in the organization who requested the review -- of the change template. -- -- 'documentVersion', 'listDocumentMetadataHistoryResponse_documentVersion' - The version of the change template. -- -- 'metadata', 'listDocumentMetadataHistoryResponse_metadata' - Information about the response to the change template approval request. -- -- 'name', 'listDocumentMetadataHistoryResponse_name' - The name of the change template. -- -- 'nextToken', 'listDocumentMetadataHistoryResponse_nextToken' - 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. -- -- 'httpStatus', 'listDocumentMetadataHistoryResponse_httpStatus' - The response's http status code. newListDocumentMetadataHistoryResponse :: -- | 'httpStatus' Prelude.Int -> ListDocumentMetadataHistoryResponse newListDocumentMetadataHistoryResponse pHttpStatus_ = ListDocumentMetadataHistoryResponse' { author = Prelude.Nothing, documentVersion = Prelude.Nothing, metadata = Prelude.Nothing, name = Prelude.Nothing, nextToken = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The user ID of the person in the organization who requested the review -- of the change template. listDocumentMetadataHistoryResponse_author :: Lens.Lens' ListDocumentMetadataHistoryResponse (Prelude.Maybe Prelude.Text) listDocumentMetadataHistoryResponse_author = Lens.lens (\ListDocumentMetadataHistoryResponse' {author} -> author) (\s@ListDocumentMetadataHistoryResponse' {} a -> s {author = a} :: ListDocumentMetadataHistoryResponse) -- | The version of the change template. listDocumentMetadataHistoryResponse_documentVersion :: Lens.Lens' ListDocumentMetadataHistoryResponse (Prelude.Maybe Prelude.Text) listDocumentMetadataHistoryResponse_documentVersion = Lens.lens (\ListDocumentMetadataHistoryResponse' {documentVersion} -> documentVersion) (\s@ListDocumentMetadataHistoryResponse' {} a -> s {documentVersion = a} :: ListDocumentMetadataHistoryResponse) -- | Information about the response to the change template approval request. listDocumentMetadataHistoryResponse_metadata :: Lens.Lens' ListDocumentMetadataHistoryResponse (Prelude.Maybe DocumentMetadataResponseInfo) listDocumentMetadataHistoryResponse_metadata = Lens.lens (\ListDocumentMetadataHistoryResponse' {metadata} -> metadata) (\s@ListDocumentMetadataHistoryResponse' {} a -> s {metadata = a} :: ListDocumentMetadataHistoryResponse) -- | The name of the change template. listDocumentMetadataHistoryResponse_name :: Lens.Lens' ListDocumentMetadataHistoryResponse (Prelude.Maybe Prelude.Text) listDocumentMetadataHistoryResponse_name = Lens.lens (\ListDocumentMetadataHistoryResponse' {name} -> name) (\s@ListDocumentMetadataHistoryResponse' {} a -> s {name = a} :: ListDocumentMetadataHistoryResponse) -- | 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. listDocumentMetadataHistoryResponse_nextToken :: Lens.Lens' ListDocumentMetadataHistoryResponse (Prelude.Maybe Prelude.Text) listDocumentMetadataHistoryResponse_nextToken = Lens.lens (\ListDocumentMetadataHistoryResponse' {nextToken} -> nextToken) (\s@ListDocumentMetadataHistoryResponse' {} a -> s {nextToken = a} :: ListDocumentMetadataHistoryResponse) -- | The response's http status code. listDocumentMetadataHistoryResponse_httpStatus :: Lens.Lens' ListDocumentMetadataHistoryResponse Prelude.Int listDocumentMetadataHistoryResponse_httpStatus = Lens.lens (\ListDocumentMetadataHistoryResponse' {httpStatus} -> httpStatus) (\s@ListDocumentMetadataHistoryResponse' {} a -> s {httpStatus = a} :: ListDocumentMetadataHistoryResponse) instance Prelude.NFData ListDocumentMetadataHistoryResponse where rnf ListDocumentMetadataHistoryResponse' {..} = Prelude.rnf author `Prelude.seq` Prelude.rnf documentVersion `Prelude.seq` Prelude.rnf metadata `Prelude.seq` Prelude.rnf name `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf httpStatus