new_account is back !
getRegInfo can be synchronous if we want
This commit is contained in:
parent
d0299a2f3f
commit
3a8a6e4d8d
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue