# HG changeset patch # User Emmanuel Gil Peyrot # Date 1327711822 -3600 # Node ID 1506992c33e247c0164b9e3eb1938354a6ec1961 # Parent 630b9579fe4a722cc251b334052d172003b6d18b Split plugins.js into multiple plugins. 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,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. +*/ + +//////////// +//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)); +}; 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); + }); +}