db_manage.py
587 lines
| 20.4 KiB
| text/x-python
|
PythonLexer
r835 | # -*- coding: utf-8 -*- | |||
r1206 | # This program is free software: you can redistribute it and/or modify | |||
# it under the terms of the GNU General Public License as published by | ||||
# the Free Software Foundation, either version 3 of the License, or | ||||
# (at your option) any later version. | ||||
r1203 | # | |||
r547 | # This program is distributed in the hope that it will be useful, | |||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
r1203 | # | |||
r547 | # You should have received a copy of the GNU General Public License | |||
r1206 | # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
Bradley M. Kuhn
|
r4116 | """ | ||
rhodecode.lib.db_manage | ||||
~~~~~~~~~~~~~~~~~~~~~~~ | ||||
Database creation, and setup module for RhodeCode. Used for creation | ||||
of database as well as for migration operations | ||||
:created_on: Apr 10, 2010 | ||||
:author: marcink | ||||
:copyright: (c) 2013 RhodeCode GmbH. | ||||
:license: GPLv3, see LICENSE for more details. | ||||
""" | ||||
r547 | ||||
import os | ||||
import sys | ||||
r3907 | import time | |||
r547 | import uuid | |||
r835 | import logging | |||
from os.path import dirname as dn, join as jn | ||||
r3972 | import datetime | |||
r835 | ||||
r2827 | from rhodecode import __dbversion__, __py_version__ | |||
r547 | ||||
r1634 | from rhodecode.model.user import UserModel | |||
r547 | from rhodecode.lib.utils import ask_ok | |||
from rhodecode.model import init_model | ||||
r1266 | from rhodecode.model.db import User, Permission, RhodeCodeUi, \ | |||
r2765 | RhodeCodeSetting, UserToPerm, DbMigrateVersion, RepoGroup, \ | |||
Bradley M. Kuhn
|
r4116 | UserRepoGroupToPerm, CacheInvalidation, UserGroup, Repository | ||
r835 | ||||
r547 | from sqlalchemy.engine import create_engine | |||
Bradley M. Kuhn
|
r4116 | from rhodecode.model.repo_group import RepoGroupModel | ||
r2765 | #from rhodecode.model import meta | |||
from rhodecode.model.meta import Session, Base | ||||
r3309 | from rhodecode.model.repo import RepoModel | |||
r3733 | from rhodecode.model.permission import PermissionModel | |||
Bradley M. Kuhn
|
r4116 | from rhodecode.model.user_group import UserGroupModel | ||
r2765 | ||||
r835 | ||||
r547 | log = logging.getLogger(__name__) | |||
r1266 | ||||
r2779 | def notify(msg): | |||
""" | ||||
Notification for migrations messages | ||||
""" | ||||
ml = len(msg) + (4 * 2) | ||||
r3907 | print('\n%s\n*** %s ***\n%s' % ('*' * ml, msg, '*' * ml)).upper() | |||
r547 | class DbManage(object): | |||
Bradley M. Kuhn
|
r4116 | def __init__(self, log_sql, dbconf, root, tests=False, SESSION=None, cli_args={}): | ||
r781 | self.dbname = dbconf.split('/')[-1] | |||
r547 | self.tests = tests | |||
r552 | self.root = root | |||
r781 | self.dburi = dbconf | |||
r907 | self.log_sql = log_sql | |||
self.db_exists = False | ||||
r2919 | self.cli_args = cli_args | |||
Bradley M. Kuhn
|
r4116 | self.init_db(SESSION=SESSION) | ||
r2919 | ||||
Mads Kiilerich
|
r3671 | force_ask = self.cli_args.get('force_ask') | ||
if force_ask is not None: | ||||
global ask_ok | ||||
ask_ok = lambda *args, **kwargs: force_ask | ||||
r907 | ||||
Bradley M. Kuhn
|
r4116 | def init_db(self, SESSION=None): | ||
if SESSION: | ||||
self.sa = SESSION | ||||
else: | ||||
#init new sessions | ||||
engine = create_engine(self.dburi, echo=self.log_sql) | ||||
init_model(engine) | ||||
self.sa = Session() | ||||
r629 | ||||
r2919 | def create_tables(self, override=False): | |||
r1783 | """ | |||
Create a auth database | ||||
r547 | """ | |||
r2919 | ||||
r1138 | log.info("Any existing database is going to be destroyed") | |||
r2919 | if self.tests: | |||
r1138 | destroy = True | |||
else: | ||||
destroy = ask_ok('Are you sure to destroy old database ? [y/n]') | ||||
if not destroy: | ||||
Bradley M. Kuhn
|
r4116 | print 'Nothing done.' | ||
sys.exit(0) | ||||
r1138 | if destroy: | |||
r2765 | Base.metadata.drop_all() | |||
r964 | ||||
r547 | checkfirst = not override | |||
r2765 | Base.metadata.create_all(checkfirst=checkfirst) | |||
r1976 | log.info('Created tables for %s' % self.dbname) | |||
r629 | ||||
r834 | def set_db_version(self): | |||
r1734 | ver = DbMigrateVersion() | |||
ver.version = __dbversion__ | ||||
ver.repository_id = 'rhodecode_db_migrations' | ||||
ver.repository_path = 'versions' | ||||
self.sa.add(ver) | ||||
r1976 | log.info('db version set to: %s' % __dbversion__) | |||
r834 | ||||
r839 | def upgrade(self): | |||
r1783 | """ | |||
Upgrades given database schema to given revision following | ||||
r900 | all needed steps, to perform the upgrade | |||
r1203 | ||||
r839 | """ | |||
r841 | ||||
from rhodecode.lib.dbmigrate.migrate.versioning import api | ||||
from rhodecode.lib.dbmigrate.migrate.exceptions import \ | ||||
DatabaseNotControlledError | ||||
r1835 | if 'sqlite' in self.dburi: | |||
print ( | ||||
'********************** WARNING **********************\n' | ||||
'Make sure your version of sqlite is at least 3.7.X. \n' | ||||
'Earlier versions are known to fail on some migrations\n' | ||||
Bradley M. Kuhn
|
r4116 | '*****************************************************\n') | ||
r839 | upgrade = ask_ok('You are about to perform database upgrade, make ' | |||
'sure You backed up your database before. ' | ||||
'Continue ? [y/n]') | ||||
if not upgrade: | ||||
Bradley M. Kuhn
|
r4116 | print 'No upgrade performed' | ||
sys.exit(0) | ||||
r839 | ||||
r843 | repository_path = jn(dn(dn(dn(os.path.realpath(__file__)))), | |||
'rhodecode/lib/dbmigrate') | ||||
r839 | db_uri = self.dburi | |||
try: | ||||
curr_version = api.db_version(db_uri, repository_path) | ||||
Bradley M. Kuhn
|
r4116 | msg = ('Found current database under version ' | ||
'control with version %s' % curr_version) | ||||
r839 | ||||
r1299 | except (RuntimeError, DatabaseNotControlledError): | |||
r839 | curr_version = 1 | |||
Bradley M. Kuhn
|
r4116 | msg = ('Current database is not under version control. Setting ' | ||
'as version %s' % curr_version) | ||||
r839 | api.version_control(db_uri, repository_path, curr_version) | |||
r2779 | notify(msg) | |||
r839 | if curr_version == __dbversion__: | |||
Bradley M. Kuhn
|
r4116 | print 'This database is already at the newest version' | ||
sys.exit(0) | ||||
r839 | ||||
Mads Kiilerich
|
r3757 | # clear cache keys | ||
log.info("Clearing cache keys now...") | ||||
CacheInvalidation.clear_cache() | ||||
r3906 | upgrade_steps = range(curr_version + 1, __dbversion__ + 1) | |||
notify('attempting to do database upgrade from ' | ||||
'version %s to version %s' % (curr_version, __dbversion__)) | ||||
r839 | ||||
r1783 | # CALL THE PROPER ORDER OF STEPS TO PERFORM FULL UPGRADE | |||
r2779 | _step = None | |||
r839 | for step in upgrade_steps: | |||
r2779 | notify('performing upgrade step %s' % step) | |||
Bradley M. Kuhn
|
r4116 | time.sleep(0.5) | ||
r3906 | ||||
api.upgrade(db_uri, repository_path, step) | ||||
r3907 | notify('schema upgrade for step %s completed' % (step,)) | |||
r3906 | ||||
r2779 | _step = step | |||
notify('upgrade to version %s successful' % _step) | ||||
r2000 | ||||
r837 | def fix_repo_paths(self): | |||
r1783 | """ | |||
Fixes a old rhodecode version path into new one without a '*' | ||||
r837 | """ | |||
paths = self.sa.query(RhodeCodeUi)\ | ||||
.filter(RhodeCodeUi.ui_key == '/')\ | ||||
.scalar() | ||||
paths.ui_value = paths.ui_value.replace('*', '') | ||||
try: | ||||
self.sa.add(paths) | ||||
self.sa.commit() | ||||
r3631 | except Exception: | |||
r837 | self.sa.rollback() | |||
raise | ||||
r838 | def fix_default_user(self): | |||
r1783 | """ | |||
Fixes a old default user with some 'nicer' default values, | ||||
r838 | used mostly for anonymous access | |||
""" | ||||
def_user = self.sa.query(User)\ | ||||
Bradley M. Kuhn
|
r4116 | .filter(User.username == User.DEFAULT_USER)\ | ||
r838 | .one() | |||
def_user.name = 'Anonymous' | ||||
def_user.lastname = 'User' | ||||
Bradley M. Kuhn
|
r4184 | def_user.email = 'anonymous@kallithea-scm.org' | ||
r838 | ||||
try: | ||||
self.sa.add(def_user) | ||||
self.sa.commit() | ||||
r3631 | except Exception: | |||
r838 | self.sa.rollback() | |||
raise | ||||
r890 | def fix_settings(self): | |||
r1783 | """ | |||
Fixes rhodecode settings adds ga_code key for google analytics | ||||
r890 | """ | |||
r837 | ||||
r1633 | hgsettings3 = RhodeCodeSetting('ga_code', '') | |||
r907 | ||||
r890 | try: | |||
self.sa.add(hgsettings3) | ||||
self.sa.commit() | ||||
r3631 | except Exception: | |||
r890 | self.sa.rollback() | |||
raise | ||||
r837 | ||||
r2919 | def admin_prompt(self, second=False): | |||
r547 | if not self.tests: | |||
import getpass | ||||
r629 | ||||
r2284 | # defaults | |||
r2919 | defaults = self.cli_args | |||
r2284 | username = defaults.get('username') | |||
password = defaults.get('password') | ||||
email = defaults.get('email') | ||||
r597 | def get_password(): | |||
r1266 | password = getpass.getpass('Specify admin password ' | |||
'(min 6 chars):') | ||||
r597 | confirm = getpass.getpass('Confirm password:') | |||
r629 | ||||
r597 | if password != confirm: | |||
log.error('passwords mismatch') | ||||
return False | ||||
if len(password) < 6: | ||||
log.error('password is to short use at least 6 characters') | ||||
return False | ||||
r629 | ||||
r597 | return password | |||
r2284 | if username is None: | |||
username = raw_input('Specify admin username:') | ||||
if password is None: | ||||
r597 | password = get_password() | |||
if not password: | ||||
r2284 | #second try | |||
password = get_password() | ||||
if not password: | ||||
sys.exit() | ||||
if email is None: | ||||
email = raw_input('Specify admin email:') | ||||
r547 | self.create_user(username, password, email, True) | |||
else: | ||||
log.info('creating admin and regular test users') | ||||
r2765 | from rhodecode.tests import TEST_USER_ADMIN_LOGIN, \ | |||
TEST_USER_ADMIN_PASS, TEST_USER_ADMIN_EMAIL, \ | ||||
TEST_USER_REGULAR_LOGIN, TEST_USER_REGULAR_PASS, \ | ||||
r1783 | TEST_USER_REGULAR_EMAIL, TEST_USER_REGULAR2_LOGIN, \ | |||
TEST_USER_REGULAR2_PASS, TEST_USER_REGULAR2_EMAIL | ||||
r1758 | ||||
self.create_user(TEST_USER_ADMIN_LOGIN, TEST_USER_ADMIN_PASS, | ||||
TEST_USER_ADMIN_EMAIL, True) | ||||
r1783 | ||||
r1758 | self.create_user(TEST_USER_REGULAR_LOGIN, TEST_USER_REGULAR_PASS, | |||
TEST_USER_REGULAR_EMAIL, False) | ||||
r1783 | ||||
r1758 | self.create_user(TEST_USER_REGULAR2_LOGIN, TEST_USER_REGULAR2_PASS, | |||
TEST_USER_REGULAR2_EMAIL, False) | ||||
r629 | ||||
Bradley M. Kuhn
|
r4116 | def create_ui_settings(self, repo_store_path): | ||
r1783 | """ | |||
Creates ui settings, fills out hooks | ||||
r837 | and disables dotencode | |||
r1783 | """ | |||
r1203 | ||||
r837 | #HOOKS | |||
r1460 | hooks1_key = RhodeCodeUi.HOOK_UPDATE | |||
r837 | hooks1_ = self.sa.query(RhodeCodeUi)\ | |||
.filter(RhodeCodeUi.ui_key == hooks1_key).scalar() | ||||
r629 | ||||
r837 | hooks1 = RhodeCodeUi() if hooks1_ is None else hooks1_ | |||
hooks1.ui_section = 'hooks' | ||||
hooks1.ui_key = hooks1_key | ||||
hooks1.ui_value = 'hg update >&2' | ||||
hooks1.ui_active = False | ||||
r2726 | self.sa.add(hooks1) | |||
r837 | ||||
r1460 | hooks2_key = RhodeCodeUi.HOOK_REPO_SIZE | |||
r837 | hooks2_ = self.sa.query(RhodeCodeUi)\ | |||
.filter(RhodeCodeUi.ui_key == hooks2_key).scalar() | ||||
hooks2 = RhodeCodeUi() if hooks2_ is None else hooks2_ | ||||
hooks2.ui_section = 'hooks' | ||||
hooks2.ui_key = hooks2_key | ||||
hooks2.ui_value = 'python:rhodecode.lib.hooks.repo_size' | ||||
r2726 | self.sa.add(hooks2) | |||
r837 | ||||
hooks3 = RhodeCodeUi() | ||||
hooks3.ui_section = 'hooks' | ||||
r1460 | hooks3.ui_key = RhodeCodeUi.HOOK_PUSH | |||
r837 | hooks3.ui_value = 'python:rhodecode.lib.hooks.log_push_action' | |||
r2726 | self.sa.add(hooks3) | |||
r837 | ||||
hooks4 = RhodeCodeUi() | ||||
hooks4.ui_section = 'hooks' | ||||
r2726 | hooks4.ui_key = RhodeCodeUi.HOOK_PRE_PUSH | |||
hooks4.ui_value = 'python:rhodecode.lib.hooks.pre_push' | ||||
self.sa.add(hooks4) | ||||
r837 | ||||
r2726 | hooks5 = RhodeCodeUi() | |||
hooks5.ui_section = 'hooks' | ||||
hooks5.ui_key = RhodeCodeUi.HOOK_PULL | ||||
hooks5.ui_value = 'python:rhodecode.lib.hooks.log_pull_action' | ||||
self.sa.add(hooks5) | ||||
hooks6 = RhodeCodeUi() | ||||
hooks6.ui_section = 'hooks' | ||||
hooks6.ui_key = RhodeCodeUi.HOOK_PRE_PULL | ||||
hooks6.ui_value = 'python:rhodecode.lib.hooks.pre_pull' | ||||
self.sa.add(hooks6) | ||||
r837 | ||||
r1694 | # enable largefiles | |||
r1734 | largefiles = RhodeCodeUi() | |||
largefiles.ui_section = 'extensions' | ||||
largefiles.ui_key = 'largefiles' | ||||
r1783 | largefiles.ui_value = '' | |||
r2726 | self.sa.add(largefiles) | |||
r1694 | ||||
Bradley M. Kuhn
|
r4116 | # set default largefiles cache dir, defaults to | ||
# /repo location/.cache/largefiles | ||||
largefiles = RhodeCodeUi() | ||||
largefiles.ui_section = 'largefiles' | ||||
largefiles.ui_key = 'usercache' | ||||
largefiles.ui_value = os.path.join(repo_store_path, '.cache', | ||||
'largefiles') | ||||
self.sa.add(largefiles) | ||||
r2705 | # enable hgsubversion disabled by default | |||
hgsubversion = RhodeCodeUi() | ||||
hgsubversion.ui_section = 'extensions' | ||||
hgsubversion.ui_key = 'hgsubversion' | ||||
hgsubversion.ui_value = '' | ||||
hgsubversion.ui_active = False | ||||
r2726 | self.sa.add(hgsubversion) | |||
r2705 | ||||
r2708 | # enable hggit disabled by default | |||
hggit = RhodeCodeUi() | ||||
hggit.ui_section = 'extensions' | ||||
hggit.ui_key = 'hggit' | ||||
hggit.ui_value = '' | ||||
hggit.ui_active = False | ||||
self.sa.add(hggit) | ||||
r837 | ||||
Bradley M. Kuhn
|
r4116 | def create_auth_plugin_options(self, skip_existing=False): | ||
""" | ||||
Create default auth plugin settings, and make it active | ||||
r837 | ||||
Bradley M. Kuhn
|
r4116 | :param skip_existing: | ||
""" | ||||
r837 | ||||
Bradley M. Kuhn
|
r4116 | for k, v, t in [('auth_plugins', 'rhodecode.lib.auth_modules.auth_rhodecode', 'list'), | ||
('auth_rhodecode_enabled', 'True', 'bool')]: | ||||
if skip_existing and RhodeCodeSetting.get_by_name(k) != None: | ||||
r1734 | log.debug('Skipping option %s' % k) | |||
continue | ||||
Bradley M. Kuhn
|
r4116 | setting = RhodeCodeSetting(k, v, t) | ||
r1734 | self.sa.add(setting) | |||
r629 | ||||
r3056 | def create_default_options(self, skip_existing=False): | |||
"""Creates default settings""" | ||||
Bradley M. Kuhn
|
r4116 | for k, v, t in [ | ||
('default_repo_enable_locking', False, 'bool'), | ||||
('default_repo_enable_downloads', False, 'bool'), | ||||
('default_repo_enable_statistics', False, 'bool'), | ||||
('default_repo_private', False, 'bool'), | ||||
('default_repo_type', 'hg', 'unicode')]: | ||||
r3056 | ||||
r3889 | if skip_existing and RhodeCodeSetting.get_by_name(k) is not None: | |||
r3056 | log.debug('Skipping option %s' % k) | |||
continue | ||||
Bradley M. Kuhn
|
r4116 | setting = RhodeCodeSetting(k, v, t) | ||
r3056 | self.sa.add(setting) | |||
r1985 | def fixup_groups(self): | |||
r3734 | def_usr = User.get_default_user() | |||
r1985 | for g in RepoGroup.query().all(): | |||
g.group_name = g.get_new_name(g.name) | ||||
self.sa.add(g) | ||||
# get default perm | ||||
default = UserRepoGroupToPerm.query()\ | ||||
.filter(UserRepoGroupToPerm.group == g)\ | ||||
.filter(UserRepoGroupToPerm.user == def_usr)\ | ||||
.scalar() | ||||
if default is None: | ||||
log.debug('missing default permission for group %s adding' % g) | ||||
Bradley M. Kuhn
|
r4116 | perm_obj = RepoGroupModel()._create_default_perms(g) | ||
r3714 | self.sa.add(perm_obj) | |||
r1985 | ||||
r2798 | def reset_permissions(self, username): | |||
""" | ||||
Resets permissions to default state, usefull when old systems had | ||||
bad permissions, we must clean them up | ||||
:param username: | ||||
""" | ||||
default_user = User.get_by_username(username) | ||||
if not default_user: | ||||
return | ||||
u2p = UserToPerm.query()\ | ||||
.filter(UserToPerm.user == default_user).all() | ||||
fixed = False | ||||
r3733 | if len(u2p) != len(Permission.DEFAULT_USER_PERMISSIONS): | |||
r2798 | for p in u2p: | |||
Session().delete(p) | ||||
fixed = True | ||||
self.populate_default_permissions() | ||||
return fixed | ||||
r3309 | def update_repo_info(self): | |||
RepoModel.update_repoinfo() | ||||
r2919 | def config_prompt(self, test_repo_path='', retries=3): | |||
defaults = self.cli_args | ||||
r2284 | _path = defaults.get('repos_location') | |||
r1094 | if retries == 3: | |||
log.info('Setting up repositories config') | ||||
r629 | ||||
r2284 | if _path is not None: | |||
path = _path | ||||
elif not self.tests and not test_repo_path: | ||||
r1896 | path = raw_input( | |||
r2112 | 'Enter a valid absolute path to store repositories. ' | |||
r1896 | 'All repositories in that path will be added automatically:' | |||
) | ||||
r547 | else: | |||
path = test_repo_path | ||||
r1094 | path_ok = True | |||
r629 | ||||
r1783 | # check proper dir | |||
r547 | if not os.path.isdir(path): | |||
r1094 | path_ok = False | |||
r3980 | log.error('Given path %s is not a valid directory' % (path,)) | |||
r1094 | ||||
r2112 | elif not os.path.isabs(path): | |||
path_ok = False | ||||
r3980 | log.error('Given path %s is not an absolute path' % (path,)) | |||
# check if path is at least readable. | ||||
if not os.access(path, os.R_OK): | ||||
path_ok = False | ||||
log.error('Given path %s is not readable' % (path,)) | ||||
r2112 | ||||
r3980 | # check write access, warn user about non writeable paths | |||
r2112 | elif not os.access(path, os.W_OK) and path_ok: | |||
r3980 | log.warn('No write permission to given path %s' % (path,)) | |||
if not ask_ok('Given path %s is not writeable, do you want to ' | ||||
'continue with read only mode ? [y/n]' % (path,)): | ||||
log.error('Canceled by user') | ||||
sys.exit(-1) | ||||
r1094 | ||||
if retries == 0: | ||||
r1399 | sys.exit('max retries reached') | |||
Mads Kiilerich
|
r3625 | if not path_ok: | ||
r1094 | retries -= 1 | |||
return self.config_prompt(test_repo_path, retries) | ||||
r2918 | real_path = os.path.normpath(os.path.realpath(path)) | |||
r2819 | ||||
r2918 | if real_path != os.path.normpath(path): | |||
r2819 | if not ask_ok(('Path looks like a symlink, Rhodecode will store ' | |||
r3980 | 'given path as %s ? [y/n]') % (real_path,)): | |||
r2819 | log.error('Canceled by user') | |||
sys.exit(-1) | ||||
return real_path | ||||
r1094 | ||||
def create_settings(self, path): | ||||
r629 | ||||
Bradley M. Kuhn
|
r4116 | self.create_ui_settings(path) | ||
r673 | ||||
r3909 | ui_config = [ | |||
('web', 'push_ssl', 'false'), | ||||
('web', 'allow_archive', 'gz zip bz2'), | ||||
('web', 'allow_push', '*'), | ||||
('web', 'baseurl', '/'), | ||||
('paths', '/', path), | ||||
#('phases', 'publish', 'false') | ||||
] | ||||
r3911 | for section, key, value in ui_config: | |||
r3909 | ui_conf = RhodeCodeUi() | |||
setattr(ui_conf, 'ui_section', section) | ||||
setattr(ui_conf, 'ui_key', key) | ||||
setattr(ui_conf, 'ui_value', value) | ||||
r3911 | self.sa.add(ui_conf) | |||
r629 | ||||
r3909 | settings = [ | |||
Bradley M. Kuhn
|
r4116 | ('realm', 'RhodeCode', 'unicode'), | ||
('title', '', 'unicode'), | ||||
('ga_code', '', 'unicode'), | ||||
('show_public_icon', True, 'bool'), | ||||
('show_private_icon', True, 'bool'), | ||||
('stylify_metatags', False, 'bool'), | ||||
('dashboard_items', 100, 'int'), | ||||
('admin_grid_items', 25, 'int'), | ||||
('show_version', True, 'bool'), | ||||
('use_gravatar', True, 'bool'), | ||||
('gravatar_url', User.DEFAULT_GRAVATAR_URL, 'unicode'), | ||||
('clone_uri_tmpl', Repository.DEFAULT_CLONE_URI, 'unicode'), | ||||
('update_url', RhodeCodeSetting.DEFAULT_UPDATE_URL, 'unicode'), | ||||
r3909 | ] | |||
for key, val, type_ in settings: | ||||
Bradley M. Kuhn
|
r4116 | sett = RhodeCodeSetting(key, val, type_) | ||
r3909 | self.sa.add(sett) | |||
r837 | ||||
Bradley M. Kuhn
|
r4116 | self.create_auth_plugin_options() | ||
r3056 | self.create_default_options() | |||
r837 | ||||
r547 | log.info('created ui config') | |||
r629 | ||||
r547 | def create_user(self, username, password, email='', admin=False): | |||
r1976 | log.info('creating user %s' % username) | |||
r1734 | UserModel().create_or_update(username, password, email, | |||
r2513 | firstname='RhodeCode', lastname='Admin', | |||
Bradley M. Kuhn
|
r4116 | active=True, admin=admin, | ||
extern_type="rhodecode") | ||||
r547 | ||||
def create_default_user(self): | ||||
log.info('creating default user') | ||||
r1634 | # create default user for handling default permissions. | |||
r4028 | user = UserModel().create_or_update(username=User.DEFAULT_USER, | |||
password=str(uuid.uuid1())[:20], | ||||
Bradley M. Kuhn
|
r4184 | email='anonymous@kallithea-scm.org', | ||
r4028 | firstname='Anonymous', | |||
lastname='User') | ||||
# based on configuration options activate/deactive this user which | ||||
# controlls anonymous access | ||||
if self.cli_args.get('public_access') is False: | ||||
log.info('Public access disabled') | ||||
user.active = False | ||||
Session().add(user) | ||||
Session().commit() | ||||
r1734 | ||||
r547 | def create_permissions(self): | |||
r3733 | """ | |||
Creates all permissions defined in the system | ||||
""" | ||||
r1783 | # module.(access|create|change|delete)_[name] | |||
r1982 | # module.(none|read|write|admin) | |||
r3734 | log.info('creating permissions') | |||
PermissionModel(self.sa).create_permissions() | ||||
r547 | ||||
def populate_default_permissions(self): | ||||
r3733 | """ | |||
Populate default permissions. It will create only the default | ||||
permissions that are missing, and not alter already defined ones | ||||
""" | ||||
r547 | log.info('creating default user permissions') | |||
r3733 | PermissionModel(self.sa).create_default_permissions(user=User.DEFAULT_USER) | |||
r2827 | ||||
r3232 | @staticmethod | |||
def check_waitress(): | ||||
r2827 | """ | |||
Function executed at the end of setup | ||||
""" | ||||
if not __py_version__ >= (2, 6): | ||||
notify('Python2.5 detected, please switch ' | ||||
'egg:waitress#main -> egg:Paste#http ' | ||||
r2907 | 'in your .ini file') | |||