core commands: make /last_activity async

This commit is contained in:
Emmanuel Gil Peyrot 2021-02-04 00:48:31 +01:00 committed by mathieui
parent ac96beb240
commit ab690bbd50

View file

@ -902,22 +902,29 @@ class CommandCore:
tab.join()
@command_args_parser.quoted(1)
def last_activity(self, args):
async def last_activity(self, args):
"""
/last_activity <jid>
"""
def callback(iq):
"Callback for the last activity"
if iq['type'] != 'result':
if iq['error']['type'] == 'auth':
self.core.information(
'You are not allowed to see the '
'activity of this contact.', 'Error')
if args is None:
return self.help('last_activity')
try:
jid = JID(args[0])
except InvalidJID:
return self.core.information('Invalid JID for /last_activity: %s' % args[0], 'Error')
try:
await self.core.xmpp.plugin['xep_0012'].get_last_activity(jid)
except IqError as error:
if error.etype == 'auth':
msg = 'You are not allowed to see the activity of %s' % jid
else:
self.core.information('Error retrieving the activity',
'Error')
return
msg = 'Error retrieving the activity of %s: %s' % (jid, error)
return self.core.information(msg, 'Error')
except IqTimeout:
return self.core.information('Timeout while retrieving the last activity of %s' % jid, 'Error')
seconds = iq['last_activity']['seconds']
status = iq['last_activity']['status']
from_ = iq['from']
@ -931,15 +938,6 @@ class CommandCore:
if status else '')
self.core.information(msg, 'Info')
if args is None:
return self.help('last_activity')
try:
jid = JID(args[0])
except InvalidJID:
return self.core.information('Invalid JID for /last_activity: %s' % args[0], 'Error')
self.core.xmpp.plugin['xep_0012'].get_last_activity(
jid, callback=callback)
@command_args_parser.quoted(0, 2)
def mood(self, args):
"""