1 # -*- coding: utf-8 -*-
2 ##############################################################################
4 # OpenERP, Open Source Management Solution
5 # Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
7 # This program is free software: you can redistribute it and/or modify
8 # it under the terms of the GNU Affero General Public License as
9 # published by the Free Software Foundation, either version 3 of the
10 # License, or (at your option) any later version.
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU Affero General Public License for more details.
17 # You should have received a copy of the GNU Affero General Public License
18 # along with this program. If not, see <http://www.gnu.org/licenses/>.
20 ##############################################################################
22 """ OpenERP core library."""
24 #----------------------------------------------------------
25 # Running mode flags (gevent, prefork)
26 #----------------------------------------------------------
27 # Is the server running with gevent.
30 if sys.modules.get("gevent") is not None:
33 # Is the server running in pefork mode (e.g. behind Gunicorn).
34 # If this is True, the processes have to communicate some events,
35 # e.g. database update or cache invalidation. Each process has also
36 # its own copy of the data structure and we don't need to care about
37 # locks between threads.
40 #----------------------------------------------------------
42 #----------------------------------------------------------
43 # Make sure the OpenERP server runs in UTC. This is especially necessary
44 # under Windows as under Linux it seems the real import of time is
45 # sufficiently deferred so that setting the TZ environment variable
46 # in openerp.cli.server was working.
48 os.environ['TZ'] = 'UTC' # Set the timezone...
49 import time # ... *then* import time.
53 #----------------------------------------------------------
55 #----------------------------------------------------------
56 # The hard-coded super-user id (a.k.a. administrator, or root user).
59 def registry(database_name):
61 Return the model registry for the given database. If the registry does not
62 exist yet, it is created on the fly.
64 return modules.registry.RegistryManager.get(database_name)
66 #----------------------------------------------------------
68 #----------------------------------------------------------
83 #----------------------------------------------------------
84 # Model classes, fields, api decorators, and translations
85 #----------------------------------------------------------
89 from openerp.tools.translate import _
91 #----------------------------------------------------------
92 # Other imports, which may require stuff from above
93 #----------------------------------------------------------
97 # vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: