changeset 215:70f645fa97cc

Moved repo creation to admin/repos, as part of crud controller. Now repo creation is based on a form, which can be auto filled with data from 404 page. Fixed the error controller to properly give the repo name.
author Marcin Kuzminski <marcin@python-works.com>
date Mon, 24 May 2010 22:18:15 +0200
parents 5b8d00d40bd4
children c8162373f214
files pylons_app/controllers/error.py pylons_app/controllers/repos.py pylons_app/templates/errors/error_404.html
diffstat 3 files changed, 42 insertions(+), 15 deletions(-) [+]
line wrap: on
line diff
--- a/pylons_app/controllers/error.py	Mon May 24 22:16:10 2010 +0200
+++ b/pylons_app/controllers/error.py	Mon May 24 22:18:15 2010 +0200
@@ -8,8 +8,9 @@
 from pylons_app.lib.base import BaseController, render
 from pylons.middleware import  media_path
 from pylons_app.lib.utils import check_repo
+from pylons_app.lib.filters import clean_repo
+log = logging.getLogger(__name__)
 
-log = logging.getLogger(__name__)
 class ErrorController(BaseController):
     """
     Generates error documents as and when they are required.
@@ -20,9 +21,12 @@
     This behaviour can be altered by changing the parameters to the
     ErrorDocuments middleware in your config/middleware.py file.
     """
+#    def __before__(self):
+#        super(ErrorController, self).__before__()
         
     def document(self):
         resp = request.environ.get('pylons.original_response')
+        
         log.debug(resp.status)
 
         e = request.environ
@@ -33,7 +37,10 @@
 
                         
         if resp.status_int == 404:
-            if check_repo(c.repo_name, g.base_path):
+            org_e = request.environ.get('pylons.original_request').environ
+            c.repo_name = repo_name = org_e['PATH_INFO'].split('/')[1]
+            c.repo_name_cleaned = clean_repo(c.repo_name)
+            if check_repo(repo_name, g.base_path):
                 return render('/errors/error_404.html')
                 
         c.error_message = cgi.escape(request.GET.get('code', str(resp.status)))
--- a/pylons_app/controllers/repos.py	Mon May 24 22:16:10 2010 +0200
+++ b/pylons_app/controllers/repos.py	Mon May 24 22:18:15 2010 +0200
@@ -1,14 +1,12 @@
+from pylons import request, response, session, tmpl_context as c, url, \
+    app_globals as g
+from pylons.controllers.util import abort, redirect
+from pylons_app.lib.base import BaseController, render
+from pylons_app.lib.utils import check_repo, invalidate_cache
 import logging
 import os
-from pylons import request, response, session, tmpl_context as c, url, app_globals as g
-from pylons.controllers.util import abort, redirect
-from pylons_app.lib import auth
-from pylons_app.lib.base import BaseController, render
-from pylons_app.model.db import Users, UserLogs
-from pylons_app.model.hg_model import HgModel
-from operator import itemgetter
 import shutil
-from pylons_app.lib.utils import invalidate_cache
+from pylons_app.lib.filters import clean_repo
 log = logging.getLogger(__name__)
 
 class ReposController(BaseController):
@@ -31,10 +29,31 @@
     def create(self):
         """POST /repos: Create a new item"""
         # url('repos')
+        name = request.POST.get('name')
+
+        try:
+            self._create_repo(name)
+            #clear our cached list for refresh with new repo
+            invalidate_cache('cached_repo_list')
+        except Exception as e:
+            log.error(e)
+        
+        return redirect('repos')
+        
+    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 new(self, format='html'):
         """GET /repos/new: Form to create a new item"""
-        # url('new_repo')
+        new_repo = request.GET.get('repo', '')
+        c.new_repo = clean_repo(new_repo)
+
+        return render('admin/repos/repo_add.html')
 
     def update(self, id):
         """PUT /repos/id: Update an existing item"""
--- a/pylons_app/templates/errors/error_404.html	Mon May 24 22:16:10 2010 +0200
+++ b/pylons_app/templates/errors/error_404.html	Mon May 24 22:18:15 2010 +0200
@@ -22,13 +22,14 @@
 </%def>
 <%def name="main()">
 
-    <h2 class="no-link no-border">Not Found</h2>
-    <p class="normal">The specified repository "${c.repo_name}" is unknown, sorry.</p>
+    <h2 class="no-link no-border">${_('Not Found')}</h2>
+    <p class="normal">${_('The specified repository "%s" is unknown, sorry.') % c.repo_name}</p>
     <p class="normal">
-    <a href="/_admin/add_repo/${c.repo_name|n,filters.clean_repo}">Create "${c.repo_name}" repository as ${c.repo_name|n,filters.clean_repo}</a>
+    <a href="${h.url('new_repo',repo=c.repo_name_cleaned)}">
+    ${_('Create "%s" repository as %s' % (c.repo_name,c.repo_name_cleaned))}</a>
 
     </p>
-    <p class="normal">Go back to the ${h.link_to(_('main repository list page'),h.url('hg_home'))}.</p>
+    <p class="normal">${h.link_to(_('Go back to the main repository list page'),h.url('hg_home'))}</p>
     <div class="page-footer">
     </div>
 </%def>
\ No newline at end of file