@whiskeysockets/baileys
Version:
WhatsApp API
1,068 lines (999 loc) • 5.19 MB
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.proto = (function() {
/**
* Namespace proto.
* @exports proto
* @namespace
*/
var proto = {};
proto.ADVDeviceIdentity = (function() {
/**
* Properties of a ADVDeviceIdentity.
* @memberof proto
* @interface IADVDeviceIdentity
* @property {number|null} [rawId] ADVDeviceIdentity rawId
* @property {number|Long|null} [timestamp] ADVDeviceIdentity timestamp
* @property {number|null} [keyIndex] ADVDeviceIdentity keyIndex
* @property {proto.ADVEncryptionType|null} [accountType] ADVDeviceIdentity accountType
* @property {proto.ADVEncryptionType|null} [deviceType] ADVDeviceIdentity deviceType
*/
/**
* Constructs a new ADVDeviceIdentity.
* @memberof proto
* @classdesc Represents a ADVDeviceIdentity.
* @implements IADVDeviceIdentity
* @constructor
* @param {proto.IADVDeviceIdentity=} [properties] Properties to set
*/
function ADVDeviceIdentity(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]];
}
/**
* ADVDeviceIdentity rawId.
* @member {number} rawId
* @memberof proto.ADVDeviceIdentity
* @instance
*/
ADVDeviceIdentity.prototype.rawId = 0;
/**
* ADVDeviceIdentity timestamp.
* @member {number|Long} timestamp
* @memberof proto.ADVDeviceIdentity
* @instance
*/
ADVDeviceIdentity.prototype.timestamp = $util.Long ? $util.Long.fromBits(0,0,true) : 0;
/**
* ADVDeviceIdentity keyIndex.
* @member {number} keyIndex
* @memberof proto.ADVDeviceIdentity
* @instance
*/
ADVDeviceIdentity.prototype.keyIndex = 0;
/**
* ADVDeviceIdentity accountType.
* @member {proto.ADVEncryptionType} accountType
* @memberof proto.ADVDeviceIdentity
* @instance
*/
ADVDeviceIdentity.prototype.accountType = 0;
/**
* ADVDeviceIdentity deviceType.
* @member {proto.ADVEncryptionType} deviceType
* @memberof proto.ADVDeviceIdentity
* @instance
*/
ADVDeviceIdentity.prototype.deviceType = 0;
/**
* Creates a new ADVDeviceIdentity instance using the specified properties.
* @function create
* @memberof proto.ADVDeviceIdentity
* @static
* @param {proto.IADVDeviceIdentity=} [properties] Properties to set
* @returns {proto.ADVDeviceIdentity} ADVDeviceIdentity instance
*/
ADVDeviceIdentity.create = function create(properties) {
return new ADVDeviceIdentity(properties);
};
/**
* Encodes the specified ADVDeviceIdentity message. Does not implicitly {@link proto.ADVDeviceIdentity.verify|verify} messages.
* @function encode
* @memberof proto.ADVDeviceIdentity
* @static
* @param {proto.IADVDeviceIdentity} message ADVDeviceIdentity message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVDeviceIdentity.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.rawId != null && Object.hasOwnProperty.call(message, "rawId"))
writer.uint32(/* id 1, wireType 0 =*/8).uint32(message.rawId);
if (message.timestamp != null && Object.hasOwnProperty.call(message, "timestamp"))
writer.uint32(/* id 2, wireType 0 =*/16).uint64(message.timestamp);
if (message.keyIndex != null && Object.hasOwnProperty.call(message, "keyIndex"))
writer.uint32(/* id 3, wireType 0 =*/24).uint32(message.keyIndex);
if (message.accountType != null && Object.hasOwnProperty.call(message, "accountType"))
writer.uint32(/* id 4, wireType 0 =*/32).int32(message.accountType);
if (message.deviceType != null && Object.hasOwnProperty.call(message, "deviceType"))
writer.uint32(/* id 5, wireType 0 =*/40).int32(message.deviceType);
return writer;
};
/**
* Encodes the specified ADVDeviceIdentity message, length delimited. Does not implicitly {@link proto.ADVDeviceIdentity.verify|verify} messages.
* @function encodeDelimited
* @memberof proto.ADVDeviceIdentity
* @static
* @param {proto.IADVDeviceIdentity} message ADVDeviceIdentity message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVDeviceIdentity.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a ADVDeviceIdentity message from the specified reader or buffer.
* @function decode
* @memberof proto.ADVDeviceIdentity
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {proto.ADVDeviceIdentity} ADVDeviceIdentity
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ADVDeviceIdentity.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.proto.ADVDeviceIdentity();
while (reader.pos < end) {
var tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.rawId = reader.uint32();
break;
case 2:
message.timestamp = reader.uint64();
break;
case 3:
message.keyIndex = reader.uint32();
break;
case 4:
message.accountType = reader.int32();
break;
case 5:
message.deviceType = reader.int32();
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a ADVDeviceIdentity message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof proto.ADVDeviceIdentity
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {proto.ADVDeviceIdentity} ADVDeviceIdentity
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ADVDeviceIdentity.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a ADVDeviceIdentity message.
* @function verify
* @memberof proto.ADVDeviceIdentity
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
ADVDeviceIdentity.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.rawId != null && message.hasOwnProperty("rawId"))
if (!$util.isInteger(message.rawId))
return "rawId: integer expected";
if (message.timestamp != null && message.hasOwnProperty("timestamp"))
if (!$util.isInteger(message.timestamp) && !(message.timestamp && $util.isInteger(message.timestamp.low) && $util.isInteger(message.timestamp.high)))
return "timestamp: integer|Long expected";
if (message.keyIndex != null && message.hasOwnProperty("keyIndex"))
if (!$util.isInteger(message.keyIndex))
return "keyIndex: integer expected";
if (message.accountType != null && message.hasOwnProperty("accountType"))
switch (message.accountType) {
default:
return "accountType: enum value expected";
case 0:
case 1:
break;
}
if (message.deviceType != null && message.hasOwnProperty("deviceType"))
switch (message.deviceType) {
default:
return "deviceType: enum value expected";
case 0:
case 1:
break;
}
return null;
};
/**
* Creates a ADVDeviceIdentity message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof proto.ADVDeviceIdentity
* @static
* @param {Object.<string,*>} object Plain object
* @returns {proto.ADVDeviceIdentity} ADVDeviceIdentity
*/
ADVDeviceIdentity.fromObject = function fromObject(object) {
if (object instanceof $root.proto.ADVDeviceIdentity)
return object;
var message = new $root.proto.ADVDeviceIdentity();
if (object.rawId != null)
message.rawId = object.rawId >>> 0;
if (object.timestamp != null)
if ($util.Long)
(message.timestamp = $util.Long.fromValue(object.timestamp)).unsigned = true;
else if (typeof object.timestamp === "string")
message.timestamp = parseInt(object.timestamp, 10);
else if (typeof object.timestamp === "number")
message.timestamp = object.timestamp;
else if (typeof object.timestamp === "object")
message.timestamp = new $util.LongBits(object.timestamp.low >>> 0, object.timestamp.high >>> 0).toNumber(true);
if (object.keyIndex != null)
message.keyIndex = object.keyIndex >>> 0;
switch (object.accountType) {
case "E2EE":
case 0:
message.accountType = 0;
break;
case "HOSTED":
case 1:
message.accountType = 1;
break;
}
switch (object.deviceType) {
case "E2EE":
case 0:
message.deviceType = 0;
break;
case "HOSTED":
case 1:
message.deviceType = 1;
break;
}
return message;
};
/**
* Creates a plain object from a ADVDeviceIdentity message. Also converts values to other types if specified.
* @function toObject
* @memberof proto.ADVDeviceIdentity
* @static
* @param {proto.ADVDeviceIdentity} message ADVDeviceIdentity
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
ADVDeviceIdentity.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.defaults) {
object.rawId = 0;
if ($util.Long) {
var long = new $util.Long(0, 0, true);
object.timestamp = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long;
} else
object.timestamp = options.longs === String ? "0" : 0;
object.keyIndex = 0;
object.accountType = options.enums === String ? "E2EE" : 0;
object.deviceType = options.enums === String ? "E2EE" : 0;
}
if (message.rawId != null && message.hasOwnProperty("rawId"))
object.rawId = message.rawId;
if (message.timestamp != null && message.hasOwnProperty("timestamp"))
if (typeof message.timestamp === "number")
object.timestamp = options.longs === String ? String(message.timestamp) : message.timestamp;
else
object.timestamp = options.longs === String ? $util.Long.prototype.toString.call(message.timestamp) : options.longs === Number ? new $util.LongBits(message.timestamp.low >>> 0, message.timestamp.high >>> 0).toNumber(true) : message.timestamp;
if (message.keyIndex != null && message.hasOwnProperty("keyIndex"))
object.keyIndex = message.keyIndex;
if (message.accountType != null && message.hasOwnProperty("accountType"))
object.accountType = options.enums === String ? $root.proto.ADVEncryptionType[message.accountType] : message.accountType;
if (message.deviceType != null && message.hasOwnProperty("deviceType"))
object.deviceType = options.enums === String ? $root.proto.ADVEncryptionType[message.deviceType] : message.deviceType;
return object;
};
/**
* Converts this ADVDeviceIdentity to JSON.
* @function toJSON
* @memberof proto.ADVDeviceIdentity
* @instance
* @returns {Object.<string,*>} JSON object
*/
ADVDeviceIdentity.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
return ADVDeviceIdentity;
})();
/**
* ADVEncryptionType enum.
* @name proto.ADVEncryptionType
* @enum {number}
* @property {number} E2EE=0 E2EE value
* @property {number} HOSTED=1 HOSTED value
*/
proto.ADVEncryptionType = (function() {
var valuesById = {}, values = Object.create(valuesById);
values[valuesById[0] = "E2EE"] = 0;
values[valuesById[1] = "HOSTED"] = 1;
return values;
})();
proto.ADVKeyIndexList = (function() {
/**
* Properties of a ADVKeyIndexList.
* @memberof proto
* @interface IADVKeyIndexList
* @property {number|null} [rawId] ADVKeyIndexList rawId
* @property {number|Long|null} [timestamp] ADVKeyIndexList timestamp
* @property {number|null} [currentIndex] ADVKeyIndexList currentIndex
* @property {Array.<number>|null} [validIndexes] ADVKeyIndexList validIndexes
* @property {proto.ADVEncryptionType|null} [accountType] ADVKeyIndexList accountType
*/
/**
* Constructs a new ADVKeyIndexList.
* @memberof proto
* @classdesc Represents a ADVKeyIndexList.
* @implements IADVKeyIndexList
* @constructor
* @param {proto.IADVKeyIndexList=} [properties] Properties to set
*/
function ADVKeyIndexList(properties) {
this.validIndexes = [];
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]];
}
/**
* ADVKeyIndexList rawId.
* @member {number} rawId
* @memberof proto.ADVKeyIndexList
* @instance
*/
ADVKeyIndexList.prototype.rawId = 0;
/**
* ADVKeyIndexList timestamp.
* @member {number|Long} timestamp
* @memberof proto.ADVKeyIndexList
* @instance
*/
ADVKeyIndexList.prototype.timestamp = $util.Long ? $util.Long.fromBits(0,0,true) : 0;
/**
* ADVKeyIndexList currentIndex.
* @member {number} currentIndex
* @memberof proto.ADVKeyIndexList
* @instance
*/
ADVKeyIndexList.prototype.currentIndex = 0;
/**
* ADVKeyIndexList validIndexes.
* @member {Array.<number>} validIndexes
* @memberof proto.ADVKeyIndexList
* @instance
*/
ADVKeyIndexList.prototype.validIndexes = $util.emptyArray;
/**
* ADVKeyIndexList accountType.
* @member {proto.ADVEncryptionType} accountType
* @memberof proto.ADVKeyIndexList
* @instance
*/
ADVKeyIndexList.prototype.accountType = 0;
/**
* Creates a new ADVKeyIndexList instance using the specified properties.
* @function create
* @memberof proto.ADVKeyIndexList
* @static
* @param {proto.IADVKeyIndexList=} [properties] Properties to set
* @returns {proto.ADVKeyIndexList} ADVKeyIndexList instance
*/
ADVKeyIndexList.create = function create(properties) {
return new ADVKeyIndexList(properties);
};
/**
* Encodes the specified ADVKeyIndexList message. Does not implicitly {@link proto.ADVKeyIndexList.verify|verify} messages.
* @function encode
* @memberof proto.ADVKeyIndexList
* @static
* @param {proto.IADVKeyIndexList} message ADVKeyIndexList message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVKeyIndexList.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.rawId != null && Object.hasOwnProperty.call(message, "rawId"))
writer.uint32(/* id 1, wireType 0 =*/8).uint32(message.rawId);
if (message.timestamp != null && Object.hasOwnProperty.call(message, "timestamp"))
writer.uint32(/* id 2, wireType 0 =*/16).uint64(message.timestamp);
if (message.currentIndex != null && Object.hasOwnProperty.call(message, "currentIndex"))
writer.uint32(/* id 3, wireType 0 =*/24).uint32(message.currentIndex);
if (message.validIndexes != null && message.validIndexes.length) {
writer.uint32(/* id 4, wireType 2 =*/34).fork();
for (var i = 0; i < message.validIndexes.length; ++i)
writer.uint32(message.validIndexes[i]);
writer.ldelim();
}
if (message.accountType != null && Object.hasOwnProperty.call(message, "accountType"))
writer.uint32(/* id 5, wireType 0 =*/40).int32(message.accountType);
return writer;
};
/**
* Encodes the specified ADVKeyIndexList message, length delimited. Does not implicitly {@link proto.ADVKeyIndexList.verify|verify} messages.
* @function encodeDelimited
* @memberof proto.ADVKeyIndexList
* @static
* @param {proto.IADVKeyIndexList} message ADVKeyIndexList message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVKeyIndexList.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a ADVKeyIndexList message from the specified reader or buffer.
* @function decode
* @memberof proto.ADVKeyIndexList
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {proto.ADVKeyIndexList} ADVKeyIndexList
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ADVKeyIndexList.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.proto.ADVKeyIndexList();
while (reader.pos < end) {
var tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.rawId = reader.uint32();
break;
case 2:
message.timestamp = reader.uint64();
break;
case 3:
message.currentIndex = reader.uint32();
break;
case 4:
if (!(message.validIndexes && message.validIndexes.length))
message.validIndexes = [];
if ((tag & 7) === 2) {
var end2 = reader.uint32() + reader.pos;
while (reader.pos < end2)
message.validIndexes.push(reader.uint32());
} else
message.validIndexes.push(reader.uint32());
break;
case 5:
message.accountType = reader.int32();
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a ADVKeyIndexList message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof proto.ADVKeyIndexList
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {proto.ADVKeyIndexList} ADVKeyIndexList
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ADVKeyIndexList.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a ADVKeyIndexList message.
* @function verify
* @memberof proto.ADVKeyIndexList
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
ADVKeyIndexList.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.rawId != null && message.hasOwnProperty("rawId"))
if (!$util.isInteger(message.rawId))
return "rawId: integer expected";
if (message.timestamp != null && message.hasOwnProperty("timestamp"))
if (!$util.isInteger(message.timestamp) && !(message.timestamp && $util.isInteger(message.timestamp.low) && $util.isInteger(message.timestamp.high)))
return "timestamp: integer|Long expected";
if (message.currentIndex != null && message.hasOwnProperty("currentIndex"))
if (!$util.isInteger(message.currentIndex))
return "currentIndex: integer expected";
if (message.validIndexes != null && message.hasOwnProperty("validIndexes")) {
if (!Array.isArray(message.validIndexes))
return "validIndexes: array expected";
for (var i = 0; i < message.validIndexes.length; ++i)
if (!$util.isInteger(message.validIndexes[i]))
return "validIndexes: integer[] expected";
}
if (message.accountType != null && message.hasOwnProperty("accountType"))
switch (message.accountType) {
default:
return "accountType: enum value expected";
case 0:
case 1:
break;
}
return null;
};
/**
* Creates a ADVKeyIndexList message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof proto.ADVKeyIndexList
* @static
* @param {Object.<string,*>} object Plain object
* @returns {proto.ADVKeyIndexList} ADVKeyIndexList
*/
ADVKeyIndexList.fromObject = function fromObject(object) {
if (object instanceof $root.proto.ADVKeyIndexList)
return object;
var message = new $root.proto.ADVKeyIndexList();
if (object.rawId != null)
message.rawId = object.rawId >>> 0;
if (object.timestamp != null)
if ($util.Long)
(message.timestamp = $util.Long.fromValue(object.timestamp)).unsigned = true;
else if (typeof object.timestamp === "string")
message.timestamp = parseInt(object.timestamp, 10);
else if (typeof object.timestamp === "number")
message.timestamp = object.timestamp;
else if (typeof object.timestamp === "object")
message.timestamp = new $util.LongBits(object.timestamp.low >>> 0, object.timestamp.high >>> 0).toNumber(true);
if (object.currentIndex != null)
message.currentIndex = object.currentIndex >>> 0;
if (object.validIndexes) {
if (!Array.isArray(object.validIndexes))
throw TypeError(".proto.ADVKeyIndexList.validIndexes: array expected");
message.validIndexes = [];
for (var i = 0; i < object.validIndexes.length; ++i)
message.validIndexes[i] = object.validIndexes[i] >>> 0;
}
switch (object.accountType) {
case "E2EE":
case 0:
message.accountType = 0;
break;
case "HOSTED":
case 1:
message.accountType = 1;
break;
}
return message;
};
/**
* Creates a plain object from a ADVKeyIndexList message. Also converts values to other types if specified.
* @function toObject
* @memberof proto.ADVKeyIndexList
* @static
* @param {proto.ADVKeyIndexList} message ADVKeyIndexList
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
ADVKeyIndexList.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.arrays || options.defaults)
object.validIndexes = [];
if (options.defaults) {
object.rawId = 0;
if ($util.Long) {
var long = new $util.Long(0, 0, true);
object.timestamp = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long;
} else
object.timestamp = options.longs === String ? "0" : 0;
object.currentIndex = 0;
object.accountType = options.enums === String ? "E2EE" : 0;
}
if (message.rawId != null && message.hasOwnProperty("rawId"))
object.rawId = message.rawId;
if (message.timestamp != null && message.hasOwnProperty("timestamp"))
if (typeof message.timestamp === "number")
object.timestamp = options.longs === String ? String(message.timestamp) : message.timestamp;
else
object.timestamp = options.longs === String ? $util.Long.prototype.toString.call(message.timestamp) : options.longs === Number ? new $util.LongBits(message.timestamp.low >>> 0, message.timestamp.high >>> 0).toNumber(true) : message.timestamp;
if (message.currentIndex != null && message.hasOwnProperty("currentIndex"))
object.currentIndex = message.currentIndex;
if (message.validIndexes && message.validIndexes.length) {
object.validIndexes = [];
for (var j = 0; j < message.validIndexes.length; ++j)
object.validIndexes[j] = message.validIndexes[j];
}
if (message.accountType != null && message.hasOwnProperty("accountType"))
object.accountType = options.enums === String ? $root.proto.ADVEncryptionType[message.accountType] : message.accountType;
return object;
};
/**
* Converts this ADVKeyIndexList to JSON.
* @function toJSON
* @memberof proto.ADVKeyIndexList
* @instance
* @returns {Object.<string,*>} JSON object
*/
ADVKeyIndexList.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
return ADVKeyIndexList;
})();
proto.ADVSignedDeviceIdentity = (function() {
/**
* Properties of a ADVSignedDeviceIdentity.
* @memberof proto
* @interface IADVSignedDeviceIdentity
* @property {Uint8Array|null} [details] ADVSignedDeviceIdentity details
* @property {Uint8Array|null} [accountSignatureKey] ADVSignedDeviceIdentity accountSignatureKey
* @property {Uint8Array|null} [accountSignature] ADVSignedDeviceIdentity accountSignature
* @property {Uint8Array|null} [deviceSignature] ADVSignedDeviceIdentity deviceSignature
*/
/**
* Constructs a new ADVSignedDeviceIdentity.
* @memberof proto
* @classdesc Represents a ADVSignedDeviceIdentity.
* @implements IADVSignedDeviceIdentity
* @constructor
* @param {proto.IADVSignedDeviceIdentity=} [properties] Properties to set
*/
function ADVSignedDeviceIdentity(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]];
}
/**
* ADVSignedDeviceIdentity details.
* @member {Uint8Array} details
* @memberof proto.ADVSignedDeviceIdentity
* @instance
*/
ADVSignedDeviceIdentity.prototype.details = $util.newBuffer([]);
/**
* ADVSignedDeviceIdentity accountSignatureKey.
* @member {Uint8Array} accountSignatureKey
* @memberof proto.ADVSignedDeviceIdentity
* @instance
*/
ADVSignedDeviceIdentity.prototype.accountSignatureKey = $util.newBuffer([]);
/**
* ADVSignedDeviceIdentity accountSignature.
* @member {Uint8Array} accountSignature
* @memberof proto.ADVSignedDeviceIdentity
* @instance
*/
ADVSignedDeviceIdentity.prototype.accountSignature = $util.newBuffer([]);
/**
* ADVSignedDeviceIdentity deviceSignature.
* @member {Uint8Array} deviceSignature
* @memberof proto.ADVSignedDeviceIdentity
* @instance
*/
ADVSignedDeviceIdentity.prototype.deviceSignature = $util.newBuffer([]);
/**
* Creates a new ADVSignedDeviceIdentity instance using the specified properties.
* @function create
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {proto.IADVSignedDeviceIdentity=} [properties] Properties to set
* @returns {proto.ADVSignedDeviceIdentity} ADVSignedDeviceIdentity instance
*/
ADVSignedDeviceIdentity.create = function create(properties) {
return new ADVSignedDeviceIdentity(properties);
};
/**
* Encodes the specified ADVSignedDeviceIdentity message. Does not implicitly {@link proto.ADVSignedDeviceIdentity.verify|verify} messages.
* @function encode
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {proto.IADVSignedDeviceIdentity} message ADVSignedDeviceIdentity message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVSignedDeviceIdentity.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.details != null && Object.hasOwnProperty.call(message, "details"))
writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.details);
if (message.accountSignatureKey != null && Object.hasOwnProperty.call(message, "accountSignatureKey"))
writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.accountSignatureKey);
if (message.accountSignature != null && Object.hasOwnProperty.call(message, "accountSignature"))
writer.uint32(/* id 3, wireType 2 =*/26).bytes(message.accountSignature);
if (message.deviceSignature != null && Object.hasOwnProperty.call(message, "deviceSignature"))
writer.uint32(/* id 4, wireType 2 =*/34).bytes(message.deviceSignature);
return writer;
};
/**
* Encodes the specified ADVSignedDeviceIdentity message, length delimited. Does not implicitly {@link proto.ADVSignedDeviceIdentity.verify|verify} messages.
* @function encodeDelimited
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {proto.IADVSignedDeviceIdentity} message ADVSignedDeviceIdentity message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVSignedDeviceIdentity.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a ADVSignedDeviceIdentity message from the specified reader or buffer.
* @function decode
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {proto.ADVSignedDeviceIdentity} ADVSignedDeviceIdentity
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ADVSignedDeviceIdentity.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.proto.ADVSignedDeviceIdentity();
while (reader.pos < end) {
var tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.details = reader.bytes();
break;
case 2:
message.accountSignatureKey = reader.bytes();
break;
case 3:
message.accountSignature = reader.bytes();
break;
case 4:
message.deviceSignature = reader.bytes();
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a ADVSignedDeviceIdentity message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {proto.ADVSignedDeviceIdentity} ADVSignedDeviceIdentity
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
ADVSignedDeviceIdentity.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a ADVSignedDeviceIdentity message.
* @function verify
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
ADVSignedDeviceIdentity.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.details != null && message.hasOwnProperty("details"))
if (!(message.details && typeof message.details.length === "number" || $util.isString(message.details)))
return "details: buffer expected";
if (message.accountSignatureKey != null && message.hasOwnProperty("accountSignatureKey"))
if (!(message.accountSignatureKey && typeof message.accountSignatureKey.length === "number" || $util.isString(message.accountSignatureKey)))
return "accountSignatureKey: buffer expected";
if (message.accountSignature != null && message.hasOwnProperty("accountSignature"))
if (!(message.accountSignature && typeof message.accountSignature.length === "number" || $util.isString(message.accountSignature)))
return "accountSignature: buffer expected";
if (message.deviceSignature != null && message.hasOwnProperty("deviceSignature"))
if (!(message.deviceSignature && typeof message.deviceSignature.length === "number" || $util.isString(message.deviceSignature)))
return "deviceSignature: buffer expected";
return null;
};
/**
* Creates a ADVSignedDeviceIdentity message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {Object.<string,*>} object Plain object
* @returns {proto.ADVSignedDeviceIdentity} ADVSignedDeviceIdentity
*/
ADVSignedDeviceIdentity.fromObject = function fromObject(object) {
if (object instanceof $root.proto.ADVSignedDeviceIdentity)
return object;
var message = new $root.proto.ADVSignedDeviceIdentity();
if (object.details != null)
if (typeof object.details === "string")
$util.base64.decode(object.details, message.details = $util.newBuffer($util.base64.length(object.details)), 0);
else if (object.details.length)
message.details = object.details;
if (object.accountSignatureKey != null)
if (typeof object.accountSignatureKey === "string")
$util.base64.decode(object.accountSignatureKey, message.accountSignatureKey = $util.newBuffer($util.base64.length(object.accountSignatureKey)), 0);
else if (object.accountSignatureKey.length)
message.accountSignatureKey = object.accountSignatureKey;
if (object.accountSignature != null)
if (typeof object.accountSignature === "string")
$util.base64.decode(object.accountSignature, message.accountSignature = $util.newBuffer($util.base64.length(object.accountSignature)), 0);
else if (object.accountSignature.length)
message.accountSignature = object.accountSignature;
if (object.deviceSignature != null)
if (typeof object.deviceSignature === "string")
$util.base64.decode(object.deviceSignature, message.deviceSignature = $util.newBuffer($util.base64.length(object.deviceSignature)), 0);
else if (object.deviceSignature.length)
message.deviceSignature = object.deviceSignature;
return message;
};
/**
* Creates a plain object from a ADVSignedDeviceIdentity message. Also converts values to other types if specified.
* @function toObject
* @memberof proto.ADVSignedDeviceIdentity
* @static
* @param {proto.ADVSignedDeviceIdentity} message ADVSignedDeviceIdentity
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
ADVSignedDeviceIdentity.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.defaults) {
if (options.bytes === String)
object.details = "";
else {
object.details = [];
if (options.bytes !== Array)
object.details = $util.newBuffer(object.details);
}
if (options.bytes === String)
object.accountSignatureKey = "";
else {
object.accountSignatureKey = [];
if (options.bytes !== Array)
object.accountSignatureKey = $util.newBuffer(object.accountSignatureKey);
}
if (options.bytes === String)
object.accountSignature = "";
else {
object.accountSignature = [];
if (options.bytes !== Array)
object.accountSignature = $util.newBuffer(object.accountSignature);
}
if (options.bytes === String)
object.deviceSignature = "";
else {
object.deviceSignature = [];
if (options.bytes !== Array)
object.deviceSignature = $util.newBuffer(object.deviceSignature);
}
}
if (message.details != null && message.hasOwnProperty("details"))
object.details = options.bytes === String ? $util.base64.encode(message.details, 0, message.details.length) : options.bytes === Array ? Array.prototype.slice.call(message.details) : message.details;
if (message.accountSignatureKey != null && message.hasOwnProperty("accountSignatureKey"))
object.accountSignatureKey = options.bytes === String ? $util.base64.encode(message.accountSignatureKey, 0, message.accountSignatureKey.length) : options.bytes === Array ? Array.prototype.slice.call(message.accountSignatureKey) : message.accountSignatureKey;
if (message.accountSignature != null && message.hasOwnProperty("accountSignature"))
object.accountSignature = options.bytes === String ? $util.base64.encode(message.accountSignature, 0, message.accountSignature.length) : options.bytes === Array ? Array.prototype.slice.call(message.accountSignature) : message.accountSignature;
if (message.deviceSignature != null && message.hasOwnProperty("deviceSignature"))
object.deviceSignature = options.bytes === String ? $util.base64.encode(message.deviceSignature, 0, message.deviceSignature.length) : options.bytes === Array ? Array.prototype.slice.call(message.deviceSignature) : message.deviceSignature;
return object;
};
/**
* Converts this ADVSignedDeviceIdentity to JSON.
* @function toJSON
* @memberof proto.ADVSignedDeviceIdentity
* @instance
* @returns {Object.<string,*>} JSON object
*/
ADVSignedDeviceIdentity.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
return ADVSignedDeviceIdentity;
})();
proto.ADVSignedDeviceIdentityHMAC = (function() {
/**
* Properties of a ADVSignedDeviceIdentityHMAC.
* @memberof proto
* @interface IADVSignedDeviceIdentityHMAC
* @property {Uint8Array|null} [details] ADVSignedDeviceIdentityHMAC details
* @property {Uint8Array|null} [hmac] ADVSignedDeviceIdentityHMAC hmac
* @property {proto.ADVEncryptionType|null} [accountType] ADVSignedDeviceIdentityHMAC accountType
*/
/**
* Constructs a new ADVSignedDeviceIdentityHMAC.
* @memberof proto
* @classdesc Represents a ADVSignedDeviceIdentityHMAC.
* @implements IADVSignedDeviceIdentityHMAC
* @constructor
* @param {proto.IADVSignedDeviceIdentityHMAC=} [properties] Properties to set
*/
function ADVSignedDeviceIdentityHMAC(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]];
}
/**
* ADVSignedDeviceIdentityHMAC details.
* @member {Uint8Array} details
* @memberof proto.ADVSignedDeviceIdentityHMAC
* @instance
*/
ADVSignedDeviceIdentityHMAC.prototype.details = $util.newBuffer([]);
/**
* ADVSignedDeviceIdentityHMAC hmac.
* @member {Uint8Array} hmac
* @memberof proto.ADVSignedDeviceIdentityHMAC
* @instance
*/
ADVSignedDeviceIdentityHMAC.prototype.hmac = $util.newBuffer([]);
/**
* ADVSignedDeviceIdentityHMAC accountType.
* @member {proto.ADVEncryptionType} accountType
* @memberof proto.ADVSignedDeviceIdentityHMAC
* @instance
*/
ADVSignedDeviceIdentityHMAC.prototype.accountType = 0;
/**
* Creates a new ADVSignedDeviceIdentityHMAC instance using the specified properties.
* @function create
* @memberof proto.ADVSignedDeviceIdentityHMAC
* @static
* @param {proto.IADVSignedDeviceIdentityHMAC=} [properties] Properties to set
* @returns {proto.ADVSignedDeviceIdentityHMAC} ADVSignedDeviceIdentityHMAC instance
*/
ADVSignedDeviceIdentityHMAC.create = function create(properties) {
return new ADVSignedDeviceIdentityHMAC(properties);
};
/**
* Encodes the specified ADVSignedDeviceIdentityHMAC message. Does not implicitly {@link proto.ADVSignedDeviceIdentityHMAC.verify|verify} messages.
* @function encode
* @memberof proto.ADVSignedDeviceIdentityHMAC
* @static
* @param {proto.IADVSignedDeviceIdentityHMAC} message ADVSignedDeviceIdentityHMAC message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVSignedDeviceIdentityHMAC.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.details != null && Object.hasOwnProperty.call(message, "details"))
writer.uint32(/* id 1, wireType 2 =*/10).bytes(message.details);
if (message.hmac != null && Object.hasOwnProperty.call(message, "hmac"))
writer.uint32(/* id 2, wireType 2 =*/18).bytes(message.hmac);
if (message.accountType != null && Object.hasOwnProperty.call(message, "accountType"))
writer.uint32(/* id 3, wireType 0 =*/24).int32(message.accountType);
return writer;
};
/**
* Encodes the specified ADVSignedDeviceIdentityHMAC message, length delimited. Does not implicitly {@link proto.ADVSignedDeviceIdentityHMAC.verify|verify} messages.
* @function encodeDelimited
* @memberof proto.ADVSignedDeviceIdentityHMAC
* @static
* @param {proto.IADVSignedDeviceIdentityHMAC} message ADVSignedDeviceIdentityHMAC message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
ADVSignedDeviceIdentityHMAC.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a ADVSignedDeviceIdentityHMAC message from the specified reader or buffer.
* @function decode
* @memberof proto.ADVSignedDeviceIden