- bot.add_event_handler("muc::%s::message" %
- self.bot.room, self.muc_message)
-
- def muc_message(self, msg):
- """Handler method dealing with MUC incoming messages"""
- # Does not reply to myself
- if msg['mucnick'] == self.bot.nick:
- return
- if '#' not in msg['body']:
- return
- bugs = list()
- for bug_id in set(Bugs.re_bugs.findall(msg['body'].strip())):
- self.log.debug('got bug id: %s', bug_id)
- query = debianbts.get_status(bug_id)
- if len(query) == 1:
- bug = query[0]
- url = debianbts.BTS_URL + bug_id
- bugs.append({'id': bug_id,
- 'package': bug.package,
- 'summary': bug.subject,
- 'url': url})
- else:
- self.log.warning('Wrong bug number "%s"?', bug_id)
- bugs.append({'id': bug_id})
- for bug in bugs:
- if len(bug) == 1:
- message = 'Invalid bug id: {id}'.format(**bug)
- self.reply(msg, message)
- else:
- message = {'mhtml': '<a href="%(url)s">#%(id)s</a>: %(package)s “ %(summary)s ”' % bug,
- 'mbody': '#%(id)s: %(package)s “ %(summary)s ” %(url)s' % bug}
- self.reply(msg, message)