Source: stream/index_v1/response_pb.js

// source: sdk/stream/index_v1/response.proto
/**
 * @fileoverview
 * @enhanceable
 * @suppress {missingRequire} reports error on implicit type usages.
 * @suppress {messageConventions} JS Compiler reports an error if a variable or
 *     field starts with 'MSG_' and isn't a translatable message.
 * @public
 */
// GENERATED CODE -- DO NOT EDIT!
/* eslint-disable */
// @ts-nocheck

var jspb = require('google-protobuf');
var goog = jspb;
var global =
    (typeof globalThis !== 'undefined' && globalThis) ||
    (typeof window !== 'undefined' && window) ||
    (typeof global !== 'undefined' && global) ||
    (typeof self !== 'undefined' && self) ||
    (function () { return this; }).call(null) ||
    Function('return this')();

var google_protobuf_timestamp_pb = require('google-protobuf/google/protobuf/timestamp_pb.js');
goog.object.extend(proto, google_protobuf_timestamp_pb);
var sdk_core_data_interval_pb = require('../../../sdk/core/data_interval_pb.js');
goog.object.extend(proto, sdk_core_data_interval_pb);
var sdk_stream_index_v1_commodity_pb = require('../../../sdk/stream/index_v1/commodity_pb.js');
goog.object.extend(proto, sdk_stream_index_v1_commodity_pb);
goog.exportSymbol('proto.kaikosdk.StreamIndexServiceResponseBaseAsset', null, global);
goog.exportSymbol('proto.kaikosdk.StreamIndexServiceResponseInstruments', null, global);
goog.exportSymbol('proto.kaikosdk.StreamIndexServiceResponsePairs', null, global);
goog.exportSymbol('proto.kaikosdk.StreamIndexServiceResponsePercentage', null, global);
goog.exportSymbol('proto.kaikosdk.StreamIndexServiceResponseV1', null, global);
goog.exportSymbol('proto.kaikosdk.StreamIndexServiceUnderlyingTrade', null, global);
/**
 * Generated by JsPbCodeGenerator.
 * @param {Array=} opt_data Optional initial data array, typically from a
 * server response, or constructed directly in Javascript. The array is used
 * in place and becomes part of the constructed object. It is not cloned.
 * If no data is provided, the constructed object will be empty, but still
 * valid.
 * @extends {jspb.Message}
 * @constructor
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage = function(opt_data) {
  jspb.Message.initialize(this, opt_data, 0, -1, proto.kaikosdk.StreamIndexServiceResponsePercentage.repeatedFields_, null);
};
goog.inherits(proto.kaikosdk.StreamIndexServiceResponsePercentage, jspb.Message);
if (goog.DEBUG && !COMPILED) {
  /**
   * @public
   * @override
   */
  proto.kaikosdk.StreamIndexServiceResponsePercentage.displayName = 'proto.kaikosdk.StreamIndexServiceResponsePercentage';
}
/**
 * Generated by JsPbCodeGenerator.
 * @param {Array=} opt_data Optional initial data array, typically from a
 * server response, or constructed directly in Javascript. The array is used
 * in place and becomes part of the constructed object. It is not cloned.
 * If no data is provided, the constructed object will be empty, but still
 * valid.
 * @extends {jspb.Message}
 * @constructor
 */
proto.kaikosdk.StreamIndexServiceResponsePairs = function(opt_data) {
  jspb.Message.initialize(this, opt_data, 0, -1, proto.kaikosdk.StreamIndexServiceResponsePairs.repeatedFields_, null);
};
goog.inherits(proto.kaikosdk.StreamIndexServiceResponsePairs, jspb.Message);
if (goog.DEBUG && !COMPILED) {
  /**
   * @public
   * @override
   */
  proto.kaikosdk.StreamIndexServiceResponsePairs.displayName = 'proto.kaikosdk.StreamIndexServiceResponsePairs';
}
/**
 * Generated by JsPbCodeGenerator.
 * @param {Array=} opt_data Optional initial data array, typically from a
 * server response, or constructed directly in Javascript. The array is used
 * in place and becomes part of the constructed object. It is not cloned.
 * If no data is provided, the constructed object will be empty, but still
 * valid.
 * @extends {jspb.Message}
 * @constructor
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade = function(opt_data) {
  jspb.Message.initialize(this, opt_data, 0, -1, null, null);
};
goog.inherits(proto.kaikosdk.StreamIndexServiceUnderlyingTrade, jspb.Message);
if (goog.DEBUG && !COMPILED) {
  /**
   * @public
   * @override
   */
  proto.kaikosdk.StreamIndexServiceUnderlyingTrade.displayName = 'proto.kaikosdk.StreamIndexServiceUnderlyingTrade';
}
/**
 * Generated by JsPbCodeGenerator.
 * @param {Array=} opt_data Optional initial data array, typically from a
 * server response, or constructed directly in Javascript. The array is used
 * in place and becomes part of the constructed object. It is not cloned.
 * If no data is provided, the constructed object will be empty, but still
 * valid.
 * @extends {jspb.Message}
 * @constructor
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments = function(opt_data) {
  jspb.Message.initialize(this, opt_data, 0, -1, null, null);
};
goog.inherits(proto.kaikosdk.StreamIndexServiceResponseInstruments, jspb.Message);
if (goog.DEBUG && !COMPILED) {
  /**
   * @public
   * @override
   */
  proto.kaikosdk.StreamIndexServiceResponseInstruments.displayName = 'proto.kaikosdk.StreamIndexServiceResponseInstruments';
}
/**
 * Generated by JsPbCodeGenerator.
 * @param {Array=} opt_data Optional initial data array, typically from a
 * server response, or constructed directly in Javascript. The array is used
 * in place and becomes part of the constructed object. It is not cloned.
 * If no data is provided, the constructed object will be empty, but still
 * valid.
 * @extends {jspb.Message}
 * @constructor
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset = function(opt_data) {
  jspb.Message.initialize(this, opt_data, 0, -1, null, null);
};
goog.inherits(proto.kaikosdk.StreamIndexServiceResponseBaseAsset, jspb.Message);
if (goog.DEBUG && !COMPILED) {
  /**
   * @public
   * @override
   */
  proto.kaikosdk.StreamIndexServiceResponseBaseAsset.displayName = 'proto.kaikosdk.StreamIndexServiceResponseBaseAsset';
}
/**
 * Generated by JsPbCodeGenerator.
 * @param {Array=} opt_data Optional initial data array, typically from a
 * server response, or constructed directly in Javascript. The array is used
 * in place and becomes part of the constructed object. It is not cloned.
 * If no data is provided, the constructed object will be empty, but still
 * valid.
 * @extends {jspb.Message}
 * @constructor
 */
