/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
/*
* Do not modify this file. This file is generated from the iot-jobs-data-2017-09-29.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.IoTJobsDataPlane.Model
{
///
/// Container for the parameters to the UpdateJobExecution operation.
/// Updates the status of a job execution.
///
public partial class UpdateJobExecutionRequest : AmazonIoTJobsDataPlaneRequest
{
private long? _executionNumber;
private long? _expectedVersion;
private bool? _includeJobDocument;
private bool? _includeJobExecutionState;
private string _jobId;
private JobExecutionStatus _status;
private Dictionary _statusDetails = new Dictionary();
private long? _stepTimeoutInMinutes;
private string _thingName;
///
/// Gets and sets the property ExecutionNumber.
///
/// Optional. A number that identifies a particular job execution on a particular device.
///
///
public long ExecutionNumber
{
get { return this._executionNumber.GetValueOrDefault(); }
set { this._executionNumber = value; }
}
// Check to see if ExecutionNumber property is set
internal bool IsSetExecutionNumber()
{
return this._executionNumber.HasValue;
}
///
/// Gets and sets the property ExpectedVersion.
///
/// Optional. The expected current version of the job execution. Each time you update
/// the job execution, its version is incremented. If the version of the job execution
/// stored in Jobs does not match, the update is rejected with a VersionMismatch error,
/// and an ErrorResponse that contains the current job execution status data is returned.
/// (This makes it unnecessary to perform a separate DescribeJobExecution request in order
/// to obtain the job execution status data.)
///
///
public long ExpectedVersion
{
get { return this._expectedVersion.GetValueOrDefault(); }
set { this._expectedVersion = value; }
}
// Check to see if ExpectedVersion property is set
internal bool IsSetExpectedVersion()
{
return this._expectedVersion.HasValue;
}
///
/// Gets and sets the property IncludeJobDocument.
///
/// Optional. When set to true, the response contains the job document. The default is
/// false.
///
///
public bool IncludeJobDocument
{
get { return this._includeJobDocument.GetValueOrDefault(); }
set { this._includeJobDocument = value; }
}
// Check to see if IncludeJobDocument property is set
internal bool IsSetIncludeJobDocument()
{
return this._includeJobDocument.HasValue;
}
///
/// Gets and sets the property IncludeJobExecutionState.
///
/// Optional. When included and set to true, the response contains the JobExecutionState
/// data. The default is false.
///
///
public bool IncludeJobExecutionState
{
get { return this._includeJobExecutionState.GetValueOrDefault(); }
set { this._includeJobExecutionState = value; }
}
// Check to see if IncludeJobExecutionState property is set
internal bool IsSetIncludeJobExecutionState()
{
return this._includeJobExecutionState.HasValue;
}
///
/// Gets and sets the property JobId.
///
/// The unique identifier assigned to this job when it was created.
///
///
[AWSProperty(Required=true, Min=1, Max=64)]
public string JobId
{
get { return this._jobId; }
set { this._jobId = value; }
}
// Check to see if JobId property is set
internal bool IsSetJobId()
{
return this._jobId != null;
}
///
/// Gets and sets the property Status.
///
/// The new status for the job execution (IN_PROGRESS, FAILED, SUCCESS, or REJECTED).
/// This must be specified on every update.
///
///
[AWSProperty(Required=true)]
public JobExecutionStatus Status
{
get { return this._status; }
set { this._status = value; }
}
// Check to see if Status property is set
internal bool IsSetStatus()
{
return this._status != null;
}
///
/// Gets and sets the property StatusDetails.
///
/// Optional. A collection of name/value pairs that describe the status of the job execution.
/// If not specified, the statusDetails are unchanged.
///
///
public Dictionary StatusDetails
{
get { return this._statusDetails; }
set { this._statusDetails = value; }
}
// Check to see if StatusDetails property is set
internal bool IsSetStatusDetails()
{
return this._statusDetails != null && this._statusDetails.Count > 0;
}
///
/// Gets and sets the property StepTimeoutInMinutes.
///
/// Specifies the amount of time this device has to finish execution of this job. If the
/// job execution status is not set to a terminal state before this timer expires, or
/// before the timer is reset (by again calling UpdateJobExecution
, setting
/// the status to IN_PROGRESS
and specifying a new timeout value in this
/// field) the job execution status will be automatically set to TIMED_OUT
.
/// Note that setting or resetting this timeout has no effect on that job execution timeout
/// which may have been specified when the job was created (CreateJob
using
/// field timeoutConfig
).
///
///
public long StepTimeoutInMinutes
{
get { return this._stepTimeoutInMinutes.GetValueOrDefault(); }
set { this._stepTimeoutInMinutes = value; }
}
// Check to see if StepTimeoutInMinutes property is set
internal bool IsSetStepTimeoutInMinutes()
{
return this._stepTimeoutInMinutes.HasValue;
}
///
/// Gets and sets the property ThingName.
///
/// The name of the thing associated with the device.
///
///
[AWSProperty(Required=true, Min=1, Max=128)]
public string ThingName
{
get { return this._thingName; }
set { this._thingName = value; }
}
// Check to see if ThingName property is set
internal bool IsSetThingName()
{
return this._thingName != null;
}
}
}