##// END OF EJS Templates
use normpath when comparing paths used to determine if directory is a symlink, it's a part of pull-request #77
marcink -
r2918:ce8572f4 beta
parent child Browse files
Show More
@@ -1,670 +1,670 b''
1 1 # -*- coding: utf-8 -*-
2 2 """
3 3 rhodecode.lib.db_manage
4 4 ~~~~~~~~~~~~~~~~~~~~~~~
5 5
6 6 Database creation, and setup module for RhodeCode. Used for creation
7 7 of database as well as for migration operations
8 8
9 9 :created_on: Apr 10, 2010
10 10 :author: marcink
11 11 :copyright: (C) 2010-2012 Marcin Kuzminski <marcin@python-works.com>
12 12 :license: GPLv3, see COPYING for more details.
13 13 """
14 14 # This program is free software: you can redistribute it and/or modify
15 15 # it under the terms of the GNU General Public License as published by
16 16 # the Free Software Foundation, either version 3 of the License, or
17 17 # (at your option) any later version.
18 18 #
19 19 # This program is distributed in the hope that it will be useful,
20 20 # but WITHOUT ANY WARRANTY; without even the implied warranty of
21 21 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 22 # GNU General Public License for more details.
23 23 #
24 24 # You should have received a copy of the GNU General Public License
25 25 # along with this program. If not, see <http://www.gnu.org/licenses/>.
26 26
27 27 import os
28 28 import sys
29 29 import uuid
30 30 import logging
31 31 from os.path import dirname as dn, join as jn
32 32
33 33 from rhodecode import __dbversion__, __py_version__
34 34
35 35 from rhodecode.model.user import UserModel
36 36 from rhodecode.lib.utils import ask_ok
37 37 from rhodecode.model import init_model
38 38 from rhodecode.model.db import User, Permission, RhodeCodeUi, \
39 39 RhodeCodeSetting, UserToPerm, DbMigrateVersion, RepoGroup, \
40 40 UserRepoGroupToPerm
41 41
42 42 from sqlalchemy.engine import create_engine
43 43 from rhodecode.model.repos_group import ReposGroupModel
44 44 #from rhodecode.model import meta
45 45 from rhodecode.model.meta import Session, Base
46 46
47 47
48 48 log = logging.getLogger(__name__)
49 49
50 50
51 51 def notify(msg):
52 52 """
53 53 Notification for migrations messages
54 54 """
55 55 ml = len(msg) + (4 * 2)
56 56 print >> sys.stdout, ('*** %s ***\n%s' % (msg, '*' * ml)).upper()
57 57
58 58
59 59 class DbManage(object):
60 60 def __init__(self, log_sql, dbconf, root, tests=False):
61 61 self.dbname = dbconf.split('/')[-1]
62 62 self.tests = tests
63 63 self.root = root
64 64 self.dburi = dbconf
65 65 self.log_sql = log_sql
66 66 self.db_exists = False
67 67 self.init_db()
68 68
69 69 def init_db(self):
70 70 engine = create_engine(self.dburi, echo=self.log_sql)
71 71 init_model(engine)
72 72 self.sa = Session()
73 73
74 74 def create_tables(self, override=False, defaults={}):
75 75 """
76 76 Create a auth database
77 77 """
78 78 quiet = defaults.get('quiet')
79 79 log.info("Any existing database is going to be destroyed")
80 80 if self.tests or quiet:
81 81 destroy = True
82 82 else:
83 83 destroy = ask_ok('Are you sure to destroy old database ? [y/n]')
84 84 if not destroy:
85 85 sys.exit()
86 86 if destroy:
87 87 Base.metadata.drop_all()
88 88
89 89 checkfirst = not override
90 90 Base.metadata.create_all(checkfirst=checkfirst)
91 91 log.info('Created tables for %s' % self.dbname)
92 92
93 93 def set_db_version(self):
94 94 ver = DbMigrateVersion()
95 95 ver.version = __dbversion__
96 96 ver.repository_id = 'rhodecode_db_migrations'
97 97 ver.repository_path = 'versions'
98 98 self.sa.add(ver)
99 99 log.info('db version set to: %s' % __dbversion__)
100 100
101 101 def upgrade(self):
102 102 """
103 103 Upgrades given database schema to given revision following
104 104 all needed steps, to perform the upgrade
105 105
106 106 """
107 107
108 108 from rhodecode.lib.dbmigrate.migrate.versioning import api
109 109 from rhodecode.lib.dbmigrate.migrate.exceptions import \
110 110 DatabaseNotControlledError
111 111
112 112 if 'sqlite' in self.dburi:
113 113 print (
114 114 '********************** WARNING **********************\n'
115 115 'Make sure your version of sqlite is at least 3.7.X. \n'
116 116 'Earlier versions are known to fail on some migrations\n'
117 117 '*****************************************************\n'
118 118 )
119 119 upgrade = ask_ok('You are about to perform database upgrade, make '
120 120 'sure You backed up your database before. '
121 121 'Continue ? [y/n]')
122 122 if not upgrade:
123 123 sys.exit('Nothing done')
124 124
125 125 repository_path = jn(dn(dn(dn(os.path.realpath(__file__)))),
126 126 'rhodecode/lib/dbmigrate')
127 127 db_uri = self.dburi
128 128
129 129 try:
130 130 curr_version = api.db_version(db_uri, repository_path)
131 131 msg = ('Found current database under version'
132 132 ' control with version %s' % curr_version)
133 133
134 134 except (RuntimeError, DatabaseNotControlledError):
135 135 curr_version = 1
136 136 msg = ('Current database is not under version control. Setting'
137 137 ' as version %s' % curr_version)
138 138 api.version_control(db_uri, repository_path, curr_version)
139 139
140 140 notify(msg)
141 141
142 142 if curr_version == __dbversion__:
143 143 sys.exit('This database is already at the newest version')
144 144
145 145 #======================================================================
146 146 # UPGRADE STEPS
147 147 #======================================================================
148 148
149 149 class UpgradeSteps(object):
150 150 """
151 151 Those steps follow schema versions so for example schema
152 152 for example schema with seq 002 == step_2 and so on.
153 153 """
154 154
155 155 def __init__(self, klass):
156 156 self.klass = klass
157 157
158 158 def step_0(self):
159 159 # step 0 is the schema upgrade, and than follow proper upgrades
160 160 notify('attempting to do database upgrade to version %s' \
161 161 % __dbversion__)
162 162 api.upgrade(db_uri, repository_path, __dbversion__)
163 163 notify('Schema upgrade completed')
164 164
165 165 def step_1(self):
166 166 pass
167 167
168 168 def step_2(self):
169 169 notify('Patching repo paths for newer version of RhodeCode')
170 170 self.klass.fix_repo_paths()
171 171
172 172 notify('Patching default user of RhodeCode')
173 173 self.klass.fix_default_user()
174 174
175 175 log.info('Changing ui settings')
176 176 self.klass.create_ui_settings()
177 177
178 178 def step_3(self):
179 179 notify('Adding additional settings into RhodeCode db')
180 180 self.klass.fix_settings()
181 181 notify('Adding ldap defaults')
182 182 self.klass.create_ldap_options(skip_existing=True)
183 183
184 184 def step_4(self):
185 185 notify('create permissions and fix groups')
186 186 self.klass.create_permissions()
187 187 self.klass.fixup_groups()
188 188
189 189 def step_5(self):
190 190 pass
191 191
192 192 def step_6(self):
193 193
194 194 notify('re-checking permissions')
195 195 self.klass.create_permissions()
196 196
197 197 notify('installing new UI options')
198 198 sett4 = RhodeCodeSetting('show_public_icon', True)
199 199 Session().add(sett4)
200 200 sett5 = RhodeCodeSetting('show_private_icon', True)
201 201 Session().add(sett5)
202 202 sett6 = RhodeCodeSetting('stylify_metatags', False)
203 203 Session().add(sett6)
204 204
205 205 notify('fixing old PULL hook')
206 206 _pull = RhodeCodeUi.get_by_key('preoutgoing.pull_logger')
207 207 if _pull:
208 208 _pull.ui_key = RhodeCodeUi.HOOK_PULL
209 209 Session().add(_pull)
210 210
211 211 notify('fixing old PUSH hook')
212 212 _push = RhodeCodeUi.get_by_key('pretxnchangegroup.push_logger')
213 213 if _push:
214 214 _push.ui_key = RhodeCodeUi.HOOK_PUSH
215 215 Session().add(_push)
216 216
217 217 notify('installing new pre-push hook')
218 218 hooks4 = RhodeCodeUi()
219 219 hooks4.ui_section = 'hooks'
220 220 hooks4.ui_key = RhodeCodeUi.HOOK_PRE_PUSH
221 221 hooks4.ui_value = 'python:rhodecode.lib.hooks.pre_push'
222 222 Session().add(hooks4)
223 223
224 224 notify('installing new pre-pull hook')
225 225 hooks6 = RhodeCodeUi()
226 226 hooks6.ui_section = 'hooks'
227 227 hooks6.ui_key = RhodeCodeUi.HOOK_PRE_PULL
228 228 hooks6.ui_value = 'python:rhodecode.lib.hooks.pre_pull'
229 229 Session().add(hooks6)
230 230
231 231 notify('installing hgsubversion option')
232 232 # enable hgsubversion disabled by default
233 233 hgsubversion = RhodeCodeUi()
234 234 hgsubversion.ui_section = 'extensions'
235 235 hgsubversion.ui_key = 'hgsubversion'
236 236 hgsubversion.ui_value = ''
237 237 hgsubversion.ui_active = False
238 238 Session().add(hgsubversion)
239 239
240 240 notify('installing hg git option')
241 241 # enable hggit disabled by default
242 242 hggit = RhodeCodeUi()
243 243 hggit.ui_section = 'extensions'
244 244 hggit.ui_key = 'hggit'
245 245 hggit.ui_value = ''
246 246 hggit.ui_active = False
247 247 Session().add(hggit)
248 248
249 249 notify('re-check default permissions')
250 250 default_user = User.get_by_username(User.DEFAULT_USER)
251 251 perm = Permission.get_by_key('hg.fork.repository')
252 252 reg_perm = UserToPerm()
253 253 reg_perm.user = default_user
254 254 reg_perm.permission = perm
255 255 Session().add(reg_perm)
256 256
257 257 def step_7(self):
258 258 perm_fixes = self.klass.reset_permissions(User.DEFAULT_USER)
259 259 Session().commit()
260 260 if perm_fixes:
261 261 notify('There was an inconsistent state of permissions '
262 262 'detected for default user. Permissions are now '
263 263 'reset to the default value for default user. '
264 264 'Please validate and check default permissions '
265 265 'in admin panel')
266 266
267 267 upgrade_steps = [0] + range(curr_version + 1, __dbversion__ + 1)
268 268
269 269 # CALL THE PROPER ORDER OF STEPS TO PERFORM FULL UPGRADE
270 270 _step = None
271 271 for step in upgrade_steps:
272 272 notify('performing upgrade step %s' % step)
273 273 getattr(UpgradeSteps(self), 'step_%s' % step)()
274 274 self.sa.commit()
275 275 _step = step
276 276
277 277 notify('upgrade to version %s successful' % _step)
278 278
279 279 def fix_repo_paths(self):
280 280 """
281 281 Fixes a old rhodecode version path into new one without a '*'
282 282 """
283 283
284 284 paths = self.sa.query(RhodeCodeUi)\
285 285 .filter(RhodeCodeUi.ui_key == '/')\
286 286 .scalar()
287 287
288 288 paths.ui_value = paths.ui_value.replace('*', '')
289 289
290 290 try:
291 291 self.sa.add(paths)
292 292 self.sa.commit()
293 293 except:
294 294 self.sa.rollback()
295 295 raise
296 296
297 297 def fix_default_user(self):
298 298 """
299 299 Fixes a old default user with some 'nicer' default values,
300 300 used mostly for anonymous access
301 301 """
302 302 def_user = self.sa.query(User)\
303 303 .filter(User.username == 'default')\
304 304 .one()
305 305
306 306 def_user.name = 'Anonymous'
307 307 def_user.lastname = 'User'
308 308 def_user.email = 'anonymous@rhodecode.org'
309 309
310 310 try:
311 311 self.sa.add(def_user)
312 312 self.sa.commit()
313 313 except:
314 314 self.sa.rollback()
315 315 raise
316 316
317 317 def fix_settings(self):
318 318 """
319 319 Fixes rhodecode settings adds ga_code key for google analytics
320 320 """
321 321
322 322 hgsettings3 = RhodeCodeSetting('ga_code', '')
323 323
324 324 try:
325 325 self.sa.add(hgsettings3)
326 326 self.sa.commit()
327 327 except:
328 328 self.sa.rollback()
329 329 raise
330 330
331 331 def admin_prompt(self, second=False, defaults={}):
332 332 if not self.tests:
333 333 import getpass
334 334
335 335 # defaults
336 336 username = defaults.get('username')
337 337 password = defaults.get('password')
338 338 email = defaults.get('email')
339 339
340 340 def get_password():
341 341 password = getpass.getpass('Specify admin password '
342 342 '(min 6 chars):')
343 343 confirm = getpass.getpass('Confirm password:')
344 344
345 345 if password != confirm:
346 346 log.error('passwords mismatch')
347 347 return False
348 348 if len(password) < 6:
349 349 log.error('password is to short use at least 6 characters')
350 350 return False
351 351
352 352 return password
353 353 if username is None:
354 354 username = raw_input('Specify admin username:')
355 355 if password is None:
356 356 password = get_password()
357 357 if not password:
358 358 #second try
359 359 password = get_password()
360 360 if not password:
361 361 sys.exit()
362 362 if email is None:
363 363 email = raw_input('Specify admin email:')
364 364 self.create_user(username, password, email, True)
365 365 else:
366 366 log.info('creating admin and regular test users')
367 367 from rhodecode.tests import TEST_USER_ADMIN_LOGIN, \
368 368 TEST_USER_ADMIN_PASS, TEST_USER_ADMIN_EMAIL, \
369 369 TEST_USER_REGULAR_LOGIN, TEST_USER_REGULAR_PASS, \
370 370 TEST_USER_REGULAR_EMAIL, TEST_USER_REGULAR2_LOGIN, \
371 371 TEST_USER_REGULAR2_PASS, TEST_USER_REGULAR2_EMAIL
372 372
373 373 self.create_user(TEST_USER_ADMIN_LOGIN, TEST_USER_ADMIN_PASS,
374 374 TEST_USER_ADMIN_EMAIL, True)
375 375
376 376 self.create_user(TEST_USER_REGULAR_LOGIN, TEST_USER_REGULAR_PASS,
377 377 TEST_USER_REGULAR_EMAIL, False)
378 378
379 379 self.create_user(TEST_USER_REGULAR2_LOGIN, TEST_USER_REGULAR2_PASS,
380 380 TEST_USER_REGULAR2_EMAIL, False)
381 381
382 382 def create_ui_settings(self):
383 383 """
384 384 Creates ui settings, fills out hooks
385 385 and disables dotencode
386 386 """
387 387
388 388 #HOOKS
389 389 hooks1_key = RhodeCodeUi.HOOK_UPDATE
390 390 hooks1_ = self.sa.query(RhodeCodeUi)\
391 391 .filter(RhodeCodeUi.ui_key == hooks1_key).scalar()
392 392
393 393 hooks1 = RhodeCodeUi() if hooks1_ is None else hooks1_
394 394 hooks1.ui_section = 'hooks'
395 395 hooks1.ui_key = hooks1_key
396 396 hooks1.ui_value = 'hg update >&2'
397 397 hooks1.ui_active = False
398 398 self.sa.add(hooks1)
399 399
400 400 hooks2_key = RhodeCodeUi.HOOK_REPO_SIZE
401 401 hooks2_ = self.sa.query(RhodeCodeUi)\
402 402 .filter(RhodeCodeUi.ui_key == hooks2_key).scalar()
403 403 hooks2 = RhodeCodeUi() if hooks2_ is None else hooks2_
404 404 hooks2.ui_section = 'hooks'
405 405 hooks2.ui_key = hooks2_key
406 406 hooks2.ui_value = 'python:rhodecode.lib.hooks.repo_size'
407 407 self.sa.add(hooks2)
408 408
409 409 hooks3 = RhodeCodeUi()
410 410 hooks3.ui_section = 'hooks'
411 411 hooks3.ui_key = RhodeCodeUi.HOOK_PUSH
412 412 hooks3.ui_value = 'python:rhodecode.lib.hooks.log_push_action'
413 413 self.sa.add(hooks3)
414 414
415 415 hooks4 = RhodeCodeUi()
416 416 hooks4.ui_section = 'hooks'
417 417 hooks4.ui_key = RhodeCodeUi.HOOK_PRE_PUSH
418 418 hooks4.ui_value = 'python:rhodecode.lib.hooks.pre_push'
419 419 self.sa.add(hooks4)
420 420
421 421 hooks5 = RhodeCodeUi()
422 422 hooks5.ui_section = 'hooks'
423 423 hooks5.ui_key = RhodeCodeUi.HOOK_PULL
424 424 hooks5.ui_value = 'python:rhodecode.lib.hooks.log_pull_action'
425 425 self.sa.add(hooks5)
426 426
427 427 hooks6 = RhodeCodeUi()
428 428 hooks6.ui_section = 'hooks'
429 429 hooks6.ui_key = RhodeCodeUi.HOOK_PRE_PULL
430 430 hooks6.ui_value = 'python:rhodecode.lib.hooks.pre_pull'
431 431 self.sa.add(hooks6)
432 432
433 433 # enable largefiles
434 434 largefiles = RhodeCodeUi()
435 435 largefiles.ui_section = 'extensions'
436 436 largefiles.ui_key = 'largefiles'
437 437 largefiles.ui_value = ''
438 438 self.sa.add(largefiles)
439 439
440 440 # enable hgsubversion disabled by default
441 441 hgsubversion = RhodeCodeUi()
442 442 hgsubversion.ui_section = 'extensions'
443 443 hgsubversion.ui_key = 'hgsubversion'
444 444 hgsubversion.ui_value = ''
445 445 hgsubversion.ui_active = False
446 446 self.sa.add(hgsubversion)
447 447
448 448 # enable hggit disabled by default
449 449 hggit = RhodeCodeUi()
450 450 hggit.ui_section = 'extensions'
451 451 hggit.ui_key = 'hggit'
452 452 hggit.ui_value = ''
453 453 hggit.ui_active = False
454 454 self.sa.add(hggit)
455 455
456 456 def create_ldap_options(self, skip_existing=False):
457 457 """Creates ldap settings"""
458 458
459 459 for k, v in [('ldap_active', 'false'), ('ldap_host', ''),
460 460 ('ldap_port', '389'), ('ldap_tls_kind', 'PLAIN'),
461 461 ('ldap_tls_reqcert', ''), ('ldap_dn_user', ''),
462 462 ('ldap_dn_pass', ''), ('ldap_base_dn', ''),
463 463 ('ldap_filter', ''), ('ldap_search_scope', ''),
464 464 ('ldap_attr_login', ''), ('ldap_attr_firstname', ''),
465 465 ('ldap_attr_lastname', ''), ('ldap_attr_email', '')]:
466 466
467 467 if skip_existing and RhodeCodeSetting.get_by_name(k) != None:
468 468 log.debug('Skipping option %s' % k)
469 469 continue
470 470 setting = RhodeCodeSetting(k, v)
471 471 self.sa.add(setting)
472 472
473 473 def fixup_groups(self):
474 474 def_usr = User.get_by_username('default')
475 475 for g in RepoGroup.query().all():
476 476 g.group_name = g.get_new_name(g.name)
477 477 self.sa.add(g)
478 478 # get default perm
479 479 default = UserRepoGroupToPerm.query()\
480 480 .filter(UserRepoGroupToPerm.group == g)\
481 481 .filter(UserRepoGroupToPerm.user == def_usr)\
482 482 .scalar()
483 483
484 484 if default is None:
485 485 log.debug('missing default permission for group %s adding' % g)
486 486 ReposGroupModel()._create_default_perms(g)
487 487
488 488 def reset_permissions(self, username):
489 489 """
490 490 Resets permissions to default state, usefull when old systems had
491 491 bad permissions, we must clean them up
492 492
493 493 :param username:
494 494 :type username:
495 495 """
496 496 default_user = User.get_by_username(username)
497 497 if not default_user:
498 498 return
499 499
500 500 u2p = UserToPerm.query()\
501 501 .filter(UserToPerm.user == default_user).all()
502 502 fixed = False
503 503 if len(u2p) != len(User.DEFAULT_PERMISSIONS):
504 504 for p in u2p:
505 505 Session().delete(p)
506 506 fixed = True
507 507 self.populate_default_permissions()
508 508 return fixed
509 509
510 510 def config_prompt(self, test_repo_path='', retries=3, defaults={}):
511 511 _path = defaults.get('repos_location')
512 512 if retries == 3:
513 513 log.info('Setting up repositories config')
514 514
515 515 if _path is not None:
516 516 path = _path
517 517 elif not self.tests and not test_repo_path:
518 518 path = raw_input(
519 519 'Enter a valid absolute path to store repositories. '
520 520 'All repositories in that path will be added automatically:'
521 521 )
522 522 else:
523 523 path = test_repo_path
524 524 path_ok = True
525 525
526 526 # check proper dir
527 527 if not os.path.isdir(path):
528 528 path_ok = False
529 529 log.error('Given path %s is not a valid directory' % path)
530 530
531 531 elif not os.path.isabs(path):
532 532 path_ok = False
533 533 log.error('Given path %s is not an absolute path' % path)
534 534
535 535 # check write access
536 536 elif not os.access(path, os.W_OK) and path_ok:
537 537 path_ok = False
538 538 log.error('No write permission to given path %s' % path)
539 539
540 540 if retries == 0:
541 541 sys.exit('max retries reached')
542 542 if path_ok is False:
543 543 retries -= 1
544 544 return self.config_prompt(test_repo_path, retries)
545 545
546 real_path = os.path.realpath(path)
546 real_path = os.path.normpath(os.path.realpath(path))
547 547
548 if real_path != path:
548 if real_path != os.path.normpath(path):
549 549 if not ask_ok(('Path looks like a symlink, Rhodecode will store '
550 550 'given path as %s ? [y/n]') % (real_path)):
551 551 log.error('Canceled by user')
552 552 sys.exit(-1)
553 553
554 554 return real_path
555 555
556 556 def create_settings(self, path):
557 557
558 558 self.create_ui_settings()
559 559
560 560 #HG UI OPTIONS
561 561 web1 = RhodeCodeUi()
562 562 web1.ui_section = 'web'
563 563 web1.ui_key = 'push_ssl'
564 564 web1.ui_value = 'false'
565 565
566 566 web2 = RhodeCodeUi()
567 567 web2.ui_section = 'web'
568 568 web2.ui_key = 'allow_archive'
569 569 web2.ui_value = 'gz zip bz2'
570 570
571 571 web3 = RhodeCodeUi()
572 572 web3.ui_section = 'web'
573 573 web3.ui_key = 'allow_push'
574 574 web3.ui_value = '*'
575 575
576 576 web4 = RhodeCodeUi()
577 577 web4.ui_section = 'web'
578 578 web4.ui_key = 'baseurl'
579 579 web4.ui_value = '/'
580 580
581 581 paths = RhodeCodeUi()
582 582 paths.ui_section = 'paths'
583 583 paths.ui_key = '/'
584 584 paths.ui_value = path
585 585
586 586 phases = RhodeCodeUi()
587 587 phases.ui_section = 'phases'
588 588 phases.ui_key = 'publish'
589 589 phases.ui_value = False
590 590
591 591 sett1 = RhodeCodeSetting('realm', 'RhodeCode authentication')
592 592 sett2 = RhodeCodeSetting('title', 'RhodeCode')
593 593 sett3 = RhodeCodeSetting('ga_code', '')
594 594
595 595 sett4 = RhodeCodeSetting('show_public_icon', True)
596 596 sett5 = RhodeCodeSetting('show_private_icon', True)
597 597 sett6 = RhodeCodeSetting('stylify_metatags', False)
598 598
599 599 self.sa.add(web1)
600 600 self.sa.add(web2)
601 601 self.sa.add(web3)
602 602 self.sa.add(web4)
603 603 self.sa.add(paths)
604 604 self.sa.add(sett1)
605 605 self.sa.add(sett2)
606 606 self.sa.add(sett3)
607 607 self.sa.add(sett4)
608 608 self.sa.add(sett5)
609 609 self.sa.add(sett6)
610 610
611 611 self.create_ldap_options()
612 612
613 613 log.info('created ui config')
614 614
615 615 def create_user(self, username, password, email='', admin=False):
616 616 log.info('creating user %s' % username)
617 617 UserModel().create_or_update(username, password, email,
618 618 firstname='RhodeCode', lastname='Admin',
619 619 active=True, admin=admin)
620 620
621 621 def create_default_user(self):
622 622 log.info('creating default user')
623 623 # create default user for handling default permissions.
624 624 UserModel().create_or_update(username='default',
625 625 password=str(uuid.uuid1())[:8],
626 626 email='anonymous@rhodecode.org',
627 627 firstname='Anonymous', lastname='User')
628 628
629 629 def create_permissions(self):
630 630 # module.(access|create|change|delete)_[name]
631 631 # module.(none|read|write|admin)
632 632
633 633 for p in Permission.PERMS:
634 634 if not Permission.get_by_key(p[0]):
635 635 new_perm = Permission()
636 636 new_perm.permission_name = p[0]
637 637 new_perm.permission_longname = p[0]
638 638 self.sa.add(new_perm)
639 639
640 640 def populate_default_permissions(self):
641 641 log.info('creating default user permissions')
642 642
643 643 default_user = User.get_by_username('default')
644 644
645 645 for def_perm in User.DEFAULT_PERMISSIONS:
646 646
647 647 perm = self.sa.query(Permission)\
648 648 .filter(Permission.permission_name == def_perm)\
649 649 .scalar()
650 650 if not perm:
651 651 raise Exception(
652 652 'CRITICAL: permission %s not found inside database !!'
653 653 % def_perm
654 654 )
655 655 if not UserToPerm.query()\
656 656 .filter(UserToPerm.permission == perm)\
657 657 .filter(UserToPerm.user == default_user).scalar():
658 658 reg_perm = UserToPerm()
659 659 reg_perm.user = default_user
660 660 reg_perm.permission = perm
661 661 self.sa.add(reg_perm)
662 662
663 663 def finish(self):
664 664 """
665 665 Function executed at the end of setup
666 666 """
667 667 if not __py_version__ >= (2, 6):
668 668 notify('Python2.5 detected, please switch '
669 669 'egg:waitress#main -> egg:Paste#http '
670 670 'in your .ini file')
General Comments 0
You need to be logged in to leave comments. Login now