proto.kaikosdk.StreamIndexServiceResponseV1 = function(opt_data) {
  jspb.Message.initialize(this, opt_data, 0, -1, proto.kaikosdk.StreamIndexServiceResponseV1.repeatedFields_, null);
};
goog.inherits(proto.kaikosdk.StreamIndexServiceResponseV1, jspb.Message);
if (goog.DEBUG && !COMPILED) {
  /**
   * @public
   * @override
   */
  proto.kaikosdk.StreamIndexServiceResponseV1.displayName = 'proto.kaikosdk.StreamIndexServiceResponseV1';
}

/**
 * List of repeated fields within this message type.
 * @private {!Array<number>}
 * @const
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.repeatedFields_ = [3];



if (jspb.Message.GENERATE_TO_OBJECT) {
/**
 * Creates an object representation of this proto.
 * Field names that are reserved in JavaScript and will be renamed to pb_name.
 * Optional fields that are not set will be set to undefined.
 * To access a reserved field use, foo.pb_<name>, eg, foo.pb_default.
 * For the list of reserved names please see:
 *     net/proto2/compiler/js/internal/generator.cc#kKeyword.
 * @param {boolean=} opt_includeInstance Deprecated. whether to include the
 *     JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @return {!Object}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.toObject = function(opt_includeInstance) {
  return proto.kaikosdk.StreamIndexServiceResponsePercentage.toObject(opt_includeInstance, this);
};


/**
 * Static version of the {@see toObject} method.
 * @param {boolean|undefined} includeInstance Deprecated. Whether to include
 *     the JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePercentage} msg The msg instance to transform.
 * @return {!Object}
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.toObject = function(includeInstance, msg) {
  var f, obj = {
    percentage: jspb.Message.getFloatingPointFieldWithDefault(msg, 1, 0.0),
    price: jspb.Message.getFloatingPointFieldWithDefault(msg, 2, 0.0),
    pairsList: jspb.Message.toObjectList(msg.getPairsList(),
    proto.kaikosdk.StreamIndexServiceResponsePairs.toObject, includeInstance)
  };

  if (includeInstance) {
    obj.$jspbMessageInstance = msg;
  }
  return obj;
};
}


/**
 * Deserializes binary data (in protobuf wire format).
 * @param {jspb.ByteSource} bytes The bytes to deserialize.
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePercentage}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.deserializeBinary = function(bytes) {
  var reader = new jspb.BinaryReader(bytes);
  var msg = new proto.kaikosdk.StreamIndexServiceResponsePercentage;
  return proto.kaikosdk.StreamIndexServiceResponsePercentage.deserializeBinaryFromReader(msg, reader);
};


/**
 * Deserializes binary data (in protobuf wire format) from the
 * given reader into the given message object.
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePercentage} msg The message object to deserialize into.
 * @param {!jspb.BinaryReader} reader The BinaryReader to use.
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePercentage}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.deserializeBinaryFromReader = function(msg, reader) {
  while (reader.nextField()) {
    if (reader.isEndGroup()) {
      break;
    }
    var field = reader.getFieldNumber();
    switch (field) {
    case 1:
      var value = /** @type {number} */ (reader.readDouble());
      msg.setPercentage(value);
      break;
    case 2:
      var value = /** @type {number} */ (reader.readDouble());
      msg.setPrice(value);
      break;
    case 3:
      var value = new proto.kaikosdk.StreamIndexServiceResponsePairs;
      reader.readMessage(value,proto.kaikosdk.StreamIndexServiceResponsePairs.deserializeBinaryFromReader);
      msg.addPairs(value);
      break;
    default:
      reader.skipField();
      break;
    }
  }
  return msg;
};


