author | Sylvain Thénault <sylvain.thenault@logilab.fr> |
Tue, 22 Dec 2009 19:25:08 +0100 | |
changeset 4187 | c29a49d646af |
parent 4106 | ea4e93f9b151 |
child 4252 | 6c4f109c2b03 |
permissions | -rw-r--r-- |
0 | 1 |
"""server.serverconfig definition |
2 |
||
3 |
:organization: Logilab |
|
1977
606923dff11b
big bunch of copyright / docstring update
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
1666
diff
changeset
|
4 |
:copyright: 2001-2009 LOGILAB S.A. (Paris, FRANCE), license is LGPL v2. |
0 | 5 |
:contact: http://www.logilab.fr/ -- mailto:contact@logilab.fr |
1977
606923dff11b
big bunch of copyright / docstring update
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
1666
diff
changeset
|
6 |
:license: GNU Lesser General Public License, v2.1 - http://www.gnu.org/licenses |
0 | 7 |
""" |
8 |
__docformat__ = "restructuredtext en" |
|
9 |
||
10 |
import os |
|
11 |
from os.path import join, exists |
|
12 |
||
3900
a26f50cb7e70
password is required, else we get obscure validation failure when inserting the admin user into cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3835
diff
changeset
|
13 |
from logilab.common.configuration import REQUIRED, Method, Configuration, \ |
2105
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
14 |
ini_format_section |
0 | 15 |
from logilab.common.decorators import wproperty, cached, clear_cache |
16 |
||
17 |
from cubicweb import CW_SOFTWARE_ROOT, RegistryNotFound |
|
3637 | 18 |
from cubicweb.toolsutils import read_config, restrict_perms_to_user |
0 | 19 |
from cubicweb.cwconfig import CubicWebConfiguration, merge_options |
2107
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
20 |
from cubicweb.server import SOURCE_TYPES |
0 | 21 |
|
22 |
||
2107
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
23 |
USER_OPTIONS = ( |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
24 |
('login', {'type' : 'string', |
3835
a191b3b9e455
more sensible default values to c-c "create" inputs
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3638
diff
changeset
|
25 |
'default': 'admin', |
2107
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
26 |
'help': "cubicweb manager account's login " |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
27 |
'(this user will be created)', |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
28 |
'inputlevel': 0, |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
29 |
}), |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
30 |
('password', {'type' : 'password', |
3900
a26f50cb7e70
password is required, else we get obscure validation failure when inserting the admin user into cw
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3835
diff
changeset
|
31 |
'default': REQUIRED, |
2107
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
32 |
'help': "cubicweb manager account's password", |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
33 |
'inputlevel': 0, |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
34 |
}), |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
35 |
) |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
36 |
|
3904
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
37 |
class SourceConfiguration(Configuration): |
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
38 |
def __init__(self, appid, options): |
3912
412eb366740b
set appid attribute before super call to avoid attribute error when fetching configuration's defaults
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3905
diff
changeset
|
39 |
self.appid = appid # has to be done before super call |
3904
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
40 |
super(SourceConfiguration, self).__init__(options=options) |
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
41 |
|
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
42 |
# make Method('default_instance_id') usable in db option defs (in native.py) |
3905 | 43 |
def default_instance_id(self): |
3904
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
44 |
return self.appid |
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
45 |
|
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
46 |
def generate_sources_file(appid, sourcesfile, sourcescfg, keys=None): |
2105
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
47 |
"""serialize repository'sources configuration into a INI like file |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
48 |
|
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
49 |
the `keys` parameter may be used to sort sections |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
50 |
""" |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
51 |
if keys is None: |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
52 |
keys = sourcescfg.keys() |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
53 |
else: |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
54 |
for key in sourcescfg: |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
55 |
if not key in keys: |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
56 |
keys.append(key) |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
57 |
stream = open(sourcesfile, 'w') |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
58 |
for uri in keys: |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
59 |
sconfig = sourcescfg[uri] |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
60 |
if isinstance(sconfig, dict): |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
61 |
# get a Configuration object |
2107
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
62 |
if uri == 'admin': |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
63 |
options = USER_OPTIONS |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
64 |
else: |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
65 |
options = SOURCE_TYPES[sconfig['adapter']].options |
3904
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
66 |
_sconfig = SourceConfiguration(appid, options=options) |
2105
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
67 |
for attr, val in sconfig.items(): |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
68 |
if attr == 'uri': |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
69 |
continue |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
70 |
if attr == 'adapter': |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
71 |
_sconfig.adapter = val |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
72 |
else: |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
73 |
_sconfig.set_option(attr, val) |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
74 |
sconfig = _sconfig |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
75 |
optsbysect = list(sconfig.options_by_section()) |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
76 |
assert len(optsbysect) == 1, 'all options for a source should be in the same group' |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
77 |
ini_format_section(stream, uri, optsbysect[0][1]) |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
78 |
if hasattr(sconfig, 'adapter'): |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
79 |
print >> stream |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
80 |
print >> stream, '# adapter for this source (YOU SHOULD NOT CHANGE THIS)' |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
81 |
print >> stream, 'adapter=%s' % sconfig.adapter |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
82 |
print >> stream |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
83 |
|
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
84 |
|
0 | 85 |
class ServerConfiguration(CubicWebConfiguration): |
86 |
"""standalone RQL server""" |
|
87 |
name = 'repository' |
|
88 |
||
2835
04034421b072
[hooks] major refactoring:
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2810
diff
changeset
|
89 |
cubicweb_appobject_path = CubicWebConfiguration.cubicweb_appobject_path | set(['sobjects', 'hooks']) |
2657
de974465d381
[appobject] kill VObject class, move base selector classes to appobject
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2650
diff
changeset
|
90 |
cube_appobject_path = CubicWebConfiguration.cube_appobject_path | set(['sobjects', 'hooks']) |
0 | 91 |
|
92 |
options = merge_options(( |
|
93 |
# ctl configuration |
|
94 |
('host', |
|
95 |
{'type' : 'string', |
|
96 |
'default': None, |
|
97 |
'help': 'host name if not correctly detectable through gethostname', |
|
98 |
'group': 'main', 'inputlevel': 1, |
|
99 |
}), |
|
100 |
('pid-file', |
|
101 |
{'type' : 'string', |
|
102 |
'default': Method('default_pid_file'), |
|
103 |
'help': 'repository\'s pid file', |
|
104 |
'group': 'main', 'inputlevel': 2, |
|
105 |
}), |
|
106 |
('uid', |
|
107 |
{'type' : 'string', |
|
108 |
'default': None, |
|
109 |
'help': 'if this option is set, use the specified user to start \ |
|
110 |
the repository rather than the user running the command', |
|
136
ff51a18c66a3
ask less questions on instance creation
Adrien Di Mascio <Adrien.DiMascio@logilab.fr>
parents:
0
diff
changeset
|
111 |
'group': 'main', 'inputlevel': (CubicWebConfiguration.mode == 'installed') and 0 or 1, |
0 | 112 |
}), |
113 |
('session-time', |
|
114 |
{'type' : 'int', |
|
115 |
'default': 30*60, |
|
116 |
'help': 'session expiration time, default to 30 minutes', |
|
117 |
'group': 'main', 'inputlevel': 1, |
|
118 |
}), |
|
119 |
('connections-pool-size', |
|
120 |
{'type' : 'int', |
|
121 |
'default': 4, |
|
122 |
'help': 'size of the connections pools. Each source supporting multiple \ |
|
123 |
connections will have this number of opened connections.', |
|
124 |
'group': 'main', 'inputlevel': 1, |
|
125 |
}), |
|
126 |
('rql-cache-size', |
|
127 |
{'type' : 'int', |
|
128 |
'default': 300, |
|
129 |
'help': 'size of the parsed rql cache size.', |
|
130 |
'group': 'main', 'inputlevel': 1, |
|
131 |
}), |
|
1160
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
132 |
('delay-full-text-indexation', |
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
133 |
{'type' : 'yn', 'default': False, |
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
134 |
'help': 'When full text indexation of entity has a too important cost' |
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
135 |
' to be done when entity are added/modified by users, activate this ' |
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
136 |
'option and setup a job using cubicweb-ctl db-rebuild-fti on your ' |
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
137 |
'system (using cron for instance).', |
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
138 |
'group': 'main', 'inputlevel': 1, |
77bf88f01fcc
new delay-full-text-indexation configuration option
sylvain.thenault@logilab.fr
parents:
136
diff
changeset
|
139 |
}), |
1666 | 140 |
|
0 | 141 |
# email configuration |
142 |
('default-recipients-mode', |
|
143 |
{'type' : 'choice', |
|
144 |
'choices' : ('default-dest-addrs', 'users', 'none'), |
|
145 |
'default': 'default-dest-addrs', |
|
146 |
'help': 'when a notification should be sent with no specific rules \ |
|
147 |
to find recipients, recipients will be found according to this mode. Available \ |
|
148 |
modes are "default-dest-addrs" (emails specified in the configuration \ |
|
149 |
variable with the same name), "users" (every users which has activated \ |
|
150 |
account with an email set), "none" (no notification).', |
|
151 |
'group': 'email', 'inputlevel': 1, |
|
152 |
}), |
|
153 |
('default-dest-addrs', |
|
154 |
{'type' : 'csv', |
|
155 |
'default': (), |
|
156 |
'help': 'comma separated list of email addresses that will be used \ |
|
157 |
as default recipient when an email is sent and the notification has no \ |
|
158 |
specific recipient rules.', |
|
159 |
'group': 'email', 'inputlevel': 1, |
|
160 |
}), |
|
161 |
('supervising-addrs', |
|
162 |
{'type' : 'csv', |
|
163 |
'default': (), |
|
164 |
'help': 'comma separated list of email addresses that will be \ |
|
165 |
notified of every changes.', |
|
166 |
'group': 'email', 'inputlevel': 2, |
|
167 |
}), |
|
168 |
# pyro server.serverconfig |
|
2665
0c6281487f90
[pyro] use lgc.pyro_ext, simplify pyro related options
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2657
diff
changeset
|
169 |
('pyro-host', |
3547
0c18a6c8d9b7
fix pyro-host option type
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3539
diff
changeset
|
170 |
{'type' : 'string', |
0 | 171 |
'default': None, |
2665
0c6281487f90
[pyro] use lgc.pyro_ext, simplify pyro related options
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2657
diff
changeset
|
172 |
'help': 'Pyro server host, if not detectable correctly through \ |
0c6281487f90
[pyro] use lgc.pyro_ext, simplify pyro related options
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2657
diff
changeset
|
173 |
gethostname(). It may contains port information using <host>:<port> notation, \ |
0c6281487f90
[pyro] use lgc.pyro_ext, simplify pyro related options
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2657
diff
changeset
|
174 |
and if not set, it will be choosen randomly', |
3539
f3b14d052798
[pyro] merge pyro-id / pyro-instance-id options, put all pyro options in the same section of the configuration file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2959
diff
changeset
|
175 |
'group': 'pyro', 'inputlevel': 2, |
0 | 176 |
}), |
177 |
) + CubicWebConfiguration.options) |
|
1666 | 178 |
|
2959
daabb9bc5233
make db-restore command work even with no/corrupted database
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2730
diff
changeset
|
179 |
# should we open connections pools (eg connect to sources). This is usually |
daabb9bc5233
make db-restore command work even with no/corrupted database
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2730
diff
changeset
|
180 |
# necessary... |
daabb9bc5233
make db-restore command work even with no/corrupted database
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2730
diff
changeset
|
181 |
open_connections_pools = True |
daabb9bc5233
make db-restore command work even with no/corrupted database
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2730
diff
changeset
|
182 |
|
0 | 183 |
# read the schema from the database |
2476
1294a6bdf3bf
application -> instance where it makes sense
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2107
diff
changeset
|
184 |
read_instance_schema = True |
0 | 185 |
bootstrap_schema = True |
1666 | 186 |
|
0 | 187 |
# check user's state at login time |
188 |
consider_user_state = True |
|
1666 | 189 |
|
2835
04034421b072
[hooks] major refactoring:
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2810
diff
changeset
|
190 |
# hooks activation configuration |
0 | 191 |
# all hooks should be activated during normal execution |
2835
04034421b072
[hooks] major refactoring:
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2810
diff
changeset
|
192 |
disabled_hooks_categories = set() |
4106
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
193 |
enabled_hooks_categories = set() |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
194 |
ALLOW_ALL = object() |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
195 |
DENY_ALL = object() |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
196 |
hooks_mode = ALLOW_ALL |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
197 |
|
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
198 |
@classmethod |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
199 |
def set_hooks_mode(cls, mode): |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
200 |
assert mode is cls.ALLOW_ALL or mode is cls.DENY_ALL |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
201 |
oldmode = cls.hooks_mode |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
202 |
cls.hooks_mode = mode |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
203 |
return oldmode |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
204 |
|
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
205 |
@classmethod |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
206 |
def disable_hook_category(cls, *categories): |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
207 |
changes = set() |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
208 |
if cls.hooks_mode is cls.DENY_ALL: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
209 |
for category in categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
210 |
if category in cls.enabled_hooks_categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
211 |
cls.enabled_hooks_categories.remove(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
212 |
changes.add(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
213 |
else: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
214 |
for category in categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
215 |
if category not in cls.disabled_hooks_categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
216 |
cls.disabled_hooks_categories.add(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
217 |
changes.add(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
218 |
return changes |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
219 |
|
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
220 |
@classmethod |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
221 |
def enable_hook_category(cls, *categories): |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
222 |
changes = set() |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
223 |
if cls.hooks_mode is cls.DENY_ALL: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
224 |
for category in categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
225 |
if category not in cls.enabled_hooks_categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
226 |
cls.enabled_hooks_categories.add(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
227 |
changes.add(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
228 |
else: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
229 |
for category in categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
230 |
if category in cls.disabled_hooks_categories: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
231 |
cls.disabled_hooks_categories.remove(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
232 |
changes.add(category) |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
233 |
return changes |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
234 |
|
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
235 |
@classmethod |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
236 |
def is_hook_activated(cls, hook): |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
237 |
if cls.hooks_mode is cls.DENY_ALL: |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
238 |
return hook.category in cls.enabled_hooks_categories |
ea4e93f9b151
more advanced hooks control
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3998
diff
changeset
|
239 |
return hook.category not in cls.disabled_hooks_categories |
0 | 240 |
|
241 |
# should some hooks be deactivated during [pre|post]create script execution |
|
242 |
free_wheel = False |
|
1666 | 243 |
|
0 | 244 |
# list of enables sources when sources restriction is necessary |
245 |
# (eg repository initialization at least) |
|
246 |
_enabled_sources = None |
|
247 |
@wproperty |
|
248 |
def enabled_sources(self, sourceuris=None): |
|
249 |
self._enabled_sources = sourceuris |
|
250 |
clear_cache(self, 'sources') |
|
1666 | 251 |
|
0 | 252 |
def bootstrap_cubes(self): |
2633
bc9386c3b2c9
get_csv is being renamed to splitstrip
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2493
diff
changeset
|
253 |
from logilab.common.textutils import splitstrip |
0 | 254 |
for line in file(join(self.apphome, 'bootstrap_cubes')): |
255 |
line = line.strip() |
|
256 |
if not line or line.startswith('#'): |
|
257 |
continue |
|
2633
bc9386c3b2c9
get_csv is being renamed to splitstrip
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2493
diff
changeset
|
258 |
self.init_cubes(self.expand_cubes(splitstrip(line))) |
0 | 259 |
break |
260 |
else: |
|
261 |
# no cubes |
|
262 |
self.init_cubes(()) |
|
1666 | 263 |
|
0 | 264 |
def write_bootstrap_cubes_file(self, cubes): |
265 |
stream = file(join(self.apphome, 'bootstrap_cubes'), 'w') |
|
266 |
stream.write('# this is a generated file only used for bootstraping\n') |
|
267 |
stream.write('# you should not have to edit this\n') |
|
268 |
stream.write('%s\n' % ','.join(cubes)) |
|
269 |
stream.close() |
|
1666 | 270 |
|
0 | 271 |
def sources_file(self): |
272 |
return join(self.apphome, 'sources') |
|
1666 | 273 |
|
0 | 274 |
# this method has to be cached since when the server is running using a |
275 |
# restricted user, this user usually don't have access to the sources |
|
276 |
# configuration file (#16102) |
|
277 |
@cached |
|
2105
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
278 |
def read_sources_file(self): |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
279 |
return read_config(self.sources_file()) |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
280 |
|
0 | 281 |
def sources(self): |
282 |
"""return a dictionnaries containing sources definitions indexed by |
|
283 |
sources'uri |
|
284 |
""" |
|
2105
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
285 |
allsources = self.read_sources_file() |
0 | 286 |
if self._enabled_sources is None: |
287 |
return allsources |
|
288 |
return dict((uri, config) for uri, config in allsources.items() |
|
289 |
if uri in self._enabled_sources or uri == 'admin') |
|
1666 | 290 |
|
2105
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
291 |
def write_sources_file(self, sourcescfg): |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
292 |
sourcesfile = self.sources_file() |
2107
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
293 |
if exists(sourcesfile): |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
294 |
import shutil |
6c4a4c514ac2
add source to sources configuration when adding a cube defining a source
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2105
diff
changeset
|
295 |
shutil.copy(sourcesfile, sourcesfile + '.bak') |
3904
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
296 |
generate_sources_file(self.appid, sourcesfile, sourcescfg, |
dc7d315165fc
default_instance id should also be available when silently rebuilding soures file
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
3900
diff
changeset
|
297 |
['admin', 'system']) |
2105
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
298 |
restrict_perms_to_user(sourcesfile) |
92ea410806fe
refactor sources configuration, add source to sources when using a cube defining
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
1977
diff
changeset
|
299 |
|
0 | 300 |
def pyro_enabled(self): |
301 |
"""pyro is always enabled in standalone repository configuration""" |
|
302 |
return True |
|
1666 | 303 |
|
304 |
def load_schema(self, expand_cubes=False, **kwargs): |
|
0 | 305 |
from cubicweb.schema import CubicWebSchemaLoader |
306 |
if expand_cubes: |
|
307 |
# in case some new dependencies have been introduced, we have to |
|
308 |
# reinitialize cubes so the full filesystem schema is read |
|
309 |
origcubes = self.cubes() |
|
310 |
self._cubes = None |
|
311 |
self.init_cubes(self.expand_cubes(origcubes)) |
|
1666 | 312 |
schema = CubicWebSchemaLoader().load(self, **kwargs) |
0 | 313 |
if expand_cubes: |
314 |
# restaure original value |
|
315 |
self._cubes = origcubes |
|
316 |
return schema |
|
1666 | 317 |
|
0 | 318 |
def load_bootstrap_schema(self): |
319 |
from cubicweb.schema import BootstrapSchemaLoader |
|
320 |
schema = BootstrapSchemaLoader().load(self) |
|
321 |
schema.name = 'bootstrap' |
|
322 |
return schema |
|
1666 | 323 |
|
0 | 324 |
def set_sources_mode(self, sources): |
325 |
if 'migration' in sources: |
|
326 |
from cubicweb.server.sources import source_adapter |
|
327 |
assert len(sources) == 1 |
|
328 |
enabled_sources = [] |
|
329 |
for uri, config in self.sources().iteritems(): |
|
330 |
if uri == 'admin': |
|
331 |
continue |
|
332 |
if source_adapter(config).connect_for_migration: |
|
333 |
enabled_sources.append(uri) |
|
334 |
else: |
|
335 |
print 'not connecting to source', uri, 'during migration' |
|
336 |
elif 'all' in sources: |
|
337 |
assert len(sources) == 1 |
|
1133 | 338 |
enabled_sources = None |
0 | 339 |
else: |
340 |
known_sources = self.sources() |
|
341 |
for uri in sources: |
|
342 |
assert uri in known_sources, uri |
|
343 |
enabled_sources = sources |
|
344 |
self._enabled_sources = enabled_sources |
|
345 |
clear_cache(self, 'sources') |
|
1666 | 346 |
|
0 | 347 |
def migration_handler(self, schema=None, interactive=True, |
2493
9806571ea790
major refactoring of database dump/restore:
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2489
diff
changeset
|
348 |
cnx=None, repo=None, connect=True, verbosity=None): |
0 | 349 |
"""return a migration handler instance""" |
350 |
from cubicweb.server.migractions import ServerMigrationHelper |
|
2493
9806571ea790
major refactoring of database dump/restore:
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2489
diff
changeset
|
351 |
if verbosity is None: |
9806571ea790
major refactoring of database dump/restore:
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2489
diff
changeset
|
352 |
verbosity = getattr(self, 'verbosity', 0) |
0 | 353 |
return ServerMigrationHelper(self, schema, interactive=interactive, |
354 |
cnx=cnx, repo=repo, connect=connect, |
|
2493
9806571ea790
major refactoring of database dump/restore:
Sylvain Thénault <sylvain.thenault@logilab.fr>
parents:
2489
diff
changeset
|
355 |
verbosity=verbosity) |