##// END OF EJS Templates
admin: fixed problems with generating last change in admin panels....
admin: fixed problems with generating last change in admin panels. - from now on also updated_on will refer as last commit change instead of last update of DB. Reason for that is since we have audit logs the last db update should be taken from there along the change info. Storing last commit date in the dedicated field makes it searchable, sortable and faster to read.

File last commit:

r3894:22ee809d default
r4000:52837660 default
Show More
settings.py
894 lines | 31.8 KiB | text/x-python | PythonLexer
project: added all source files and assets
r1 # -*- coding: utf-8 -*-
docs: updated copyrights to 2019
r3363 # Copyright (C) 2010-2019 RhodeCode GmbH
project: added all source files and assets
r1 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# 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.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
vcs-settings: moved creation of largefiles default dirs into vcs settings view....
r1682 import os
project: added all source files and assets
r1 import hashlib
import logging
from collections import namedtuple
from functools import wraps
issue-trackers: bleach.clean the url entry to avoid JS injections.
r2444 import bleach
project: added all source files and assets
r1
caches: new cache context managers....
r2932 from rhodecode.lib import rc_cache
project: added all source files and assets
r1 from rhodecode.lib.utils2 import (
Optional, AttributeDict, safe_str, remove_prefix, str2bool)
vcs: moved svn proxy settings into vcs related settings...
r754 from rhodecode.lib.vcs.backends import base
project: added all source files and assets
r1 from rhodecode.model import BaseModel
from rhodecode.model.db import (
caches: use process aware settings cache with proper invalidation.
r2937 RepoRhodeCodeUi, RepoRhodeCodeSetting, RhodeCodeUi, RhodeCodeSetting, CacheKey)
project: added all source files and assets
r1 from rhodecode.model.meta import Session
log = logging.getLogger(__name__)
UiSetting = namedtuple(
'UiSetting', ['section', 'key', 'value', 'active'])
SOCIAL_PLUGINS_LIST = ['github', 'bitbucket', 'twitter', 'google']
class SettingNotFound(Exception):
repo-settings: ensure deletion on repo settings model validate...
r2180 def __init__(self, setting_id):
msg = 'Setting `{}` is not found'.format(setting_id)
super(SettingNotFound, self).__init__(msg)
project: added all source files and assets
r1
class SettingsModel(BaseModel):
BUILTIN_HOOKS = (
RhodeCodeUi.HOOK_REPO_SIZE, RhodeCodeUi.HOOK_PUSH,
hooks: added new pretx hook to allow mercurial checks such as protected branches, or force push.
r1461 RhodeCodeUi.HOOK_PRE_PUSH, RhodeCodeUi.HOOK_PRETX_PUSH,
hooks: expose refs on push....
r1755 RhodeCodeUi.HOOK_PULL, RhodeCodeUi.HOOK_PRE_PULL,
RhodeCodeUi.HOOK_PUSH_KEY,)
project: added all source files and assets
r1 HOOKS_SECTION = 'hooks'
def __init__(self, sa=None, repo=None):
self.repo = repo
self.UiDbModel = RepoRhodeCodeUi if repo else RhodeCodeUi
self.SettingsDbModel = (
RepoRhodeCodeSetting if repo else RhodeCodeSetting)
super(SettingsModel, self).__init__(sa)
def get_ui_by_key(self, key):
q = self.UiDbModel.query()
q = q.filter(self.UiDbModel.ui_key == key)
q = self._filter_by_repo(RepoRhodeCodeUi, q)
return q.scalar()
def get_ui_by_section(self, section):
q = self.UiDbModel.query()
q = q.filter(self.UiDbModel.ui_section == section)
q = self._filter_by_repo(RepoRhodeCodeUi, q)
return q.all()
def get_ui_by_section_and_key(self, section, key):
q = self.UiDbModel.query()
q = q.filter(self.UiDbModel.ui_section == section)
q = q.filter(self.UiDbModel.ui_key == key)
q = self._filter_by_repo(RepoRhodeCodeUi, q)
return q.scalar()
def get_ui(self, section=None, key=None):
q = self.UiDbModel.query()
q = self._filter_by_repo(RepoRhodeCodeUi, q)
if section:
q = q.filter(self.UiDbModel.ui_section == section)
if key:
q = q.filter(self.UiDbModel.ui_key == key)
# TODO: mikhail: add caching
result = [
UiSetting(
section=safe_str(r.ui_section), key=safe_str(r.ui_key),
value=safe_str(r.ui_value), active=r.ui_active
)
for r in q.all()
]
return result
def get_builtin_hooks(self):
q = self.UiDbModel.query()
q = q.filter(self.UiDbModel.ui_key.in_(self.BUILTIN_HOOKS))
return self._get_hooks(q)
def get_custom_hooks(self):
q = self.UiDbModel.query()
q = q.filter(~self.UiDbModel.ui_key.in_(self.BUILTIN_HOOKS))
return self._get_hooks(q)
def create_ui_section_value(self, section, val, key=None, active=True):
new_ui = self.UiDbModel()
new_ui.ui_section = section
new_ui.ui_value = val
new_ui.ui_active = active
mercurial: enabled full evolve+topic extensions
r3625 repository_id = ''
project: added all source files and assets
r1 if self.repo:
repo = self._get_repo(self.repo)
repository_id = repo.repo_id
new_ui.repository_id = repository_id
if not key:
# keys are unique so they need appended info
if self.repo:
key = hashlib.sha1(
'{}{}{}'.format(section, val, repository_id)).hexdigest()
else:
key = hashlib.sha1('{}{}'.format(section, val)).hexdigest()
new_ui.ui_key = key
Session().add(new_ui)
return new_ui
def create_or_update_hook(self, key, value):
ui = (
self.get_ui_by_section_and_key(self.HOOKS_SECTION, key) or
self.UiDbModel())
ui.ui_section = self.HOOKS_SECTION
ui.ui_active = True
ui.ui_key = key
ui.ui_value = value
if self.repo:
repo = self._get_repo(self.repo)
repository_id = repo.repo_id
ui.repository_id = repository_id
Session().add(ui)
return ui
def delete_ui(self, id_):
ui = self.UiDbModel.get(id_)
if not ui:
repo-settings: ensure deletion on repo settings model validate...
r2180 raise SettingNotFound(id_)
project: added all source files and assets
r1 Session().delete(ui)
def get_setting_by_name(self, name):
q = self._get_settings_query()
q = q.filter(self.SettingsDbModel.app_settings_name == name)
return q.scalar()
def create_or_update_setting(
self, name, val=Optional(''), type_=Optional('unicode')):
"""
Creates or updates RhodeCode setting. If updates is triggered it will
only update parameters that are explicityl set Optional instance will
be skipped
:param name:
:param val:
:param type_:
:return:
"""
res = self.get_setting_by_name(name)
repo = self._get_repo(self.repo) if self.repo else None
if not res:
val = Optional.extract(val)
type_ = Optional.extract(type_)
args = (
(repo.repo_id, name, val, type_)
if repo else (name, val, type_))
res = self.SettingsDbModel(*args)
else:
if self.repo:
res.repository_id = repo.repo_id
res.app_settings_name = name
if not isinstance(type_, Optional):
# update if set
res.app_settings_type = type_
if not isinstance(val, Optional):
# update if set
res.app_settings_value = val
db: always use Session() for compatibility, Using Session is actually the...
r506 Session().add(res)
project: added all source files and assets
r1 return res
settings: use invalidate after updating settings.
r276 def invalidate_settings_cache(self):
caches: use process aware settings cache with proper invalidation.
r2937 invalidation_namespace = CacheKey.SETTINGS_INVALIDATION_NAMESPACE
CacheKey.set_invalidate(invalidation_namespace)
settings: use invalidate after updating settings.
r276
project: added all source files and assets
r1 def get_all_settings(self, cache=False):
caches: use dogpile for sql_cache_short region.
r2883 region = rc_cache.get_or_create_region('sql_cache_short')
caches: use process aware settings cache with proper invalidation.
r2937 invalidation_namespace = CacheKey.SETTINGS_INVALIDATION_NAMESPACE
core: added ops view to pyramid to have a PING command with pure pyramid.
r1669
caches: use new decorator that uses conditional caches skipping dogpile if cache is disabled.
r2892 @region.conditional_cache_on_arguments(condition=cache)
caches: use dogpile for sql_cache_short region.
r2883 def _get_all_settings(name, key):
settings: use cache on whole result not just the query since it's the computation...
r259 q = self._get_settings_query()
if not q:
raise Exception('Could not get application settings !')
settings = {
'rhodecode_' + result.app_settings_name: result.app_settings_value
for result in q
}
return settings
caches: use dogpile for sql_cache_short region.
r2883 repo = self._get_repo(self.repo) if self.repo else None
key = "settings_repo.{}".format(repo.repo_id) if repo else "settings_app"
caches: use process aware settings cache with proper invalidation.
r2937
inv_context_manager = rc_cache.InvalidationContext(
uid='cache_settings', invalidation_namespace=invalidation_namespace)
with inv_context_manager as invalidation_context:
# check for stored invalidation signal, and maybe purge the cache
# before computing it again
if invalidation_context.should_invalidate():
# NOTE:(marcink) we flush the whole sql_cache_short region, because it
# reads different settings etc. It's little too much but those caches
# are anyway very short lived and it's a safest way.
region = rc_cache.get_or_create_region('sql_cache_short')
region.invalidate()
result = _get_all_settings('rhodecode_settings', key)
core: added more accurate time measurement for called functions
r3853 log.debug('Fetching app settings for key: %s took: %.4fs', key,
logging: use lazy parameter evaluation in log calls.
r3061 inv_context_manager.compute_time)
project: added all source files and assets
r1
caches: use dogpile for sql_cache_short region.
r2883 return result
project: added all source files and assets
r1
def get_auth_settings(self):
q = self._get_settings_query()
q = q.filter(
self.SettingsDbModel.app_settings_name.startswith('auth_'))
rows = q.all()
auth_settings = {
row.app_settings_name: row.app_settings_value for row in rows}
return auth_settings
def get_auth_plugins(self):
auth_plugins = self.get_setting_by_name("auth_plugins")
return auth_plugins.app_settings_value
def get_default_repo_settings(self, strip_prefix=False):
q = self._get_settings_query()
q = q.filter(
self.SettingsDbModel.app_settings_name.startswith('default_'))
rows = q.all()
result = {}
for row in rows:
key = row.app_settings_name
if strip_prefix:
key = remove_prefix(key, prefix='default_')
result.update({key: row.app_settings_value})
return result
def get_repo(self):
repo = self._get_repo(self.repo)
if not repo:
raise Exception(
exception-handling: nicer error catching on repository creation.
r1187 'Repository `{}` cannot be found inside the database'.format(
self.repo))
project: added all source files and assets
r1 return repo
def _filter_by_repo(self, model, query):
if self.repo:
repo = self.get_repo()
query = query.filter(model.repository_id == repo.repo_id)
return query
def _get_hooks(self, query):
query = query.filter(self.UiDbModel.ui_section == self.HOOKS_SECTION)
query = self._filter_by_repo(RepoRhodeCodeUi, query)
return query.all()
def _get_settings_query(self):
q = self.SettingsDbModel.query()
return self._filter_by_repo(RepoRhodeCodeSetting, q)
def list_enabled_social_plugins(self, settings):
enabled = []
for plug in SOCIAL_PLUGINS_LIST:
if str2bool(settings.get('rhodecode_auth_{}_enabled'.format(plug)
)):
enabled.append(plug)
return enabled
def assert_repo_settings(func):
@wraps(func)
def _wrapper(self, *args, **kwargs):
if not self.repo_settings:
raise Exception('Repository is not specified')
return func(self, *args, **kwargs)
return _wrapper
class IssueTrackerSettingsModel(object):
INHERIT_SETTINGS = 'inherit_issue_tracker_settings'
SETTINGS_PREFIX = 'issuetracker_'
def __init__(self, sa=None, repo=None):
self.global_settings = SettingsModel(sa=sa)
self.repo_settings = SettingsModel(sa=sa, repo=repo) if repo else None
@property
def inherit_global_settings(self):
if not self.repo_settings:
return True
setting = self.repo_settings.get_setting_by_name(self.INHERIT_SETTINGS)
return setting.app_settings_value if setting else True
@inherit_global_settings.setter
def inherit_global_settings(self, value):
if self.repo_settings:
settings = self.repo_settings.create_or_update_setting(
self.INHERIT_SETTINGS, value, type_='bool')
Session().add(settings)
def _get_keyname(self, key, uid, prefix=''):
return '{0}{1}{2}_{3}'.format(
prefix, self.SETTINGS_PREFIX, key, uid)
def _make_dict_for_settings(self, qs):
prefix_match = self._get_keyname('pat', '', 'rhodecode_')
issuetracker_entries = {}
# create keys
for k, v in qs.items():
if k.startswith(prefix_match):
uid = k[len(prefix_match):]
issuetracker_entries[uid] = None
security: fix possible XSS in the issue tracker URL.
r3439 def url_cleaner(input_str):
input_str = input_str.replace('"', '').replace("'", '')
input_str = bleach.clean(input_str, strip=True)
return input_str
project: added all source files and assets
r1 # populate
for uid in issuetracker_entries:
security: fix possible XSS in the issue tracker URL.
r3439 url_data = qs.get(self._get_keyname('url', uid, 'rhodecode_'))
project: added all source files and assets
r1 issuetracker_entries[uid] = AttributeDict({
issue-trackers: bleach.clean the url entry to avoid JS injections.
r2444 'pat': qs.get(
self._get_keyname('pat', uid, 'rhodecode_')),
security: fix possible XSS in the issue tracker URL.
r3439 'url': url_cleaner(
issue-trackers: bleach.clean the url entry to avoid JS injections.
r2444 qs.get(self._get_keyname('url', uid, 'rhodecode_')) or ''),
issue-tracker: fix prefix to be escaped as well as the url pattern.
r2448 'pref': bleach.clean(
qs.get(self._get_keyname('pref', uid, 'rhodecode_')) or ''),
issue-trackers: bleach.clean the url entry to avoid JS injections.
r2444 'desc': qs.get(
self._get_keyname('desc', uid, 'rhodecode_')),
project: added all source files and assets
r1 })
security: fix possible XSS in the issue tracker URL.
r3439
project: added all source files and assets
r1 return issuetracker_entries
def get_global_settings(self, cache=False):
"""
Returns list of global issue tracker settings
"""
defaults = self.global_settings.get_all_settings(cache=cache)
settings = self._make_dict_for_settings(defaults)
return settings
def get_repo_settings(self, cache=False):
"""
Returns list of issue tracker settings per repository
"""
if not self.repo_settings:
raise Exception('Repository is not specified')
all_settings = self.repo_settings.get_all_settings(cache=cache)
settings = self._make_dict_for_settings(all_settings)
return settings
def get_settings(self, cache=False):
if self.inherit_global_settings:
return self.get_global_settings(cache=cache)
else:
return self.get_repo_settings(cache=cache)
def delete_entries(self, uid):
if self.repo_settings:
all_patterns = self.get_repo_settings()
settings_model = self.repo_settings
else:
all_patterns = self.get_global_settings()
settings_model = self.global_settings
settings: fix potential 500 problem on bad data passed in.
r2247 entries = all_patterns.get(uid, [])
project: added all source files and assets
r1
for del_key in entries:
setting_name = self._get_keyname(del_key, uid)
entry = settings_model.get_setting_by_name(setting_name)
if entry:
Session().delete(entry)
Session().commit()
def create_or_update_setting(
self, name, val=Optional(''), type_=Optional('unicode')):
if self.repo_settings:
setting = self.repo_settings.create_or_update_setting(
name, val, type_)
else:
setting = self.global_settings.create_or_update_setting(
name, val, type_)
return setting
class VcsSettingsModel(object):
INHERIT_SETTINGS = 'inherit_vcs_settings'
Martin Bornhold
settings: Add the 'rebase-merge' setting to VCS base form and VCS settings model.
r358 GENERAL_SETTINGS = (
vcs: moved svn proxy settings into vcs related settings...
r754 'use_outdated_comments',
'pr_merge_enabled',
Mathieu Cantin
mercurial: Add option to close a branch before merging
r2055 'hg_use_rebase_for_merging',
pull-requests: use close action with proper --close-commit solution....
r2056 'hg_close_branch_before_merging',
'git_use_rebase_for_merging',
Bartłomiej Wołyńczyk
caching: add option to cache diffs for commits and pull requests....
r2685 'git_close_branch_before_merging',
'diff_cache',
)
vcs: moved svn proxy settings into vcs related settings...
r754
project: added all source files and assets
r1 HOOKS_SETTINGS = (
('hooks', 'changegroup.repo_size'),
('hooks', 'changegroup.push_logger'),
mercurial: enabled full evolve+topic extensions
r3625 ('hooks', 'outgoing.pull_logger'),
)
project: added all source files and assets
r1 HG_SETTINGS = (
vcs: moved svn proxy settings into vcs related settings...
r754 ('extensions', 'largefiles'),
mercurial-evolve: enable evolve setting on repositories.
r1738 ('phases', 'publish'),
mercurial: enabled full evolve+topic extensions
r3625 ('extensions', 'evolve'),
('extensions', 'topic'),
('experimental', 'evolution'),
Mercurial: fix ssh-server support for UI objects...
r3626 ('experimental', 'evolution.exchange'),
mercurial: enabled full evolve+topic extensions
r3625 )
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570 GIT_SETTINGS = (
mercurial: enabled full evolve+topic extensions
r3625 ('vcs_git_lfs', 'enabled'),
)
vcs: moved svn proxy settings into vcs related settings...
r754 GLOBAL_HG_SETTINGS = (
('extensions', 'largefiles'),
mercurial: allow editing largefile store from web interface.
r1563 ('largefiles', 'usercache'),
vcs: moved svn proxy settings into vcs related settings...
r754 ('phases', 'publish'),
mercurial-evolve: enable evolve setting on repositories.
r1738 ('extensions', 'hgsubversion'),
mercurial: enabled full evolve+topic extensions
r3625 ('extensions', 'evolve'),
('extensions', 'topic'),
('experimental', 'evolution'),
Mercurial: fix ssh-server support for UI objects...
r3626 ('experimental', 'evolution.exchange'),
mercurial: enabled full evolve+topic extensions
r3625 )
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570 GLOBAL_GIT_SETTINGS = (
('vcs_git_lfs', 'enabled'),
mercurial: enabled full evolve+topic extensions
r3625 ('vcs_git_lfs', 'store_location')
)
Bartłomiej Wołyńczyk
caching: add option to cache diffs for commits and pull requests....
r2685
svn: moving svn http support out of labs settings.
r748 GLOBAL_SVN_SETTINGS = (
vcs: moved svn proxy settings into vcs related settings...
r754 ('vcs_svn_proxy', 'http_requests_enabled'),
mercurial: enabled full evolve+topic extensions
r3625 ('vcs_svn_proxy', 'http_server_url')
)
vcs: moved svn proxy settings into vcs related settings...
r754
project: added all source files and assets
r1 SVN_BRANCH_SECTION = 'vcs_svn_branch'
SVN_TAG_SECTION = 'vcs_svn_tag'
SSL_SETTING = ('web', 'push_ssl')
PATH_SETTING = ('paths', '/')
def __init__(self, sa=None, repo=None):
self.global_settings = SettingsModel(sa=sa)
self.repo_settings = SettingsModel(sa=sa, repo=repo) if repo else None
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570 self._ui_settings = (
self.HG_SETTINGS + self.GIT_SETTINGS + self.HOOKS_SETTINGS)
project: added all source files and assets
r1 self._svn_sections = (self.SVN_BRANCH_SECTION, self.SVN_TAG_SECTION)
@property
@assert_repo_settings
def inherit_global_settings(self):
setting = self.repo_settings.get_setting_by_name(self.INHERIT_SETTINGS)
return setting.app_settings_value if setting else True
@inherit_global_settings.setter
@assert_repo_settings
def inherit_global_settings(self, value):
self.repo_settings.create_or_update_setting(
self.INHERIT_SETTINGS, value, type_='bool')
def get_global_svn_branch_patterns(self):
return self.global_settings.get_ui_by_section(self.SVN_BRANCH_SECTION)
@assert_repo_settings
def get_repo_svn_branch_patterns(self):
return self.repo_settings.get_ui_by_section(self.SVN_BRANCH_SECTION)
def get_global_svn_tag_patterns(self):
return self.global_settings.get_ui_by_section(self.SVN_TAG_SECTION)
@assert_repo_settings
def get_repo_svn_tag_patterns(self):
return self.repo_settings.get_ui_by_section(self.SVN_TAG_SECTION)
def get_global_settings(self):
return self._collect_all_settings(global_=True)
@assert_repo_settings
def get_repo_settings(self):
return self._collect_all_settings(global_=False)
@assert_repo_settings
files: only check for git_lfs/hg_largefiles if they are enabled....
r3894 def get_repo_settings_inherited(self):
global_settings = self.get_global_settings()
global_settings.update(self.get_repo_settings())
return global_settings
@assert_repo_settings
project: added all source files and assets
r1 def create_or_update_repo_settings(
self, data, inherit_global_settings=False):
from rhodecode.model.scm import ScmModel
self.inherit_global_settings = inherit_global_settings
repo = self.repo_settings.get_repo()
if not inherit_global_settings:
if repo.repo_type == 'svn':
self.create_repo_svn_settings(data)
else:
self.create_or_update_repo_hook_settings(data)
self.create_or_update_repo_pr_settings(data)
if repo.repo_type == 'hg':
self.create_or_update_repo_hg_settings(data)
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570 if repo.repo_type == 'git':
self.create_or_update_repo_git_settings(data)
project: added all source files and assets
r1 ScmModel().mark_for_invalidation(repo.repo_name, delete=True)
@assert_repo_settings
def create_or_update_repo_hook_settings(self, data):
for section, key in self.HOOKS_SETTINGS:
data_key = self._get_form_ui_key(section, key)
if data_key not in data:
raise ValueError(
'The given data does not contain {} key'.format(data_key))
active = data.get(data_key)
repo_setting = self.repo_settings.get_ui_by_section_and_key(
section, key)
if not repo_setting:
global_setting = self.global_settings.\
get_ui_by_section_and_key(section, key)
self.repo_settings.create_ui_section_value(
section, global_setting.ui_value, key=key, active=active)
else:
repo_setting.ui_active = active
Session().add(repo_setting)
def update_global_hook_settings(self, data):
for section, key in self.HOOKS_SETTINGS:
data_key = self._get_form_ui_key(section, key)
if data_key not in data:
raise ValueError(
'The given data does not contain {} key'.format(data_key))
active = data.get(data_key)
repo_setting = self.global_settings.get_ui_by_section_and_key(
section, key)
repo_setting.ui_active = active
Session().add(repo_setting)
@assert_repo_settings
def create_or_update_repo_pr_settings(self, data):
return self._create_or_update_general_settings(
self.repo_settings, data)
def create_or_update_global_pr_settings(self, data):
return self._create_or_update_general_settings(
self.global_settings, data)
@assert_repo_settings
def create_repo_svn_settings(self, data):
return self._create_svn_settings(self.repo_settings, data)
mercurial: enabled full evolve+topic extensions
r3625 def _set_evolution(self, settings, is_enabled):
if is_enabled:
# if evolve is active set evolution=all
self._create_or_update_ui(
settings, *('experimental', 'evolution'), value='all',
active=True)
self._create_or_update_ui(
settings, *('experimental', 'evolution.exchange'), value='yes',
active=True)
# if evolve is active set topics server support
self._create_or_update_ui(
settings, *('extensions', 'topic'), value='',
active=True)
else:
self._create_or_update_ui(
settings, *('experimental', 'evolution'), value='',
active=False)
self._create_or_update_ui(
settings, *('experimental', 'evolution.exchange'), value='no',
active=False)
self._create_or_update_ui(
settings, *('extensions', 'topic'), value='',
active=False)
project: added all source files and assets
r1 @assert_repo_settings
def create_or_update_repo_hg_settings(self, data):
mercurial-evolve: enable evolve setting on repositories.
r1738 largefiles, phases, evolve = \
mercurial: enabled full evolve+topic extensions
r3625 self.HG_SETTINGS[:3]
mercurial-evolve: enable evolve setting on repositories.
r1738 largefiles_key, phases_key, evolve_key = \
mercurial: enabled full evolve+topic extensions
r3625 self._get_settings_keys(self.HG_SETTINGS[:3], data)
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570
project: added all source files and assets
r1 self._create_or_update_ui(
self.repo_settings, *largefiles, value='',
active=data[largefiles_key])
self._create_or_update_ui(
mercurial-evolve: enable evolve setting on repositories.
r1738 self.repo_settings, *evolve, value='',
active=data[evolve_key])
mercurial: enabled full evolve+topic extensions
r3625 self._set_evolution(self.repo_settings, is_enabled=data[evolve_key])
mercurial-evolve: enable evolve setting on repositories.
r1738 self._create_or_update_ui(
project: added all source files and assets
r1 self.repo_settings, *phases, value=safe_str(data[phases_key]))
def create_or_update_global_hg_settings(self, data):
mercurial-evolve: enable evolve setting on repositories.
r1738 largefiles, largefiles_store, phases, hgsubversion, evolve \
mercurial: enabled full evolve+topic extensions
r3625 = self.GLOBAL_HG_SETTINGS[:5]
mercurial-evolve: enable evolve setting on repositories.
r1738 largefiles_key, largefiles_store_key, phases_key, subversion_key, evolve_key \
mercurial: enabled full evolve+topic extensions
r3625 = self._get_settings_keys(self.GLOBAL_HG_SETTINGS[:5], data)
mercurial-evolve: enable evolve setting on repositories.
r1738
project: added all source files and assets
r1 self._create_or_update_ui(
self.global_settings, *largefiles, value='',
active=data[largefiles_key])
self._create_or_update_ui(
mercurial: enabled full evolve+topic extensions
r3625 self.global_settings, *largefiles_store, value=data[largefiles_store_key])
mercurial: allow editing largefile store from web interface.
r1563 self._create_or_update_ui(
project: added all source files and assets
r1 self.global_settings, *phases, value=safe_str(data[phases_key]))
self._create_or_update_ui(
vcs: moved svn proxy settings into vcs related settings...
r754 self.global_settings, *hgsubversion, active=data[subversion_key])
mercurial-evolve: enable evolve setting on repositories.
r1738 self._create_or_update_ui(
self.global_settings, *evolve, value='',
active=data[evolve_key])
mercurial: enabled full evolve+topic extensions
r3625 self._set_evolution(self.global_settings, is_enabled=data[evolve_key])
project: added all source files and assets
r1
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570 def create_or_update_repo_git_settings(self, data):
mercurial: enabled full evolve+topic extensions
r3625 # NOTE(marcink): # comma makes unpack work properly
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570 lfs_enabled, \
= self.GIT_SETTINGS
lfs_enabled_key, \
= self._get_settings_keys(self.GIT_SETTINGS, data)
self._create_or_update_ui(
self.repo_settings, *lfs_enabled, value=data[lfs_enabled_key],
active=data[lfs_enabled_key])
def create_or_update_global_git_settings(self, data):
lfs_enabled, lfs_store_location \
= self.GLOBAL_GIT_SETTINGS
lfs_enabled_key, lfs_store_location_key \
= self._get_settings_keys(self.GLOBAL_GIT_SETTINGS, data)
self._create_or_update_ui(
self.global_settings, *lfs_enabled, value=data[lfs_enabled_key],
active=data[lfs_enabled_key])
self._create_or_update_ui(
self.global_settings, *lfs_store_location,
value=data[lfs_store_location_key])
svn: moving svn http support out of labs settings.
r748 def create_or_update_global_svn_settings(self, data):
vcs: moved svn proxy settings into vcs related settings...
r754 # branch/tags patterns
self._create_svn_settings(self.global_settings, data)
http_requests_enabled, http_server_url = self.GLOBAL_SVN_SETTINGS
http_requests_enabled_key, http_server_url_key = self._get_settings_keys(
svn: moving svn http support out of labs settings.
r748 self.GLOBAL_SVN_SETTINGS, data)
vcs: moved svn proxy settings into vcs related settings...
r754
svn: moving svn http support out of labs settings.
r748 self._create_or_update_ui(
vcs: moved svn proxy settings into vcs related settings...
r754 self.global_settings, *http_requests_enabled,
value=safe_str(data[http_requests_enabled_key]))
svn: moving svn http support out of labs settings.
r748 self._create_or_update_ui(
vcs: moved svn proxy settings into vcs related settings...
r754 self.global_settings, *http_server_url,
value=data[http_server_url_key])
svn: moving svn http support out of labs settings.
r748
project: added all source files and assets
r1 def update_global_ssl_setting(self, value):
self._create_or_update_ui(
self.global_settings, *self.SSL_SETTING, value=value)
def update_global_path_setting(self, value):
self._create_or_update_ui(
self.global_settings, *self.PATH_SETTING, value=value)
@assert_repo_settings
def delete_repo_svn_pattern(self, id_):
repo-settings: ensure deletion on repo settings model validate...
r2180 ui = self.repo_settings.UiDbModel.get(id_)
if ui and ui.repository.repo_name == self.repo_settings.repo:
# only delete if it's the same repo as initialized settings
self.repo_settings.delete_ui(id_)
else:
# raise error as if we wouldn't find this option
self.repo_settings.delete_ui(-1)
project: added all source files and assets
r1
def delete_global_svn_pattern(self, id_):
self.global_settings.delete_ui(id_)
@assert_repo_settings
def get_repo_ui_settings(self, section=None, key=None):
global_uis = self.global_settings.get_ui(section, key)
repo_uis = self.repo_settings.get_ui(section, key)
mercurial: enabled full evolve+topic extensions
r3625
project: added all source files and assets
r1 filtered_repo_uis = self._filter_ui_settings(repo_uis)
filtered_repo_uis_keys = [
(s.section, s.key) for s in filtered_repo_uis]
def _is_global_ui_filtered(ui):
return (
(ui.section, ui.key) in filtered_repo_uis_keys
or ui.section in self._svn_sections)
filtered_global_uis = [
ui for ui in global_uis if not _is_global_ui_filtered(ui)]
return filtered_global_uis + filtered_repo_uis
def get_global_ui_settings(self, section=None, key=None):
return self.global_settings.get_ui(section, key)
vcs: moved svn proxy settings into vcs related settings...
r754 def get_ui_settings_as_config_obj(self, section=None, key=None):
config = base.Config()
ui_settings = self.get_ui_settings(section=section, key=key)
for entry in ui_settings:
config.set(entry.section, entry.key, entry.value)
return config
project: added all source files and assets
r1 def get_ui_settings(self, section=None, key=None):
if not self.repo_settings or self.inherit_global_settings:
return self.get_global_ui_settings(section, key)
else:
return self.get_repo_ui_settings(section, key)
def get_svn_patterns(self, section=None):
if not self.repo_settings:
return self.get_global_ui_settings(section)
else:
return self.get_repo_ui_settings(section)
@assert_repo_settings
def get_repo_general_settings(self):
global_settings = self.global_settings.get_all_settings()
repo_settings = self.repo_settings.get_all_settings()
filtered_repo_settings = self._filter_general_settings(repo_settings)
global_settings.update(filtered_repo_settings)
return global_settings
def get_global_general_settings(self):
return self.global_settings.get_all_settings()
def get_general_settings(self):
if not self.repo_settings or self.inherit_global_settings:
return self.get_global_general_settings()
else:
return self.get_repo_general_settings()
def get_repos_location(self):
return self.global_settings.get_ui_by_key('/').ui_value
def _filter_ui_settings(self, settings):
filtered_settings = [
s for s in settings if self._should_keep_setting(s)]
return filtered_settings
def _should_keep_setting(self, setting):
keep = (
(setting.section, setting.key) in self._ui_settings or
setting.section in self._svn_sections)
return keep
def _filter_general_settings(self, settings):
keys = ['rhodecode_{}'.format(key) for key in self.GENERAL_SETTINGS]
return {
k: settings[k]
for k in settings if k in keys}
def _collect_all_settings(self, global_=False):
settings = self.global_settings if global_ else self.repo_settings
result = {}
for section, key in self._ui_settings:
ui = settings.get_ui_by_section_and_key(section, key)
result_key = self._get_form_ui_key(section, key)
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570
project: added all source files and assets
r1 if ui:
if section in ('hooks', 'extensions'):
result[result_key] = ui.ui_active
git-lfs: settings for GIT repos to enable git-lfs and set store location...
r1570 elif result_key in ['vcs_git_lfs_enabled']:
result[result_key] = ui.ui_active
project: added all source files and assets
r1 else:
result[result_key] = ui.ui_value
for name in self.GENERAL_SETTINGS:
setting = settings.get_setting_by_name(name)
if setting:
result_key = 'rhodecode_{}'.format(name)
result[result_key] = setting.app_settings_value
return result
def _get_form_ui_key(self, section, key):
return '{section}_{key}'.format(
section=section, key=key.replace('.', '_'))
def _create_or_update_ui(
self, settings, section, key, value=None, active=None):
ui = settings.get_ui_by_section_and_key(section, key)
if not ui:
active = True if active is None else active
settings.create_ui_section_value(
section, value, key=key, active=active)
else:
if active is not None:
ui.ui_active = active
if value is not None:
ui.ui_value = value
Session().add(ui)
def _create_svn_settings(self, settings, data):
svn_settings = {
'new_svn_branch': self.SVN_BRANCH_SECTION,
'new_svn_tag': self.SVN_TAG_SECTION
}
for key in svn_settings:
if data.get(key):
settings.create_ui_section_value(svn_settings[key], data[key])
def _create_or_update_general_settings(self, settings, data):
for name in self.GENERAL_SETTINGS:
data_key = 'rhodecode_{}'.format(name)
if data_key not in data:
raise ValueError(
'The given data does not contain {} key'.format(data_key))
setting = settings.create_or_update_setting(
name, data[data_key], 'bool')
Session().add(setting)
vcs: moved svn proxy settings into vcs related settings...
r754 def _get_settings_keys(self, settings, data):
project: added all source files and assets
r1 data_keys = [self._get_form_ui_key(*s) for s in settings]
for data_key in data_keys:
if data_key not in data:
raise ValueError(
'The given data does not contain {} key'.format(data_key))
return data_keys
vcs-settings: moved creation of largefiles default dirs into vcs settings view....
r1682
def create_largeobjects_dirs_if_needed(self, repo_store_path):
"""
This is subscribed to the `pyramid.events.ApplicationCreated` event. It
does a repository scan if enabled in the settings.
"""
from rhodecode.lib.vcs.backends.hg import largefiles_store
from rhodecode.lib.vcs.backends.git import lfs_store
paths = [
largefiles_store(repo_store_path),
lfs_store(repo_store_path)]
for path in paths:
if os.path.isdir(path):
continue
if os.path.isfile(path):
continue
# not a file nor dir, we try to create it
try:
os.makedirs(path)
except Exception:
log.warning('Failed to create largefiles dir:%s', path)