diff options
author | Chris Ball <cjb@laptop.org> | 2010-09-06 18:14:04 -0400 |
---|---|---|
committer | Chris Ball <cjb@laptop.org> | 2010-09-07 11:00:56 -0400 |
commit | c4fe20ef4fe29bf6d98ee5b2eee06d8f277c7b1b (patch) | |
tree | a9ce3753a9df3601477681090816035a4aad6d64 /interfaces/web | |
parent | 3099e08c62410f16e99393ba09b36e79c0fa53ab (diff) | |
download | bugseverywhere-c4fe20ef4fe29bf6d98ee5b2eee06d8f277c7b1b.tar.gz |
cfbe: API: implement search-by-target
Diffstat (limited to 'interfaces/web')
-rw-r--r-- | interfaces/web/web.py | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/interfaces/web/web.py b/interfaces/web/web.py index d910420..77c3c09 100644 --- a/interfaces/web/web.py +++ b/interfaces/web/web.py @@ -6,7 +6,8 @@ import cherrypy from libbe import storage from libbe import bugdir -from libbe.command.depend import get_blocks +from libbe.command.depend import get_blocked_by, get_blocks +from libbe.command.target import bug_from_target_summary, bug_target from libbe.command.util import bug_comment_from_user_id from libbe.storage.util import settings_object @@ -67,8 +68,16 @@ class WebInterface: if target != '': target = None if target == 'None' else target - bugs = [bug for bug in bugs if bug.target == target] - + if target == None: + # Return all bugs that don't block any targets. + return [bug for bug in bugs if not bug_target(self.bd, bug)] + else: + # Return all bugs that block the supplied target. + targetbug = bug_from_target_summary(self.bd, target) + if targetbug == None: + return [] + bugs = [bug for bug in get_blocked_by(self.bd, targetbug) if + bug.active] return bugs |