/**
 * Serializes the message to binary data (in protobuf wire format).
 * @return {!Uint8Array}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.serializeBinary = function() {
  var writer = new jspb.BinaryWriter();
  proto.kaikosdk.StreamIndexServiceResponsePercentage.serializeBinaryToWriter(this, writer);
  return writer.getResultBuffer();
};


/**
 * Serializes the given message to binary data (in protobuf wire
 * format), writing to the given BinaryWriter.
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePercentage} message
 * @param {!jspb.BinaryWriter} writer
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.serializeBinaryToWriter = function(message, writer) {
  var f = undefined;
  f = message.getPercentage();
  if (f !== 0.0) {
    writer.writeDouble(
      1,
      f
    );
  }
  f = message.getPrice();
  if (f !== 0.0) {
    writer.writeDouble(
      2,
      f
    );
  }
  f = message.getPairsList();
  if (f.length > 0) {
    writer.writeRepeatedMessage(
      3,
      f,
      proto.kaikosdk.StreamIndexServiceResponsePairs.serializeBinaryToWriter
    );
  }
};


/**
 * optional double percentage = 1;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.getPercentage = function() {
  return /** @type {number} */ (jspb.Message.getFloatingPointFieldWithDefault(this, 1, 0.0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePercentage} returns this
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.setPercentage = function(value) {
  return jspb.Message.setProto3FloatField(this, 1, value);
};


/**
 * optional double price = 2;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.getPrice = function() {
  return /** @type {number} */ (jspb.Message.getFloatingPointFieldWithDefault(this, 2, 0.0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePercentage} returns this
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.setPrice = function(value) {
  return jspb.Message.setProto3FloatField(this, 2, value);
};


/**
 * repeated StreamIndexServiceResponsePairs pairs = 3;
 * @return {!Array<!proto.kaikosdk.StreamIndexServiceResponsePairs>}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.getPairsList = function() {
  return /** @type{!Array<!proto.kaikosdk.StreamIndexServiceResponsePairs>} */ (
    jspb.Message.getRepeatedWrapperField(this, proto.kaikosdk.StreamIndexServiceResponsePairs, 3));
};


/**
 * @param {!Array<!proto.kaikosdk.StreamIndexServiceResponsePairs>} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePercentage} returns this
*/
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.setPairsList = function(value) {
  return jspb.Message.setRepeatedWrapperField(this, 3, value);
};


/**
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePairs=} opt_value
 * @param {number=} opt_index
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePairs}
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.addPairs = function(opt_value, opt_index) {
  return jspb.Message.addToRepeatedWrapperField(this, 3, opt_value, proto.kaikosdk.StreamIndexServiceResponsePairs, opt_index);
};


/**
 * Clears the list making it empty but non-null.
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePercentage} returns this
 */
proto.kaikosdk.StreamIndexServiceResponsePercentage.prototype.clearPairsList = function() {
  return this.setPairsList([]);
};



/**
 * List of repeated fields within this message type.
 * @private {!Array<number>}
 * @const
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.repeatedFields_ = [3];



if (jspb.Message.GENERATE_TO_OBJECT) {
/**
 * Creates an object representation of this proto.
 * Field names that are reserved in JavaScript and will be renamed to pb_name.
 * Optional fields that are not set will be set to undefined.
 * To access a reserved field use, foo.pb_<name>, eg, foo.pb_default.
 * For the list of reserved names please see:
 *     net/proto2/compiler/js/internal/generator.cc#kKeyword.
 * @param {boolean=} opt_includeInstance Deprecated. whether to include the
 *     JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @return {!Object}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.toObject = function(opt_includeInstance) {
  return proto.kaikosdk.StreamIndexServiceResponsePairs.toObject(opt_includeInstance, this);
};


/**
 * Static version of the {@see toObject} method.
 * @param {boolean|undefined} includeInstance Deprecated. Whether to include
 *     the JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePairs} msg The msg instance to transform.
 * @return {!Object}
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.toObject = function(includeInstance, msg) {
  var f, obj = {
    pair: jspb.Message.getFieldWithDefault(msg, 1, ""),
    weight: jspb.Message.getFloatingPointFieldWithDefault(msg, 2, 0.0),
    instrumentsList: jspb.Message.toObjectList(msg.getInstrumentsList(),
    proto.kaikosdk.StreamIndexServiceResponseInstruments.toObject, includeInstance)
  };

  if (includeInstance) {
    obj.$jspbMessageInstance = msg;
  }
  return obj;
};
}


/**
 * Deserializes binary data (in protobuf wire format).
 * @param {jspb.ByteSource} bytes The bytes to deserialize.
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePairs}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.deserializeBinary = function(bytes) {
  var reader = new jspb.BinaryReader(bytes);
  var msg = new proto.kaikosdk.StreamIndexServiceResponsePairs;
  return proto.kaikosdk.StreamIndexServiceResponsePairs.deserializeBinaryFromReader(msg, reader);
};


/**
 * Deserializes binary data (in protobuf wire format) from the
 * given reader into the given message object.
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePairs} msg The message object to deserialize into.
 * @param {!jspb.BinaryReader} reader The BinaryReader to use.
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePairs}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.deserializeBinaryFromReader = function(msg, reader) {
  while (reader.nextField()) {
    if (reader.isEndGroup()) {
      break;
    }
    var field = reader.getFieldNumber();
    switch (field) {
    case 1:
      var value = /** @type {string} */ (reader.readString());
      msg.setPair(value);
      break;
    case 2:
      var value = /** @type {number} */ (reader.readDouble());
      msg.setWeight(value);
      break;
    case 3:
      var value = new proto.kaikosdk.StreamIndexServiceResponseInstruments;
      reader.readMessage(value,proto.kaikosdk.StreamIndexServiceResponseInstruments.deserializeBinaryFromReader);
      msg.addInstruments(value);
      break;
    default:
      reader.skipField();
      break;
    }
  }
  return msg;
};


/**
 * Serializes the message to binary data (in protobuf wire format).
 * @return {!Uint8Array}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.serializeBinary = function() {
  var writer = new jspb.BinaryWriter();
  proto.kaikosdk.StreamIndexServiceResponsePairs.serializeBinaryToWriter(this, writer);
  return writer.getResultBuffer();
};


/**
 * Serializes the given message to binary data (in protobuf wire
 * format), writing to the given BinaryWriter.
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePairs} message
 * @param {!jspb.BinaryWriter} writer
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.serializeBinaryToWriter = function(message, writer) {
  var f = undefined;
  f = message.getPair();
  if (f.length > 0) {
    writer.writeString(
      1,
      f
    );
  }
  f = message.getWeight();
  if (f !== 0.0) {
    writer.writeDouble(
      2,
      f
    );
  }
  f = message.getInstrumentsList();
  if (f.length > 0) {
    writer.writeRepeatedMessage(
      3,
      f,
      proto.kaikosdk.StreamIndexServiceResponseInstruments.serializeBinaryToWriter
    );
  }
};


/**
 * optional string pair = 1;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.getPair = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 1, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePairs} returns this
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.setPair = function(value) {
  return jspb.Message.setProto3StringField(this, 1, value);
};


/**
 * optional double weight = 2;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.getWeight = function() {
  return /** @type {number} */ (jspb.Message.getFloatingPointFieldWithDefault(this, 2, 0.0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePairs} returns this
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.setWeight = function(value) {
  return jspb.Message.setProto3FloatField(this, 2, value);
};


/**
 * repeated StreamIndexServiceResponseInstruments instruments = 3;
 * @return {!Array<!proto.kaikosdk.StreamIndexServiceResponseInstruments>}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.getInstrumentsList = function() {
  return /** @type{!Array<!proto.kaikosdk.StreamIndexServiceResponseInstruments>} */ (
    jspb.Message.getRepeatedWrapperField(this, proto.kaikosdk.StreamIndexServiceResponseInstruments, 3));
};


/**
 * @param {!Array<!proto.kaikosdk.StreamIndexServiceResponseInstruments>} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePairs} returns this
*/
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.setInstrumentsList = function(value) {
  return jspb.Message.setRepeatedWrapperField(this, 3, value);
};


/**
 * @param {!proto.kaikosdk.StreamIndexServiceResponseInstruments=} opt_value
 * @param {number=} opt_index
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments}
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.addInstruments = function(opt_value, opt_index) {
  return jspb.Message.addToRepeatedWrapperField(this, 3, opt_value, proto.kaikosdk.StreamIndexServiceResponseInstruments, opt_index);
};


/**
 * Clears the list making it empty but non-null.
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePairs} returns this
 */
