##// END OF EJS Templates
Merged in liads/rhodecode (pull request #14)
Merged in liads/rhodecode (pull request #14)

File last commit:

r1594:9dae92a6 beta
r1623:b7094c69 merge beta
Show More
repos_group.py
164 lines | 4.9 KiB | text/x-python | PythonLexer
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 # -*- coding: utf-8 -*-
"""
rhodecode.model.user_group
~~~~~~~~~~~~~~~~~~~~~~~~~~
users groups model for RhodeCode
:created_on: Jan 25, 2011
:author: marcink
:copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com>
:license: GPLv3, see COPYING for more details.
"""
# 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.
#
# 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 General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import os
import logging
import traceback
#47 implemented basic edition of groups
r1347 import shutil
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
from pylons.i18n.translation import _
from vcs.utils.lazy import LazyProperty
from rhodecode.model import BaseModel
from rhodecode.model.caching_query import FromCache
from rhodecode.model.db import Group, RhodeCodeUi
Nicolas VINOT
Correct code style
r1593 log = logging.getLogger(__name__)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
Nicolas VINOT
Correct code style
r1593 class ReposGroupModel(BaseModel):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
@LazyProperty
Nicolas VINOT
Correct code style
r1593 def repos_path(self):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 """
Get's the repositories root path from database
"""
Nicolas VINOT
Correct code style
r1593 q = RhodeCodeUi.get_by_key('/').one()
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 return q.ui_value
fixes #288...
r1594 def __create_group(self, group_name):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 """
makes repositories group on filesystem
:param repo_name:
:param parent_id:
"""
fixes #288...
r1594 create_path = os.path.join(self.repos_path, group_name)
Nicolas VINOT
Correct code style
r1593 log.debug('creating new group in %s', create_path)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
Nicolas VINOT
Correct code style
r1593 if os.path.isdir(create_path):
raise Exception('That directory already exists !')
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
Nicolas VINOT
Correct code style
r1593 os.makedirs(create_path)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
fixes #288...
r1594 def __rename_group(self, old, new):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 """
Renames a group on filesystem
fixes #288...
r1594
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 :param group_name:
"""
fixes #288...
r1594
if old == new:
log.debug('skipping group rename')
return
Nicolas VINOT
Correct code style
r1593 log.debug('renaming repos group from %s to %s', old, new)
#47 added editing of groups, and moving them between. Added check constraint for groups...
r1349
#47 implemented basic edition of groups
r1347
fixes #288...
r1594 old_path = os.path.join(self.repos_path, old)
new_path = os.path.join(self.repos_path, new)
#47 added editing of groups, and moving them between. Added check constraint for groups...
r1349
Nicolas VINOT
Correct code style
r1593 log.debug('renaming repos paths from %s to %s', old_path, new_path)
#47 added editing of groups, and moving them between. Added check constraint for groups...
r1349
Nicolas VINOT
Correct code style
r1593 if os.path.isdir(new_path):
raise Exception('Was trying to rename to already '
'existing dir %s' % new_path)
shutil.move(old_path, new_path)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
Nicolas VINOT
Correct code style
r1593 def __delete_group(self, group):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 """
Deletes a group from a filesystem
fixes #288...
r1594
#47 implemented deleting of empty groups. Fixed problem with full paths on nested groups
r1346 :param group: instance of group from database
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 """
Nicolas VINOT
Correct code style
r1593 paths = group.full_path.split(Group.url_sep())
paths = os.sep.join(paths)
#47 implemented deleting of empty groups. Fixed problem with full paths on nested groups
r1346
Nicolas VINOT
Correct code style
r1593 rm_path = os.path.join(self.repos_path, paths)
fixes #288...
r1594 if os.path.isdir(rm_path):
# delete only if that path really exists
os.rmdir(rm_path)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
Nicolas VINOT
Correct code style
r1593 def create(self, form_data):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 try:
new_repos_group = Group()
fixes #288...
r1594 new_repos_group.group_description = form_data['group_description']
new_repos_group.parent_group = Group.get(form_data['group_parent_id'])
new_repos_group.group_name = new_repos_group.get_new_name(form_data['group_name'])
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
Nicolas VINOT
Correct code style
r1593 self.sa.add(new_repos_group)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
fixes #288...
r1594 self.__create_group(new_repos_group.group_name)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
self.sa.commit()
Nicolas VINOT
[API] Create groups needed when creating repo
r1589 return new_repos_group
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 except:
Nicolas VINOT
Correct code style
r1593 log.error(traceback.format_exc())
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 self.sa.rollback()
raise
Nicolas VINOT
Correct code style
r1593 def update(self, repos_group_id, form_data):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
try:
Nicolas VINOT
Correct code style
r1593 repos_group = Group.get(repos_group_id)
fixes #288...
r1594 old_path = repos_group.full_path
# change properties
repos_group.group_description = form_data['group_description']
repos_group.parent_group = Group.get(form_data['group_parent_id'])
repos_group.group_name = repos_group.get_new_name(form_data['group_name'])
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
fixes #288...
r1594 new_path = repos_group.full_path
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345
Nicolas VINOT
Correct code style
r1593 self.sa.add(repos_group)
#47 implemented basic edition of groups
r1347
fixes #288...
r1594 self.__rename_group(old_path, new_path)
# we need to get all repositories from this new group and
# rename them accordingly to new group path
for r in repos_group.repositories:
r.repo_name = r.get_new_name(r.just_name)
self.sa.add(r)
#47 implemented basic edition of groups
r1347
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 self.sa.commit()
fixes #288...
r1594 return repos_group
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 except:
Nicolas VINOT
Correct code style
r1593 log.error(traceback.format_exc())
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 self.sa.rollback()
raise
Nicolas VINOT
Correct code style
r1593 def delete(self, users_group_id):
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 try:
Nicolas VINOT
Correct code style
r1593 users_group = Group.get(users_group_id)
self.sa.delete(users_group)
self.__delete_group(users_group)
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 self.sa.commit()
except:
Nicolas VINOT
Correct code style
r1593 log.error(traceback.format_exc())
#47 implemented Adding of new repo_groups+forms+validators. Fixed sorting of repo groups by main names in multiple locations. Removed some unneeded calls to self.sa for exchange to .query() methods....
r1345 self.sa.rollback()
raise