Mercurial > libervia-backend
view tools/jid.py @ 64:d46f849664aa
SàT: multi-profile, plugins updated
- core: 2 new convenient methods: getJidNStream and getClient
- new param in plugin info: "handler" to know if there is a handler to plug on profiles clients
- plugins with handler now use an other class which is returned to profile client with the new method "getHandler" and pluged when connecting
author | Goffi <goffi@goffi.org> |
---|---|
date | Sat, 30 Jan 2010 16:17:33 +1100 |
parents | a5b5fb5fc9fd |
children | 2240f34f6452 |
line wrap: on
line source
#!/usr/bin/python # -*- coding: utf-8 -*- """ SAT: a jabber client Copyright (C) 2009, 2010 Jérôme Poisson (goffi@goffi.org) This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. """ class JID(str): """This class help manage JID (Node@Domaine/Resource)""" def __new__(cls, jid): self = str.__new__(cls, jid) self.__parse() return self def __parse(self): """find node domaine and resource""" node_end=self.find('@') if node_end<0: node_end=0 domain_end=self.find('/') if domain_end<1: domain_end=len(self) self.node=self[:node_end] self.domain=self[(node_end+1) if node_end else 0:domain_end] self.resource=self[domain_end+1:] if not node_end: self.short=self else: self.short=self.node+'@'+self.domain def is_valid(self): """return True if the jid is xmpp compliant""" #FIXME: always return True for the moment return True