repo_model.py
170 lines
| 6.6 KiB
| text/x-python
|
PythonLexer
r265 | #!/usr/bin/env python | |||
# encoding: utf-8 | ||||
# model for handling repositories actions | ||||
# Copyright (C) 2009-2010 Marcin Kuzminski <marcin@python-works.com> | ||||
# 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; version 2 | ||||
# of the License or (at your opinion) any later version of the license. | ||||
# | ||||
# 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, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||||
# MA 02110-1301, USA. | ||||
""" | ||||
Created on Jun 5, 2010 | ||||
model for handling repositories actions | ||||
@author: marcink | ||||
""" | ||||
from pylons_app.model.meta import Session | ||||
r296 | from pylons_app.model.db import Repository, Repo2Perm, User, Permission | |||
r265 | import shutil | |||
import os | ||||
from datetime import datetime | ||||
from pylons_app.lib.utils import check_repo | ||||
from pylons import app_globals as g | ||||
r296 | import traceback | |||
r265 | import logging | |||
log = logging.getLogger(__name__) | ||||
class RepoModel(object): | ||||
def __init__(self): | ||||
self.sa = Session() | ||||
def get(self, id): | ||||
return self.sa.query(Repository).get(id) | ||||
r298 | def get_users_js(self): | |||
r328 | users = self.sa.query(User).filter(User.active == True).all() | |||
r298 | u_tmpl = '''{id:%s, fname:"%s", lname:"%s", nname:"%s"},''' | |||
users_array = '[%s];' % '\n'.join([u_tmpl % (u.user_id, u.name, | ||||
u.lastname, u.username) | ||||
for u in users]) | ||||
return users_array | ||||
r265 | ||||
r296 | def update(self, repo_id, form_data): | |||
r265 | try: | |||
r296 | if repo_id != form_data['repo_name']: | |||
r356 | #rename our data | |||
r296 | self.__rename_repo(repo_id, form_data['repo_name']) | |||
cur_repo = self.sa.query(Repository).get(repo_id) | ||||
r265 | for k, v in form_data.items(): | |||
if k == 'user': | ||||
cur_repo.user_id = v | ||||
else: | ||||
setattr(cur_repo, k, v) | ||||
r296 | ||||
#update permissions | ||||
for username, perm in form_data['perms_updates']: | ||||
r2p = self.sa.query(Repo2Perm)\ | ||||
.filter(Repo2Perm.user == self.sa.query(User)\ | ||||
.filter(User.username == username).one())\ | ||||
.filter(Repo2Perm.repository == repo_id).one() | ||||
r265 | ||||
r296 | r2p.permission_id = self.sa.query(Permission).filter( | |||
Permission.permission_name == | ||||
perm).one().permission_id | ||||
self.sa.add(r2p) | ||||
for username, perm in form_data['perms_new']: | ||||
r2p = Repo2Perm() | ||||
r2p.repository = repo_id | ||||
r2p.user = self.sa.query(User)\ | ||||
.filter(User.username == username).one() | ||||
r2p.permission_id = self.sa.query(Permission).filter( | ||||
Permission.permission_name == | ||||
perm).one().permission_id | ||||
self.sa.add(r2p) | ||||
r265 | self.sa.add(cur_repo) | |||
self.sa.commit() | ||||
r296 | except: | |||
log.error(traceback.format_exc()) | ||||
r265 | self.sa.rollback() | |||
raise | ||||
r296 | def create(self, form_data, cur_user, just_db=False): | |||
r265 | try: | |||
r296 | repo_name = form_data['repo_name'] | |||
r265 | new_repo = Repository() | |||
for k, v in form_data.items(): | ||||
setattr(new_repo, k, v) | ||||
new_repo.user_id = cur_user.user_id | ||||
self.sa.add(new_repo) | ||||
r296 | ||||
#create default permission | ||||
repo2perm = Repo2Perm() | ||||
r299 | default_perm = 'repository.none' if form_data['private'] \ | |||
else 'repository.read' | ||||
r296 | repo2perm.permission_id = self.sa.query(Permission)\ | |||
r299 | .filter(Permission.permission_name == default_perm)\ | |||
r296 | .one().permission_id | |||
repo2perm.repository = repo_name | ||||
repo2perm.user_id = self.sa.query(User)\ | ||||
.filter(User.username == 'default').one().user_id | ||||
self.sa.add(repo2perm) | ||||
r265 | self.sa.commit() | |||
r296 | if not just_db: | |||
self.__create_repo(repo_name) | ||||
except: | ||||
log.error(traceback.format_exc()) | ||||
r265 | self.sa.rollback() | |||
raise | ||||
def delete(self, repo): | ||||
try: | ||||
self.sa.delete(repo) | ||||
self.sa.commit() | ||||
self.__delete_repo(repo.repo_name) | ||||
r296 | except: | |||
log.error(traceback.format_exc()) | ||||
r265 | self.sa.rollback() | |||
raise | ||||
r299 | def delete_perm_user(self, form_data, repo_name): | |||
try: | ||||
r2p = self.sa.query(Repo2Perm).filter(Repo2Perm.repository == repo_name)\ | ||||
.filter(Repo2Perm.user_id == form_data['user_id']).delete() | ||||
self.sa.commit() | ||||
except: | ||||
log.error(traceback.format_exc()) | ||||
self.sa.rollback() | ||||
raise | ||||
r265 | def __create_repo(self, repo_name): | |||
repo_path = os.path.join(g.base_path, repo_name) | ||||
if check_repo(repo_name, g.base_path): | ||||
log.info('creating repo %s in %s', repo_name, repo_path) | ||||
from vcs.backends.hg import MercurialRepository | ||||
MercurialRepository(repo_path, create=True) | ||||
def __rename_repo(self, old, new): | ||||
r356 | log.info('renaming repo from %s to %s', old, new) | |||
r265 | old_path = os.path.join(g.base_path, old) | |||
new_path = os.path.join(g.base_path, new) | ||||
r356 | if os.path.isdir(new_path): | |||
raise Exception('Was trying to rename to already existing dir %s', | ||||
new_path) | ||||
r265 | shutil.move(old_path, new_path) | |||
def __delete_repo(self, name): | ||||
rm_path = os.path.join(g.base_path, name) | ||||
log.info("Removing %s", rm_path) | ||||
#disable hg | ||||
shutil.move(os.path.join(rm_path, '.hg'), os.path.join(rm_path, 'rm__.hg')) | ||||
#disable repo | ||||
r296 | shutil.move(rm_path, os.path.join(g.base_path, 'rm__%s__%s' \ | |||
% (datetime.today(), name))) | ||||