Commit e235fa44 authored by JC Brand's avatar JC Brand

Refactored local storage code and fixed data leakage.

parent 72e9698d
...@@ -50,32 +50,6 @@ ...@@ -50,32 +50,6 @@
}(this, function (jarnxmpp, $, store, _, console) { }(this, function (jarnxmpp, $, store, _, console) {
var xmppchat = jarnxmpp; var xmppchat = jarnxmpp;
xmppchat.messages = {};
xmppchat.messages.ClientStorage = (function () {
// TODO: Messages must be encrypted with a key and salt
methods = {};
methods.addMessage = function (jid, msg, direction) {
var bare_jid = Strophe.getBareJidFromJid(jid),
now = new Date().toISOString(),
msgs = store.get(bare_jid) || [];
if (msgs.length >= 30) {
msgs.shift();
}
msgs.push(now+' '+direction+' '+msg);
store.set(bare_jid, msgs);
};
methods.getMessages = function (jid) {
return store.get(jid) || [];
};
return methods;
})();
xmppchat.messages.getMessages = function (jid, callback) {
var bare_jid = Strophe.getBareJidFromJid(jid),
msgs = this.ClientStorage.getMessages(bare_jid);
callback(msgs);
};
xmppchat.collections = { xmppchat.collections = {
/* FIXME: XEP-0136 specifies 'urn:xmpp:archive' but the mod_archive_odbc /* FIXME: XEP-0136 specifies 'urn:xmpp:archive' but the mod_archive_odbc
...@@ -84,6 +58,7 @@ ...@@ -84,6 +58,7 @@
*/ */
'URI': 'http://www.xmpp.org/extensions/xep-0136.html#ns' 'URI': 'http://www.xmpp.org/extensions/xep-0136.html#ns'
}; };
xmppchat.collections.getLastCollection = function (jid, callback) { xmppchat.collections.getLastCollection = function (jid, callback) {
var bare_jid = Strophe.getBareJidFromJid(jid), var bare_jid = Strophe.getBareJidFromJid(jid),
iq = $iq({'type':'get'}) iq = $iq({'type':'get'})
...@@ -121,6 +96,29 @@ ...@@ -121,6 +96,29 @@
}); });
}; };
xmppchat.ClientStorage = Backbone.Model.extend({
// TODO: Messages must be encrypted with a key and salt
initialize: function (own_jid) {
this.set({ 'own_jid' : own_jid });
},
addMessage: function (jid, msg, direction) {
var bare_jid = Strophe.getBareJidFromJid(jid),
now = new Date().toISOString(),
msgs = store.get(hex_sha1(this.get('own_jid')+bare_jid)) || [];
if (msgs.length >= 30) {
msgs.shift();
}
msgs.push(now+' '+direction+' '+msg);
store.set(hex_sha1(this.get('own_jid')+bare_jid), msgs);
},
getMessages: function (jid) {
var bare_jid = Strophe.getBareJidFromJid(jid);
return store.get(hex_sha1(this.get('own_jid')+bare_jid)) || [];
}
});
xmppchat.ChatBox = Backbone.Model.extend({ xmppchat.ChatBox = Backbone.Model.extend({
initialize: function () { initialize: function () {
this.set({ this.set({
...@@ -225,7 +223,7 @@ ...@@ -225,7 +223,7 @@
return; return;
} }
} else { } else {
xmppchat.messages.ClientStorage.addMessage(jid, body, 'from'); xmppchat.storage.addMessage(jid, body, 'from');
$chat_content.find('div.chat-event').remove(); $chat_content.find('div.chat-event').remove();
if (delayed) { if (delayed) {
// XXX: Test properly (for really old messages we somehow need to show // XXX: Test properly (for really old messages we somehow need to show
...@@ -248,8 +246,9 @@ ...@@ -248,8 +246,9 @@
}, },
insertClientStoredMessages: function () { insertClientStoredMessages: function () {
xmppchat.messages.getMessages(this.model.get('jid'), $.proxy(function (msgs) { var msgs = xmppchat.storage.getMessages(this.model.get('jid')),
var $content = this.$el.find('.chat-content'); $content = this.$el.find('.chat-content');
for (var i=0; i<_.size(msgs); i++) { for (var i=0; i<_.size(msgs); i++) {
var msg = msgs[i], var msg = msgs[i],
msg_array = msg.split(' ', 2), msg_array = msg.split(' ', 2),
...@@ -277,7 +276,6 @@ ...@@ -277,7 +276,6 @@
})); }));
} }
} }
}, this));
}, },
sendMessage: function (text) { sendMessage: function (text) {
...@@ -292,7 +290,7 @@ ...@@ -292,7 +290,7 @@
.c('body').t(text).up() .c('body').t(text).up()
.c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'}); .c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'});
xmppchat.connection.send(message); xmppchat.connection.send(message);
xmppchat.messages.ClientStorage.addMessage(bare_jid, text, 'to'); xmppchat.storage.addMessage(bare_jid, text, 'to');
this.appendMessage(text); this.appendMessage(text);
}, },
...@@ -1043,7 +1041,7 @@ ...@@ -1043,7 +1041,7 @@
} }
}); });
RosterItems = Backbone.Collection.extend({ xmppchat.RosterItems = Backbone.Collection.extend({
model: xmppchat.RosterItem, model: xmppchat.RosterItem,
initialize: function () { initialize: function () {
this._connection = xmppchat.connection; this._connection = xmppchat.connection;
...@@ -1521,9 +1519,9 @@ ...@@ -1521,9 +1519,9 @@
// XXX: Better if configurable? // XXX: Better if configurable?
this.connection.muc_domain = 'conference.' + this.connection.domain; this.connection.muc_domain = 'conference.' + this.connection.domain;
this.roster = new RosterItems(); this.storage = new this.ClientStorage(Strophe.getBareJidFromJid(this.connection.jid));
//_.extend(this.roster, this.Roster);
this.roster = new this.RosterItems();
this.rosterview = Backbone.View.extend(this.RosterView(this.roster, _, $, console)); this.rosterview = Backbone.View.extend(this.RosterView(this.roster, _, $, console));
this.connection.addHandler( this.connection.addHandler(
$.proxy(this.roster.subscribeToSuggestedItems, this.roster), $.proxy(this.roster.subscribeToSuggestedItems, this.roster),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment