# HG changeset patch # User Sonny Piers # Date 1327721943 -3600 # Node ID 6ce66fba02429ce192b3bbf5f54fb70e8d079cb9 # Parent 1e6d2ca2daae5eb718c8f18cd201330f7b7c157d# Parent 88d24231bf248ef55a64ffe384f1ae28e65f7df5 Merging. diff --git a/lightstring.js b/lightstring.js --- a/lightstring.js +++ b/lightstring.js @@ -86,7 +86,20 @@ var Lightstring = { finally { return XML; }; - } + }, + /** + * @function Get an unique identifier. + * @param {String} [aString] Prefix to put before the identifier. + * @return {String} Identifier. + */ + newId: (function() { + var id = 1024; + return function(prefix) { + if (typeof prefix === 'string') + return prefix + id++; + return '' + id++; + }; + })() }; /** @@ -98,11 +111,6 @@ Lightstring.Connection = function(aServi if (aService) this.service = aService; this.handlers = {}; - this.iqid = 1024; - this.getNewId = function() { - this.iqid++; - return 'sendiq:' + this.iqid; - }; this.on('stream:features', function(stanza, that) { var nodes = stanza.DOM.querySelectorAll('mechanism'); //SASL/Auth features @@ -321,8 +329,7 @@ Lightstring.Connection.prototype = { var id = stanza.DOM.getAttribute('id'); //TODO: This should be done by a plugin if (!id) { - alert(Lightstring.DOM2XML(stanza.DOM)); - stanza.DOM.setAttribute('id', this.getNewId()); + stanza.DOM.setAttribute('id', Lightstring.newId('sendiq:')); } if (aCallback) this.on(stanza.DOM.getAttribute('id'), aCallback); diff --git a/plugins/disco.js b/plugins/disco.js new file mode 100644 --- /dev/null +++ b/plugins/disco.js @@ -0,0 +1,96 @@ +'use strict'; + +/** + Copyright (c) 2011, Sonny Piers + + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted, provided that the above + copyright notice and this permission notice appear in all copies. + + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +*/ + +///////// +//Disco// +///////// +Lightstring.NS['disco#info'] = "http://jabber.org/protocol/disco#info"; +Lightstring.NS['disco#items'] = "http://jabber.org/protocol/disco#items"; +Lightstring.stanza.disco = { + items: function(aTo, aNode) { + if(aTo) + var iq = ""; + else + var iq = ""; + + if(aNode) + var query = ""; + else + var query = ""; + + return iq+query+""; + }, + info: function(aTo, aNode) { + if(aTo) + var iq = ""; + else + var iq = ""; + if(aNode) + var query = ""; + else + var query = ""; + + return iq+query+""; + } +}; +Lightstring.discoItems = function(aConnection, aTo, aCallback) { + aConnection.send(Lightstring.stanza.disco.items(aTo), function(answer){ + var items = []; + var elms = answer.querySelectorAll('item'); + for(var i = 0; i < elms.length; i++) { + var node = elms[i]; + var item = { + jid: node.getAttribute('jid'), + name: node.getAttribute('name'), + node: node.getAttribute('node') + } + items.push(item); + }; + if(aCallback) + aCallback(items); + }); +}; +Lightstring.discoInfo = function(aConnection, aTo, aNode, aCallback) { + aConnection.send(Lightstring.stanza.disco.info(aTo, aNode), function(answer){ + var identities = []; + var features = []; + + var children = answer.firstChild.children; + var length = children.length; + + for (var i = 0; i < length; i++) { + var child = children[i]; + + if (child.localName === 'feature') + features.push(child.getAttributeNS(null, 'var')); + + else if (child.localName === 'identity') { + var identity = { + category: child.getAttributeNS(null, 'category'), + type: child.getAttributeNS(null, 'type') + }; + var name = child.getAttributeNS(null, 'name'); + if (name) + identity.name = name; + identities.push(identity); + } + } + + aCallback({identities: identities, features: features}); + }); +}; diff --git a/plugins/im.js b/plugins/im.js new file mode 100644 --- /dev/null +++ b/plugins/im.js @@ -0,0 +1,30 @@ +'use strict'; + +/** + Copyright (c) 2011, Sonny Piers + + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted, provided that the above + copyright notice and this permission notice appear in all copies. + + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +*/ + +////// +//IM// +////// +Lightstring.stanza.message = { + normal: function(aTo, aSubject, aText) { + return ""+aSubject+""+aText+""; + }, + chat: function(aTo, aText) { + return ""+aText+""; + } +}; + diff --git a/plugins/presence.js b/plugins/presence.js new file mode 100644 --- /dev/null +++ b/plugins/presence.js @@ -0,0 +1,57 @@ +'use strict'; + +/** + Copyright (c) 2011, Sonny Piers + Copyright (c) 2012, Emmanuel Gil Peyrot + + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted, provided that the above + copyright notice and this permission notice appear in all copies. + + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +*/ + +//////////// +//Presence// http://xmpp.org/rfcs/rfc6121.html#presence +//////////// +(function() { + var legal_types = ['error', 'probe', 'subscribe', 'subscribed', 'unavailable', 'unsubscribe', 'unsubscribed']; + + Lightstring.stanza.presence = function(object) { + if (object) { + var payloads = ""; + var attributs = ""; + if (object.type && legal_types.indexOf(object.type) !== -1) + attributs += " type='" + object.type + "'"; + + if (object.priority) + payloads += "" + object.priority + ""; + + if (object.show) + payloads += "" + object.show + ""; + + if (object.status) + payloads += "" + object.status + ""; + + if (object.payload) + payloads += object.payload; + + if (payloads) + return "" + payloads + ""; + else + return ""; + + } else + return ""; + }; + + Lightstring.presence = function(aConnection, aObject) { + aConnection.send(Lightstring.stanza.presence(aObject)); + }; +})(); diff --git a/plugins.js b/plugins/pubsub.js rename from plugins.js rename to plugins/pubsub.js --- a/plugins.js +++ b/plugins/pubsub.js @@ -16,171 +16,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ -//////////// -//Presence// http://xmpp.org/rfcs/rfc6121.html#presence -//////////// -Lightstring.stanza.presence = function(aPriority) { - if(aPriority) - return ""+aPriority+""; - else - return ""; -}; -Lightstring.presence = function(aConnection, aPriority) { - aConnection.send(Lightstring.stanza.presence(aPriority)); -}; - -////////// -//Roster// -////////// -Lightstring.NS.roster = 'jabber:iq:roster'; -Lightstring.stanza.roster = { - 'get': function() { - return ""; - }, - add: function(aAddress, aGroups, aCustomName) { - var iq = $iq({type: 'set'}).c('query', {xmlns: Lightstring.NS.roster}).c('item', {jid: aAddress}).tree(); - if(aCustomName) iq.querySelector('item').setAttribute(aCustomName); - for (var i=0; i 0) { - contact.groups = []; - groups.forEach(function(group) { - contact.groups.push(group.textContent); - }); - } - - contacts.push(contact); - }; - aCallback(contacts); - }); -} -///////// -//vCard// -///////// -Lightstring.NS.vcard = 'vcard-temp'; -Lightstring.stanza.vcard = { - 'get': function(aTo) { - if(aTo) - return ""; - else - return ""; - } -}; -//FIXME we should return a proper vcard, not an XMPP one -Lightstring.getVcard = function(aConnection, aTo, aCallback) { - aConnection.send(Lightstring.stanza.vcard.get(aTo), function(answer, err){ - if(answer) { - var vcard = answer.querySelector('vCard'); - if(vcard) - aCallback(vcard); - } - else - aCallback(null); - }); -} -///////// -//Disco// -///////// -Lightstring.NS['disco#info'] = "http://jabber.org/protocol/disco#info"; -Lightstring.NS['disco#items'] = "http://jabber.org/protocol/disco#items"; -Lightstring.stanza.disco = { - items: function(aTo, aNode) { - if(aTo) - var iq = ""; - else - var iq = ""; - - if(aNode) - var query = ""; - else - var query = ""; - - return iq+query+""; - }, - info: function(aTo, aNode) { - if(aTo) - var iq = ""; - else - var iq = ""; - if(aNode) - var query = ""; - else - var query = ""; - - return iq+query+""; - } -}; -Lightstring.discoItems = function(aConnection, aTo, aCallback) { - aConnection.send(Lightstring.stanza.disco.items(aTo), function(answer){ - var items = []; - var elms = answer.querySelectorAll('item'); - for(var i = 0; i < elms.length; i++) { - var node = elms[i]; - var item = { - jid: node.getAttribute('jid'), - name: node.getAttribute('name'), - node: node.getAttribute('node') - } - items.push(item); - }; - if(aCallback) - aCallback(items); - }); -}; -Lightstring.discoInfo = function(aConnection, aTo, aNode, aCallback) { - aConnection.send(Lightstring.stanza.disco.info(aTo, aNode), function(answer){ - var identities = []; - var features = []; - - var children = answer.firstChild.children; - var length = children.length; - - for (var i = 0; i < length; i++) { - var child = children[i]; - - if (child.localName === 'feature') - features.push(child.getAttributeNS(null, 'var')); - - else if (child.localName === 'identity') { - var identity = { - category: child.getAttributeNS(null, 'category'), - type: child.getAttributeNS(null, 'type') - }; - var name = child.getAttributeNS(null, 'name'); - if (name) - identity.name = name; - identities.push(identity); - } - } - - aCallback({identities: identities, features: features}); - }); -}; ////////// //PubSub// ////////// @@ -299,15 +134,3 @@ Lightstring.pubsubGetAffiliations = func Lightstring.pubsubSetAffiliations = function(aConnection, aTo, aNode, aAffiliations, aCallback) { aConnection.send(Lightstring.stanza.pubsub.setAffiliations(aTo, aNode, aAffiliations)); }; -////// -//IM// -////// -Lightstring.stanza.message = { - normal: function(aTo, aSubject, aText) { - return ""+aSubject+""+aText+""; - }, - chat: function(aTo, aText) { - return ""+aText+""; - } -}; - diff --git a/plugins/roster.js b/plugins/roster.js new file mode 100644 --- /dev/null +++ b/plugins/roster.js @@ -0,0 +1,68 @@ +'use strict'; + +/** + Copyright (c) 2011, Sonny Piers + + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted, provided that the above + copyright notice and this permission notice appear in all copies. + + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +*/ + +////////// +//Roster// +////////// +Lightstring.NS.roster = 'jabber:iq:roster'; +Lightstring.stanza.roster = { + 'get': function() { + return ""; + }, + add: function(aAddress, aGroups, aCustomName) { + var iq = $iq({type: 'set'}).c('query', {xmlns: Lightstring.NS.roster}).c('item', {jid: aAddress}).tree(); + if(aCustomName) iq.querySelector('item').setAttribute(aCustomName); + for (var i=0; i 0) { + contact.groups = []; + groups.forEach(function(group) { + contact.groups.push(group.textContent); + }); + } + + contacts.push(contact); + }; + aCallback(contacts); + }); +} diff --git a/plugins/vcard.js b/plugins/vcard.js new file mode 100644 --- /dev/null +++ b/plugins/vcard.js @@ -0,0 +1,42 @@ +'use strict'; + +/** + Copyright (c) 2011, Sonny Piers + + Permission to use, copy, modify, and/or distribute this software for any + purpose with or without fee is hereby granted, provided that the above + copyright notice and this permission notice appear in all copies. + + THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +*/ + +///////// +//vCard// +///////// +Lightstring.NS.vcard = 'vcard-temp'; +Lightstring.stanza.vcard = { + 'get': function(aTo) { + if(aTo) + return ""; + else + return ""; + } +}; +//FIXME we should return a proper vcard, not an XMPP one +Lightstring.getVcard = function(aConnection, aTo, aCallback) { + aConnection.send(Lightstring.stanza.vcard.get(aTo), function(answer, err){ + if(answer) { + var vcard = answer.querySelector('vCard'); + if(vcard) + aCallback(vcard); + } + else + aCallback(null); + }); +}