{-# 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.UpdateJob -- 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 supported fields of the specified job. -- -- Requires permission to access the -- -- action. module Amazonka.IoT.UpdateJob ( -- * Creating a Request UpdateJob (..), newUpdateJob, -- * Request Lenses updateJob_abortConfig, updateJob_description, updateJob_jobExecutionsRetryConfig, updateJob_jobExecutionsRolloutConfig, updateJob_namespaceId, updateJob_presignedUrlConfig, updateJob_timeoutConfig, updateJob_jobId, -- * Destructuring the Response UpdateJobResponse (..), newUpdateJobResponse, ) 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:/ 'newUpdateJob' smart constructor. data UpdateJob = UpdateJob' { -- | Allows you to create criteria to abort a job. abortConfig :: Prelude.Maybe AbortConfig, -- | A short text description of the job. description :: Prelude.Maybe Prelude.Text, -- | Allows you to create the criteria to retry a job. jobExecutionsRetryConfig :: Prelude.Maybe JobExecutionsRetryConfig, -- | Allows you to create a staged rollout of the job. jobExecutionsRolloutConfig :: Prelude.Maybe JobExecutionsRolloutConfig, -- | The namespace used to indicate that a job is a customer-managed job. -- -- When you specify a value for this parameter, Amazon Web Services IoT -- Core sends jobs notifications to MQTT topics that contain the value in -- the following format. -- -- @$aws\/things\/@/@THING_NAME@/@\/jobs\/@/@JOB_ID@/@\/notify-namespace-@/@NAMESPACE_ID@/@\/@ -- -- The @namespaceId@ feature is in public preview. namespaceId :: Prelude.Maybe Prelude.Text, -- | Configuration information for pre-signed S3 URLs. presignedUrlConfig :: Prelude.Maybe PresignedUrlConfig, -- | Specifies the amount of time each device has to finish its execution of -- the job. The timer is started when the job execution status is set to -- @IN_PROGRESS@. If the job execution status is not set to another -- terminal state before the time expires, it will be automatically set to -- @TIMED_OUT@. timeoutConfig :: Prelude.Maybe TimeoutConfig, -- | The ID of the job to be updated. jobId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateJob' 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: -- -- 'abortConfig', 'updateJob_abortConfig' - Allows you to create criteria to abort a job. -- -- 'description', 'updateJob_description' - A short text description of the job. -- -- 'jobExecutionsRetryConfig', 'updateJob_jobExecutionsRetryConfig' - Allows you to create the criteria to retry a job. -- -- 'jobExecutionsRolloutConfig', 'updateJob_jobExecutionsRolloutConfig' - Allows you to create a staged rollout of the job. -- -- 'namespaceId', 'updateJob_namespaceId' - The namespace used to indicate that a job is a customer-managed job. -- -- When you specify a value for this parameter, Amazon Web Services IoT -- Core sends jobs notifications to MQTT topics that contain the value in -- the following format. -- -- @$aws\/things\/@/@THING_NAME@/@\/jobs\/@/@JOB_ID@/@\/notify-namespace-@/@NAMESPACE_ID@/@\/@ -- -- The @namespaceId@ feature is in public preview. -- -- 'presignedUrlConfig', 'updateJob_presignedUrlConfig' - Configuration information for pre-signed S3 URLs. -- -- 'timeoutConfig', 'updateJob_timeoutConfig' - Specifies the amount of time each device has to finish its execution of -- the job. The timer is started when the job execution status is set to -- @IN_PROGRESS@. If the job execution status is not set to another -- terminal state before the time expires, it will be automatically set to -- @TIMED_OUT@. -- -- 'jobId', 'updateJob_jobId' - The ID of the job to be updated. newUpdateJob :: -- | 'jobId' Prelude.Text -> UpdateJob newUpdateJob pJobId_ = UpdateJob' { abortConfig = Prelude.Nothing, description = Prelude.Nothing, jobExecutionsRetryConfig = Prelude.Nothing, jobExecutionsRolloutConfig = Prelude.Nothing, namespaceId = Prelude.Nothing, presignedUrlConfig = Prelude.Nothing, timeoutConfig = Prelude.Nothing, jobId = pJobId_ } -- | Allows you to create criteria to abort a job. updateJob_abortConfig :: Lens.Lens' UpdateJob (Prelude.Maybe AbortConfig) updateJob_abortConfig = Lens.lens (\UpdateJob' {abortConfig} -> abortConfig) (\s@UpdateJob' {} a -> s {abortConfig = a} :: UpdateJob) -- | A short text description of the job. updateJob_description :: Lens.Lens' UpdateJob (Prelude.Maybe Prelude.Text) updateJob_description = Lens.lens (\UpdateJob' {description} -> description) (\s@UpdateJob' {} a -> s {description = a} :: UpdateJob) -- | Allows you to create the criteria to retry a job. updateJob_jobExecutionsRetryConfig :: Lens.Lens' UpdateJob (Prelude.Maybe JobExecutionsRetryConfig) updateJob_jobExecutionsRetryConfig = Lens.lens (\UpdateJob' {jobExecutionsRetryConfig} -> jobExecutionsRetryConfig) (\s@UpdateJob' {} a -> s {jobExecutionsRetryConfig = a} :: UpdateJob) -- | Allows you to create a staged rollout of the job. updateJob_jobExecutionsRolloutConfig :: Lens.Lens' UpdateJob (Prelude.Maybe JobExecutionsRolloutConfig) updateJob_jobExecutionsRolloutConfig = Lens.lens (\UpdateJob' {jobExecutionsRolloutConfig} -> jobExecutionsRolloutConfig) (\s@UpdateJob' {} a -> s {jobExecutionsRolloutConfig = a} :: UpdateJob) -- | The namespace used to indicate that a job is a customer-managed job. -- -- When you specify a value for this parameter, Amazon Web Services IoT -- Core sends jobs notifications to MQTT topics that contain the value in -- the following format. -- -- @$aws\/things\/@/@THING_NAME@/@\/jobs\/@/@JOB_ID@/@\/notify-namespace-@/@NAMESPACE_ID@/@\/@ -- -- The @namespaceId@ feature is in public preview. updateJob_namespaceId :: Lens.Lens' UpdateJob (Prelude.Maybe Prelude.Text) updateJob_namespaceId = Lens.lens (\UpdateJob' {namespaceId} -> namespaceId) (\s@UpdateJob' {} a -> s {namespaceId = a} :: UpdateJob) -- | Configuration information for pre-signed S3 URLs. updateJob_presignedUrlConfig :: Lens.Lens' UpdateJob (Prelude.Maybe PresignedUrlConfig) updateJob_presignedUrlConfig = Lens.lens (\UpdateJob' {presignedUrlConfig} -> presignedUrlConfig) (\s@UpdateJob' {} a -> s {presignedUrlConfig = a} :: UpdateJob) -- | Specifies the amount of time each device has to finish its execution of -- the job. The timer is started when the job execution status is set to -- @IN_PROGRESS@. If the job execution status is not set to another -- terminal state before the time expires, it will be automatically set to -- @TIMED_OUT@. updateJob_timeoutConfig :: Lens.Lens' UpdateJob (Prelude.Maybe TimeoutConfig) updateJob_timeoutConfig = Lens.lens (\UpdateJob' {timeoutConfig} -> timeoutConfig) (\s@UpdateJob' {} a -> s {timeoutConfig = a} :: UpdateJob) -- | The ID of the job to be updated. updateJob_jobId :: Lens.Lens' UpdateJob Prelude.Text updateJob_jobId = Lens.lens (\UpdateJob' {jobId} -> jobId) (\s@UpdateJob' {} a -> s {jobId = a} :: UpdateJob) instance Core.AWSRequest UpdateJob where type AWSResponse UpdateJob = UpdateJobResponse request overrides = Request.patchJSON (overrides defaultService) response = Response.receiveNull UpdateJobResponse' instance Prelude.Hashable UpdateJob where hashWithSalt _salt UpdateJob' {..} = _salt `Prelude.hashWithSalt` abortConfig `Prelude.hashWithSalt` description `Prelude.hashWithSalt` jobExecutionsRetryConfig `Prelude.hashWithSalt` jobExecutionsRolloutConfig `Prelude.hashWithSalt` namespaceId `Prelude.hashWithSalt` presignedUrlConfig `Prelude.hashWithSalt` timeoutConfig `Prelude.hashWithSalt` jobId instance Prelude.NFData UpdateJob where rnf UpdateJob' {..} = Prelude.rnf abortConfig `Prelude.seq` Prelude.rnf description `Prelude.seq` Prelude.rnf jobExecutionsRetryConfig `Prelude.seq` Prelude.rnf jobExecutionsRolloutConfig `Prelude.seq` Prelude.rnf namespaceId `Prelude.seq` Prelude.rnf presignedUrlConfig `Prelude.seq` Prelude.rnf timeoutConfig `Prelude.seq` Prelude.rnf jobId instance Data.ToHeaders UpdateJob where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON UpdateJob where toJSON UpdateJob' {..} = Data.object ( Prelude.catMaybes [ ("abortConfig" Data..=) Prelude.<$> abortConfig, ("description" Data..=) Prelude.<$> description, ("jobExecutionsRetryConfig" Data..=) Prelude.<$> jobExecutionsRetryConfig, ("jobExecutionsRolloutConfig" Data..=) Prelude.<$> jobExecutionsRolloutConfig, ("presignedUrlConfig" Data..=) Prelude.<$> presignedUrlConfig, ("timeoutConfig" Data..=) Prelude.<$> timeoutConfig ] ) instance Data.ToPath UpdateJob where toPath UpdateJob' {..} = Prelude.mconcat ["/jobs/", Data.toBS jobId] instance Data.ToQuery UpdateJob where toQuery UpdateJob' {..} = Prelude.mconcat ["namespaceId" Data.=: namespaceId] -- | /See:/ 'newUpdateJobResponse' smart constructor. data UpdateJobResponse = UpdateJobResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateJobResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newUpdateJobResponse :: UpdateJobResponse newUpdateJobResponse = UpdateJobResponse' instance Prelude.NFData UpdateJobResponse where rnf _ = ()