new_account is back !

getRegInfo can be synchronous if we want
This commit is contained in:
Yann Leboulanger 2005-07-07 20:45:24 +00:00
parent d0299a2f3f
commit 3a8a6e4d8d
2 changed files with 38 additions and 19 deletions

View File

@ -128,6 +128,7 @@ class Connection:
self.gpg = None self.gpg = None
self.status = '' self.status = ''
self.myVCardID = [] self.myVCardID = []
self.new_account_info = None
self.bookmarks = [] self.bookmarks = []
self.on_purpose = False self.on_purpose = False
self.last_incoming = time.time() self.last_incoming = time.time()
@ -623,6 +624,25 @@ class Connection:
if realm == common.xmpp.NS_REGISTER: if realm == common.xmpp.NS_REGISTER:
if event == common.xmpp.features.REGISTER_DATA_RECEIVED: if event == common.xmpp.features.REGISTER_DATA_RECEIVED:
# data is (agent, DataFrom) # data is (agent, DataFrom)
if self.new_account_info and self.new_account_info['hostname'] == data[0]:
#it's a new account
req = data[1].asDict()
req['username'] = self.new_account_info['name']
req['password'] = self.new_account_info['password']
if not common.xmpp.features.register(self.connection, data[0], req):
self.dispatch('ERROR', (_('Error:'), self.connection.lastErr))
return
self.connected = 0
self.password = self.new_account_info['password']
if USE_GPG:
self.gpg = GnuPG.GnuPG()
gajim.config.set('usegpg', True)
else:
gajim.config.set('usegpg', False)
self.dispatch('ACC_OK', (self.name, self.new_account_info))
gajim.connections[self.name] = self
self.new_account_info = None
return
self.dispatch('REGISTER_AGENT_INFO', (data[0], data[1].asDict())) self.dispatch('REGISTER_AGENT_INFO', (data[0], data[1].asDict()))
def connect(self): def connect(self):
@ -930,7 +950,7 @@ class Connection:
def request_register_agent_info(self, agent): def request_register_agent_info(self, agent):
if not self.connection: if not self.connection:
return None return None
common.xmpp.features.getRegInfo(self.connection, agent) common.xmpp.features.getRegInfo(self.connection, agent, sync = False)
def register_agent(self, agent, info): def register_agent(self, agent, info):
if not self.connection: if not self.connection:
@ -938,7 +958,14 @@ class Connection:
# FIXME: Blocking # FIXME: Blocking
common.xmpp.features.register(self.connection, agent, info) common.xmpp.features.register(self.connection, agent, info)
def new_account(self, name, config): def new_account(self, name, config, sync = False):
if sync:
self.new_account2(name, config)
else:
t = threading.Thread(target=self.new_account2, args = (name, config))
t.start()
def new_account2(self, name, config):
# If a connection already exist we cannot create a new account # If a connection already exist we cannot create a new account
if self.connection: if self.connection:
return return
@ -976,22 +1003,11 @@ class Connection:
return False return False
gajim.log.debug('Connected to server with %s', con_type) gajim.log.debug('Connected to server with %s', con_type)
req = common.xmpp.features.getRegInfo(c, config['hostname']).asDict() c.RegisterEventHandler(self._event_dispatcher)
req['username'] = config['name'] self.new_account_info = config
req['password'] = config['password'] self.connection = c
if not common.xmpp.features.register(c, config['hostname'], req):
self.dispatch('ERROR', (_('Error:'), c.lastErr))
return False
self.name = name self.name = name
self.connected = 0 common.xmpp.features.getRegInfo(c, config['hostname'])
self.password = config['password']
if USE_GPG:
self.gpg = GnuPG.GnuPG()
gajim.config.set('usegpg', True)
else:
gajim.config.set('usegpg', False)
gajim.connections[name] = self
self.dispatch('ACC_OK', (name, config))
def account_changed(self, new_name): def account_changed(self, new_name):
self.name = new_name self.name = new_name

View File

@ -76,7 +76,7 @@ def discoverInfo(disp,jid,node=None):
return identities , features return identities , features
### Registration ### jabber:iq:register ### JEP-0077 ########################### ### Registration ### jabber:iq:register ### JEP-0077 ###########################
def getRegInfo(disp,host,info={}): def getRegInfo(disp,host,info={},sync=True):
""" Gets registration form from remote host. """ Gets registration form from remote host.
You can pre-fill the info dictionary. You can pre-fill the info dictionary.
F.e. if you are requesting info on registering user joey than specify F.e. if you are requesting info on registering user joey than specify
@ -84,7 +84,10 @@ def getRegInfo(disp,host,info={}):
'disp' must be connected dispatcher instance.""" 'disp' must be connected dispatcher instance."""
iq=Iq('get',NS_REGISTER,to=host) iq=Iq('get',NS_REGISTER,to=host)
for i in info.keys(): iq.setTagData(i,info[i]) for i in info.keys(): iq.setTagData(i,info[i])
disp.SendAndCallForResponse(iq,_ReceivedRegInfo, {'agent': host}) if sync:
resp=disp.SendAndWaitForResponse(iq)
_ReceivedRegInfo(disp.Dispatcher,resp, host)
else: disp.SendAndCallForResponse(iq,_ReceivedRegInfo, {'agent': host})
def _ReceivedRegInfo(con, resp, agent): def _ReceivedRegInfo(con, resp, agent):
iq=Iq('get',NS_REGISTER,to=agent) iq=Iq('get',NS_REGISTER,to=agent)