##// END OF EJS Templates
Fixed test_hg_operations test and added concurency test
Fixed test_hg_operations test and added concurency test

File last commit:

r1518:55856097 merge default
r1529:0b268dd3 beta
Show More
repo.py
361 lines | 13.1 KiB | text/x-python | PythonLexer
when new repo is created make user follow it automatically,...
r786 # -*- coding: utf-8 -*-
"""
docs updates
r811 rhodecode.model.repo
~~~~~~~~~~~~~~~~~~~~
when new repo is created make user follow it automatically,...
r786
Repository model for rhodecode
source code cleanup: remove trailing white space, normalize file endings
r1203
when new repo is created make user follow it automatically,...
r786 :created_on: Jun 5, 2010
:author: marcink
source code cleanup: remove trailing white space, normalize file endings
r1203 :copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com>
when new repo is created make user follow it automatically,...
r786 :license: GPLv3, see COPYING for more details.
"""
fixed license issue #149
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.
source code cleanup: remove trailing white space, normalize file endings
r1203 #
Code refactoring,models renames...
r629 # 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.
source code cleanup: remove trailing white space, normalize file endings
r1203 #
Code refactoring,models renames...
r629 # You should have received a copy of the GNU General Public License
fixed license issue #149
r1206 # along with this program. If not, see <http://www.gnu.org/licenses/>.
when new repo is created make user follow it automatically,...
r786 import os
import shutil
import logging
import traceback
Code refactoring,models renames...
r629 from datetime import datetime
when new repo is created make user follow it automatically,...
r786
another major codes rewrite:...
r1045 from sqlalchemy.orm import joinedload, make_transient
Major refactoring, removed when possible calls to app globals....
r1036
from vcs.utils.lazy import LazyProperty
from vcs.backends import get_backend
Unicode fixes, added safe_str method for global str() operations +better test sandboxing
r1401 from rhodecode.lib import safe_str
when new repo is created make user follow it automatically,...
r786 from rhodecode.model import BaseModel
from rhodecode.model.caching_query import FromCache
added cache reset, stats reset, and delete into repository settings in admin....
r708 from rhodecode.model.db import Repository, RepoToPerm, User, Permission, \
fixed saving settings on repositories inside groups, also fixes #187...
r1323 Statistics, UsersGroup, UsersGroupRepoToPerm, RhodeCodeUi, Group
Code refactoring,models renames...
r629 from rhodecode.model.user import UserModel
when new repo is created make user follow it automatically,...
r786
Code refactoring,models renames...
r629 log = logging.getLogger(__name__)
Fixed permissions for users groups, group can have create repo permission now....
r1271
fixed Example celery config to ampq,...
r752 class RepoModel(BaseModel):
Code refactoring,models renames...
r629
Major refactoring, removed when possible calls to app globals....
r1036 @LazyProperty
def repos_path(self):
"""Get's the repositories root path from database
"""
Fixed problems with repository creation
r1017
Major refactoring, removed when possible calls to app globals....
r1036 q = self.sa.query(RhodeCodeUi).filter(RhodeCodeUi.ui_key == '/').one()
return q.ui_value
#56 hacking on forms, and model for users groups
r1013
Code refactoring,models renames...
r629 def get(self, repo_id, cache=False):
repo = self.sa.query(Repository)\
added action loggers to following repositories,...
r735 .filter(Repository.repo_id == repo_id)
Code refactoring,models renames...
r629
if cache:
repo = repo.options(FromCache("sql_cache_short",
added action loggers to following repositories,...
r735 "get_repo_%s" % repo_id))
Code refactoring,models renames...
r629 return repo.scalar()
added action loggers to following repositories,...
r735 def get_by_repo_name(self, repo_name, cache=False):
repo = self.sa.query(Repository)\
.filter(Repository.repo_name == repo_name)
if cache:
repo = repo.options(FromCache("sql_cache_short",
"get_repo_%s" % repo_name))
fixed Example celery config to ampq,...
r752 return repo.scalar()
added action loggers to following repositories,...
r735
Major refactoring, removed when possible calls to app globals....
r1036
Code refactoring,models renames...
r629 def get_users_js(self):
users = self.sa.query(User).filter(User.active == True).all()
u_tmpl = '''{id:%s, fname:"%s", lname:"%s", nname:"%s"},'''
#56 hacking on forms, and model for users groups
r1013 users_array = '[%s]' % '\n'.join([u_tmpl % (u.user_id, u.name,
Code refactoring,models renames...
r629 u.lastname, u.username)
for u in users])
return users_array
#56 hacking on forms, and model for users groups
r1013 def get_users_groups_js(self):
users_groups = self.sa.query(UsersGroup)\
.filter(UsersGroup.users_group_active == True).all()
g_tmpl = '''{id:%s, grname:"%s",grmembers:"%s"},'''
users_groups_array = '[%s]' % '\n'.join([g_tmpl % \
(gr.users_group_id, gr.users_group_name,
len(gr.members))
for gr in users_groups])
return users_groups_array
Code refactoring,models renames...
r629 def update(self, repo_name, form_data):
try:
small code fixes to repo model
r822 cur_repo = self.get_by_repo_name(repo_name, cache=False)
Code refactoring,models renames...
r629
#update permissions
#56 added assignments of users groups into repository
r1014 for member, perm, member_type in form_data['perms_updates']:
if member_type == 'user':
r2p = self.sa.query(RepoToPerm)\
Use scoped session for model base
r1393 .filter(RepoToPerm.user == User.by_username(member))\
#56 added assignments of users groups into repository
r1014 .filter(RepoToPerm.repository == cur_repo)\
.one()
Code refactoring,models renames...
r629
#56 added assignments of users groups into repository
r1014 r2p.permission = self.sa.query(Permission)\
Fixed permissions for users groups, group can have create repo permission now....
r1271 .filter(Permission.permission_name ==
perm).scalar()
#56 added assignments of users groups into repository
r1014 self.sa.add(r2p)
else:
Fixed permissions for users groups, group can have create repo permission now....
r1271 g2p = self.sa.query(UsersGroupRepoToPerm)\
.filter(UsersGroupRepoToPerm.users_group ==
UsersGroup.get_by_group_name(member))\
.filter(UsersGroupRepoToPerm.repository ==
cur_repo).one()
#56 added assignments of users groups into repository
r1014
g2p.permission = self.sa.query(Permission)\
Fixed permissions for users groups, group can have create repo permission now....
r1271 .filter(Permission.permission_name ==
perm).scalar()
#56 added assignments of users groups into repository
r1014 self.sa.add(g2p)
Code refactoring,models renames...
r629
#set new permissions
#56 added assignments of users groups into repository
r1014 for member, perm, member_type in form_data['perms_new']:
if member_type == 'user':
r2p = RepoToPerm()
r2p.repository = cur_repo
Use scoped session for model base
r1393 r2p.user = User.by_username(member)
Code refactoring,models renames...
r629
#56 added assignments of users groups into repository
r1014 r2p.permission = self.sa.query(Permission)\
Fixed permissions for users groups, group can have create repo permission now....
r1271 .filter(Permission.
permission_name == perm)\
.scalar()
#56 added assignments of users groups into repository
r1014 self.sa.add(r2p)
else:
Fixed permissions for users groups, group can have create repo permission now....
r1271 g2p = UsersGroupRepoToPerm()
#56 added assignments of users groups into repository
r1014 g2p.repository = cur_repo
Fixed permissions for users groups, group can have create repo permission now....
r1271 g2p.users_group = UsersGroup.get_by_group_name(member)
#56 added assignments of users groups into repository
r1014 g2p.permission = self.sa.query(Permission)\
Fixed permissions for users groups, group can have create repo permission now....
r1271 .filter(Permission.
permission_name == perm)\
.scalar()
#56 added assignments of users groups into repository
r1014 self.sa.add(g2p)
Code refactoring,models renames...
r629
#update current repo
for k, v in form_data.items():
if k == 'user':
Use scoped session for model base
r1393 cur_repo.user = User.by_username(v)
fixed saving settings on repositories inside groups, also fixes #187...
r1323 elif k == 'repo_name':
cur_repo.repo_name = form_data['repo_name_full']
fixes #205 db value was not set to none after moving out of group
r1379 elif k == 'repo_group':
fixed saving settings on repositories inside groups, also fixes #187...
r1323 cur_repo.group_id = v
Code refactoring,models renames...
r629 else:
setattr(cur_repo, k, v)
self.sa.add(cur_repo)
fixed saving settings on repositories inside groups, also fixes #187...
r1323 if repo_name != form_data['repo_name_full']:
# rename repository
self.__rename_repo(old=repo_name,
new=form_data['repo_name_full'])
Code refactoring,models renames...
r629
self.sa.commit()
except:
log.error(traceback.format_exc())
self.sa.rollback()
raise
def create(self, form_data, cur_user, just_db=False, fork=False):
fixes #200, rewrote the whole caching mechanism to get rid of such problems. Now cached instances are attached...
r1366
Code refactoring,models renames...
r629 try:
if fork:
Unicode fixes, added safe_str method for global str() operations +better test sandboxing
r1401 repo_name = form_data['fork_name']
org_name = form_data['repo_name']
org_full_name = org_name
Code refactoring,models renames...
r629
else:
Unicode fixes, added safe_str method for global str() operations +better test sandboxing
r1401 org_name = repo_name = form_data['repo_name']
fixed #47 adding a new repo that have a group chosen had wrong paths.
r1361 repo_name_full = form_data['repo_name_full']
Code refactoring,models renames...
r629 new_repo = Repository()
Enable statistics are disabled by default now
r1075 new_repo.enable_statistics = False
Code refactoring,models renames...
r629 for k, v in form_data.items():
if k == 'repo_name':
fixes #200, rewrote the whole caching mechanism to get rid of such problems. Now cached instances are attached...
r1366 if fork:
v = repo_name
else:
v = repo_name_full
#47 fixed group aware on adding new repo
r1350 if k == 'repo_group':
k = 'group_id'
assure that we don't have an empty description when creating a repo
r1517 if k == 'description':
v = v or repo_name
Code refactoring,models renames...
r629 setattr(new_repo, k, v)
if fork:
parent_repo = self.sa.query(Repository)\
fixes #200, rewrote the whole caching mechanism to get rid of such problems. Now cached instances are attached...
r1366 .filter(Repository.repo_name == org_full_name).one()
Code refactoring,models renames...
r629 new_repo.fork = parent_repo
new_repo.user_id = cur_user.user_id
self.sa.add(new_repo)
#create default permission
repo_to_perm = RepoToPerm()
default = 'repository.read'
fixes #126, all credits go to cejones <chad.jones@milwaukeetool.com>
r1119 for p in UserModel(self.sa).get_by_username('default',
cache=False).user_perms:
Code refactoring,models renames...
r629 if p.permission.permission_name.startswith('repository.'):
default = p.permission.permission_name
break
default_perm = 'repository.none' if form_data['private'] else default
repo_to_perm.permission_id = self.sa.query(Permission)\
.filter(Permission.permission_name == default_perm)\
.one().permission_id
fixed issue with db transaction when filesystem creation of repository failed...
r1028 repo_to_perm.repository = new_repo
fixed Example celery config to ampq,...
r752 repo_to_perm.user_id = UserModel(self.sa)\
.get_by_username('default', cache=False).user_id
Code refactoring,models renames...
r629
self.sa.add(repo_to_perm)
fixed issue with db transaction when filesystem creation of repository failed...
r1028
if not just_db:
#109, added optional clone uri when creating repo....
r1112 self.__create_repo(repo_name, form_data['repo_type'],
#47 fixed group aware on adding new repo
r1350 form_data['repo_group'],
#109, added optional clone uri when creating repo....
r1112 form_data['clone_uri'])
fixed issue with db transaction when filesystem creation of repository failed...
r1028
Code refactoring,models renames...
r629 self.sa.commit()
when new repo is created make user follow it automatically,...
r786
#now automatically start following this repository as owner
from rhodecode.model.scm import ScmModel
ScmModel(self.sa).toggle_following_repo(new_repo.repo_id,
cur_user.user_id)
Code refactoring,models renames...
r629 except:
log.error(traceback.format_exc())
self.sa.rollback()
raise
def create_fork(self, form_data, cur_user):
from rhodecode.lib.celerylib import tasks, run_task
run_task(tasks.create_repo_fork, form_data, cur_user)
def delete(self, repo):
try:
self.sa.delete(repo)
fixed deletion of repository on filesystem, works based on scm type for git and hg....
r668 self.__delete_repo(repo)
Code refactoring,models renames...
r629 self.sa.commit()
except:
log.error(traceback.format_exc())
self.sa.rollback()
raise
def delete_perm_user(self, form_data, repo_name):
try:
self.sa.query(RepoToPerm)\
added action loggers to following repositories,...
r735 .filter(RepoToPerm.repository \
== self.get_by_repo_name(repo_name))\
Code refactoring,models renames...
r629 .filter(RepoToPerm.user_id == form_data['user_id']).delete()
self.sa.commit()
except:
log.error(traceback.format_exc())
self.sa.rollback()
raise
#56 added ajax removal of users groups,...
r1015 def delete_perm_users_group(self, form_data, repo_name):
try:
Fixed permissions for users groups, group can have create repo permission now....
r1271 self.sa.query(UsersGroupRepoToPerm)\
.filter(UsersGroupRepoToPerm.repository \
#56 added ajax removal of users groups,...
r1015 == self.get_by_repo_name(repo_name))\
Fixed permissions for users groups, group can have create repo permission now....
r1271 .filter(UsersGroupRepoToPerm.users_group_id \
#56 added ajax removal of users groups,...
r1015 == form_data['users_group_id']).delete()
self.sa.commit()
except:
log.error(traceback.format_exc())
self.sa.rollback()
raise
added cache reset, stats reset, and delete into repository settings in admin....
r708 def delete_stats(self, repo_name):
try:
self.sa.query(Statistics)\
added action loggers to following repositories,...
r735 .filter(Statistics.repository == \
self.get_by_repo_name(repo_name)).delete()
added cache reset, stats reset, and delete into repository settings in admin....
r708 self.sa.commit()
except:
log.error(traceback.format_exc())
self.sa.rollback()
raise
#47 fixed group aware on adding new repo
r1350 def __create_repo(self, repo_name, alias, new_parent_id, clone_uri=False):
docs update for repo model
r787 """
fixed #47 adding a new repo that have a group chosen had wrong paths.
r1361 makes repository on filesystem. It's group aware means it'll create
a repository within a group, and alter the paths accordingly of
group location
source code cleanup: remove trailing white space, normalize file endings
r1203
docs update for repo model
r787 :param repo_name:
:param alias:
#47 fixed group aware on adding new repo
r1350 :param parent_id:
:param clone_uri:
docs update for repo model
r787 """
changed check_... functions from their stupid names to something less retarded :)
r1507 from rhodecode.lib.utils import is_valid_repo
assure that we don't have an empty description when creating a repo
r1517
#47 fixed group aware on adding new repo
r1350 if new_parent_id:
paths = Group.get(new_parent_id).full_path.split(Group.url_sep())
new_parent_path = os.sep.join(paths)
else:
new_parent_path = ''
Unicode fixes, added safe_str method for global str() operations +better test sandboxing
r1401 repo_path = os.path.join(*map(lambda x:safe_str(x),
[self.repos_path, new_parent_path, repo_name]))
#47 fixed group aware on adding new repo
r1350
changed check_... functions from their stupid names to something less retarded :)
r1507 if is_valid_repo(repo_path, self.repos_path) is False:
#109, added optional clone uri when creating repo....
r1112 log.info('creating repo %s in %s @ %s', repo_name, repo_path,
Unicode fixes, added safe_str method for global str() operations +better test sandboxing
r1401 clone_uri)
extended repo creation by repo type. fixed fork creation to maintain repo type.
r659 backend = get_backend(alias)
Unicode fixes, added safe_str method for global str() operations +better test sandboxing
r1401
#109, added optional clone uri when creating repo....
r1112 backend(repo_path, create=True, src_url=clone_uri)
Code refactoring,models renames...
r629
Unicode fixes, added safe_str method for global str() operations +better test sandboxing
r1401
Code refactoring,models renames...
r629 def __rename_repo(self, old, new):
docs update for repo model
r787 """
renames repository on filesystem
source code cleanup: remove trailing white space, normalize file endings
r1203
docs update for repo model
r787 :param old: old name
:param new: new name
"""
Code refactoring,models renames...
r629 log.info('renaming repo from %s to %s', old, new)
Major refactoring, removed when possible calls to app globals....
r1036 old_path = os.path.join(self.repos_path, old)
new_path = os.path.join(self.repos_path, new)
Code refactoring,models renames...
r629 if os.path.isdir(new_path):
fixed exception message
r1492 raise Exception('Was trying to rename to already existing dir %s' \
% new_path)
Code refactoring,models renames...
r629 shutil.move(old_path, new_path)
fixed deletion of repository on filesystem, works based on scm type for git and hg....
r668 def __delete_repo(self, repo):
docs update for repo model
r787 """
removes repo from filesystem, the removal is acctually made by
added rm__ prefix into dir, and rename internat .hg/.git dirs so this
repository is no longer valid for rhodecode, can be undeleted later on
by reverting the renames on this repository
source code cleanup: remove trailing white space, normalize file endings
r1203
docs update for repo model
r787 :param repo: repo object
"""
Major refactoring, removed when possible calls to app globals....
r1036 rm_path = os.path.join(self.repos_path, repo.repo_name)
Code refactoring,models renames...
r629 log.info("Removing %s", rm_path)
fixed deletion of repository on filesystem, works based on scm type for git and hg....
r668 #disable hg/git
alias = repo.repo_type
shutil.move(os.path.join(rm_path, '.%s' % alias),
os.path.join(rm_path, 'rm__.%s' % alias))
Code refactoring,models renames...
r629 #disable repo
Major refactoring, removed when possible calls to app globals....
r1036 shutil.move(rm_path, os.path.join(self.repos_path, 'rm__%s__%s' \
fixes #126, all credits go to cejones <chad.jones@milwaukeetool.com>
r1119 % (datetime.today()\
.strftime('%Y%m%d_%H%M%S_%f'),
repo.repo_name)))