3021: Propagate unhandled exceptions back to the caller instead of returning None...
[arvados.git] / sdk / python / arvados / config.py
1 # config.py - configuration settings and global variables for Arvados clients
2 #
3 # Arvados configuration settings are taken from $HOME/.config/arvados.
4 # Environment variables override settings in the config file.
5
6 import os
7 import re
8
9 _settings = None
10 if os.environ.get('HOME') is not None:
11     default_config_file = os.environ['HOME'] + '/.config/arvados/settings.conf'
12 else:
13     default_config_file = ''
14
15 EMPTY_BLOCK_LOCATOR = 'd41d8cd98f00b204e9800998ecf8427e+0'
16
17 def initialize(config_file=default_config_file):
18     global _settings
19     _settings = {}
20
21     # load the specified config file if available
22     try:
23         _settings = load(config_file)
24     except IOError:
25         pass
26
27     # override any settings with environment vars
28     for var in os.environ:
29         if var.startswith('ARVADOS_'):
30             _settings[var] = os.environ[var]
31
32 def load(config_file):
33     cfg = {}
34     with open(config_file, "r") as f:
35         for config_line in f:
36             if re.match('^\s*$', config_line):
37                 continue
38             if re.match('^\s*#', config_line):
39                 continue
40             var, val = config_line.rstrip().split('=', 2)
41             cfg[var] = val
42     return cfg
43
44 def flag_is_true(key):
45     return get(key, '').lower() in set(['1', 't', 'true', 'y', 'yes'])
46
47 def get(key, default_val=None):
48     return settings().get(key, default_val)
49
50 def settings():
51     if _settings is None:
52         initialize()
53     return _settings