##// END OF EJS Templates
Added tag v1.1.7 for changeset bd102f45950f
Added tag v1.1.7 for changeset bd102f45950f

File last commit:

r1209:45fed9a4 default
r1234:d15669d9 default
Show More
environment.py
87 lines | 3.1 KiB | text/x-python | PythonLexer
renamed project to rhodecode
r547 """Pylons environment configuration"""
rhodecode release 1.1.3 changes
r1057
import os
import logging
renamed project to rhodecode
r547 from mako.lookup import TemplateLookup
from pylons.configuration import PylonsConfig
from pylons.error import handle_mako_error
rhodecode release 1.1.3 changes
r1057 from sqlalchemy import engine_from_config
import rhodecode.lib.app_globals as app_globals
import rhodecode.lib.helpers
renamed project to rhodecode
r547 from rhodecode.config.routing import make_map
rhodecode release 1.1.3 changes
r1057 from rhodecode.lib import celerypylons
renamed project to rhodecode
r547 from rhodecode.lib.auth import set_available_permissions, set_base_path
renamed hg_app to rhodecode
r548 from rhodecode.lib.utils import repo2db_mapper, make_ui, set_rhodecode_config
renamed project to rhodecode
r547 from rhodecode.model import init_model
Refactor codes for scm model...
r691 from rhodecode.model.scm import ScmModel
rhodecode release 1.1.3 changes
r1057 from rhodecode.lib.timerproxy import TimerProxy
renamed project to rhodecode
r547
log = logging.getLogger(__name__)
merges for upcoming release
r1209
renamed project to rhodecode
r547 def load_environment(global_conf, app_conf, initial=False):
"""Configure the Pylons environment via the ``pylons.config``
object
"""
config = PylonsConfig()
Hacking for git support,and new faster repo scan
r631
renamed project to rhodecode
r547 # Pylons paths
root = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
paths = dict(root=root,
controllers=os.path.join(root, 'controllers'),
static_files=os.path.join(root, 'public'),
templates=[os.path.join(root, 'templates')])
# Initialize config with the basic options
config.init_app(global_conf, app_conf, package='rhodecode', paths=paths)
config['routes.map'] = make_map(config)
config['pylons.app_globals'] = app_globals.Globals(config)
config['pylons.h'] = rhodecode.lib.helpers
Hacking for git support,and new faster repo scan
r631
renamed project to rhodecode
r547 # Setup cache object as early as possible
import pylons
pylons.cache._push_object(config['pylons.app_globals'].cache)
Hacking for git support,and new faster repo scan
r631
renamed project to rhodecode
r547 # Create the Mako TemplateLookup, with the default auto-escaping
config['pylons.app_globals'].mako_lookup = TemplateLookup(
directories=paths['templates'],
error_handler=handle_mako_error,
module_directory=os.path.join(app_conf['cache_dir'], 'templates'),
input_encoding='utf-8', default_filters=['escape'],
imports=['from webhelpers.html import escape'])
#sets the c attribute access when don't existing attribute are accessed
config['pylons.strict_tmpl_context'] = True
test = os.path.split(config['__file__'])[-1] == 'test.ini'
if test:
from rhodecode.lib.utils import create_test_env, create_test_index
Tests rewrite for 1.2 added some globals configs to make tests easier....
r688 from rhodecode.tests import TESTS_TMP_PATH
create_test_env(TESTS_TMP_PATH, config)
create_test_index(TESTS_TMP_PATH, True)
Hacking for git support,and new faster repo scan
r631
renamed project to rhodecode
r547 #MULTIPLE DB configs
# Setup the SQLAlchemy database engine
if config['debug'] and not test:
#use query time debugging.
sa_engine_db1 = engine_from_config(config, 'sqlalchemy.db1.',
merges for upcoming release
r1209 proxy=TimerProxy())
renamed project to rhodecode
r547 else:
sa_engine_db1 = engine_from_config(config, 'sqlalchemy.db1.')
init_model(sa_engine_db1)
#init baseui
config['pylons.app_globals'].baseui = make_ui('db')
Hacking for git support,and new faster repo scan
r631
Moved out reposcan into hg Model....
r665 g = config['pylons.app_globals']
Cleaned up scm model codes,Admin/admin permissions controller codes
r760 repo2db_mapper(ScmModel().repo_scan(g.paths[0][1], g.baseui))
renamed project to rhodecode
r547 set_available_permissions(config)
set_base_path(config)
renamed hg_app to rhodecode
r548 set_rhodecode_config(config)
renamed project to rhodecode
r547 # CONFIGURATION OPTIONS HERE (note: all config options will override
# any Pylons config options)
Hacking for git support,and new faster repo scan
r631
renamed project to rhodecode
r547 return config