{-# 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.CancelJob -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Cancels a job. -- -- Requires permission to access the -- -- action. module Amazonka.IoT.CancelJob ( -- * Creating a Request CancelJob (..), newCancelJob, -- * Request Lenses cancelJob_comment, cancelJob_force, cancelJob_reasonCode, cancelJob_jobId, -- * Destructuring the Response CancelJobResponse (..), newCancelJobResponse, -- * Response Lenses cancelJobResponse_description, cancelJobResponse_jobArn, cancelJobResponse_jobId, cancelJobResponse_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:/ 'newCancelJob' smart constructor. data CancelJob = CancelJob' { -- | An optional comment string describing why the job was canceled. comment :: Prelude.Maybe Prelude.Text, -- | (Optional) If @true@ job executions with status \"IN_PROGRESS\" and -- \"QUEUED\" are canceled, otherwise only job executions with status -- \"QUEUED\" are canceled. The default is @false@. -- -- Canceling a job which is \"IN_PROGRESS\", will cause a device which is -- executing the job to be unable to update the job execution status. Use -- caution and ensure that each device executing a job which is canceled is -- able to recover to a valid state. force :: Prelude.Maybe Prelude.Bool, -- | (Optional)A reason code string that explains why the job was canceled. reasonCode :: Prelude.Maybe Prelude.Text, -- | The unique identifier you assigned to this job when it was created. jobId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CancelJob' 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: -- -- 'comment', 'cancelJob_comment' - An optional comment string describing why the job was canceled. -- -- 'force', 'cancelJob_force' - (Optional) If @true@ job executions with status \"IN_PROGRESS\" and -- \"QUEUED\" are canceled, otherwise only job executions with status -- \"QUEUED\" are canceled. The default is @false@. -- -- Canceling a job which is \"IN_PROGRESS\", will cause a device which is -- executing the job to be unable to update the job execution status. Use -- caution and ensure that each device executing a job which is canceled is -- able to recover to a valid state. -- -- 'reasonCode', 'cancelJob_reasonCode' - (Optional)A reason code string that explains why the job was canceled. -- -- 'jobId', 'cancelJob_jobId' - The unique identifier you assigned to this job when it was created. newCancelJob :: -- | 'jobId' Prelude.Text -> CancelJob newCancelJob pJobId_ = CancelJob' { comment = Prelude.Nothing, force = Prelude.Nothing, reasonCode = Prelude.Nothing, jobId = pJobId_ } -- | An optional comment string describing why the job was canceled. cancelJob_comment :: Lens.Lens' CancelJob (Prelude.Maybe Prelude.Text) cancelJob_comment = Lens.lens (\CancelJob' {comment} -> comment) (\s@CancelJob' {} a -> s {comment = a} :: CancelJob) -- | (Optional) If @true@ job executions with status \"IN_PROGRESS\" and -- \"QUEUED\" are canceled, otherwise only job executions with status -- \"QUEUED\" are canceled. The default is @false@. -- -- Canceling a job which is \"IN_PROGRESS\", will cause a device which is -- executing the job to be unable to update the job execution status. Use -- caution and ensure that each device executing a job which is canceled is -- able to recover to a valid state. cancelJob_force :: Lens.Lens' CancelJob (Prelude.Maybe Prelude.Bool) cancelJob_force = Lens.lens (\CancelJob' {force} -> force) (\s@CancelJob' {} a -> s {force = a} :: CancelJob) -- | (Optional)A reason code string that explains why the job was canceled. cancelJob_reasonCode :: Lens.Lens' CancelJob (Prelude.Maybe Prelude.Text) cancelJob_reasonCode = Lens.lens (\CancelJob' {reasonCode} -> reasonCode) (\s@CancelJob' {} a -> s {reasonCode = a} :: CancelJob) -- | The unique identifier you assigned to this job when it was created. cancelJob_jobId :: Lens.Lens' CancelJob Prelude.Text cancelJob_jobId = Lens.lens (\CancelJob' {jobId} -> jobId) (\s@CancelJob' {} a -> s {jobId = a} :: CancelJob) instance Core.AWSRequest CancelJob where type AWSResponse CancelJob = CancelJobResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CancelJobResponse' Prelude.<$> (x Data..?> "description") Prelude.<*> (x Data..?> "jobArn") Prelude.<*> (x Data..?> "jobId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CancelJob where hashWithSalt _salt CancelJob' {..} = _salt `Prelude.hashWithSalt` comment `Prelude.hashWithSalt` force `Prelude.hashWithSalt` reasonCode `Prelude.hashWithSalt` jobId instance Prelude.NFData CancelJob where rnf CancelJob' {..} = Prelude.rnf comment `Prelude.seq` Prelude.rnf force `Prelude.seq` Prelude.rnf reasonCode `Prelude.seq` Prelude.rnf jobId instance Data.ToHeaders CancelJob where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON CancelJob where toJSON CancelJob' {..} = Data.object ( Prelude.catMaybes [ ("comment" Data..=) Prelude.<$> comment, ("reasonCode" Data..=) Prelude.<$> reasonCode ] ) instance Data.ToPath CancelJob where toPath CancelJob' {..} = Prelude.mconcat ["/jobs/", Data.toBS jobId, "/cancel"] instance Data.ToQuery CancelJob where toQuery CancelJob' {..} = Prelude.mconcat ["force" Data.=: force] -- | /See:/ 'newCancelJobResponse' smart constructor. data CancelJobResponse = CancelJobResponse' { -- | A short text description of the job. description :: Prelude.Maybe Prelude.Text, -- | The job ARN. jobArn :: Prelude.Maybe Prelude.Text, -- | The unique identifier you assigned to this job when it was created. jobId :: 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 'CancelJobResponse' 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: -- -- 'description', 'cancelJobResponse_description' - A short text description of the job. -- -- 'jobArn', 'cancelJobResponse_jobArn' - The job ARN. -- -- 'jobId', 'cancelJobResponse_jobId' - The unique identifier you assigned to this job when it was created. -- -- 'httpStatus', 'cancelJobResponse_httpStatus' - The response's http status code. newCancelJobResponse :: -- | 'httpStatus' Prelude.Int -> CancelJobResponse newCancelJobResponse pHttpStatus_ = CancelJobResponse' { description = Prelude.Nothing, jobArn = Prelude.Nothing, jobId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A short text description of the job. cancelJobResponse_description :: Lens.Lens' CancelJobResponse (Prelude.Maybe Prelude.Text) cancelJobResponse_description = Lens.lens (\CancelJobResponse' {description} -> description) (\s@CancelJobResponse' {} a -> s {description = a} :: CancelJobResponse) -- | The job ARN. cancelJobResponse_jobArn :: Lens.Lens' CancelJobResponse (Prelude.Maybe Prelude.Text) cancelJobResponse_jobArn = Lens.lens (\CancelJobResponse' {jobArn} -> jobArn) (\s@CancelJobResponse' {} a -> s {jobArn = a} :: CancelJobResponse) -- | The unique identifier you assigned to this job when it was created. cancelJobResponse_jobId :: Lens.Lens' CancelJobResponse (Prelude.Maybe Prelude.Text) cancelJobResponse_jobId = Lens.lens (\CancelJobResponse' {jobId} -> jobId) (\s@CancelJobResponse' {} a -> s {jobId = a} :: CancelJobResponse) -- | The response's http status code. cancelJobResponse_httpStatus :: Lens.Lens' CancelJobResponse Prelude.Int cancelJobResponse_httpStatus = Lens.lens (\CancelJobResponse' {httpStatus} -> httpStatus) (\s@CancelJobResponse' {} a -> s {httpStatus = a} :: CancelJobResponse) instance Prelude.NFData CancelJobResponse where rnf CancelJobResponse' {..} = Prelude.rnf description `Prelude.seq` Prelude.rnf jobArn `Prelude.seq` Prelude.rnf jobId `Prelude.seq` Prelude.rnf httpStatus