Source: model/JobPayloadDestination.js

/**
 * Forge SDK
 * The Forge Platform contains an expanding collection of web service components that can be used with Autodesk cloud-based products or your own technologies. Take advantage of Autodesk’s expertise in design and engineering.
 *
 * Contact: forge.help@autodesk.com
 *
 * NOTE: This class is auto generated by the swagger code generator program.
 * https://github.com/swagger-api/swagger-codegen.git
 * Do not edit the class manually.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License 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.
 */

module.exports = (function () {
	'use strict';

	var ApiClient = require('../ApiClient');

	/**
	 * The JobPayloadDestination model module.
	 * @module model/JobPayloadDestination
	 */

	/**
	 * Constructs a <code>JobPayloadDestination</code> from a plain JavaScript object, optionally creating a new instance.
	 * Copies all relevant properties from <code>data</code> to <code>obj</code> if supplied or a new instance if not.
	 * @param {Object} data The plain JavaScript object bearing properties of interest.
	 * @param {module:model/JobPayloadDestination} obj Optional instance to populate.
	 * @return {module:model/JobPayloadDestination} The populated <code>JobPayloadDestination</code> instance.
	 */
	var constructFromObject = function (data, obj) {
		if (data) {
			obj = obj || new exports();
			if (data.hasOwnProperty('region'))
				obj.region = ApiClient.convertToType(data.region, 'String');
		}
		return obj;
	};

	/**
	 * Constructs a new <code>JobPayloadDestination</code>.
	 * Group of inputs
	 * @alias module:model/JobPayloadDestination
	 * @class
	 * @param region {module:model/JobPayloadDestination.RegionEnum} Region in which to store outputs. Possible values: US, EMEA. By default, it is set to US.
	 * @param {Object} theData The plain JavaScript object bearing properties of interest.
	 * @param {module:model/JobPayloadDestination} obj Optional instance to populate.
	 */
	var exports = function (region, theData, obj) {
		var _this = this;
		_this.region = region;
		return constructFromObject(theData, obj || _this);
	};

	/**
	 * Constructs a <code>JobPayloadDestination</code> from a plain JavaScript object, optionally creating a new instance.
	 * Copies all relevant properties from <code>data</code> to <code>obj</code> if supplied or a new instance if not.
	 * @param {Object} data The plain JavaScript object bearing properties of interest.
	 * @param {module:model/JobPayloadDestination} obj Optional instance to populate.
	 * @return {module:model/JobPayloadDestination} The populated <code>JobPayloadDestination</code> instance.
	 */
	exports.constructFromObject = constructFromObject;

	/**
	 * Region in which to store outputs. Possible values: US, EMEA. By default, it is set to US.
	 * @member {module:model/JobPayloadDestination.RegionEnum} region
	 */
	exports.prototype.region = 'US';

	/**
	 * Allowed values for the <code>region</code> property.
	 * @enum {String}
	 * @readonly
	 */
	exports.RegionEnum = {
		/**
		 * value: "US"
		 * @const
		 */
		"US": "US",
		/**
		 * value: "EMEA"
		 * @const
		 */
		"EMEA": "EMEA",
		/**
		 * value: "EU"
		 * @const
		 */
		"EU": "EMEA",

	};

	return exports;
}());