1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-14 17:46:17 +01:00

fixed several functions to respect 'osc -A'

This commit is contained in:
Danny Kukawka 2010-07-29 17:29:07 +02:00
parent cb18807622
commit db08e0b496

View File

@ -183,11 +183,13 @@ class Osc(cmdln.Cmdln):
${cmd_option_list} ${cmd_option_list}
""" """
apiurl = self.get_api_url()
if not package: if not package:
init_project_dir(conf.config['apiurl'], os.curdir, project) init_project_dir(apiurl, os.curdir, project)
print 'Initializing %s (Project: %s)' % (os.curdir, project) print 'Initializing %s (Project: %s)' % (os.curdir, project)
else: else:
init_package_dir(conf.config['apiurl'], project, package, os.path.curdir) init_package_dir(apiurl, project, package, os.path.curdir)
print 'Initializing %s (Project: %s, Package: %s)' % (os.curdir, project, package) print 'Initializing %s (Project: %s, Package: %s)' % (os.curdir, project, package)
@cmdln.alias('ls') @cmdln.alias('ls')
@ -243,7 +245,6 @@ class Osc(cmdln.Cmdln):
${cmd_option_list} ${cmd_option_list}
""" """
apiurl = conf.config['apiurl']
args = slash_split(args) args = slash_split(args)
if subcmd == 'll': if subcmd == 'll':
opts.verbose = True opts.verbose = True
@ -285,6 +286,8 @@ class Osc(cmdln.Cmdln):
if opts.binaries and opts.expand: if opts.binaries and opts.expand:
raise oscerr.WrongOptions('Sorry, --binaries and --expand are mutual exclusive.') raise oscerr.WrongOptions('Sorry, --binaries and --expand are mutual exclusive.')
apiurl = self.get_api_url()
# list binaries # list binaries
if opts.binaries: if opts.binaries:
# ls -b toplevel doesn't make sense, so use info from # ls -b toplevel doesn't make sense, so use info from
@ -297,8 +300,6 @@ class Osc(cmdln.Cmdln):
project = store_read_project(dir) project = store_read_project(dir)
package = store_read_package(dir) package = store_read_package(dir)
apiurl = self.get_api_url()
if not project: if not project:
raise oscerr.WrongArgs('There are no binaries to list above project level.') raise oscerr.WrongArgs('There are no binaries to list above project level.')
if opts.revision: if opts.revision:
@ -335,7 +336,7 @@ class Osc(cmdln.Cmdln):
# list sources # list sources
elif not opts.binaries: elif not opts.binaries:
if not args: if not args:
print '\n'.join(meta_get_project_list(conf.config['apiurl'], opts.deleted)) print '\n'.join(meta_get_project_list(apiurl, opts.deleted))
elif len(args) == 1: elif len(args) == 1:
if opts.verbose: if opts.verbose:
@ -344,14 +345,14 @@ class Osc(cmdln.Cmdln):
if opts.expand: if opts.expand:
raise oscerr.WrongOptions('Sorry, the --expand option is not implemented for projects.') raise oscerr.WrongOptions('Sorry, the --expand option is not implemented for projects.')
print '\n'.join(meta_get_packagelist(conf.config['apiurl'], project, opts.deleted)) print '\n'.join(meta_get_packagelist(apiurl, project, opts.deleted))
elif len(args) == 2 or len(args) == 3: elif len(args) == 2 or len(args) == 3:
link_seen = False link_seen = False
print_not_found = True print_not_found = True
rev = opts.revision rev = opts.revision
for i in [ 1, 2 ]: for i in [ 1, 2 ]:
l = meta_get_filelist(conf.config['apiurl'], l = meta_get_filelist(apiurl,
project, project,
package, package,
verbose=opts.verbose, verbose=opts.verbose,
@ -371,7 +372,7 @@ class Osc(cmdln.Cmdln):
else: else:
print '\n'.join(l) print '\n'.join(l)
if opts.expand or opts.unexpand or not link_seen: break if opts.expand or opts.unexpand or not link_seen: break
m = show_files_meta(conf.config['apiurl'], project, package) m = show_files_meta(apiurl, project, package)
li = Linkinfo() li = Linkinfo()
li.read(ET.fromstring(''.join(m)).find('linkinfo')) li.read(ET.fromstring(''.join(m)).find('linkinfo'))
if li.haserror(): if li.haserror():
@ -954,7 +955,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
'superseded by %s' % result, result) 'superseded by %s' % result, result)
if opts.supersede: if opts.supersede:
change_request_state(conf.config['apiurl'], opts.supersede, 'superseded', change_request_state(apiurl, opts.supersede, 'superseded',
opts.message or '', result) opts.message or '', result)
print 'created request id', result print 'created request id', result
@ -1356,7 +1357,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
elif len(args) > 2: elif len(args) > 2:
raise oscerr.WrongArgs('Too many arguments.') raise oscerr.WrongArgs('Too many arguments.')
apiurl = self.get_api_url() apiurl = self.get_api_url()
if not opts.message: if not opts.message:
import textwrap import textwrap
@ -1651,7 +1652,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
opts.message = edit_message() opts.message = edit_message()
for result in results: for result in results:
print result.reqid, ": ", print result.reqid, ": ",
r = change_request_state(conf.config['apiurl'], r = change_request_state(apiurl,
str(result.reqid), 'accepted', opts.message or '') str(result.reqid), 'accepted', opts.message or '')
print r print r
else: else:
@ -1659,16 +1660,16 @@ Please submit there instead, or use --nodevelproject to force direct submission.
raise oscerr.UserAbort() raise oscerr.UserAbort()
elif cmd == 'log': elif cmd == 'log':
for l in get_request_log(conf.config['apiurl'], reqid): for l in get_request_log(apiurl, reqid):
print l print l
# show # show
elif cmd == 'show': elif cmd == 'show':
r = get_request(conf.config['apiurl'], reqid) r = get_request('apiurl', reqid)
if opts.brief: if opts.brief:
print r.list_view() print r.list_view()
elif (opts.interactive or conf.config['request_show_interactive']) and not opts.non_interactive: elif (opts.interactive or conf.config['request_show_interactive']) and not opts.non_interactive:
return request_interactive_review(conf.config['apiurl'], r) return request_interactive_review(apiurl, r)
else: else:
print r print r
# fixme: will inevitably fail if the given target doesn't exist # fixme: will inevitably fail if the given target doesn't exist
@ -1676,7 +1677,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
raise oscerr.WrongOptions('\'--diff\' is not possible for request type: \'%s\'' % r.actions[0].type) raise oscerr.WrongOptions('\'--diff\' is not possible for request type: \'%s\'' % r.actions[0].type)
elif opts.diff: elif opts.diff:
try: try:
print server_diff(conf.config['apiurl'], print server_diff(apiurl,
r.actions[0].dst_project, r.actions[0].dst_package, None, r.actions[0].dst_project, r.actions[0].dst_package, None,
r.actions[0].src_project, r.actions[0].src_package, r.actions[0].src_rev, opts.unified, True) r.actions[0].src_project, r.actions[0].src_package, r.actions[0].src_rev, opts.unified, True)
except urllib2.HTTPError, e: except urllib2.HTTPError, e:
@ -1685,7 +1686,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
raise e raise e
# backward compatiblity: only a recent api/backend supports the missingok parameter # backward compatiblity: only a recent api/backend supports the missingok parameter
try: try:
print server_diff(conf.config['apiurl'], print server_diff(apiurl,
r.actions[0].dst_project, r.actions[0].dst_package, None, r.actions[0].dst_project, r.actions[0].dst_package, None,
r.actions[0].src_project, r.actions[0].src_package, r.actions[0].src_rev, opts.unified, False) r.actions[0].src_project, r.actions[0].src_package, r.actions[0].src_rev, opts.unified, False)
except urllib2.HTTPError, e: except urllib2.HTTPError, e:
@ -1694,11 +1695,11 @@ Please submit there instead, or use --nodevelproject to force direct submission.
# checkout # checkout
elif cmd == 'checkout' or cmd == 'co': elif cmd == 'checkout' or cmd == 'co':
r = get_request(conf.config['apiurl'], reqid) r = get_request(apiurl, reqid)
submits = [ i for i in r.actions if i.type == 'submit' ] submits = [ i for i in r.actions if i.type == 'submit' ]
if not len(submits): if not len(submits):
raise oscerr.WrongArgs('\'checkout\' only works for \'submit\' requests') raise oscerr.WrongArgs('\'checkout\' only works for \'submit\' requests')
checkout_package(conf.config['apiurl'], submits[0].src_project, submits[0].src_package, \ checkout_package(apiurl, submits[0].src_project, submits[0].src_package, \
submits[0].src_rev, expand_link=True, prj_dir=submits[0].src_project) submits[0].src_rev, expand_link=True, prj_dir=submits[0].src_project)
else: else:
@ -1708,12 +1709,12 @@ Please submit there instead, or use --nodevelproject to force direct submission.
# Change review state only # Change review state only
if subcmd == 'review': if subcmd == 'review':
if cmd in ['accept', 'decline', 'new']: if cmd in ['accept', 'decline', 'new']:
r = change_review_state(conf.config['apiurl'], r = change_review_state(apiurl,
reqid, state_map[cmd], conf.config['user'], opts.message or '') reqid, state_map[cmd], conf.config['user'], opts.message or '')
print r print r
# Change state of entire request # Change state of entire request
elif cmd in ['reopen', 'accept', 'decline', 'wipe', 'revoke']: elif cmd in ['reopen', 'accept', 'decline', 'wipe', 'revoke']:
r = change_request_state(conf.config['apiurl'], r = change_request_state(apiurl,
reqid, state_map[cmd], opts.message or '') reqid, state_map[cmd], opts.message or '')
print r print r
@ -1757,7 +1758,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
""" """
args = slash_split(args) args = slash_split(args)
apiurl = conf.config['apiurl'] apiurl = self.get_api_url()
package = None package = None
if len(args) == 0: if len(args) == 0:
p = findpacs(os.curdir)[0] p = findpacs(os.curdir)[0]
@ -1859,6 +1860,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
""" """
args = slash_split(args) args = slash_split(args)
apiurl = self.get_api_url()
if not args or len(args) < 3: if not args or len(args) < 3:
raise oscerr.WrongArgs('Incorrect number of arguments.\n\n' \ raise oscerr.WrongArgs('Incorrect number of arguments.\n\n' \
@ -1883,7 +1885,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
opts.cicount = "copy" opts.cicount = "copy"
if opts.current: if opts.current:
rev = show_upstream_rev(conf.config['apiurl'], src_project, src_package) rev = show_upstream_rev(apiurl, src_project, src_package)
if rev and not checkRevision(src_project, src_package, rev): if rev and not checkRevision(src_project, src_package, rev):
print >>sys.stderr, 'Revision \'%s\' does not exist' % rev print >>sys.stderr, 'Revision \'%s\' does not exist' % rev
@ -2051,6 +2053,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
${cmd_option_list} ${cmd_option_list}
""" """
args = slash_split(args) args = slash_split(args)
apiurl = self.get_api_url()
tproject = None tproject = None
maintained_attribute = conf.config['maintained_attribute'] maintained_attribute = conf.config['maintained_attribute']
@ -2063,7 +2066,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if len(args) >= 2: if len(args) >= 2:
tproject = args[1] tproject = args[1]
r = attribute_branch_pkg(conf.config['apiurl'], maintained_attribute, maintained_update_project_attribute, \ r = attribute_branch_pkg(apiurl, maintained_attribute, maintained_update_project_attribute, \
package, tproject) package, tproject)
if r is None: if r is None:
@ -2073,13 +2076,13 @@ Please submit there instead, or use --nodevelproject to force direct submission.
print "Project " + r + " created." print "Project " + r + " created."
if opts.checkout: if opts.checkout:
init_project_dir(conf.config['apiurl'], r, r) init_project_dir(apiurl, r, r)
print statfrmt('A', r) print statfrmt('A', r)
# all packages # all packages
for package in meta_get_packagelist(conf.config['apiurl'], r): for package in meta_get_packagelist(apiurl, r):
try: try:
checkout_package(conf.config['apiurl'], r, package, expand_link = True, prj_dir = r) checkout_package(apiurl, r, package, expand_link = True, prj_dir = r)
except: except:
print >>sys.stderr, 'Error while checkout package:\n', package print >>sys.stderr, 'Error while checkout package:\n', package
@ -2144,6 +2147,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if len(args) < 2 or len(args) > 4: if len(args) < 2 or len(args) > 4:
raise oscerr.WrongArgs('Wrong number of arguments.') raise oscerr.WrongArgs('Wrong number of arguments.')
apiurl = self.get_api_url()
expected = 'home:%s:branches:%s' % (conf.config['user'], args[0]) expected = 'home:%s:branches:%s' % (conf.config['user'], args[0])
if len(args) >= 3: if len(args) >= 3:
expected = tproject = args[2] expected = tproject = args[2]
@ -2156,7 +2161,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
opts.message = edit_message(footer, template) opts.message = edit_message(footer, template)
exists, targetprj, targetpkg, srcprj, srcpkg = \ exists, targetprj, targetpkg, srcprj, srcpkg = \
branch_pkg(conf.config['apiurl'], args[0], args[1], branch_pkg(apiurl, args[0], args[1],
nodevelproject=opts.nodevelproject, rev=opts.revision, nodevelproject=opts.nodevelproject, rev=opts.revision,
target_project=tproject, target_package=tpackage, target_project=tproject, target_package=tpackage,
return_existing=opts.checkout, msg=opts.message or '', return_existing=opts.checkout, msg=opts.message or '',
@ -2180,20 +2185,20 @@ Please submit there instead, or use --nodevelproject to force direct submission.
package = tpackage or args[1] package = tpackage or args[1]
if opts.checkout: if opts.checkout:
checkout_package(conf.config['apiurl'], targetprj, package, checkout_package(apiurl, targetprj, package,
expand_link=True, prj_dir=targetprj) expand_link=True, prj_dir=targetprj)
if conf.config['verbose']: if conf.config['verbose']:
print 'Note: You can use "osc delete" or "osc submitpac" when done.\n' print 'Note: You can use "osc delete" or "osc submitpac" when done.\n'
else: else:
apiopt = '' apiopt = ''
if conf.get_configParser().get('general', 'apiurl') != conf.config['apiurl']: if conf.get_configParser().get('general', 'apiurl') != apiurl:
apiopt = '-A %s ' % conf.config['apiurl'] apiopt = '-A %s ' % apiurl
print 'A working copy of the branched package can be checked out with:\n\n' \ print 'A working copy of the branched package can be checked out with:\n\n' \
'osc %sco %s/%s' \ 'osc %sco %s/%s' \
% (apiopt, targetprj, package) % (apiopt, targetprj, package)
print_request_list(conf.config['apiurl'], args[0], args[1]) print_request_list(apiurl, args[0], args[1])
if devloc: if devloc:
print_request_list(conf.config['apiurl'], devloc, args[1]) print_request_list(apiurl, devloc, args[1])
def do_undelete(self, subcmd, opts, *args): def do_undelete(self, subcmd, opts, *args):
@ -2212,14 +2217,16 @@ Please submit there instead, or use --nodevelproject to force direct submission.
args = slash_split(args) args = slash_split(args)
if len(args) < 1: if len(args) < 1:
raise oscerr.WrongArgs('Missing argument.') raise oscerr.WrongArgs('Missing argument.')
apiurl = self.get_api_url()
prj = args[0] prj = args[0]
pkgs = args[1:] pkgs = args[1:]
if pkgs: if pkgs:
for pkg in pkgs: for pkg in pkgs:
undelete_package(conf.config['apiurl'], prj, pkg) undelete_package(apiurl, prj, pkg)
else: else:
undelete_project(conf.config['apiurl'], prj) undelete_project(apiurl, prj)
@cmdln.option('-f', '--force', action='store_true', @cmdln.option('-f', '--force', action='store_true',
@ -2241,6 +2248,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
args = slash_split(args) args = slash_split(args)
if len(args) < 1: if len(args) < 1:
raise oscerr.WrongArgs('Missing argument.') raise oscerr.WrongArgs('Missing argument.')
apiurl = self.get_api_url()
prj = args[0] prj = args[0]
pkgs = args[1:] pkgs = args[1:]
@ -2249,14 +2258,14 @@ Please submit there instead, or use --nodevelproject to force direct submission.
# careful: if pkg is an empty string, the package delete request results # careful: if pkg is an empty string, the package delete request results
# into a project delete request - which works recursively... # into a project delete request - which works recursively...
if pkg: if pkg:
delete_package(conf.config['apiurl'], prj, pkg) delete_package(apiurl, prj, pkg)
elif len(meta_get_packagelist(conf.config['apiurl'], prj)) >= 1 and not opts.force: elif len(meta_get_packagelist(apiurl, prj)) >= 1 and not opts.force:
print >>sys.stderr, 'Project contains packages. It must be empty before deleting it. ' \ print >>sys.stderr, 'Project contains packages. It must be empty before deleting it. ' \
'If you are sure that you want to remove this project and all its ' \ 'If you are sure that you want to remove this project and all its ' \
'packages use the \'--force\' switch' 'packages use the \'--force\' switch'
sys.exit(1) sys.exit(1)
else: else:
delete_project(conf.config['apiurl'], prj) delete_project(apiurl, prj)
@cmdln.hide(1) @cmdln.hide(1)
def do_deletepac(self, subcmd, opts, *args): def do_deletepac(self, subcmd, opts, *args):
@ -2393,6 +2402,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
""" """
args = slash_split(args) args = slash_split(args)
apiurl = self.get_api_url()
rev1 = None rev1 = None
rev2 = None rev2 = None
@ -2439,7 +2449,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if opts.revision: if opts.revision:
rev1, rev2 = parseRevisionOption(opts.revision) rev1, rev2 = parseRevisionOption(opts.revision)
rdiff = server_diff(conf.config['apiurl'], rdiff = server_diff(apiurl,
old_project, old_package, rev1, old_project, old_package, rev1,
new_project, new_package, rev2, not opts.plain, opts.missingok) new_project, new_package, rev2, not opts.plain, opts.missingok)
print rdiff print rdiff
@ -3201,6 +3211,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
${cmd_usage} ${cmd_usage}
${cmd_option_list} ${cmd_option_list}
""" """
apiurl = self.get_api_url()
if len(files) == 0: if len(files) == 0:
if not '/' in project: if not '/' in project:
@ -3215,7 +3226,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if resp not in ('y', 'Y'): if resp not in ('y', 'Y'):
continue continue
try: try:
delete_files(conf.config['apiurl'], project, package, (file, )) delete_files(apiurl, project, package, (file, ))
except urllib2.HTTPError, e: except urllib2.HTTPError, e:
if opts.force: if opts.force:
print >>sys.stderr, e print >>sys.stderr, e
@ -3430,7 +3441,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
apiurl, project, package, repository, arch = parse_buildlogurl(args[0]) apiurl, project, package, repository, arch = parse_buildlogurl(args[0])
else: else:
args = slash_split(args) args = slash_split(args)
apiurl = conf.config['apiurl'] apiurl = self.get_api_url()
if len(args) < 4: if len(args) < 4:
raise oscerr.WrongArgs('Too few arguments.') raise oscerr.WrongArgs('Too few arguments.')
elif len(args) > 4: elif len(args) > 4:
@ -4268,7 +4279,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
args = slash_split(args) args = slash_split(args)
package = repo = arch = code = None package = repo = arch = code = None
apiurl = conf.config['apiurl'] apiurl = self.get_api_url()
if len(args) < 1: if len(args) < 1:
if is_package_dir(os.curdir): if is_package_dir(os.curdir):
@ -4324,6 +4335,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
osc abortbuild [OPTS] PROJECT [PACKAGE] osc abortbuild [OPTS] PROJECT [PACKAGE]
${cmd_option_list} ${cmd_option_list}
""" """
apiurl = self.get_api_url()
if len(args) < 1: if len(args) < 1:
raise oscerr.WrongArgs('Missing <project> argument.') raise oscerr.WrongArgs('Missing <project> argument.')
@ -4333,7 +4345,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
else: else:
package = None package = None
print abortbuild(conf.config['apiurl'], args[0], package, opts.arch, opts.repo) print abortbuild(apiurl, args[0], package, opts.arch, opts.repo)
@cmdln.option('-a', '--arch', metavar='ARCH', @cmdln.option('-a', '--arch', metavar='ARCH',
@ -4701,6 +4713,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
'or \'--bugowner\' or \'--maintainer\' or \'--limit-to-attribute <attr>\ ' \ 'or \'--bugowner\' or \'--maintainer\' or \'--limit-to-attribute <attr>\ ' \
'or \'--project\' or \'--package\' are mutually exclusive') 'or \'--project\' or \'--package\' are mutually exclusive')
apiurl = self.get_api_url()
xpath = '' xpath = ''
if opts.title: if opts.title:
xpath = xpath_join(xpath, build_xpath('title', search_term, opts.substring), inner=True) xpath = xpath_join(xpath, build_xpath('title', search_term, opts.substring), inner=True)
@ -4740,7 +4754,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
elif opts.binary: elif opts.binary:
what = {'published/binary/id': xpath} what = {'published/binary/id': xpath}
try: try:
res = search(conf.config['apiurl'], **what) res = search(apiurl, **what)
except urllib2.HTTPError, e: except urllib2.HTTPError, e:
if e.code != 400 or not role_filter: if e.code != 400 or not role_filter:
raise e raise e
@ -4748,7 +4762,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if opts.limit_to_attribute: if opts.limit_to_attribute:
role_filter_xpath = xpath_join(role_filter_xpath, 'attribute/@name=\'%s\'' % opts.limit_to_attribute, op='and') role_filter_xpath = xpath_join(role_filter_xpath, 'attribute/@name=\'%s\'' % opts.limit_to_attribute, op='and')
what = dict([[kind, role_filter_xpath] for kind in what.keys()]) what = dict([[kind, role_filter_xpath] for kind in what.keys()])
res = search(conf.config['apiurl'], **what) res = search(apiurl, **what)
filter_role(res, search_term, role_filter) filter_role(res, search_term, role_filter)
if role_filter: if role_filter:
role_filter = '%s (%s)' % (search_term, role_filter) role_filter = '%s (%s)' % (search_term, role_filter)
@ -4972,13 +4986,15 @@ Please submit there instead, or use --nodevelproject to force direct submission.
${cmd_option_list} ${cmd_option_list}
""" """
apiurl = self.get_api_url()
if not opts.method in ['GET', 'PUT', 'POST', 'DELETE']: if not opts.method in ['GET', 'PUT', 'POST', 'DELETE']:
sys.exit('unknown method %s' % opts.method) sys.exit('unknown method %s' % opts.method)
if not url.startswith('http'): if not url.startswith('http'):
if not url.startswith('/'): if not url.startswith('/'):
url = '/' + url url = '/' + url
url = conf.config['apiurl'] + url url = apiurl + url
if opts.headers: if opts.headers:
opts.headers = dict(opts.headers) opts.headers = dict(opts.headers)
@ -5074,18 +5090,20 @@ Please submit there instead, or use --nodevelproject to force direct submission.
else: else:
raise oscerr.WrongArgs('Wrong number of arguments.') raise oscerr.WrongArgs('Wrong number of arguments.')
apiurl = self.get_api_url()
if opts.add: if opts.add:
for role in roles: for role in roles:
addPerson(conf.config['apiurl'], prj, pac, opts.add, role) addPerson(apiurl, prj, pac, opts.add, role)
elif opts.delete: elif opts.delete:
for role in roles: for role in roles:
delPerson(conf.config['apiurl'], prj, pac, opts.delete, role) delPerson(apiurl, prj, pac, opts.delete, role)
elif opts.devel_project: elif opts.devel_project:
# XXX: does it really belong to this command? # XXX: does it really belong to this command?
setDevelProject(conf.config['apiurl'], prj, pac, opts.devel_project) setDevelProject(apiurl, prj, pac, opts.devel_project)
else: else:
if pac: if pac:
m = show_package_meta(conf.config['apiurl'], prj, pac) m = show_package_meta(apiurl, prj, pac)
root = ET.fromstring(''.join(m)) root = ET.fromstring(''.join(m))
if not opts.nodevelproject: if not opts.nodevelproject:
while root.findall('devel'): while root.findall('devel'):
@ -5094,16 +5112,16 @@ Please submit there instead, or use --nodevelproject to force direct submission.
pac = d.get('package', pac) pac = d.get('package', pac)
if opts.verbose: if opts.verbose:
print "Following to the development space: %s/%s" % (prj, pac) print "Following to the development space: %s/%s" % (prj, pac)
m = show_package_meta(conf.config['apiurl'], prj, pac) m = show_package_meta(apiurl, prj, pac)
root = ET.fromstring(''.join(m)) root = ET.fromstring(''.join(m))
if not root.findall('person'): if not root.findall('person'):
if opts.verbose: if opts.verbose:
print "No dedicated persons in package defined, showing the project persons." print "No dedicated persons in package defined, showing the project persons."
pac = None pac = None
m = show_project_meta(conf.config['apiurl'], prj) m = show_project_meta(apiurl, prj)
root = ET.fromstring(''.join(m)) root = ET.fromstring(''.join(m))
else: else:
m = show_project_meta(conf.config['apiurl'], prj) m = show_project_meta(apiurl, prj)
root = ET.fromstring(''.join(m)) root = ET.fromstring(''.join(m))
# showing the maintainers # showing the maintainers
@ -5120,14 +5138,14 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if opts.email: if opts.email:
emails = [] emails = []
for maintainer in maintainers.get(role, []): for maintainer in maintainers.get(role, []):
user = get_user_data(conf.config['apiurl'], maintainer, 'email') user = get_user_data(apiurl, maintainer, 'email')
if len(user): if len(user):
emails.append(''.join(user)) emails.append(''.join(user))
print ', '.join(emails) or '-' print ', '.join(emails) or '-'
elif opts.verbose: elif opts.verbose:
userdata = [] userdata = []
for maintainer in maintainers.get(role, []): for maintainer in maintainers.get(role, []):
user = get_user_data(conf.config['apiurl'], maintainer, 'login', 'realname', 'email') user = get_user_data(apiurl, maintainer, 'login', 'realname', 'email')
userdata.append(user[0]) userdata.append(user[0])
if user[1] != '-': if user[1] != '-':
userdata.append("%s <%s>"%(user[1], user[2])) userdata.append("%s <%s>"%(user[1], user[2]))
@ -5173,21 +5191,22 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if len(args) != 3: if len(args) != 3:
raise oscerr.WrongArgs('Wrong number of arguments.') raise oscerr.WrongArgs('Wrong number of arguments.')
rev, dummy = parseRevisionOption(opts.revision) rev, dummy = parseRevisionOption(opts.revision)
apiurl = self.get_api_url()
query = { } query = { }
if opts.revision: if opts.revision:
query['rev'] = opts.revision query['rev'] = opts.revision
if opts.expand: if opts.expand:
query['rev'] = show_upstream_srcmd5(conf.config['apiurl'], args[0], args[1], expand=True, revision=opts.revision) query['rev'] = show_upstream_srcmd5(apiurl, args[0], args[1], expand=True, revision=opts.revision)
u = makeurl(conf.config['apiurl'], ['source', args[0], args[1], args[2]], query=query) u = makeurl(apiurl, ['source', args[0], args[1], args[2]], query=query)
try: try:
for data in streamfile(u): for data in streamfile(u):
sys.stdout.write(data) sys.stdout.write(data)
except urllib2.HTTPError, e: except urllib2.HTTPError, e:
if e.code == 404 and not opts.expand and not opts.unexpand: if e.code == 404 and not opts.expand and not opts.unexpand:
print >>sys.stderr, 'expanding link...' print >>sys.stderr, 'expanding link...'
query['rev'] = show_upstream_srcmd5(conf.config['apiurl'], args[0], args[1], expand=True, revision=opts.revision) query['rev'] = show_upstream_srcmd5(apiurl, args[0], args[1], expand=True, revision=opts.revision)
u = makeurl(conf.config['apiurl'], ['source', args[0], args[1], args[2]], query=query) u = makeurl(apiurl, ['source', args[0], args[1], args[2]], query=query)
for data in streamfile(u): for data in streamfile(u):
sys.stdout.write(data) sys.stdout.write(data)
else: else: