Commit 921ae7ec authored by JC Brand's avatar JC Brand

More renamings/refactoring to add consistency

parent 6a45eee6
...@@ -292,10 +292,10 @@ ...@@ -292,10 +292,10 @@
}; };
this.otr = new otr.OTR(options); this.otr = new otr.OTR(options);
this.otr.on('ui', $.proxy(function (msg) { this.otr.on('ui', $.proxy(function (msg) {
this.trigger('OTRMessageReceived', msg); this.trigger('showReceivedOTRMessage', msg);
}, this)); }, this));
this.otr.on('io', $.proxy(function (msg) { this.otr.on('io', $.proxy(function (msg) {
this.trigger('sendMessage', msg); this.trigger('sendMessageStanza', msg);
}, this)); }, this));
this.otr.on('error', $.proxy(function (msg) { this.otr.on('error', $.proxy(function (msg) {
// XXX // XXX
...@@ -403,11 +403,11 @@ ...@@ -403,11 +403,11 @@
this.model.on('show', this.show, this); this.model.on('show', this.show, this);
this.model.on('destroy', this.hide, this); this.model.on('destroy', this.hide, this);
this.model.on('change', this.onChange, this); this.model.on('change', this.onChange, this);
this.model.on('sendMessage', this.onMessageSend, this); this.model.on('sendMessageStanza', this.sendMessageStanza, this);
this.model.on('sendOTRMessage', function (text) { this.model.on('showSentOTRMessage', function (text) {
this.showOTRMessage(text, 'me'); this.showOTRMessage(text, 'me');
}, this); }, this);
this.model.on('OTRMessageReceived', function (text) { this.model.on('showReceivedOTRMessage', function (text) {
this.showOTRMessage(text, 'them'); this.showOTRMessage(text, 'them');
}, this); }, this);
this.updateVCard(); this.updateVCard();
...@@ -453,8 +453,9 @@ ...@@ -453,8 +453,9 @@
}, },
showOTRMessage: function (text, sender) { showOTRMessage: function (text, sender) {
// "Off-the-record" messages are not stored at all, so we don't /* "Off-the-record" messages are encrypted and not stored at all,
// have a backbone converse.Message object to work with. * so we don't have a backbone converse.Message object to work with.
*/
var username = sender === 'me' && sender || this.model.get('fullname'); var username = sender === 'me' && sender || this.model.get('fullname');
var $el = this.$el.find('.chat-content'); var $el = this.$el.find('.chat-content');
$el.find('div.chat-event').remove(); $el.find('div.chat-event').remove();
...@@ -520,6 +521,29 @@ ...@@ -520,6 +521,29 @@
(next_date.getMonth() != prev_date.getMonth())); (next_date.getMonth() != prev_date.getMonth()));
}, },
sendMessageStanza: function (text) {
/*
* Sends the actual XML stanza to the XMPP server.
*/
// TODO: Look in ChatPartners to see what resources we have for the recipient.
// if we have one resource, we sent to only that resources, if we have multiple
// we send to the bare jid.
var timestamp = (new Date()).getTime();
var bare_jid = this.model.get('jid');
var message = $msg({from: converse.connection.jid, to: bare_jid, type: 'chat', id: timestamp})
.c('body').t(text).up()
.c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'});
// Forward the message, so that other connected resources are also aware of it.
// TODO: Forward the message only to other connected resources (inside the browser)
var forwarded = $msg({to:converse.bare_jid, type:'chat', id:timestamp})
.c('forwarded', {xmlns:'urn:xmpp:forward:0'})
.c('delay', {xmns:'urn:xmpp:delay',stamp:timestamp}).up()
.cnode(message.tree());
converse.connection.send(message);
converse.connection.send(forwarded);
},
sendMessage: function (text) { sendMessage: function (text) {
var match = text.replace(/^\s*/, "").match(/^\/(.*)\s*$/), msgs; var match = text.replace(/^\s*/, "").match(/^\/(.*)\s*$/), msgs;
if (match) { if (match) {
...@@ -560,8 +584,9 @@ ...@@ -560,8 +584,9 @@
} }
} }
if (this.model.otr) { if (this.model.otr) {
// Off-the-record encryption is active
this.model.otr.sendMsg(text); this.model.otr.sendMsg(text);
this.model.trigger('sendOTRMessage', text); this.model.trigger('showSentOTRMessage', text);
} }
else { else {
// We only save unencrypted messages. // We only save unencrypted messages.
...@@ -571,30 +596,10 @@ ...@@ -571,30 +596,10 @@
time: converse.toISOString(new Date()), time: converse.toISOString(new Date()),
message: text message: text
}); });
this.model.trigger('sendMessage', text); this.sendMessageStanza(text);
} }
}, },
onMessageSend: function (text) {
// TODO: Look in ChatPartners to see what resources we have for the recipient.
// if we have one resource, we sent to only that resources, if we have multiple
// we send to the bare jid.
var timestamp = (new Date()).getTime();
var bare_jid = this.model.get('jid');
var message = $msg({from: converse.connection.jid, to: bare_jid, type: 'chat', id: timestamp})
.c('body').t(text).up()
.c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'});
// Forward the message, so that other connected resources are also aware of it.
// TODO: Forward the message only to other connected resources (inside the browser)
var forwarded = $msg({to:converse.bare_jid, type:'chat', id:timestamp})
.c('forwarded', {xmlns:'urn:xmpp:forward:0'})
.c('delay', {xmns:'urn:xmpp:delay',stamp:timestamp}).up()
.cnode(message.tree());
converse.connection.send(message);
converse.connection.send(forwarded);
},
keyPressed: function (ev) { keyPressed: function (ev) {
var $textarea = $(ev.target), var $textarea = $(ev.target),
message, notify, composing; message, notify, composing;
......
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