proto.kaikosdk.StreamIndexServiceResponsePairs.prototype.clearInstrumentsList = function() {
  return this.setInstrumentsList([]);
};





if (jspb.Message.GENERATE_TO_OBJECT) {
/**
 * Creates an object representation of this proto.
 * Field names that are reserved in JavaScript and will be renamed to pb_name.
 * Optional fields that are not set will be set to undefined.
 * To access a reserved field use, foo.pb_<name>, eg, foo.pb_default.
 * For the list of reserved names please see:
 *     net/proto2/compiler/js/internal/generator.cc#kKeyword.
 * @param {boolean=} opt_includeInstance Deprecated. whether to include the
 *     JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @return {!Object}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.toObject = function(opt_includeInstance) {
  return proto.kaikosdk.StreamIndexServiceUnderlyingTrade.toObject(opt_includeInstance, this);
};


/**
 * Static version of the {@see toObject} method.
 * @param {boolean|undefined} includeInstance Deprecated. Whether to include
 *     the JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @param {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} msg The msg instance to transform.
 * @return {!Object}
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.toObject = function(includeInstance, msg) {
  var f, obj = {
    volume: jspb.Message.getFloatingPointFieldWithDefault(msg, 1, 0.0),
    exchange: jspb.Message.getFieldWithDefault(msg, 2, ""),
    id: jspb.Message.getFieldWithDefault(msg, 3, ""),
    datetime: (f = msg.getDatetime()) && google_protobuf_timestamp_pb.Timestamp.toObject(includeInstance, f)
  };

  if (includeInstance) {
    obj.$jspbMessageInstance = msg;
  }
  return obj;
};
}


/**
 * Deserializes binary data (in protobuf wire format).
 * @param {jspb.ByteSource} bytes The bytes to deserialize.
 * @return {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.deserializeBinary = function(bytes) {
  var reader = new jspb.BinaryReader(bytes);
  var msg = new proto.kaikosdk.StreamIndexServiceUnderlyingTrade;
  return proto.kaikosdk.StreamIndexServiceUnderlyingTrade.deserializeBinaryFromReader(msg, reader);
};


/**
 * Deserializes binary data (in protobuf wire format) from the
 * given reader into the given message object.
 * @param {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} msg The message object to deserialize into.
 * @param {!jspb.BinaryReader} reader The BinaryReader to use.
 * @return {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.deserializeBinaryFromReader = function(msg, reader) {
  while (reader.nextField()) {
    if (reader.isEndGroup()) {
      break;
    }
    var field = reader.getFieldNumber();
    switch (field) {
    case 1:
      var value = /** @type {number} */ (reader.readDouble());
      msg.setVolume(value);
      break;
    case 2:
      var value = /** @type {string} */ (reader.readString());
      msg.setExchange(value);
      break;
    case 3:
      var value = /** @type {string} */ (reader.readString());
      msg.setId(value);
      break;
    case 4:
      var value = new google_protobuf_timestamp_pb.Timestamp;
      reader.readMessage(value,google_protobuf_timestamp_pb.Timestamp.deserializeBinaryFromReader);
      msg.setDatetime(value);
      break;
    default:
      reader.skipField();
      break;
    }
  }
  return msg;
};


/**
 * Serializes the message to binary data (in protobuf wire format).
 * @return {!Uint8Array}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.serializeBinary = function() {
  var writer = new jspb.BinaryWriter();
  proto.kaikosdk.StreamIndexServiceUnderlyingTrade.serializeBinaryToWriter(this, writer);
  return writer.getResultBuffer();
};


/**
 * Serializes the given message to binary data (in protobuf wire
 * format), writing to the given BinaryWriter.
 * @param {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} message
 * @param {!jspb.BinaryWriter} writer
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.serializeBinaryToWriter = function(message, writer) {
  var f = undefined;
  f = message.getVolume();
  if (f !== 0.0) {
    writer.writeDouble(
      1,
      f
    );
  }
  f = message.getExchange();
  if (f.length > 0) {
    writer.writeString(
      2,
      f
    );
  }
  f = message.getId();
  if (f.length > 0) {
    writer.writeString(
      3,
      f
    );
  }
  f = message.getDatetime();
  if (f != null) {
    writer.writeMessage(
      4,
      f,
      google_protobuf_timestamp_pb.Timestamp.serializeBinaryToWriter
    );
  }
};


/**
 * optional double volume = 1;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.getVolume = function() {
  return /** @type {number} */ (jspb.Message.getFloatingPointFieldWithDefault(this, 1, 0.0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} returns this
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.setVolume = function(value) {
  return jspb.Message.setProto3FloatField(this, 1, value);
};


/**
 * optional string exchange = 2;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.getExchange = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 2, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} returns this
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.setExchange = function(value) {
  return jspb.Message.setProto3StringField(this, 2, value);
};


/**
 * optional string id = 3;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.getId = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 3, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} returns this
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.setId = function(value) {
  return jspb.Message.setProto3StringField(this, 3, value);
};


/**
 * optional google.protobuf.Timestamp datetime = 4;
 * @return {?proto.google.protobuf.Timestamp}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.getDatetime = function() {
  return /** @type{?proto.google.protobuf.Timestamp} */ (
    jspb.Message.getWrapperField(this, google_protobuf_timestamp_pb.Timestamp, 4));
};


/**
 * @param {?proto.google.protobuf.Timestamp|undefined} value
 * @return {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} returns this
*/
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.setDatetime = function(value) {
  return jspb.Message.setWrapperField(this, 4, value);
};


/**
 * Clears the message field making it undefined.
 * @return {!proto.kaikosdk.StreamIndexServiceUnderlyingTrade} returns this
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.clearDatetime = function() {
  return this.setDatetime(undefined);
};


/**
 * Returns whether this field is set.
 * @return {boolean}
 */
proto.kaikosdk.StreamIndexServiceUnderlyingTrade.prototype.hasDatetime = function() {
  return jspb.Message.getField(this, 4) != null;
};





