{-# 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.CostExplorer.ProvideAnomalyFeedback -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Modifies the feedback property of a given cost anomaly. module Amazonka.CostExplorer.ProvideAnomalyFeedback ( -- * Creating a Request ProvideAnomalyFeedback (..), newProvideAnomalyFeedback, -- * Request Lenses provideAnomalyFeedback_anomalyId, provideAnomalyFeedback_feedback, -- * Destructuring the Response ProvideAnomalyFeedbackResponse (..), newProvideAnomalyFeedbackResponse, -- * Response Lenses provideAnomalyFeedbackResponse_httpStatus, provideAnomalyFeedbackResponse_anomalyId, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import Amazonka.CostExplorer.Types import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newProvideAnomalyFeedback' smart constructor. data ProvideAnomalyFeedback = ProvideAnomalyFeedback' { -- | A cost anomaly ID. anomalyId :: Prelude.Text, -- | Describes whether the cost anomaly was a planned activity or you -- considered it an anomaly. feedback :: AnomalyFeedbackType } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ProvideAnomalyFeedback' 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: -- -- 'anomalyId', 'provideAnomalyFeedback_anomalyId' - A cost anomaly ID. -- -- 'feedback', 'provideAnomalyFeedback_feedback' - Describes whether the cost anomaly was a planned activity or you -- considered it an anomaly. newProvideAnomalyFeedback :: -- | 'anomalyId' Prelude.Text -> -- | 'feedback' AnomalyFeedbackType -> ProvideAnomalyFeedback newProvideAnomalyFeedback pAnomalyId_ pFeedback_ = ProvideAnomalyFeedback' { anomalyId = pAnomalyId_, feedback = pFeedback_ } -- | A cost anomaly ID. provideAnomalyFeedback_anomalyId :: Lens.Lens' ProvideAnomalyFeedback Prelude.Text provideAnomalyFeedback_anomalyId = Lens.lens (\ProvideAnomalyFeedback' {anomalyId} -> anomalyId) (\s@ProvideAnomalyFeedback' {} a -> s {anomalyId = a} :: ProvideAnomalyFeedback) -- | Describes whether the cost anomaly was a planned activity or you -- considered it an anomaly. provideAnomalyFeedback_feedback :: Lens.Lens' ProvideAnomalyFeedback AnomalyFeedbackType provideAnomalyFeedback_feedback = Lens.lens (\ProvideAnomalyFeedback' {feedback} -> feedback) (\s@ProvideAnomalyFeedback' {} a -> s {feedback = a} :: ProvideAnomalyFeedback) instance Core.AWSRequest ProvideAnomalyFeedback where type AWSResponse ProvideAnomalyFeedback = ProvideAnomalyFeedbackResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ProvideAnomalyFeedbackResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "AnomalyId") ) instance Prelude.Hashable ProvideAnomalyFeedback where hashWithSalt _salt ProvideAnomalyFeedback' {..} = _salt `Prelude.hashWithSalt` anomalyId `Prelude.hashWithSalt` feedback instance Prelude.NFData ProvideAnomalyFeedback where rnf ProvideAnomalyFeedback' {..} = Prelude.rnf anomalyId `Prelude.seq` Prelude.rnf feedback instance Data.ToHeaders ProvideAnomalyFeedback where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSInsightsIndexService.ProvideAnomalyFeedback" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ProvideAnomalyFeedback where toJSON ProvideAnomalyFeedback' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("AnomalyId" Data..= anomalyId), Prelude.Just ("Feedback" Data..= feedback) ] ) instance Data.ToPath ProvideAnomalyFeedback where toPath = Prelude.const "/" instance Data.ToQuery ProvideAnomalyFeedback where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newProvideAnomalyFeedbackResponse' smart constructor. data ProvideAnomalyFeedbackResponse = ProvideAnomalyFeedbackResponse' { -- | The response's http status code. httpStatus :: Prelude.Int, -- | The ID of the modified cost anomaly. anomalyId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ProvideAnomalyFeedbackResponse' 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: -- -- 'httpStatus', 'provideAnomalyFeedbackResponse_httpStatus' - The response's http status code. -- -- 'anomalyId', 'provideAnomalyFeedbackResponse_anomalyId' - The ID of the modified cost anomaly. newProvideAnomalyFeedbackResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'anomalyId' Prelude.Text -> ProvideAnomalyFeedbackResponse newProvideAnomalyFeedbackResponse pHttpStatus_ pAnomalyId_ = ProvideAnomalyFeedbackResponse' { httpStatus = pHttpStatus_, anomalyId = pAnomalyId_ } -- | The response's http status code. provideAnomalyFeedbackResponse_httpStatus :: Lens.Lens' ProvideAnomalyFeedbackResponse Prelude.Int provideAnomalyFeedbackResponse_httpStatus = Lens.lens (\ProvideAnomalyFeedbackResponse' {httpStatus} -> httpStatus) (\s@ProvideAnomalyFeedbackResponse' {} a -> s {httpStatus = a} :: ProvideAnomalyFeedbackResponse) -- | The ID of the modified cost anomaly. provideAnomalyFeedbackResponse_anomalyId :: Lens.Lens' ProvideAnomalyFeedbackResponse Prelude.Text provideAnomalyFeedbackResponse_anomalyId = Lens.lens (\ProvideAnomalyFeedbackResponse' {anomalyId} -> anomalyId) (\s@ProvideAnomalyFeedbackResponse' {} a -> s {anomalyId = a} :: ProvideAnomalyFeedbackResponse) instance Prelude.NFData ProvideAnomalyFeedbackResponse where rnf ProvideAnomalyFeedbackResponse' {..} = Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf anomalyId