Compare equality w/o getString (in the future)
This commit is contained in:
parent
1d2e252595
commit
4c3ee6f23b
2 changed files with 12 additions and 6 deletions
|
@ -352,18 +352,14 @@ window.textsecure.crypto = function() {
|
||||||
|
|
||||||
var verifyMACWithVersionByte = function(data, key, mac, version) {
|
var verifyMACWithVersionByte = function(data, key, mac, version) {
|
||||||
return calculateMACWithVersionByte(data, key, version).then(function(calculated_mac) {
|
return calculateMACWithVersionByte(data, key, version).then(function(calculated_mac) {
|
||||||
var macString = getString(mac);//TODO: Move away from strings for comparison?
|
if (!isEqual(calculated_mac, mac, mac.byteLength))
|
||||||
|
|
||||||
if (getString(calculated_mac).substring(0, macString.length) != macString)
|
|
||||||
throw new Error("Bad MAC");
|
throw new Error("Bad MAC");
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var verifyMAC = function(data, key, mac) {
|
var verifyMAC = function(data, key, mac) {
|
||||||
return HmacSHA256(key, data).then(function(calculated_mac) {
|
return HmacSHA256(key, data).then(function(calculated_mac) {
|
||||||
var macString = getString(mac);//TODO: Move away from strings for comparison?
|
if (!isEqual(calculated_mac, mac, mac.byteLength))
|
||||||
|
|
||||||
if (getString(calculated_mac).substring(0, macString.length) != macString)
|
|
||||||
throw new Error("Bad MAC");
|
throw new Error("Bad MAC");
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -99,6 +99,7 @@ window.textsecure = window.textsecure || {};
|
||||||
*********************************/
|
*********************************/
|
||||||
// Strings/arrays
|
// Strings/arrays
|
||||||
//TODO: Throw all this shit in favor of consistent types
|
//TODO: Throw all this shit in favor of consistent types
|
||||||
|
//TODO: Namespace
|
||||||
var StaticByteBufferProto = new dcodeIO.ByteBuffer().__proto__;
|
var StaticByteBufferProto = new dcodeIO.ByteBuffer().__proto__;
|
||||||
var StaticArrayBufferProto = new ArrayBuffer().__proto__;
|
var StaticArrayBufferProto = new ArrayBuffer().__proto__;
|
||||||
var StaticUint8ArrayProto = new Uint8Array().__proto__;
|
var StaticUint8ArrayProto = new Uint8Array().__proto__;
|
||||||
|
@ -126,6 +127,15 @@ function getStringable(thing) {
|
||||||
thing.__proto__ == StaticWordArrayProto)));
|
thing.__proto__ == StaticWordArrayProto)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isEqual(a, b, maxLegnth) {
|
||||||
|
// TODO: Special-case arraybuffers, etc
|
||||||
|
a = getString(a);
|
||||||
|
b = getString(b);
|
||||||
|
if (maxLength === undefined)
|
||||||
|
maxLength = Math.max(a.length, b.length);
|
||||||
|
return a.substring(0, Math.min(maxLength, a.length)) == b.substring(0, Math.min(maxLength, b.length));
|
||||||
|
}
|
||||||
|
|
||||||
function toArrayBuffer(thing) {
|
function toArrayBuffer(thing) {
|
||||||
//TODO: Optimize this for specific cases
|
//TODO: Optimize this for specific cases
|
||||||
if (thing === undefined)
|
if (thing === undefined)
|
||||||
|
|
Loading…
Reference in a new issue