if (jspb.Message.GENERATE_TO_OBJECT) {
/**
 * Creates an object representation of this proto.
 * Field names that are reserved in JavaScript and will be renamed to pb_name.
 * Optional fields that are not set will be set to undefined.
 * To access a reserved field use, foo.pb_<name>, eg, foo.pb_default.
 * For the list of reserved names please see:
 *     net/proto2/compiler/js/internal/generator.cc#kKeyword.
 * @param {boolean=} opt_includeInstance Deprecated. whether to include the
 *     JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @return {!Object}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.toObject = function(opt_includeInstance) {
  return proto.kaikosdk.StreamIndexServiceResponseInstruments.toObject(opt_includeInstance, this);
};


/**
 * Static version of the {@see toObject} method.
 * @param {boolean|undefined} includeInstance Deprecated. Whether to include
 *     the JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @param {!proto.kaikosdk.StreamIndexServiceResponseInstruments} msg The msg instance to transform.
 * @return {!Object}
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.toObject = function(includeInstance, msg) {
  var f, obj = {
    partition: jspb.Message.getFieldWithDefault(msg, 1, ""),
    price: jspb.Message.getFloatingPointFieldWithDefault(msg, 2, 0.0),
    volume: jspb.Message.getFloatingPointFieldWithDefault(msg, 3, 0.0),
    count: jspb.Message.getFieldWithDefault(msg, 4, 0),
    underlyingTrade: (f = msg.getUnderlyingTrade()) && proto.kaikosdk.StreamIndexServiceUnderlyingTrade.toObject(includeInstance, f)
  };

  if (includeInstance) {
    obj.$jspbMessageInstance = msg;
  }
  return obj;
};
}


/**
 * Deserializes binary data (in protobuf wire format).
 * @param {jspb.ByteSource} bytes The bytes to deserialize.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.deserializeBinary = function(bytes) {
  var reader = new jspb.BinaryReader(bytes);
  var msg = new proto.kaikosdk.StreamIndexServiceResponseInstruments;
  return proto.kaikosdk.StreamIndexServiceResponseInstruments.deserializeBinaryFromReader(msg, reader);
};


/**
 * Deserializes binary data (in protobuf wire format) from the
 * given reader into the given message object.
 * @param {!proto.kaikosdk.StreamIndexServiceResponseInstruments} msg The message object to deserialize into.
 * @param {!jspb.BinaryReader} reader The BinaryReader to use.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.deserializeBinaryFromReader = function(msg, reader) {
  while (reader.nextField()) {
    if (reader.isEndGroup()) {
      break;
    }
    var field = reader.getFieldNumber();
    switch (field) {
    case 1:
      var value = /** @type {string} */ (reader.readString());
      msg.setPartition(value);
      break;
    case 2:
      var value = /** @type {number} */ (reader.readDouble());
      msg.setPrice(value);
      break;
    case 3:
      var value = /** @type {number} */ (reader.readDouble());
      msg.setVolume(value);
      break;
    case 4:
      var value = /** @type {number} */ (reader.readUint64());
      msg.setCount(value);
      break;
    case 5:
      var value = new proto.kaikosdk.StreamIndexServiceUnderlyingTrade;
      reader.readMessage(value,proto.kaikosdk.StreamIndexServiceUnderlyingTrade.deserializeBinaryFromReader);
      msg.setUnderlyingTrade(value);
      break;
    default:
      reader.skipField();
      break;
    }
  }
  return msg;
};


