diff --git a/rhodecode/controllers/admin/repos.py b/rhodecode/controllers/admin/repos.py --- a/rhodecode/controllers/admin/repos.py +++ b/rhodecode/controllers/admin/repos.py @@ -282,10 +282,9 @@ class ReposController(BaseController): """GET /repos/repo_name/edit: Form to edit an existing item""" # url('edit_repo', repo_name=ID) repo_model = RepoModel() + r = ScmModel().get(repo_name) c.repo_info = repo_model.get_by_repo_name(repo_name) - r = ScmModel().get(repo_name) - if c.repo_info is None: h.flash(_('%s repository is not mapped to db perhaps' ' it was created or renamed from the filesystem' diff --git a/rhodecode/model/db.py b/rhodecode/model/db.py --- a/rhodecode/model/db.py +++ b/rhodecode/model/db.py @@ -201,7 +201,7 @@ class Repository(Base, BaseModel): user = relationship('User') fork = relationship('Repository', remote_side=repo_id) group = relationship('Group') - repo_to_perm = relationship('RepoToPerm', cascade='all') + repo_to_perm = relationship('RepoToPerm', cascade='all', order_by='RepoToPerm.repo_to_perm_id') users_group_to_perm = relationship('UsersGroupToPerm', cascade='all') stats = relationship('Statistics', cascade='all', uselist=False) diff --git a/rhodecode/model/scm.py b/rhodecode/model/scm.py --- a/rhodecode/model/scm.py +++ b/rhodecode/model/scm.py @@ -209,11 +209,21 @@ class ScmModel(BaseModel): .filter(Repository.repo_name == repo_name)\ .scalar() + self.sa.expunge_all() + log.debug('making transient %s', dbrepo) make_transient(dbrepo) - if dbrepo.user: - make_transient(dbrepo.user) - if dbrepo.fork: - make_transient(dbrepo.fork) + + for attr in ['user', 'forks', 'followers', 'group', 'repo_to_perm', + 'users_group_to_perm', 'stats', 'logs']: + attr = getattr(dbrepo, attr, False) + if attr: + if isinstance(attr, list): + for a in attr: + log.debug('making transient %s', a) + make_transient(a) + else: + log.debug('making transient %s', attr) + make_transient(attr) repo.dbrepo = dbrepo return repo