mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-14 01:26:23 +01:00
- added "config" command to set/get/delete a config option
maybe we should move the whole config stuff into a new config object. This would make things much easier.
This commit is contained in:
parent
76cfc033a9
commit
bc0cb438b8
@ -5069,6 +5069,27 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
self.do_add(subcmd, opts, dest)
|
self.do_add(subcmd, opts, dest)
|
||||||
self.do_delete(subcmd, opts, source)
|
self.do_delete(subcmd, opts, source)
|
||||||
|
|
||||||
|
@cmdln.option('-d', '--delete', action='store_true',
|
||||||
|
help='delete option from config or reset option to the default)')
|
||||||
|
def do_config(self, subcmd, opts, section, opt, *val):
|
||||||
|
"""${cmd_name}: get/set a config option
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
osc config section option (get current value)
|
||||||
|
osc config section option value (set to value)
|
||||||
|
osc config section option --delete (delete option/reset to the default)
|
||||||
|
(section is either an apiurl or an alias or 'generic')
|
||||||
|
|
||||||
|
${cmd_usage}
|
||||||
|
${cmd_option_list}
|
||||||
|
"""
|
||||||
|
opt, newval = conf.config_set_option(section, opt, ' '.join(val), delete=opts.delete, update=False)
|
||||||
|
if newval is None and opts.delete:
|
||||||
|
print '\'%s\': \'%s\' got removed' % (section, opt)
|
||||||
|
elif newval is None:
|
||||||
|
print '\'%s\': \'%s\' is not set' % (section, opt)
|
||||||
|
else:
|
||||||
|
print '\'%s\': \'%s\' is set to \'%s\'' % (section, opt, newval)
|
||||||
|
|
||||||
# fini!
|
# fini!
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
54
osc/conf.py
54
osc/conf.py
@ -130,7 +130,7 @@ boolean_opts = ['debug', 'do_package_tracking', 'http_debug', 'post_mortem', 'tr
|
|||||||
'checkout_no_colon', 'check_for_request_on_action', 'linkcontrol', 'show_download_progress', 'request_show_interactive',
|
'checkout_no_colon', 'check_for_request_on_action', 'linkcontrol', 'show_download_progress', 'request_show_interactive',
|
||||||
'use_keyring', 'gnome_keyring']
|
'use_keyring', 'gnome_keyring']
|
||||||
|
|
||||||
api_host_options = ['user', 'pass', 'passx', 'http_headers', 'email', 'sslcertck', 'cafile', 'capath', 'trusted_prj']
|
api_host_options = ['user', 'pass', 'passx', 'aliases', 'http_headers', 'email', 'sslcertck', 'cafile', 'capath', 'trusted_prj']
|
||||||
|
|
||||||
new_conf_template = """
|
new_conf_template = """
|
||||||
[general]
|
[general]
|
||||||
@ -397,11 +397,60 @@ def get_configParser(conffile=None, force_read=False):
|
|||||||
"""
|
"""
|
||||||
conffile = conffile or os.environ.get('OSC_CONFIG', '~/.oscrc')
|
conffile = conffile or os.environ.get('OSC_CONFIG', '~/.oscrc')
|
||||||
conffile = os.path.expanduser(conffile)
|
conffile = os.path.expanduser(conffile)
|
||||||
if force_read or not get_configParser.__dict__.has_key('cp'):
|
if not get_configParser.__dict__.has_key('conffile'):
|
||||||
|
get_configParser.conffile = conffile
|
||||||
|
if force_read or not get_configParser.__dict__.has_key('cp') or conffile != get_configParser.conffile:
|
||||||
get_configParser.cp = OscConfigParser.OscConfigParser(DEFAULTS)
|
get_configParser.cp = OscConfigParser.OscConfigParser(DEFAULTS)
|
||||||
get_configParser.cp.read(conffile)
|
get_configParser.cp.read(conffile)
|
||||||
|
get_configParser.conffile = conffile
|
||||||
return get_configParser.cp
|
return get_configParser.cp
|
||||||
|
|
||||||
|
def config_set_option(section, opt, val=None, delete=False, update=True, **kwargs):
|
||||||
|
"""
|
||||||
|
Sets a config option. If val is not specified the current/default value is
|
||||||
|
returned. If val is specified, opt is set to val and the new value is returned.
|
||||||
|
If an option was modified get_config is called with **kwargs unless update is set
|
||||||
|
to False (override_conffile defaults to config['conffile']).
|
||||||
|
If val is not specified and delete is True then the option is removed from the
|
||||||
|
config/reset to the default value.
|
||||||
|
"""
|
||||||
|
def write_config(fname, cp):
|
||||||
|
"""write new configfile in a safe way"""
|
||||||
|
try:
|
||||||
|
f = open(fname + '.new', 'w')
|
||||||
|
cp.write(f, comments=True)
|
||||||
|
f.close()
|
||||||
|
os.rename(fname + '.new', fname)
|
||||||
|
except:
|
||||||
|
if os.path.exists(fname + '.new'):
|
||||||
|
os.unlink(fname + '.new')
|
||||||
|
raise
|
||||||
|
|
||||||
|
cp = get_configParser(config['conffile'])
|
||||||
|
# don't allow "internal" options
|
||||||
|
general_opts = [i for i in DEFAULTS.keys() if not i in ['user', 'pass', 'passx']]
|
||||||
|
section = config['apiurl_aliases'].get(section, section)
|
||||||
|
if not section in cp.sections():
|
||||||
|
raise oscerr.ConfigError('unknown section \'%s\'' % section, config['conffile'])
|
||||||
|
if section == 'general' and not opt in general_opts or \
|
||||||
|
section != 'general' and not opt in api_host_options:
|
||||||
|
raise oscerr.ConfigError('unknown config option \'%s\'' % opt, config['conffile'])
|
||||||
|
run = False
|
||||||
|
if val:
|
||||||
|
cp.set(section, opt, val)
|
||||||
|
write_config(config['conffile'], cp)
|
||||||
|
run = True
|
||||||
|
elif delete and cp.has_option(section, opt):
|
||||||
|
cp.remove_option(section, opt)
|
||||||
|
write_config(config['conffile'], cp)
|
||||||
|
run = True
|
||||||
|
if run and update:
|
||||||
|
kw = {'override_conffile': config['conffile']}
|
||||||
|
kw.update(kwargs)
|
||||||
|
get_config(**kw)
|
||||||
|
if cp.has_option(section, opt):
|
||||||
|
return (opt, cp.get(section, opt, raw=True))
|
||||||
|
return (opt, None)
|
||||||
|
|
||||||
def write_initial_config(conffile, entries, custom_template = ''):
|
def write_initial_config(conffile, entries, custom_template = ''):
|
||||||
"""
|
"""
|
||||||
@ -528,6 +577,7 @@ def get_config(override_conffile = None,
|
|||||||
raise oscerr.ConfigError(msg, conffile)
|
raise oscerr.ConfigError(msg, conffile)
|
||||||
|
|
||||||
config = dict(cp.items('general', raw=1))
|
config = dict(cp.items('general', raw=1))
|
||||||
|
config['conffile'] = conffile
|
||||||
|
|
||||||
for i in boolean_opts:
|
for i in boolean_opts:
|
||||||
try:
|
try:
|
||||||
|
Loading…
Reference in New Issue
Block a user