/**
 * Serializes the message to binary data (in protobuf wire format).
 * @return {!Uint8Array}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.serializeBinary = function() {
  var writer = new jspb.BinaryWriter();
  proto.kaikosdk.StreamIndexServiceResponseInstruments.serializeBinaryToWriter(this, writer);
  return writer.getResultBuffer();
};


/**
 * Serializes the given message to binary data (in protobuf wire
 * format), writing to the given BinaryWriter.
 * @param {!proto.kaikosdk.StreamIndexServiceResponseInstruments} message
 * @param {!jspb.BinaryWriter} writer
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.serializeBinaryToWriter = function(message, writer) {
  var f = undefined;
  f = message.getPartition();
  if (f.length > 0) {
    writer.writeString(
      1,
      f
    );
  }
  f = message.getPrice();
  if (f !== 0.0) {
    writer.writeDouble(
      2,
      f
    );
  }
  f = message.getVolume();
  if (f !== 0.0) {
    writer.writeDouble(
      3,
      f
    );
  }
  f = message.getCount();
  if (f !== 0) {
    writer.writeUint64(
      4,
      f
    );
  }
  f = message.getUnderlyingTrade();
  if (f != null) {
    writer.writeMessage(
      5,
      f,
      proto.kaikosdk.StreamIndexServiceUnderlyingTrade.serializeBinaryToWriter
    );
  }
};


/**
 * optional string partition = 1;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.getPartition = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 1, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.setPartition = function(value) {
  return jspb.Message.setProto3StringField(this, 1, value);
};


/**
 * optional double price = 2;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.getPrice = function() {
  return /** @type {number} */ (jspb.Message.getFloatingPointFieldWithDefault(this, 2, 0.0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.setPrice = function(value) {
  return jspb.Message.setProto3FloatField(this, 2, value);
};


/**
 * optional double volume = 3;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.getVolume = function() {
  return /** @type {number} */ (jspb.Message.getFloatingPointFieldWithDefault(this, 3, 0.0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.setVolume = function(value) {
  return jspb.Message.setProto3FloatField(this, 3, value);
};


/**
 * optional uint64 count = 4;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.getCount = function() {
  return /** @type {number} */ (jspb.Message.getFieldWithDefault(this, 4, 0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.setCount = function(value) {
  return jspb.Message.setProto3IntField(this, 4, value);
};


/**
 * optional StreamIndexServiceUnderlyingTrade underlying_trade = 5;
 * @return {?proto.kaikosdk.StreamIndexServiceUnderlyingTrade}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.getUnderlyingTrade = function() {
  return /** @type{?proto.kaikosdk.StreamIndexServiceUnderlyingTrade} */ (
    jspb.Message.getWrapperField(this, proto.kaikosdk.StreamIndexServiceUnderlyingTrade, 5));
};


/**
 * @param {?proto.kaikosdk.StreamIndexServiceUnderlyingTrade|undefined} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments} returns this
*/
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.setUnderlyingTrade = function(value) {
  return jspb.Message.setWrapperField(this, 5, value);
};


/**
 * Clears the message field making it undefined.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseInstruments} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.clearUnderlyingTrade = function() {
  return this.setUnderlyingTrade(undefined);
};


/**
 * Returns whether this field is set.
 * @return {boolean}
 */
proto.kaikosdk.StreamIndexServiceResponseInstruments.prototype.hasUnderlyingTrade = function() {
  return jspb.Message.getField(this, 5) != null;
};





if (jspb.Message.GENERATE_TO_OBJECT) {
/**
 * Creates an object representation of this proto.
 * Field names that are reserved in JavaScript and will be renamed to pb_name.
 * Optional fields that are not set will be set to undefined.
 * To access a reserved field use, foo.pb_<name>, eg, foo.pb_default.
 * For the list of reserved names please see:
 *     net/proto2/compiler/js/internal/generator.cc#kKeyword.
 * @param {boolean=} opt_includeInstance Deprecated. whether to include the
 *     JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @return {!Object}
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.prototype.toObject = function(opt_includeInstance) {
  return proto.kaikosdk.StreamIndexServiceResponseBaseAsset.toObject(opt_includeInstance, this);
};


/**
 * Static version of the {@see toObject} method.
 * @param {boolean|undefined} includeInstance Deprecated. Whether to include
 *     the JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @param {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset} msg The msg instance to transform.
 * @return {!Object}
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.toObject = function(includeInstance, msg) {
  var f, obj = {
    asset: jspb.Message.getFieldWithDefault(msg, 1, ""),
    weight: jspb.Message.getFloatingPointFieldWithDefault(msg, 2, 0.0)
  };

  if (includeInstance) {
    obj.$jspbMessageInstance = msg;
  }
  return obj;
};
}


/**
 * Deserializes binary data (in protobuf wire format).
 * @param {jspb.ByteSource} bytes The bytes to deserialize.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset}
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.deserializeBinary = function(bytes) {
  var reader = new jspb.BinaryReader(bytes);
  var msg = new proto.kaikosdk.StreamIndexServiceResponseBaseAsset;
  return proto.kaikosdk.StreamIndexServiceResponseBaseAsset.deserializeBinaryFromReader(msg, reader);
};


/**
 * Deserializes binary data (in protobuf wire format) from the
 * given reader into the given message object.
 * @param {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset} msg The message object to deserialize into.
 * @param {!jspb.BinaryReader} reader The BinaryReader to use.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset}
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.deserializeBinaryFromReader = function(msg, reader) {
  while (reader.nextField()) {
    if (reader.isEndGroup()) {
      break;
    }
    var field = reader.getFieldNumber();
    switch (field) {
    case 1:
      var value = /** @type {string} */ (reader.readString());
      msg.setAsset(value);
      break;
    case 2:
      var value = /** @type {number} */ (reader.readDouble());
      msg.setWeight(value);
      break;
    default:
      reader.skipField();
      break;
    }
  }
  return msg;
};


/**
 * Serializes the message to binary data (in protobuf wire format).
 * @return {!Uint8Array}
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.prototype.serializeBinary = function() {
  var writer = new jspb.BinaryWriter();
  proto.kaikosdk.StreamIndexServiceResponseBaseAsset.serializeBinaryToWriter(this, writer);
  return writer.getResultBuffer();
};


/**
 * Serializes the given message to binary data (in protobuf wire
 * format), writing to the given BinaryWriter.
 * @param {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset} message
 * @param {!jspb.BinaryWriter} writer
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.serializeBinaryToWriter = function(message, writer) {
  var f = undefined;
  f = message.getAsset();
  if (f.length > 0) {
    writer.writeString(
      1,
      f
    );
  }
  f = message.getWeight();
  if (f !== 0.0) {
    writer.writeDouble(
      2,
      f
    );
  }
};


/**
 * optional string asset = 1;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.prototype.getAsset = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 1, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.prototype.setAsset = function(value) {
  return jspb.Message.setProto3StringField(this, 1, value);
};


/**
 * optional double weight = 2;
 * @return {number}
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.prototype.getWeight = function() {
  return /** @type {number} */ (jspb.Message.getFloatingPointFieldWithDefault(this, 2, 0.0));
};


/**
 * @param {number} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseBaseAsset.prototype.setWeight = function(value) {
  return jspb.Message.setProto3FloatField(this, 2, value);
};



/**
 * List of repeated fields within this message type.
 * @private {!Array<number>}
 * @const
 */
proto.kaikosdk.StreamIndexServiceResponseV1.repeatedFields_ = [5,6,7];



if (jspb.Message.GENERATE_TO_OBJECT) {
/**
 * Creates an object representation of this proto.
 * Field names that are reserved in JavaScript and will be renamed to pb_name.
 * Optional fields that are not set will be set to undefined.
 * To access a reserved field use, foo.pb_<name>, eg, foo.pb_default.
 * For the list of reserved names please see:
 *     net/proto2/compiler/js/internal/generator.cc#kKeyword.
 * @param {boolean=} opt_includeInstance Deprecated. whether to include the
 *     JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @return {!Object}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.toObject = function(opt_includeInstance) {
  return proto.kaikosdk.StreamIndexServiceResponseV1.toObject(opt_includeInstance, this);
};


/**
 * Static version of the {@see toObject} method.
 * @param {boolean|undefined} includeInstance Deprecated. Whether to include
 *     the JSPB instance for transitional soy proto support:
 *     http://goto/soy-param-migration
 * @param {!proto.kaikosdk.StreamIndexServiceResponseV1} msg The msg instance to transform.
 * @return {!Object}
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponseV1.toObject = function(includeInstance, msg) {
  var f, obj = {
    indexCode: jspb.Message.getFieldWithDefault(msg, 1, ""),
    commodity: jspb.Message.getFieldWithDefault(msg, 2, 0),
    interval: (f = msg.getInterval()) && sdk_core_data_interval_pb.DataInterval.toObject(includeInstance, f),
    quote: jspb.Message.getFieldWithDefault(msg, 4, ""),
    basesList: jspb.Message.toObjectList(msg.getBasesList(),
    proto.kaikosdk.StreamIndexServiceResponseBaseAsset.toObject, includeInstance),
    exchangesList: (f = jspb.Message.getRepeatedField(msg, 6)) == null ? undefined : f,
    percentagesList: jspb.Message.toObjectList(msg.getPercentagesList(),
    proto.kaikosdk.StreamIndexServiceResponsePercentage.toObject, includeInstance),
    tsEvent: (f = msg.getTsEvent()) && google_protobuf_timestamp_pb.Timestamp.toObject(includeInstance, f),
    sequenceId: jspb.Message.getFieldWithDefault(msg, 9, ""),
    lastIngestTime: (f = msg.getLastIngestTime()) && google_protobuf_timestamp_pb.Timestamp.toObject(includeInstance, f)
  };

  if (includeInstance) {
    obj.$jspbMessageInstance = msg;
  }
  return obj;
};
}


/**
 * Deserializes binary data (in protobuf wire format).
 * @param {jspb.ByteSource} bytes The bytes to deserialize.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.deserializeBinary = function(bytes) {
  var reader = new jspb.BinaryReader(bytes);
  var msg = new proto.kaikosdk.StreamIndexServiceResponseV1;
  return proto.kaikosdk.StreamIndexServiceResponseV1.deserializeBinaryFromReader(msg, reader);
};


/**
 * Deserializes binary data (in protobuf wire format) from the
 * given reader into the given message object.
 * @param {!proto.kaikosdk.StreamIndexServiceResponseV1} msg The message object to deserialize into.
 * @param {!jspb.BinaryReader} reader The BinaryReader to use.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.deserializeBinaryFromReader = function(msg, reader) {
  while (reader.nextField()) {
    if (reader.isEndGroup()) {
      break;
    }
    var field = reader.getFieldNumber();
    switch (field) {
    case 1:
      var value = /** @type {string} */ (reader.readString());
      msg.setIndexCode(value);
      break;
    case 2:
      var value = /** @type {!proto.kaikosdk.StreamIndexCommodity} */ (reader.readEnum());
      msg.setCommodity(value);
      break;
    case 3:
      var value = new sdk_core_data_interval_pb.DataInterval;
      reader.readMessage(value,sdk_core_data_interval_pb.DataInterval.deserializeBinaryFromReader);
      msg.setInterval(value);
      break;
    case 4:
      var value = /** @type {string} */ (reader.readString());
      msg.setQuote(value);
      break;
    case 5:
      var value = new proto.kaikosdk.StreamIndexServiceResponseBaseAsset;
      reader.readMessage(value,proto.kaikosdk.StreamIndexServiceResponseBaseAsset.deserializeBinaryFromReader);
      msg.addBases(value);
      break;
    case 6:
      var value = /** @type {string} */ (reader.readString());
      msg.addExchanges(value);
      break;
    case 7:
      var value = new proto.kaikosdk.StreamIndexServiceResponsePercentage;
      reader.readMessage(value,proto.kaikosdk.StreamIndexServiceResponsePercentage.deserializeBinaryFromReader);
      msg.addPercentages(value);
      break;
    case 8:
      var value = new google_protobuf_timestamp_pb.Timestamp;
      reader.readMessage(value,google_protobuf_timestamp_pb.Timestamp.deserializeBinaryFromReader);
      msg.setTsEvent(value);
      break;
    case 9:
      var value = /** @type {string} */ (reader.readString());
      msg.setSequenceId(value);
      break;
    case 10:
      var value = new google_protobuf_timestamp_pb.Timestamp;
      reader.readMessage(value,google_protobuf_timestamp_pb.Timestamp.deserializeBinaryFromReader);
      msg.setLastIngestTime(value);
      break;
    default:
      reader.skipField();
      break;
    }
  }
  return msg;
};


