lookup cfg files in a list of directories
environment variable SECOP_CONFDIR may be a ':' separated list of directories to lookup for cfg files Change-Id: I058be6a270d3a3f6cd8ca45fdd4ab68c80fa5c23 Reviewed-on: https://forge.frm2.tum.de/review/c/sine2020/secop/playground/+/25063 Tested-by: Jenkins Automated Tests <pedersen+jenkins@frm2.tum.de> Reviewed-by: Enrico Faulhaber <enrico.faulhaber@frm2.tum.de> Reviewed-by: Markus Zolliker <markus.zolliker@psi.ch>
This commit is contained in:
parent
899a07aec8
commit
23779c8f8c
@ -95,11 +95,7 @@ class Server:
|
|||||||
merged_cfg = OrderedDict()
|
merged_cfg = OrderedDict()
|
||||||
ambiguous_sections = set()
|
ambiguous_sections = set()
|
||||||
for cfgfile in cfgfiles.split(','):
|
for cfgfile in cfgfiles.split(','):
|
||||||
if cfgfile.endswith('.cfg') and os.path.exists(cfgfile):
|
cfgdict = self.loadCfgFile(cfgfile)
|
||||||
filename = cfgfile
|
|
||||||
else:
|
|
||||||
filename = os.path.join(cfg['confdir'], cfgfile + '.cfg')
|
|
||||||
cfgdict = self.loadCfgFile(filename)
|
|
||||||
ambiguous_sections |= set(merged_cfg) & set(cfgdict)
|
ambiguous_sections |= set(merged_cfg) & set(cfgdict)
|
||||||
merged_cfg.update(cfgdict)
|
merged_cfg.update(cfgdict)
|
||||||
self.node_cfg = merged_cfg.pop('NODE', {})
|
self.node_cfg = merged_cfg.pop('NODE', {})
|
||||||
@ -118,7 +114,20 @@ class Server:
|
|||||||
self._cfgfiles = cfgfiles
|
self._cfgfiles = cfgfiles
|
||||||
self._pidfile = os.path.join(cfg['piddir'], name + '.pid')
|
self._pidfile = os.path.join(cfg['piddir'], name + '.pid')
|
||||||
|
|
||||||
def loadCfgFile(self, filename):
|
def loadCfgFile(self, cfgfile):
|
||||||
|
if not cfgfile.endswith('.cfg'):
|
||||||
|
cfgfile += '.cfg'
|
||||||
|
cfg = getGeneralConfig()
|
||||||
|
if os.sep in cfgfile: # specified as full path
|
||||||
|
filename = cfgfile if os.path.exists(cfgfile) else None
|
||||||
|
else:
|
||||||
|
for filename in [os.path.join(d, cfgfile) for d in cfg['confdir'].split(os.pathsep)]:
|
||||||
|
if os.path.exists(filename):
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
filename = None
|
||||||
|
if filename is None:
|
||||||
|
raise ConfigError("Couldn't find cfg file %r in %s" % (cfgfile, cfg['confdir']))
|
||||||
self.log.debug('Parse config file %s ...' % filename)
|
self.log.debug('Parse config file %s ...' % filename)
|
||||||
result = OrderedDict()
|
result = OrderedDict()
|
||||||
parser = configparser.ConfigParser()
|
parser = configparser.ConfigParser()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user