{-# 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.IoT.UpdateCustomMetric -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Updates a Device Defender detect custom metric. -- -- Requires permission to access the -- -- action. module Amazonka.IoT.UpdateCustomMetric ( -- * Creating a Request UpdateCustomMetric (..), newUpdateCustomMetric, -- * Request Lenses updateCustomMetric_metricName, updateCustomMetric_displayName, -- * Destructuring the Response UpdateCustomMetricResponse (..), newUpdateCustomMetricResponse, -- * Response Lenses updateCustomMetricResponse_creationDate, updateCustomMetricResponse_displayName, updateCustomMetricResponse_lastModifiedDate, updateCustomMetricResponse_metricArn, updateCustomMetricResponse_metricName, updateCustomMetricResponse_metricType, updateCustomMetricResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoT.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateCustomMetric' smart constructor. data UpdateCustomMetric = UpdateCustomMetric' { -- | The name of the custom metric. Cannot be updated. metricName :: Prelude.Text, -- | Field represents a friendly name in the console for the custom metric, -- it doesn\'t have to be unique. Don\'t use this name as the metric -- identifier in the device metric report. Can be updated. displayName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateCustomMetric' 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: -- -- 'metricName', 'updateCustomMetric_metricName' - The name of the custom metric. Cannot be updated. -- -- 'displayName', 'updateCustomMetric_displayName' - Field represents a friendly name in the console for the custom metric, -- it doesn\'t have to be unique. Don\'t use this name as the metric -- identifier in the device metric report. Can be updated. newUpdateCustomMetric :: -- | 'metricName' Prelude.Text -> -- | 'displayName' Prelude.Text -> UpdateCustomMetric newUpdateCustomMetric pMetricName_ pDisplayName_ = UpdateCustomMetric' { metricName = pMetricName_, displayName = pDisplayName_ } -- | The name of the custom metric. Cannot be updated. updateCustomMetric_metricName :: Lens.Lens' UpdateCustomMetric Prelude.Text updateCustomMetric_metricName = Lens.lens (\UpdateCustomMetric' {metricName} -> metricName) (\s@UpdateCustomMetric' {} a -> s {metricName = a} :: UpdateCustomMetric) -- | Field represents a friendly name in the console for the custom metric, -- it doesn\'t have to be unique. Don\'t use this name as the metric -- identifier in the device metric report. Can be updated. updateCustomMetric_displayName :: Lens.Lens' UpdateCustomMetric Prelude.Text updateCustomMetric_displayName = Lens.lens (\UpdateCustomMetric' {displayName} -> displayName) (\s@UpdateCustomMetric' {} a -> s {displayName = a} :: UpdateCustomMetric) instance Core.AWSRequest UpdateCustomMetric where type AWSResponse UpdateCustomMetric = UpdateCustomMetricResponse request overrides = Request.patchJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateCustomMetricResponse' Prelude.<$> (x Data..?> "creationDate") Prelude.<*> (x Data..?> "displayName") Prelude.<*> (x Data..?> "lastModifiedDate") Prelude.<*> (x Data..?> "metricArn") Prelude.<*> (x Data..?> "metricName") Prelude.<*> (x Data..?> "metricType") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateCustomMetric where hashWithSalt _salt UpdateCustomMetric' {..} = _salt `Prelude.hashWithSalt` metricName `Prelude.hashWithSalt` displayName instance Prelude.NFData UpdateCustomMetric where rnf UpdateCustomMetric' {..} = Prelude.rnf metricName `Prelude.seq` Prelude.rnf displayName instance Data.ToHeaders UpdateCustomMetric where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON UpdateCustomMetric where toJSON UpdateCustomMetric' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("displayName" Data..= displayName)] ) instance Data.ToPath UpdateCustomMetric where toPath UpdateCustomMetric' {..} = Prelude.mconcat ["/custom-metric/", Data.toBS metricName] instance Data.ToQuery UpdateCustomMetric where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateCustomMetricResponse' smart constructor. data UpdateCustomMetricResponse = UpdateCustomMetricResponse' { -- | The creation date of the custom metric in milliseconds since epoch. creationDate :: Prelude.Maybe Data.POSIX, -- | A friendly name in the console for the custom metric displayName :: Prelude.Maybe Prelude.Text, -- | The time the custom metric was last modified in milliseconds since -- epoch. lastModifiedDate :: Prelude.Maybe Data.POSIX, -- | The Amazon Resource Number (ARN) of the custom metric. metricArn :: Prelude.Maybe Prelude.Text, -- | The name of the custom metric. metricName :: Prelude.Maybe Prelude.Text, -- | The type of the custom metric. -- -- The type @number@ only takes a single metric value as an input, but -- while submitting the metrics value in the DeviceMetrics report, it must -- be passed as an array with a single value. metricType :: Prelude.Maybe CustomMetricType, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateCustomMetricResponse' 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: -- -- 'creationDate', 'updateCustomMetricResponse_creationDate' - The creation date of the custom metric in milliseconds since epoch. -- -- 'displayName', 'updateCustomMetricResponse_displayName' - A friendly name in the console for the custom metric -- -- 'lastModifiedDate', 'updateCustomMetricResponse_lastModifiedDate' - The time the custom metric was last modified in milliseconds since -- epoch. -- -- 'metricArn', 'updateCustomMetricResponse_metricArn' - The Amazon Resource Number (ARN) of the custom metric. -- -- 'metricName', 'updateCustomMetricResponse_metricName' - The name of the custom metric. -- -- 'metricType', 'updateCustomMetricResponse_metricType' - The type of the custom metric. -- -- The type @number@ only takes a single metric value as an input, but -- while submitting the metrics value in the DeviceMetrics report, it must -- be passed as an array with a single value. -- -- 'httpStatus', 'updateCustomMetricResponse_httpStatus' - The response's http status code. newUpdateCustomMetricResponse :: -- | 'httpStatus' Prelude.Int -> UpdateCustomMetricResponse newUpdateCustomMetricResponse pHttpStatus_ = UpdateCustomMetricResponse' { creationDate = Prelude.Nothing, displayName = Prelude.Nothing, lastModifiedDate = Prelude.Nothing, metricArn = Prelude.Nothing, metricName = Prelude.Nothing, metricType = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The creation date of the custom metric in milliseconds since epoch. updateCustomMetricResponse_creationDate :: Lens.Lens' UpdateCustomMetricResponse (Prelude.Maybe Prelude.UTCTime) updateCustomMetricResponse_creationDate = Lens.lens (\UpdateCustomMetricResponse' {creationDate} -> creationDate) (\s@UpdateCustomMetricResponse' {} a -> s {creationDate = a} :: UpdateCustomMetricResponse) Prelude.. Lens.mapping Data._Time -- | A friendly name in the console for the custom metric updateCustomMetricResponse_displayName :: Lens.Lens' UpdateCustomMetricResponse (Prelude.Maybe Prelude.Text) updateCustomMetricResponse_displayName = Lens.lens (\UpdateCustomMetricResponse' {displayName} -> displayName) (\s@UpdateCustomMetricResponse' {} a -> s {displayName = a} :: UpdateCustomMetricResponse) -- | The time the custom metric was last modified in milliseconds since -- epoch. updateCustomMetricResponse_lastModifiedDate :: Lens.Lens' UpdateCustomMetricResponse (Prelude.Maybe Prelude.UTCTime) updateCustomMetricResponse_lastModifiedDate = Lens.lens (\UpdateCustomMetricResponse' {lastModifiedDate} -> lastModifiedDate) (\s@UpdateCustomMetricResponse' {} a -> s {lastModifiedDate = a} :: UpdateCustomMetricResponse) Prelude.. Lens.mapping Data._Time -- | The Amazon Resource Number (ARN) of the custom metric. updateCustomMetricResponse_metricArn :: Lens.Lens' UpdateCustomMetricResponse (Prelude.Maybe Prelude.Text) updateCustomMetricResponse_metricArn = Lens.lens (\UpdateCustomMetricResponse' {metricArn} -> metricArn) (\s@UpdateCustomMetricResponse' {} a -> s {metricArn = a} :: UpdateCustomMetricResponse) -- | The name of the custom metric. updateCustomMetricResponse_metricName :: Lens.Lens' UpdateCustomMetricResponse (Prelude.Maybe Prelude.Text) updateCustomMetricResponse_metricName = Lens.lens (\UpdateCustomMetricResponse' {metricName} -> metricName) (\s@UpdateCustomMetricResponse' {} a -> s {metricName = a} :: UpdateCustomMetricResponse) -- | The type of the custom metric. -- -- The type @number@ only takes a single metric value as an input, but -- while submitting the metrics value in the DeviceMetrics report, it must -- be passed as an array with a single value. updateCustomMetricResponse_metricType :: Lens.Lens' UpdateCustomMetricResponse (Prelude.Maybe CustomMetricType) updateCustomMetricResponse_metricType = Lens.lens (\UpdateCustomMetricResponse' {metricType} -> metricType) (\s@UpdateCustomMetricResponse' {} a -> s {metricType = a} :: UpdateCustomMetricResponse) -- | The response's http status code. updateCustomMetricResponse_httpStatus :: Lens.Lens' UpdateCustomMetricResponse Prelude.Int updateCustomMetricResponse_httpStatus = Lens.lens (\UpdateCustomMetricResponse' {httpStatus} -> httpStatus) (\s@UpdateCustomMetricResponse' {} a -> s {httpStatus = a} :: UpdateCustomMetricResponse) instance Prelude.NFData UpdateCustomMetricResponse where rnf UpdateCustomMetricResponse' {..} = Prelude.rnf creationDate `Prelude.seq` Prelude.rnf displayName `Prelude.seq` Prelude.rnf lastModifiedDate `Prelude.seq` Prelude.rnf metricArn `Prelude.seq` Prelude.rnf metricName `Prelude.seq` Prelude.rnf metricType `Prelude.seq` Prelude.rnf httpStatus