# -*- coding: utf-8 -*-
-
-# Copyright (C) 2010, 2011 Anaël Verrier <elghinn@free.fr>
-# Copyright (C) 2015 kaliko <kaliko@azylum.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, version 3 only.
-
-# 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/>.
-
+# SPDX-FileCopyrightText: 2015, 2021 kaliko <kaliko@azylum.org>
+# SPDX-FileCopyrightText: 2010, 2011 Anaël Verrier <elghinn@free.fr>
+# SPDX-License-Identifier: GPL-3.0-or-later
from re import compile as re_compile
class Bugs(Plugin):
"""Gets bugs info from the BTS
+
+ .. note::
+ This plugin depends on external module: **python-debianbts**
"""
- re_bugs = re_compile(r'(?<=#)(\d{6,7})')
+ #: Bug id regexp, intercepts bug id in strings : "#629234", "bugs.debian.org/629234" and "bugreport.cgi?bug=629234"
+ re_bugs = re_compile(r'(?:(?<=#)|(?<=bugreport\.cgi\?bug=)|(?<=bugs\.debian\.org/))(\d{6,7})')
+ #: Package name regexp
+ re_pkg = re_compile(r'(?P<package>[0-9a-z.+-]+)$')
def __init__(self, bot):
Plugin.__init__(self, bot)
- bot.add_event_handler("muc::%s::message" % self.bot.room, self.muc_message)
+ 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"""
+ """Handler method dealing with MUC incoming messages.
+
+ Intercepts bugs number in MUC messages (as #629234), replies a bug
+ summary."""
# 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)
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}
+ 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)
@botcmd
- def bugs(self, message, args):
- """ intercepts bugs number in any message, looking for string like #629234
- !bugs : nothing yet.
+ def bugs(self, rcv, args):
+ """Gets bugs info from the BTS
+
+ ``!bugs pkg-name`` : Returns latest bug reports if any
"""
- return None
+ if not args:
+ return
+ if len(args) > 1:
+ self.log.info('more than one packages provided')
+ pkg = Bugs.re_pkg.match(args[0])
+ if not pkg:
+ msg = 'Wrong package name format re: "{}"'.format(Bugs.re_pkg.pattern)
+ self.reply(rcv, msg)
+ return
+ reports_ids = debianbts.get_bugs(status='open', **pkg.groupdict())
+ if not reports_ids:
+ self.reply(rcv, 'No open bugs for "{}"'.format(pkg.string))
+ return
+ reports = debianbts.get_status(reports_ids)
+ reports = sorted(reports, key=lambda r: r.date)
+ msg = ['Latest reports for {1} (total {0})'.format(len(reports), pkg.string)]
+ # Reverse and take last reports
+ for rep in reports[::-1][:4]:
+ msg.append('{r.bug_num}: {r.date:%Y-%m-%d} {r.subject}'.format(r=rep))
+ message = {'mbody': '\n'.join(msg)}
+ self.reply(rcv, message)