/**
 * Serializes the message to binary data (in protobuf wire format).
 * @return {!Uint8Array}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.serializeBinary = function() {
  var writer = new jspb.BinaryWriter();
  proto.kaikosdk.StreamIndexServiceResponseV1.serializeBinaryToWriter(this, writer);
  return writer.getResultBuffer();
};


/**
 * Serializes the given message to binary data (in protobuf wire
 * format), writing to the given BinaryWriter.
 * @param {!proto.kaikosdk.StreamIndexServiceResponseV1} message
 * @param {!jspb.BinaryWriter} writer
 * @suppress {unusedLocalVariables} f is only used for nested messages
 */
proto.kaikosdk.StreamIndexServiceResponseV1.serializeBinaryToWriter = function(message, writer) {
  var f = undefined;
  f = message.getIndexCode();
  if (f.length > 0) {
    writer.writeString(
      1,
      f
    );
  }
  f = message.getCommodity();
  if (f !== 0.0) {
    writer.writeEnum(
      2,
      f
    );
  }
  f = message.getInterval();
  if (f != null) {
    writer.writeMessage(
      3,
      f,
      sdk_core_data_interval_pb.DataInterval.serializeBinaryToWriter
    );
  }
  f = message.getQuote();
  if (f.length > 0) {
    writer.writeString(
      4,
      f
    );
  }
  f = message.getBasesList();
  if (f.length > 0) {
    writer.writeRepeatedMessage(
      5,
      f,
      proto.kaikosdk.StreamIndexServiceResponseBaseAsset.serializeBinaryToWriter
    );
  }
  f = message.getExchangesList();
  if (f.length > 0) {
    writer.writeRepeatedString(
      6,
      f
    );
  }
  f = message.getPercentagesList();
  if (f.length > 0) {
    writer.writeRepeatedMessage(
      7,
      f,
      proto.kaikosdk.StreamIndexServiceResponsePercentage.serializeBinaryToWriter
    );
  }
  f = message.getTsEvent();
  if (f != null) {
    writer.writeMessage(
      8,
      f,
      google_protobuf_timestamp_pb.Timestamp.serializeBinaryToWriter
    );
  }
  f = message.getSequenceId();
  if (f.length > 0) {
    writer.writeString(
      9,
      f
    );
  }
  f = message.getLastIngestTime();
  if (f != null) {
    writer.writeMessage(
      10,
      f,
      google_protobuf_timestamp_pb.Timestamp.serializeBinaryToWriter
    );
  }
};


/**
 * optional string index_code = 1;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getIndexCode = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 1, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setIndexCode = function(value) {
  return jspb.Message.setProto3StringField(this, 1, value);
};


/**
 * optional StreamIndexCommodity commodity = 2;
 * @return {!proto.kaikosdk.StreamIndexCommodity}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getCommodity = function() {
  return /** @type {!proto.kaikosdk.StreamIndexCommodity} */ (jspb.Message.getFieldWithDefault(this, 2, 0));
};


