@desig/web3
Version:
Desig: The Blockchain-Agnostic Multisig Solution
1,143 lines (1,068 loc) • 103 kB
JavaScript
/*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/
"use strict";
var $protobuf = require("protobufjs/minimal");
// Common aliases
var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;
// Exported root namespace
var $root = $protobuf.roots["default"] || ($protobuf.roots["default"] = {});
$root.multisig = (function() {
/**
* Namespace multisig.
* @exports multisig
* @namespace
*/
var multisig = {};
multisig.ZKProof = (function() {
/**
* Properties of a ZKProof.
* @memberof multisig
* @interface IZKProof
* @property {Array.<Uint8Array>|null} [points] ZKProof points
*/
/**
* Constructs a new ZKProof.
* @memberof multisig
* @classdesc Represents a ZKProof.
* @implements IZKProof
* @constructor
* @param {multisig.IZKProof=} [properties] Properties to set
*/
function ZKProof(properties) {
this.points = [];
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* ZKProof points.
* @member {Array.<Uint8Array>} points
* @memberof multisig.ZKProof
* @instance
*/
ZKProof.prototype.points = $util.emptyArray;
/**
* Creates a new ZKProof instance using the specified properties.
* @function create
* @memberof multisig.ZKProof
* @static
* @param {multisig.IZKProof=} [properties] Properties to set
* @returns {multisig.ZKProof} ZKProof instance
*/
ZKProof.create = function create(properties) {
return new ZKProof(properties);
};
/**
* Encodes the specified ZKProof message. Does not implicitly {@link multisig.ZKProof.verify|verify} messages.
* @function encode
* @memberof multisig.ZKProof
* @static
* @param {multisig.IZKProof} message ZKProof message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ZKProof.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.points != null && message.points.length)
for (var i = 0; i < message.points.length; ++i)
writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.points[i]);
return writer;
};
/**
* Encodes the specified ZKProof message, length delimited. Does not implicitly {@link multisig.ZKProof.verify|verify} messages.
* @function encodeDelimited
* @memberof multisig.ZKProof
* @static
* @param {multisig.IZKProof} message ZKProof message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ZKProof.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a ZKProof message from the specified reader or buffer.
* @function decode
* @memberof multisig.ZKProof
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {multisig.ZKProof} ZKProof
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ZKProof.decode = function decode(reader, length) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.multisig.ZKProof();
while (reader.pos < end) {
var tag = reader.uint32();
switch (tag >>> 3) {
case 1: {
if (!(message.points && message.points.length))
message.points = [];
message.points.push(reader.bytes());
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a ZKProof message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof multisig.ZKProof
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {multisig.ZKProof} ZKProof
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ZKProof.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a ZKProof message.
* @function verify
* @memberof multisig.ZKProof
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
ZKProof.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.points != null && message.hasOwnProperty("points")) {
if (!Array.isArray(message.points))
return "points: array expected";
for (var i = 0; i < message.points.length; ++i)
if (!(message.points[i] && typeof message.points[i].length === "number" || $util.isString(message.points[i])))
return "points: buffer[] expected";
}
return null;
};
/**
* Creates a ZKProof message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof multisig.ZKProof
* @static
* @param {Object.<string,*>} object Plain object
* @returns {multisig.ZKProof} ZKProof
*/
ZKProof.fromObject = function fromObject(object) {
if (object instanceof $root.multisig.ZKProof)
return object;
var message = new $root.multisig.ZKProof();
if (object.points) {
if (!Array.isArray(object.points))
throw TypeError(".multisig.ZKProof.points: array expected");
message.points = [];
for (var i = 0; i < object.points.length; ++i)
if (typeof object.points[i] === "string")
$util.base64.decode(object.points[i], message.points[i] = $util.newBuffer($util.base64.length(object.points[i])), 0);
else if (object.points[i].length >= 0)
message.points[i] = object.points[i];
}
return message;
};
/**
* Creates a plain object from a ZKProof message. Also converts values to other types if specified.
* @function toObject
* @memberof multisig.ZKProof
* @static
* @param {multisig.ZKProof} message ZKProof
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
ZKProof.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.arrays || options.defaults)
object.points = [];
if (message.points && message.points.length) {
object.points = [];
for (var j = 0; j < message.points.length; ++j)
object.points[j] = options.bytes === String ? $util.base64.encode(message.points[j], 0, message.points[j].length) : options.bytes === Array ? Array.prototype.slice.call(message.points[j]) : message.points[j];
}
return object;
};
/**
* Converts this ZKProof to JSON.
* @function toJSON
* @memberof multisig.ZKProof
* @instance
* @returns {Object.<string,*>} JSON object
*/
ZKProof.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for ZKProof
* @function getTypeUrl
* @memberof multisig.ZKProof
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
ZKProof.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/multisig.ZKProof";
};
return ZKProof;
})();
return multisig;
})();
$root.transaction = (function() {
/**
* Namespace transaction.
* @exports transaction
* @namespace
*/
var transaction = {};
transaction.ZKProof = (function() {
/**
* Properties of a ZKProof.
* @memberof transaction
* @interface IZKProof
* @property {Array.<Uint8Array>|null} [zpoints] ZKProof zpoints
* @property {Array.<Uint8Array>|null} [rpoints] ZKProof rpoints
*/
/**
* Constructs a new ZKProof.
* @memberof transaction
* @classdesc Represents a ZKProof.
* @implements IZKProof
* @constructor
* @param {transaction.IZKProof=} [properties] Properties to set
*/
function ZKProof(properties) {
this.zpoints = [];
this.rpoints = [];
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* ZKProof zpoints.
* @member {Array.<Uint8Array>} zpoints
* @memberof transaction.ZKProof
* @instance
*/
ZKProof.prototype.zpoints = $util.emptyArray;
/**
* ZKProof rpoints.
* @member {Array.<Uint8Array>} rpoints
* @memberof transaction.ZKProof
* @instance
*/
ZKProof.prototype.rpoints = $util.emptyArray;
/**
* Creates a new ZKProof instance using the specified properties.
* @function create
* @memberof transaction.ZKProof
* @static
* @param {transaction.IZKProof=} [properties] Properties to set
* @returns {transaction.ZKProof} ZKProof instance
*/
ZKProof.create = function create(properties) {
return new ZKProof(properties);
};
/**
* Encodes the specified ZKProof message. Does not implicitly {@link transaction.ZKProof.verify|verify} messages.
* @function encode
* @memberof transaction.ZKProof
* @static
* @param {transaction.IZKProof} message ZKProof message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ZKProof.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.zpoints != null && message.zpoints.length)
for (var i = 0; i < message.zpoints.length; ++i)
writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.zpoints[i]);
if (message.rpoints != null && message.rpoints.length)
for (var i = 0; i < message.rpoints.length; ++i)
writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.rpoints[i]);
return writer;
};
/**
* Encodes the specified ZKProof message, length delimited. Does not implicitly {@link transaction.ZKProof.verify|verify} messages.
* @function encodeDelimited
* @memberof transaction.ZKProof
* @static
* @param {transaction.IZKProof} message ZKProof message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ZKProof.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a ZKProof message from the specified reader or buffer.
* @function decode
* @memberof transaction.ZKProof
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {transaction.ZKProof} ZKProof
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ZKProof.decode = function decode(reader, length) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.transaction.ZKProof();
while (reader.pos < end) {
var tag = reader.uint32();
switch (tag >>> 3) {
case 1: {
if (!(message.zpoints && message.zpoints.length))
message.zpoints = [];
message.zpoints.push(reader.bytes());
break;
}
case 2: {
if (!(message.rpoints && message.rpoints.length))
message.rpoints = [];
message.rpoints.push(reader.bytes());
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a ZKProof message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof transaction.ZKProof
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {transaction.ZKProof} ZKProof
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ZKProof.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a ZKProof message.
* @function verify
* @memberof transaction.ZKProof
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
ZKProof.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.zpoints != null && message.hasOwnProperty("zpoints")) {
if (!Array.isArray(message.zpoints))
return "zpoints: array expected";
for (var i = 0; i < message.zpoints.length; ++i)
if (!(message.zpoints[i] && typeof message.zpoints[i].length === "number" || $util.isString(message.zpoints[i])))
return "zpoints: buffer[] expected";
}
if (message.rpoints != null && message.hasOwnProperty("rpoints")) {
if (!Array.isArray(message.rpoints))
return "rpoints: array expected";
for (var i = 0; i < message.rpoints.length; ++i)
if (!(message.rpoints[i] && typeof message.rpoints[i].length === "number" || $util.isString(message.rpoints[i])))
return "rpoints: buffer[] expected";
}
return null;
};
/**
* Creates a ZKProof message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof transaction.ZKProof
* @static
* @param {Object.<string,*>} object Plain object
* @returns {transaction.ZKProof} ZKProof
*/
ZKProof.fromObject = function fromObject(object) {
if (object instanceof $root.transaction.ZKProof)
return object;
var message = new $root.transaction.ZKProof();
if (object.zpoints) {
if (!Array.isArray(object.zpoints))
throw TypeError(".transaction.ZKProof.zpoints: array expected");
message.zpoints = [];
for (var i = 0; i < object.zpoints.length; ++i)
if (typeof object.zpoints[i] === "string")
$util.base64.decode(object.zpoints[i], message.zpoints[i] = $util.newBuffer($util.base64.length(object.zpoints[i])), 0);
else if (object.zpoints[i].length >= 0)
message.zpoints[i] = object.zpoints[i];
}
if (object.rpoints) {
if (!Array.isArray(object.rpoints))
throw TypeError(".transaction.ZKProof.rpoints: array expected");
message.rpoints = [];
for (var i = 0; i < object.rpoints.length; ++i)
if (typeof object.rpoints[i] === "string")
$util.base64.decode(object.rpoints[i], message.rpoints[i] = $util.newBuffer($util.base64.length(object.rpoints[i])), 0);
else if (object.rpoints[i].length >= 0)
message.rpoints[i] = object.rpoints[i];
}
return message;
};
/**
* Creates a plain object from a ZKProof message. Also converts values to other types if specified.
* @function toObject
* @memberof transaction.ZKProof
* @static
* @param {transaction.ZKProof} message ZKProof
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
ZKProof.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.arrays || options.defaults) {
object.zpoints = [];
object.rpoints = [];
}
if (message.zpoints && message.zpoints.length) {
object.zpoints = [];
for (var j = 0; j < message.zpoints.length; ++j)
object.zpoints[j] = options.bytes === String ? $util.base64.encode(message.zpoints[j], 0, message.zpoints[j].length) : options.bytes === Array ? Array.prototype.slice.call(message.zpoints[j]) : message.zpoints[j];
}
if (message.rpoints && message.rpoints.length) {
object.rpoints = [];
for (var j = 0; j < message.rpoints.length; ++j)
object.rpoints[j] = options.bytes === String ? $util.base64.encode(message.rpoints[j], 0, message.rpoints[j].length) : options.bytes === Array ? Array.prototype.slice.call(message.rpoints[j]) : message.rpoints[j];
}
return object;
};
/**
* Converts this ZKProof to JSON.
* @function toJSON
* @memberof transaction.ZKProof
* @instance
* @returns {Object.<string,*>} JSON object
*/
ZKProof.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for ZKProof
* @function getTypeUrl
* @memberof transaction.ZKProof
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
ZKProof.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/transaction.ZKProof";
};
return ZKProof;
})();
transaction.BaseTransaction = (function() {
/**
* Properties of a BaseTransaction.
* @memberof transaction
* @interface IBaseTransaction
* @property {Uint8Array} selector BaseTransaction selector
* @property {Uint8Array} refgid BaseTransaction refgid
* @property {number|Long} t BaseTransaction t
* @property {number|Long} n BaseTransaction n
*/
/**
* Constructs a new BaseTransaction.
* @memberof transaction
* @classdesc Represents a BaseTransaction.
* @implements IBaseTransaction
* @constructor
* @param {transaction.IBaseTransaction=} [properties] Properties to set
*/
function BaseTransaction(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* BaseTransaction selector.
* @member {Uint8Array} selector
* @memberof transaction.BaseTransaction
* @instance
*/
BaseTransaction.prototype.selector = $util.newBuffer([]);
/**
* BaseTransaction refgid.
* @member {Uint8Array} refgid
* @memberof transaction.BaseTransaction
* @instance
*/
BaseTransaction.prototype.refgid = $util.newBuffer([]);
/**
* BaseTransaction t.
* @member {number|Long} t
* @memberof transaction.BaseTransaction
* @instance
*/
BaseTransaction.prototype.t = $util.Long ? $util.Long.fromBits(0,0,true) : 0;
/**
* BaseTransaction n.
* @member {number|Long} n
* @memberof transaction.BaseTransaction
* @instance
*/
BaseTransaction.prototype.n = $util.Long ? $util.Long.fromBits(0,0,true) : 0;
/**
* Creates a new BaseTransaction instance using the specified properties.
* @function create
* @memberof transaction.BaseTransaction
* @static
* @param {transaction.IBaseTransaction=} [properties] Properties to set
* @returns {transaction.BaseTransaction} BaseTransaction instance
*/
BaseTransaction.create = function create(properties) {
return new BaseTransaction(properties);
};
/**
* Encodes the specified BaseTransaction message. Does not implicitly {@link transaction.BaseTransaction.verify|verify} messages.
* @function encode
* @memberof transaction.BaseTransaction
* @static
* @param {transaction.IBaseTransaction} message BaseTransaction message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
BaseTransaction.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.selector);
writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.refgid);
writer.uint32(/* id 3, wireType 0 =*/24).uint64(message.t);
writer.uint32(/* id 4, wireType 0 =*/32).uint64(message.n);
return writer;
};
/**
* Encodes the specified BaseTransaction message, length delimited. Does not implicitly {@link transaction.BaseTransaction.verify|verify} messages.
* @function encodeDelimited
* @memberof transaction.BaseTransaction
* @static
* @param {transaction.IBaseTransaction} message BaseTransaction message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
BaseTransaction.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a BaseTransaction message from the specified reader or buffer.
* @function decode
* @memberof transaction.BaseTransaction
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {transaction.BaseTransaction} BaseTransaction
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
BaseTransaction.decode = function decode(reader, length) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.transaction.BaseTransaction();
while (reader.pos < end) {
var tag = reader.uint32();
switch (tag >>> 3) {
case 1: {
message.selector = reader.bytes();
break;
}
case 2: {
message.refgid = reader.bytes();
break;
}
case 3: {
message.t = reader.uint64();
break;
}
case 4: {
message.n = reader.uint64();
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
if (!message.hasOwnProperty("selector"))
throw $util.ProtocolError("missing required 'selector'", { instance: message });
if (!message.hasOwnProperty("refgid"))
throw $util.ProtocolError("missing required 'refgid'", { instance: message });
if (!message.hasOwnProperty("t"))
throw $util.ProtocolError("missing required 't'", { instance: message });
if (!message.hasOwnProperty("n"))
throw $util.ProtocolError("missing required 'n'", { instance: message });
return message;
};
/**
* Decodes a BaseTransaction message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof transaction.BaseTransaction
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {transaction.BaseTransaction} BaseTransaction
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
BaseTransaction.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a BaseTransaction message.
* @function verify
* @memberof transaction.BaseTransaction
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
BaseTransaction.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (!(message.selector && typeof message.selector.length === "number" || $util.isString(message.selector)))
return "selector: buffer expected";
if (!(message.refgid && typeof message.refgid.length === "number" || $util.isString(message.refgid)))
return "refgid: buffer expected";
if (!$util.isInteger(message.t) && !(message.t && $util.isInteger(message.t.low) && $util.isInteger(message.t.high)))
return "t: integer|Long expected";
if (!$util.isInteger(message.n) && !(message.n && $util.isInteger(message.n.low) && $util.isInteger(message.n.high)))
return "n: integer|Long expected";
return null;
};
/**
* Creates a BaseTransaction message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof transaction.BaseTransaction
* @static
* @param {Object.<string,*>} object Plain object
* @returns {transaction.BaseTransaction} BaseTransaction
*/
BaseTransaction.fromObject = function fromObject(object) {
if (object instanceof $root.transaction.BaseTransaction)
return object;
var message = new $root.transaction.BaseTransaction();
if (object.selector != null)
if (typeof object.selector === "string")
$util.base64.decode(object.selector, message.selector = $util.newBuffer($util.base64.length(object.selector)), 0);
else if (object.selector.length >= 0)
message.selector = object.selector;
if (object.refgid != null)
if (typeof object.refgid === "string")
$util.base64.decode(object.refgid, message.refgid = $util.newBuffer($util.base64.length(object.refgid)), 0);
else if (object.refgid.length >= 0)
message.refgid = object.refgid;
if (object.t != null)
if ($util.Long)
(message.t = $util.Long.fromValue(object.t)).unsigned = true;
else if (typeof object.t === "string")
message.t = parseInt(object.t, 10);
else if (typeof object.t === "number")
message.t = object.t;
else if (typeof object.t === "object")
message.t = new $util.LongBits(object.t.low >>> 0, object.t.high >>> 0).toNumber(true);
if (object.n != null)
if ($util.Long)
(message.n = $util.Long.fromValue(object.n)).unsigned = true;
else if (typeof object.n === "string")
message.n = parseInt(object.n, 10);
else if (typeof object.n === "number")
message.n = object.n;
else if (typeof object.n === "object")
message.n = new $util.LongBits(object.n.low >>> 0, object.n.high >>> 0).toNumber(true);
return message;
};
/**
* Creates a plain object from a BaseTransaction message. Also converts values to other types if specified.
* @function toObject
* @memberof transaction.BaseTransaction
* @static
* @param {transaction.BaseTransaction} message BaseTransaction
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
BaseTransaction.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.defaults) {
if (options.bytes === String)
object.selector = "";
else {
object.selector = [];
if (options.bytes !== Array)
object.selector = $util.newBuffer(object.selector);
}
if (options.bytes === String)
object.refgid = "";
else {
object.refgid = [];
if (options.bytes !== Array)
object.refgid = $util.newBuffer(object.refgid);
}
if ($util.Long) {
var long = new $util.Long(0, 0, true);
object.t = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long;
} else
object.t = options.longs === String ? "0" : 0;
if ($util.Long) {
var long = new $util.Long(0, 0, true);
object.n = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long;
} else
object.n = options.longs === String ? "0" : 0;
}
if (message.selector != null && message.hasOwnProperty("selector"))
object.selector = options.bytes === String ? $util.base64.encode(message.selector, 0, message.selector.length) : options.bytes === Array ? Array.prototype.slice.call(message.selector) : message.selector;
if (message.refgid != null && message.hasOwnProperty("refgid"))
object.refgid = options.bytes === String ? $util.base64.encode(message.refgid, 0, message.refgid.length) : options.bytes === Array ? Array.prototype.slice.call(message.refgid) : message.refgid;
if (message.t != null && message.hasOwnProperty("t"))
if (typeof message.t === "number")
object.t = options.longs === String ? String(message.t) : message.t;
else
object.t = options.longs === String ? $util.Long.prototype.toString.call(message.t) : options.longs === Number ? new $util.LongBits(message.t.low >>> 0, message.t.high >>> 0).toNumber(true) : message.t;
if (message.n != null && message.hasOwnProperty("n"))
if (typeof message.n === "number")
object.n = options.longs === String ? String(message.n) : message.n;
else
object.n = options.longs === String ? $util.Long.prototype.toString.call(message.n) : options.longs === Number ? new $util.LongBits(message.n.low >>> 0, message.n.high >>> 0).toNumber(true) : message.n;
return object;
};
/**
* Converts this BaseTransaction to JSON.
* @function toJSON
* @memberof transaction.BaseTransaction
* @instance
* @returns {Object.<string,*>} JSON object
*/
BaseTransaction.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for BaseTransaction
* @function getTypeUrl
* @memberof transaction.BaseTransaction
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
BaseTransaction.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/transaction.BaseTransaction";
};
return BaseTransaction;
})();
transaction.nExtension = (function() {
/**
* Properties of a nExtension.
* @memberof transaction
* @interface InExtension
* @property {Uint8Array} selector nExtension selector
* @property {Uint8Array} refgid nExtension refgid
* @property {number|Long} t nExtension t
* @property {number|Long} n nExtension n
* @property {Uint8Array} k nExtension k
* @property {Uint8Array} pubkey nExtension pubkey
* @property {Uint8Array} kr nExtension kr
* @property {Uint8Array} kzero nExtension kzero
*/
/**
* Constructs a new nExtension.
* @memberof transaction
* @classdesc Represents a nExtension.
* @implements InExtension
* @constructor
* @param {transaction.InExtension=} [properties] Properties to set
*/
function nExtension(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* nExtension selector.
* @member {Uint8Array} selector
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.selector = $util.newBuffer([]);
/**
* nExtension refgid.
* @member {Uint8Array} refgid
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.refgid = $util.newBuffer([]);
/**
* nExtension t.
* @member {number|Long} t
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.t = $util.Long ? $util.Long.fromBits(0,0,true) : 0;
/**
* nExtension n.
* @member {number|Long} n
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.n = $util.Long ? $util.Long.fromBits(0,0,true) : 0;
/**
* nExtension k.
* @member {Uint8Array} k
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.k = $util.newBuffer([]);
/**
* nExtension pubkey.
* @member {Uint8Array} pubkey
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.pubkey = $util.newBuffer([]);
/**
* nExtension kr.
* @member {Uint8Array} kr
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.kr = $util.newBuffer([]);
/**
* nExtension kzero.
* @member {Uint8Array} kzero
* @memberof transaction.nExtension
* @instance
*/
nExtension.prototype.kzero = $util.newBuffer([]);
/**
* Creates a new nExtension instance using the specified properties.
* @function create
* @memberof transaction.nExtension
* @static
* @param {transaction.InExtension=} [properties] Properties to set
* @returns {transaction.nExtension} nExtension instance
*/
nExtension.create = function create(properties) {
return new nExtension(properties);
};
/**
* Encodes the specified nExtension message. Does not implicitly {@link transaction.nExtension.verify|verify} messages.
* @function encode
* @memberof transaction.nExtension
* @static
* @param {transaction.InExtension} message nExtension message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
nExtension.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.selector);
writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.refgid);
writer.uint32(/* id 3, wireType 0 =*/24).uint64(message.t);
writer.uint32(/* id 4, wireType 0 =*/32).uint64(message.n);
writer.uint32(/* id 5, wireType 2 =*/42).bytes(message.k);
writer.uint32(/* id 6, wireType 2 =*/50).bytes(message.pubkey);
writer.uint32(/* id 7, wireType 2 =*/58).bytes(message.kr);
writer.uint32(/* id 8, wireType 2 =*/66).bytes(message.kzero);
return writer;
};
/**
* Encodes the specified nExtension message, length delimited. Does not implicitly {@link transaction.nExtension.verify|verify} messages.
* @function encodeDelimited
* @memberof transaction.nExtension
* @static
* @param {transaction.InExtension} message nExtension message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
nExtension.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a nExtension message from the specified reader or buffer.
* @function decode
* @memberof transaction.nExtension
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {transaction.nExtension} nExtension
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
nExtension.decode = function decode(reader, length) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.transaction.nExtension();
while (reader.pos < end) {
var tag = reader.uint32();
switch (tag >>> 3) {
case 1: {
message.selector = reader.bytes();
break;
}
case 2: {
message.refgid = reader.bytes();
break;
}
case 3: {
message.t = reader.uint64();
break;
}
case 4: {
message.n = reader.uint64();
break;
}
case 5: {
message.k = reader.bytes();
break;
}
case 6: {
message.pubkey = reader.bytes();
break;
}
case 7: {
message.kr = reader.bytes();
break;
}
case 8: {
message.kzero = reader.bytes();
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
if (!message.hasOwnProperty("selector"))
throw $util.ProtocolError("missing required 'selector'", { instance: message });
if (!message.hasOwnProperty("refgid"))
throw $util.ProtocolError("missing required 'refgid'", { instance: message });
if (!message.hasOwnProperty("t"))
throw $util.ProtocolError("missing required 't'", { instance: message });
if (!message.hasOwnProperty("n"))
throw $util.ProtocolError("missing required 'n'", { instance: message });
if (!message.hasOwnProperty("k"))
throw $util.ProtocolError("missing required 'k'", { instance: message });
if (!message.hasOwnProperty("pubkey"))
throw $util.ProtocolError("missing required 'pubkey'", { instance: message });
if (!message.hasOwnProperty("kr"))
throw $util.ProtocolError("missing required 'kr'", { instance: message });
if (!message.hasOwnProperty("kzero"))
throw $util.ProtocolError("missing required 'kzero'", { instance: message });
return message;
};
/**
* Decodes a nExtension message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof transaction.nExtension
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {transaction.nExtension} nExtension
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
nExtension.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a nExtension message.
* @function verify
* @memberof transaction.nExtension
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
nExtension.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (!(message.selector && typeof message.selector.length === "number" || $util.isString(message.selector)))
return "selector: buffer expected";
if (!(message.refgid && typeof message.refgid.length === "number" || $util.isString(message.refgid)))
return "refgid: buffer expected";
if (!$util.isInteger(message.t) && !(message.t && $util.isInteger(message.t.low) && $util.isInteger(message.t.high)))
return "t: integer|Long expected";
if (!$util.isInteger(message.n) && !(message.n && $util.isInteger(message.n.low) && $util.isInteger(message.n.high)))
return "n: integer|Long expected";
if (!(message.k && typeof message.k.length === "number" || $util.isString(message.k)))
return "k: buffer expected";
if (!(message.pubkey && typeof message.pubkey.length === "number" || $util.isString(message.pubkey)))
return "pubkey: buffer expected";
if (!(message.kr && typeof message.kr.length === "number" || $util.isString(message.kr)))
return "kr: buffer expected";
if (!(message.kzero && typeof message.kzero.length === "number" || $util.isString(message.kzero)))
return "kzero: buffer expected";
return null;
};
/**
* Creates a nExtension message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof transaction.nExtension
* @static
* @param {Object.<string,*>} object Plain object
* @returns {transaction.nExtension} nExtension
*/
nExtension.fromObject = function fromObject(object) {
if (object instanceof $root.transaction.nExtension)
return object;
var message = new $root.transaction.nExtension();
if (object.selector != null)
if (typeof object.selector === "string")
$util.base64.decode(object.selector, message.selector = $util.newBuffer($util.base64.length(object.selector)), 0);
else if (object.selector.length >= 0)
message.selector = object.selector;
if (object.refgid != null)
if (typeof object.refgid === "string")
$util.base64.decode(object.refgid, message.refgid = $util.newBuffer($util.base64.length(object.refgid)), 0);
else if (object.refgid.length >= 0)
message.refgid = object.refgid;
if (object.t != null)
if ($util.Long)
(message.t = $util.Long.fromValue(object.t)).unsigned = true;
else if (typeof object.t === "string")
message.t = parseInt(object.t, 10);
else if (typeof object.t === "number")
message.t = object.t;
else if (typeof object.t === "object")
message.t = new $util.LongBits(object.t.low >>> 0, object.t.high >>> 0).toNumber(true);
if (object.n != null)
if ($util.Long)
(message.n = $util.Long.fromValue(object.n)).unsigned = true;
else if (typeof object.n === "string")
message.n = parseInt(object.n, 10);
else if (typeof object.n === "number")
message.n = object.n;
else if (typeof object.n === "object")
message.n = new $util.LongBits(object.n.low >>> 0, object.n.high >>> 0).toNumber(true);
if (object.k != null)
if (typeof