Files
@ bbaab7501c1a
Branch filter:
Location: kallithea/pylons_app/lib/app_globals.py - annotation
bbaab7501c1a
2.0 KiB
text/x-python
Added custom templates, did over check of code to make it work.
Added templating for add repository, and styling. App globals now handles our custom static files. (logo etc can be changed)
Added templating for add repository, and styling. App globals now handles our custom static files. (logo etc can be changed)
564e40829f80 525ed90e4577 525ed90e4577 525ed90e4577 bbaab7501c1a 525ed90e4577 bbaab7501c1a bbaab7501c1a 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 564e40829f80 525ed90e4577 525ed90e4577 525ed90e4577 525ed90e4577 525ed90e4577 bbaab7501c1a 525ed90e4577 525ed90e4577 bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a 525ed90e4577 bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a bbaab7501c1a | """The application's Globals object"""
#uncomment the following if you want to serve a single repo
#from mercurial.hgweb.hgweb_mod import hgweb
from mercurial.hgweb.hgwebdir_mod import hgwebdir
from mercurial import templater
from mercurial.hgweb.request import wsgiapplication
from mercurial import ui, config
import os
class Globals(object):
"""Globals acts as a container for objects available throughout the
life of the application
"""
def __init__(self):
"""One instance of Globals is created during application
initialization and is available during requests via the
'app_globals' variable
"""
#two ways of building the merc app i don't know
#the fastest one but belive the wsgiapp is better
#self.hgapp = self.make_web_app()
self.hgapp = wsgiapplication(self.make_web_app)
def make_web_app(self):
repos = "hgwebdir.config"
baseui = ui.ui()
cfg = config.config()
cfg.read(repos)
paths = cfg.items('paths')
self.check_repo_dir(paths)
self.set_statics(cfg)
for k, v in cfg.items('web'):
baseui.setconfig('web', k, v)
#magic trick to make our custom template dir working
templater.path.append(cfg.get('web', 'templates', None))
hgwebapp = hgwebdir(paths, baseui = baseui)
return hgwebapp
def set_statics(self, cfg):
'''
set's the statics for use in mako templates
@param cfg:
'''
self.statics = cfg.get('web', 'staticurl', '/static')
if not self.statics.endswith('/'):
self.statics += '/'
def check_repo_dir(self, paths):
repos_path = paths[0][1].split('/')
if repos_path[-1] in ['*', '**']:
repos_path = repos_path[:-1]
if repos_path[0] != '/':
repos_path[0] = '/'
if not os.path.isdir(os.path.join(*repos_path)):
raise Exception('Not a valid repository in %s' % paths[0][1])
|