diff pylons_app/model/repo_model.py @ 312:d303aacb3349

repos crud controllers - change id into repo_name for compatability, added ajax repo perm user function variuos html fixes, permissions forms and managment fixes. Added permission fetching for each request in AuthUser instance
author Marcin Kuzminski <marcin@python-works.com>
date Mon, 28 Jun 2010 13:54:47 +0200
parents 15e96b5a2685
children cec5cbc956c0
line wrap: on
line diff
--- a/pylons_app/model/repo_model.py	Sat Jun 26 18:42:13 2010 +0200
+++ b/pylons_app/model/repo_model.py	Mon Jun 28 13:54:47 2010 +0200
@@ -104,8 +104,10 @@
 
             #create default permission
             repo2perm = Repo2Perm()
+            default_perm = 'repository.none' if form_data['private'] \
+                                                        else 'repository.read'
             repo2perm.permission_id = self.sa.query(Permission)\
-                    .filter(Permission.permission_name == 'repository.read')\
+                    .filter(Permission.permission_name == default_perm)\
                     .one().permission_id
                         
             repo2perm.repository = repo_name
@@ -130,7 +132,16 @@
             log.error(traceback.format_exc())
             self.sa.rollback()
             raise
-       
+    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
+           
     def __create_repo(self, repo_name):        
         repo_path = os.path.join(g.base_path, repo_name)
         if check_repo(repo_name, g.base_path):