1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-28 07:26:15 +01:00

- new meta command, replacing editmeta, editprj, createprj, editpac, createpac,

edituser. TODO: 
    - write usage info
    - implement -c|--create
    - implement -F|--file
    - check whether I broke usage of metadata copying/creation from withing
      linkpac or copypac
    - re-implement createpac and friends as aliasses to the new meta command -- I
      just commented them out for now
- fix metadata change detection, which no longer relies on the timestamp of the
  temporary file
- add close() in dgst(), which seemed to miss (I can't see a reason why it
  should not be there0
This commit is contained in:
Dr. Peter Poeml 2007-07-13 16:01:02 +00:00
parent 0e6dcd9a4a
commit 5a4f1e4d42
2 changed files with 202 additions and 180 deletions

View File

@ -132,102 +132,163 @@ class Osc(cmdln.Cmdln):
print '\n'.join(l) print '\n'.join(l)
@cmdln.option('-e', '--edit', action='store_true',
help='edit metadata')
@cmdln.option('-F', '--file', metavar='FILE',
help='File to read metadata from. \'-\' denotes standard input. '
'Per default, the program specified by the environmental variable EDITOR '
'is run on a temporary file.')
def do_meta(self, subcmd, opts, *args): def do_meta(self, subcmd, opts, *args):
"""${cmd_name}: Shows meta information """${cmd_name}: Show meta information, or edit it
examples: osc meta Apache # show meta of project 'Apache' meta: Shows build service metadata of type <prj|pkg|prjconf|user>.
osc meta Apache subversion # show meta of package 'subversion'
${cmd_usage}
${cmd_option_list}
"""
if not args:
print >>sys.stderr, 'Missing argument.'
self.do_help(['foo', 'meta'])
return 2
if len(args) == 2:
project = args[0]
package = args[1]
print ''.join(show_package_meta(conf.config['apiurl'], project, package))
print ''.join(show_files_meta(conf.config['apiurl'], project, package))
elif len(args) == 1:
project = args[0]
print ''.join(show_project_meta(conf.config['apiurl'], project))
@cmdln.alias("createpac") usage:
def do_editpac(self, subcmd, opts, project, package): osc meta <prj|pkg|prjconf|user> [-e|--edit [-f|--file] [-c|--create]] ARGS...
"""${cmd_name}: Create package or edit package metadata
If the named package does not exist, it will be created.
${cmd_usage}
${cmd_option_list}
"""
edit_meta(project, package)
@cmdln.alias('createprj')
def do_editprj(self, subcmd, opts, project):
"""${cmd_name}: Create project or edit project metadata
If the named project does not exist, it will be created.
${cmd_usage}
${cmd_option_list}
"""
edit_meta(project, None)
def do_editmeta(self, subcmd, opts, *args):
"""${cmd_name}: Edit project/package meta information
If the named project or package does not exist, it will be created.
Examples:
osc editmeta Apache # edit meta of project 'Apache'
osc editmeta Apache apache2 # edit meta of package 'apache2'
${cmd_usage}
${cmd_option_list} ${cmd_option_list}
""" """
args = slash_split(args) args = slash_split(args)
if not args: if not args or args[0] not in metatypes.keys():
print >>sys.stderr, 'Missing argument.' print >>sys.stderr, 'Unknown meta type. Choose one of %s.' % ', '.join(metatypes)
self.do_help([None, 'editmeta'])
return 2 return 2
if len(args) == 2: cmd = args[0]
project = args[0] del args[0]
package = args[1]
edit_meta(project, package)
elif len(args) == 1: if cmd == 'pkg':
project = args[0] required_args = 2
edit_meta(project, None)
def do_edituser(self, subcmd, opts, *args):
"""${cmd_name}: Edit user meta information
If the named user id does not exist, it will be created.
${cmd_usage}
${cmd_option_list}
"""
if not args or len(args) != 1:
user = conf.config['user']
else: else:
required_args = 1
if len(args) < required_args:
print >>sys.stderr, 'Too few arguments.'
return 2
if len(args) > required_args:
print >>sys.stderr, 'Too many arguments.'
return 2
# prj
if cmd == 'prj':
project = args[0]
if not opts.edit:
sys.stdout.write(''.join(show_project_meta(conf.config['apiurl'], project)))
else:
print 'XXX editing prj'
edit_meta(metatype='prj',
path_args = quote_plus(project),
template_args = (project, conf.config['user']))
# pkg
elif cmd == 'pkg':
project, package = args[0:2]
if not opts.edit:
sys.stdout.write(''.join(show_package_meta(conf.config['apiurl'], project, package)))
else:
print 'XXX editing pac'
edit_meta(metatype='pkg',
path_args = (quote_plus(project), quote_plus(package)),
template_args = (package, conf.config['user']))
# prjconf
elif cmd == 'prjconf':
project = args[0]
if not opts.edit:
sys.stdout.write(''.join(show_project_conf(conf.config['apiurl'], project)))
else:
print 'XXX editing prj'
edit_meta(metatype='prjconf',
path_args = quote_plus(project),
template_args = None)
# user
elif cmd == 'user':
user = args[0] user = args[0]
edit_user_meta(user) if not opts.edit:
r = get_user_meta(conf.config['apiurl'], user)
if r:
sys.stdout.write(''.join(r))
else:
print 'XXX editing user'
edit_meta(metatype='user',
path_args = (quote_plus(user)),
template_args = (user, user))
# @cmdln.alias("createpac")
# def do_editpac(self, subcmd, opts, project, package):
# """${cmd_name}: Create package or edit package metadata
#
# If the named package does not exist, it will be created.
#
# ${cmd_usage}
# ${cmd_option_list}
# """
#
# edit_meta(project, package)
# @cmdln.alias('createprj')
# def do_editprj(self, subcmd, opts, project):
# """${cmd_name}: Create project or edit project metadata
#
# If the named project does not exist, it will be created.
#
# ${cmd_usage}
# ${cmd_option_list}
# """
#
# edit_meta(project, None)
# def do_editmeta(self, subcmd, opts, *args):
# """${cmd_name}: Edit project/package meta information
#
# If the named project or package does not exist, it will be created.
#
# Examples:
# osc editmeta Apache # edit meta of project 'Apache'
# osc editmeta Apache apache2 # edit meta of package 'apache2'
#
# ${cmd_usage}
# ${cmd_option_list}
# """
#
# args = slash_split(args)
#
# if not args:
# print >>sys.stderr, 'Missing argument.'
# self.do_help([None, 'editmeta'])
# return 2
#
# if len(args) == 2:
# project = args[0]
# package = args[1]
# edit_meta(project, package)
#
# elif len(args) == 1:
# project = args[0]
# edit_meta(project, None)
# def do_edituser(self, subcmd, opts, *args):
# """${cmd_name}: Edit user meta information
#
# If the named user id does not exist, it will be created.
#
# ${cmd_usage}
# ${cmd_option_list}
# """
#
# if not args or len(args) != 1:
# user = conf.config['user']
# else:
# user = args[0]
# edit_user_meta(user)
def do_linkpac(self, subcmd, opts, *args): def do_linkpac(self, subcmd, opts, *args):
@ -959,18 +1020,18 @@ class Osc(cmdln.Cmdln):
p.clear_from_conflictlist(filename) p.clear_from_conflictlist(filename)
def do_usermeta(self, subcmd, opts, name): # def do_usermeta(self, subcmd, opts, name):
"""${cmd_name}: Shows user metadata # """${cmd_name}: Shows user metadata
#
Shows metadata about the buildservice user with the id NAME. # Shows metadata about the buildservice user with the id NAME.
#
${cmd_usage} # ${cmd_usage}
${cmd_option_list} # ${cmd_option_list}
""" # """
#
r = get_user_meta(conf.config['apiurl'], name) # r = get_user_meta(conf.config['apiurl'], name)
if r: # if r:
print ''.join(r) # print ''.join(r)
def do_platforms(self, subcmd, opts, *args): def do_platforms(self, subcmd, opts, *args):

View File

@ -116,11 +116,11 @@ HERE
new_user_template = """\ new_user_template = """\
<person> <person>
<login>%(user)s</login> <login>%s</login>
<email>PUT_EMAIL_ADDRESS_HERE</email> <email>PUT_EMAIL_ADDRESS_HERE</email>
<realname>PUT_REAL_NAME_HERE</realname> <realname>PUT_REAL_NAME_HERE</realname>
<watchlist> <watchlist>
<project name="home:%(user)s"/> <project name="home:%s"/>
</watchlist> </watchlist>
</person> </person>
""" """
@ -552,7 +552,7 @@ rev: %s
self.descr = descr self.descr = descr
def update_pac_meta(self, template=new_package_templ): def update_pac_meta(self, template=new_package_templ): # n.b.: not the same as Package.update_pacmeta
import tempfile import tempfile
(fd, filename) = tempfile.mkstemp(prefix = 'osc_editmeta.', suffix = '.xml', dir = '/tmp') (fd, filename) = tempfile.mkstemp(prefix = 'osc_editmeta.', suffix = '.xml', dir = '/tmp')
@ -903,40 +903,25 @@ def show_package_meta(apiurl, prj, pac):
class metafile: class metafile:
"""metafile that can be manipulated and is stored back after manipulation.""" """metafile that can be manipulated and is stored back after manipulation."""
def __init__(self, prj, pac, template=new_package_templ, change_is_required=True): def __init__(self, metatype, path, template, change_is_required=True):
import tempfile import tempfile
self.change_is_required = change_is_required self.change_is_required = change_is_required
(fd, self.filename) = tempfile.mkstemp(prefix = 'osc_editmeta.', suffix = '.xml', dir = '/tmp') (fd, self.filename) = tempfile.mkstemp(prefix = 'osc_editmeta.', suffix = '.xml', dir = '/tmp')
self.url = makeurl(conf.config['apiurl'], [path])
if pac:
# package meta
self.url = makeurl(conf.config['apiurl'], ['source', prj, pac, '_meta'])
try: try:
m = http_GET(self.url).readlines() m = http_GET(self.url).readlines()
except urllib2.HTTPError, e: # when testing this offline: <-- what did I mean with that??
if e.code == 404:
m = template % (pac, conf.config['user'])
else:
print >>sys.stderr, 'error getting package meta for project \'%s\' package \'%s\':' % (prj, pac)
print >>sys.stderr, e
sys.exit(1)
else:
# project meta
self.url = makeurl(conf.config['apiurl'], ['source', prj, '_meta'])
try:
m = http_GET(self.url).readlines()
# when testing this offline:
#except urllib2.URLError, e: #except urllib2.URLError, e:
# m = new_project_templ % (prj, conf.config['user']) # m = template
except urllib2.HTTPError, e: except urllib2.HTTPError, e:
if e.code == 404: if e.code == 404:
m = new_project_templ % (prj, conf.config['user']) m = template
else: else:
print >>sys.stderr, 'error getting package meta for project \'%s\':' % prj print >>sys.stderr, 'error getting metadata for type \'%s\', path \'%s\':' \
% (metatype, self.url)
print >>sys.stderr, e print >>sys.stderr, e
sys.exit(1) sys.exit(1)
@ -944,10 +929,11 @@ class metafile:
f.write(''.join(m)) f.write(''.join(m))
f.close() f.close()
self.timestamp = os.path.getmtime(self.filename) self.hash_orig = dgst(self.filename)
def sync(self): def sync(self):
if self.change_is_required == True and os.path.getmtime(self.filename) == self.timestamp: hash = dgst(self.filename)
if self.change_is_required == True and hash == self.hash_orig:
print 'File unchanged. Not saving.' print 'File unchanged. Not saving.'
os.unlink(self.filename) os.unlink(self.filename)
return True return True
@ -972,22 +958,31 @@ class metafile:
print >> sys.stderr, 'cannot save meta data - an unexpected error occured' print >> sys.stderr, 'cannot save meta data - an unexpected error occured'
return False return False
#metatypes = { 'prj': { 'url': ['source', prj, '_meta'],
# 'template': new_project_templ,
# },
# 'pkg': { 'url' : ['source', prj, pac, '_meta'],
# 'template': new_package_templ,
# },
# 'prjconf': { 'url': ['source', prj, '_config'],
# 'template': None,
# },
# 'user': { 'url': ['person', quote_plus(user)],
# 'template': new_user_template,
# },
# }
def edit_meta(prj, pac, template=new_package_templ, change_is_required=True): # different types of metadata
f=metafile(prj, pac, template, change_is_required) metatypes = { 'prj': { 'path': 'source/%s/_meta',
'template': new_project_templ,
},
'pkg': { 'path' : 'source/%s/%s/_meta',
'template': new_package_templ,
},
'prjconf': { 'path': 'source/%s/_config',
'template': '',
},
'user': { 'path': 'person/%s',
'template': new_user_template,
},
}
def edit_meta(metatype, path_args, template_args, change_is_required=True):
path = metatypes[metatype]['path']
template = metatypes[metatype]['template']
if path_args:
path = path % path_args
if template_args:
template = template % template_args
f=metafile(metatype, path, template, change_is_required)
editor = os.getenv('EDITOR', default='vim') editor = os.getenv('EDITOR', default='vim')
while 1: while 1:
@ -1004,41 +999,6 @@ def edit_meta(prj, pac, template=new_package_templ, change_is_required=True):
break break
def edit_user_meta(user, change_is_required=True):
import tempfile
u = makeurl(conf.config['apiurl'], ['person', quote_plus(user)])
try:
m = http_GET(u).readlines()
except urllib2.HTTPError, e:
if e.code == 404:
m = new_user_template % { 'user': user }
else:
print >>sys.stderr, 'error getting metadata for user \'%s\':' % user
print >>sys.stderr, e
sys.exit(1)
(fd, filename) = tempfile.mkstemp(prefix = 'osc_edituser.', suffix = '.xml', dir = '/tmp')
f = os.fdopen(fd, 'w')
f.write(''.join(m))
f.close()
timestamp = os.path.getmtime(filename)
editor = os.getenv('EDITOR', default='vim')
os.system('%s %s' % (editor, filename))
if change_is_required == True and os.path.getmtime(filename) == timestamp:
print 'File unchanged. Not saving.'
os.unlink(filename)
else:
print 'Sending meta data...',
http_PUT(u, file=filename)
os.unlink(filename)
print 'Done.'
def show_files_meta(apiurl, prj, pac, revision=None): def show_files_meta(apiurl, prj, pac, revision=None):
query = [] query = []
if revision: if revision:
@ -1133,6 +1093,7 @@ def dgst(file):
if not buf: break if not buf: break
s.update(buf) s.update(buf)
return s.hexdigest() return s.hexdigest()
f.close()
def binary(s): def binary(s):