##// END OF EJS Templates
core: synced vendor/ext_json with ce for better compatability
core: synced vendor/ext_json with ce for better compatability

File last commit:

r1229:fe30068d v5.0.1 stable
r1250:2c57bb5b default
Show More
config_utils.py
40 lines | 1.5 KiB | text/x-python | PythonLexer
feat: svn hooks are mandatory and blocking from now on
r1231 # Copyright (C) 2010-2023 RhodeCode GmbH
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
import os
def get_config(ini_path, **kwargs):
import configparser
parser = configparser.ConfigParser(**kwargs)
parser.read(ini_path)
return parser
def get_app_config_lightweight(ini_path):
parser = get_config(ini_path)
parser.set('app:main', 'here', os.getcwd())
parser.set('app:main', '__file__', ini_path)
return dict(parser.items('app:main'))
def get_app_config(ini_path):
"""
This loads the app context and provides a heavy type iniliaziation of config
"""
from paste.deploy.loadwsgi import appconfig
return appconfig(f'config:{ini_path}', relative_to=os.getcwd())