/**
 * @param {!proto.kaikosdk.StreamIndexCommodity} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setCommodity = function(value) {
  return jspb.Message.setProto3EnumField(this, 2, value);
};


/**
 * optional DataInterval interval = 3;
 * @return {?proto.kaikosdk.DataInterval}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getInterval = function() {
  return /** @type{?proto.kaikosdk.DataInterval} */ (
    jspb.Message.getWrapperField(this, sdk_core_data_interval_pb.DataInterval, 3));
};


/**
 * @param {?proto.kaikosdk.DataInterval|undefined} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
*/
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setInterval = function(value) {
  return jspb.Message.setWrapperField(this, 3, value);
};


/**
 * Clears the message field making it undefined.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.clearInterval = function() {
  return this.setInterval(undefined);
};


/**
 * Returns whether this field is set.
 * @return {boolean}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.hasInterval = function() {
  return jspb.Message.getField(this, 3) != null;
};


/**
 * optional string quote = 4;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getQuote = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 4, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setQuote = function(value) {
  return jspb.Message.setProto3StringField(this, 4, value);
};


/**
 * repeated StreamIndexServiceResponseBaseAsset bases = 5;
 * @return {!Array<!proto.kaikosdk.StreamIndexServiceResponseBaseAsset>}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getBasesList = function() {
  return /** @type{!Array<!proto.kaikosdk.StreamIndexServiceResponseBaseAsset>} */ (
    jspb.Message.getRepeatedWrapperField(this, proto.kaikosdk.StreamIndexServiceResponseBaseAsset, 5));
};


/**
 * @param {!Array<!proto.kaikosdk.StreamIndexServiceResponseBaseAsset>} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
*/
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setBasesList = function(value) {
  return jspb.Message.setRepeatedWrapperField(this, 5, value);
};


/**
 * @param {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset=} opt_value
 * @param {number=} opt_index
 * @return {!proto.kaikosdk.StreamIndexServiceResponseBaseAsset}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.addBases = function(opt_value, opt_index) {
  return jspb.Message.addToRepeatedWrapperField(this, 5, opt_value, proto.kaikosdk.StreamIndexServiceResponseBaseAsset, opt_index);
};


/**
 * Clears the list making it empty but non-null.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.clearBasesList = function() {
  return this.setBasesList([]);
};


/**
 * repeated string exchanges = 6;
 * @return {!Array<string>}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getExchangesList = function() {
  return /** @type {!Array<string>} */ (jspb.Message.getRepeatedField(this, 6));
};


/**
 * @param {!Array<string>} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setExchangesList = function(value) {
  return jspb.Message.setField(this, 6, value || []);
};


/**
 * @param {string} value
 * @param {number=} opt_index
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.addExchanges = function(value, opt_index) {
  return jspb.Message.addToRepeatedField(this, 6, value, opt_index);
};


/**
 * Clears the list making it empty but non-null.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.clearExchangesList = function() {
  return this.setExchangesList([]);
};


/**
 * repeated StreamIndexServiceResponsePercentage percentages = 7;
 * @return {!Array<!proto.kaikosdk.StreamIndexServiceResponsePercentage>}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getPercentagesList = function() {
  return /** @type{!Array<!proto.kaikosdk.StreamIndexServiceResponsePercentage>} */ (
    jspb.Message.getRepeatedWrapperField(this, proto.kaikosdk.StreamIndexServiceResponsePercentage, 7));
};


/**
 * @param {!Array<!proto.kaikosdk.StreamIndexServiceResponsePercentage>} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
*/
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setPercentagesList = function(value) {
  return jspb.Message.setRepeatedWrapperField(this, 7, value);
};


/**
 * @param {!proto.kaikosdk.StreamIndexServiceResponsePercentage=} opt_value
 * @param {number=} opt_index
 * @return {!proto.kaikosdk.StreamIndexServiceResponsePercentage}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.addPercentages = function(opt_value, opt_index) {
  return jspb.Message.addToRepeatedWrapperField(this, 7, opt_value, proto.kaikosdk.StreamIndexServiceResponsePercentage, opt_index);
};


/**
 * Clears the list making it empty but non-null.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.clearPercentagesList = function() {
  return this.setPercentagesList([]);
};


/**
 * optional google.protobuf.Timestamp ts_event = 8;
 * @return {?proto.google.protobuf.Timestamp}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getTsEvent = function() {
  return /** @type{?proto.google.protobuf.Timestamp} */ (
    jspb.Message.getWrapperField(this, google_protobuf_timestamp_pb.Timestamp, 8));
};


/**
 * @param {?proto.google.protobuf.Timestamp|undefined} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
*/
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setTsEvent = function(value) {
  return jspb.Message.setWrapperField(this, 8, value);
};


/**
 * Clears the message field making it undefined.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.clearTsEvent = function() {
  return this.setTsEvent(undefined);
};


/**
 * Returns whether this field is set.
 * @return {boolean}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.hasTsEvent = function() {
  return jspb.Message.getField(this, 8) != null;
};


/**
 * optional string sequence_id = 9;
 * @return {string}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getSequenceId = function() {
  return /** @type {string} */ (jspb.Message.getFieldWithDefault(this, 9, ""));
};


/**
 * @param {string} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setSequenceId = function(value) {
  return jspb.Message.setProto3StringField(this, 9, value);
};


/**
 * optional google.protobuf.Timestamp last_ingest_time = 10;
 * @return {?proto.google.protobuf.Timestamp}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.getLastIngestTime = function() {
  return /** @type{?proto.google.protobuf.Timestamp} */ (
    jspb.Message.getWrapperField(this, google_protobuf_timestamp_pb.Timestamp, 10));
};


/**
 * @param {?proto.google.protobuf.Timestamp|undefined} value
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
*/
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.setLastIngestTime = function(value) {
  return jspb.Message.setWrapperField(this, 10, value);
};


/**
 * Clears the message field making it undefined.
 * @return {!proto.kaikosdk.StreamIndexServiceResponseV1} returns this
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.clearLastIngestTime = function() {
  return this.setLastIngestTime(undefined);
};


/**
 * Returns whether this field is set.
 * @return {boolean}
 */
proto.kaikosdk.StreamIndexServiceResponseV1.prototype.hasLastIngestTime = function() {
  return jspb.Message.getField(this, 10) != null;
};


goog.object.extend(exports, proto.kaikosdk);