Source: model/VersionAttributes.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'),
    BaseAttributesExtensionObject = require('./BaseAttributesExtensionObject');



  /**
   * The VersionAttributes model module.
   * @module model/VersionAttributes
   */

  /**
   * Constructs a <code>VersionAttributes</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/VersionAttributes} obj Optional instance to populate.
   * @return {module:model/VersionAttributes} The populated <code>VersionAttributes</code> instance.
   */
  var constructFromObject = function (data, obj) {
    if (data) {
      obj = obj || new exports();

      if (data.hasOwnProperty('name')) {
        obj.name = ApiClient.convertToType(data.name, 'String');
      }
      if (data.hasOwnProperty('displayName')) {
        obj.displayName = ApiClient.convertToType(data.displayName, 'String');
      }
      if (data.hasOwnProperty('versionNumber')) {
        obj.versionNumber = ApiClient.convertToType(data.versionNumber, 'Integer');
      }
      if (data.hasOwnProperty('mimeType')) {
        obj.mimeType = ApiClient.convertToType(data.mimeType, 'String');
      }
      if (data.hasOwnProperty('fileType')) {
        obj.fileType = ApiClient.convertToType(data.fileType, 'String');
      }
      if (data.hasOwnProperty('storageSize')) {
        obj.storageSize = ApiClient.convertToType(data.storageSize, 'Integer');
      }
      if (data.hasOwnProperty('extension')) {
        obj.extension = BaseAttributesExtensionObject.constructFromObject(data.extension);
      }
    }
    return obj;
  };

  /**
   * Constructs a new <code>VersionAttributes</code>.
   * @alias module:model/VersionAttributes
   * @class
   * @param name {String} filename used when synced to local disk
   * @param displayName {String} displayable name of the version
   * @param versionNumber {Integer} version number of this version
   * @param extension {module:model/BaseAttributesExtensionObject} 
   * @param {Object} theData The plain JavaScript object bearing properties of interest.
   * @param {module:model/VersionAttributes} obj Optional instance to populate.
   */
  var exports = function (name, displayName, versionNumber, extension, theData, obj) {
    var _this = this;

    _this.name = name;
    _this.displayName = displayName;
    _this.versionNumber = versionNumber;
    _this.extension = extension;

    return constructFromObject(theData, obj || _this);
  };

  /**
   * Constructs a <code>VersionAttributes</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/VersionAttributes} obj Optional instance to populate.
   * @return {module:model/VersionAttributes} The populated <code>VersionAttributes</code> instance.
   */
  exports.constructFromObject = constructFromObject;

  /**
   * filename used when synced to local disk
   * @member {String} name
   */
  exports.prototype.name = undefined;
  /**
   * displayable name of the version
   * @member {String} displayName
   */
  exports.prototype.displayName = undefined;
  /**
   * version number of this version
   * @member {Integer} versionNumber
   */
  exports.prototype.versionNumber = undefined;
  /**
   * mimetype of the version`s content
   * @member {String} mimeType
   */
  exports.prototype.mimeType = undefined;
  /**
   * file type, only present if this version represents a file
   * @member {String} fileType
   */
  exports.prototype.fileType = undefined;
  /**
   * file size in bytes, only present if this version represents a file
   * @member {Integer} storageSize
   */
  exports.prototype.storageSize = undefined;
  /**
   * @member {module:model/BaseAttributesExtensionObject} extension
   */
  exports.prototype.extension = undefined;



  return exports;
}());