From 211129475cb4265bc1f62fdec7811128063f5854 Mon Sep 17 00:00:00 2001 From: lilia Date: Sat, 25 Oct 2014 18:01:33 -0700 Subject: [PATCH] Fix attachment ids Parse attachment ids out of the attachment pointer url and return them as strings because the copy parsed by JSON suffers a loss of precision. Convert them to and from the format expected by the protobuf using facilities from decodeIO.Long. --- js/api.js | 43 ++++++++++++++++++++++++------------------- js/helpers.js | 2 +- js/sendmessage.js | 2 +- 3 files changed, 26 insertions(+), 21 deletions(-) diff --git a/js/api.js b/js/api.js index 6ef51d1e..3ada2f8f 100644 --- a/js/api.js +++ b/js/api.js @@ -27,6 +27,7 @@ window.textsecure.api = function() { // Staging server var URL_BASE = "https://textsecure-service-staging.whispersystems.org"; self.relay = "textsecure-service-staging.whispersystems.org"; + var ATTACHMENT_HOST = "whispersystems-textsecure-attachments-staging.s3.amazonaws.com" // This is the real server //var URL_BASE = "https://textsecure-service.whispersystems.org"; @@ -253,6 +254,7 @@ window.textsecure.api = function() { }); }; + var id_regex = RegExp( "^https:\/\/" + ATTACHMENT_HOST + "\/(\\d+)\?"); self.putAttachment = function(encryptedBin) { return doAjax({ call : 'attachment', @@ -261,27 +263,30 @@ window.textsecure.api = function() { }).then(function(response) { return new Promise(function(resolve, reject) { $.ajax(response.location, { - type : "PUT", - headers: { - "Content-Type": "application/octet-stream" + type : "PUT", + headers : {"Content-Type" : "application/octet-stream"}, + data : encryptedBin, + success : function() { + try { + // Parse the id as a string from the location url + // (workaround for ids too large for Javascript numbers) + var id = response.location.match(id_regex)[1]; + resolve(id); + } catch(e) { + reject(e); + } }, - data: encryptedBin, + error : function(jqXHR, textStatus, errorThrown) { + var code = jqXHR.status; + if (code > 999 || code < 100) + code = -1; - success : function() { - resolve(response.id); - }, - - error : function(jqXHR, textStatus, errorThrown) { - var code = jqXHR.status; - if (code > 999 || code < 100) - code = -1; - - var e = new Error(code); - e.name = "HTTPError"; - if (jqXHR.responseJSON) - e.response = jqXHR.responseJSON; - reject(e); - } + var e = new Error(code); + e.name = "HTTPError"; + if (jqXHR.responseJSON) + e.response = jqXHR.responseJSON; + reject(e); + } }); }); }); diff --git a/js/helpers.js b/js/helpers.js index b15e0481..131e6d25 100644 --- a/js/helpers.js +++ b/js/helpers.js @@ -593,7 +593,7 @@ window.textsecure.subscribeToPush = function(message_callback) { throw new Error("Unknown flags in message"); var handleAttachment = function(attachment) { - return textsecure.api.getAttachment(attachment.id).then(function(encryptedBin) { + return textsecure.api.getAttachment(attachment.id.toString()).then(function(encryptedBin) { return textsecure.crypto.decryptAttachment(encryptedBin, toArrayBuffer(attachment.key)).then(function(decryptedBin) { attachment.decrypted = decryptedBin; }); diff --git a/js/sendmessage.js b/js/sendmessage.js index 5a1b8c33..33cb88ff 100644 --- a/js/sendmessage.js +++ b/js/sendmessage.js @@ -200,7 +200,7 @@ window.textsecure.messaging = function() { var iv = textsecure.crypto.getRandomBytes(16); return textsecure.crypto.encryptAttachment(attachment.data, proto.key, iv).then(function(encryptedBin) { return textsecure.api.putAttachment(encryptedBin).then(function(id) { - proto.id = id; + proto.id = dcodeIO.Long.fromString(id); proto.contentType = attachment.contentType; return proto; });