UNPKG

@desig/web3

Version:

Desig: The Blockchain-Agnostic Multisig Solution

1,143 lines (1,068 loc) 103 kB
/*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