X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=myslice%2Fconfig.py;h=61c22817e3a86672dbd514abfe158ae02f1fbade;hb=4920497313e03cc832c29aaae13e45ca060ccc94;hp=84a0ee0dcb8ebda33ff1811a3234e4f2dbbfb9c5;hpb=de93a901d06d0f4f666ff0fcafd1fa024da144e1;p=myslice.git diff --git a/myslice/config.py b/myslice/config.py index 84a0ee0d..61c22817 100644 --- a/myslice/config.py +++ b/myslice/config.py @@ -1,10 +1,48 @@ -class Config: +import os.path +from ConfigParser import RawConfigParser +from myslice.settings import ROOT -# manifold_server = 'demo.myslice.info' - manifold_server = 'debian04.pl.sophia.inria.fr' - manifold_port = '7080' - manifold_path = '/' +# as this code suggests, you have the option to override these defaults +# by writing a file myslice/myslice.ini +# that looks like this +#[manifold] +#url = http://manifold.pl.sophia.inria.fr:7080/ +#admin_user = admin +#admin_password = admin - @staticmethod - def manifold_url (): - return "http://%s:%s%s"%(Config.manifold_server,Config.manifold_port,Config.manifold_path) +# use a singleton instead of staticmethods +from manifold.util.singleton import Singleton + +class Config(object): + __metaclass__ = Singleton + + # the OpenLab-wide backend as managed by UPMC + # xxx production should probably use https of course + default_manifold_url = "http://test.myslice.info:7080/" + # the devel/unstable version runs on "http://dev.myslice.info:7080/" + # if you use a development backend running on this box, use "http://localhost:7080/" + # the INRIA setup is with "http://manifold.pl.sophia.inria.fr:7080/" + + default_manifold_admin_user = 'admin' + default_manifold_admin_password = 'admin' + + + def __init__ (self): + parser = RawConfigParser () + parser.add_section('manifold') + parser.set ('manifold', 'url', Config.default_manifold_url) + parser.set ('manifold', 'admin_user', Config.default_manifold_admin_user) + parser.set ('manifold', 'admin_password', Config.default_manifold_admin_password) + parser.read (os.path.join(ROOT,'myslice/myslice.ini')) + self.config_parser=parser + + def manifold_url (self): + return self.config_parser.get('manifold','url') + + def manifold_admin_user_password(self): + return (self.config_parser.get('manifold','admin_user'), + self.config_parser.get('manifold','admin_password')) + + # exporting these details to js + def manifold_js_export (self): + return "var MANIFOLD_URL = '%s';\n"%self.manifold_url();