]> git.openstreetmap.org Git - osqa.git/blobdiff - forum_modules/sximporter/views.py
Resolves OSQA-721, adding the ViewBox images in a separate directory in the media...
[osqa.git] / forum_modules / sximporter / views.py
index 76bc8e4be99087b82c1f1f035e7ced07f6a06f83..ebaed2133e8c2957c814b991524e646a5202a780 100644 (file)
@@ -1,21 +1,38 @@
 from django.shortcuts import render_to_response\r
 from django.template import RequestContext\r
-from forum.views.admin import super_user_required\r
+from forum.http_responses import HttpResponseUnauthorized\r
+from forum.models import User\r
 import importer\r
 from zipfile import ZipFile\r
 import os\r
 \r
-@super_user_required\r
 def sximporter(request):\r
-    list = []\r
-    if request.method == "POST" and "dump" in request.FILES:\r
-        dump = ZipFile(request.FILES['dump'])\r
-        members = [f for f in dump.namelist() if f.endswith('.xml')]\r
-        extract_to = os.path.join(os.path.dirname(__file__), 'tmp')\r
-        dump.extractall(extract_to, members)\r
-        importer.sximport(extract_to, request.POST)\r
-        dump.close()\r
-\r
-    return render_to_response('modules/sximporter/page.html', {\r
-    'names': list\r
-    }, context_instance=RequestContext(request))
\ No newline at end of file
+    if (not User.objects.exists()) or (request.user.is_authenticated() and request.user.is_superuser):\r
+        list = []\r
+        if request.method == "POST" and "dump" in request.FILES:\r
+            dump = ZipFile(request.FILES['dump'])\r
+            members = [f for f in dump.namelist() if f.endswith('.xml')]\r
+            extract_to = os.path.join(os.path.dirname(__file__), 'tmp')\r
+\r
+            if not os.path.exists(extract_to):\r
+                os.makedirs(extract_to)\r
+\r
+            for m in members:\r
+                f = open(os.path.join(extract_to, m), 'w')\r
+                f.write(dump.read(m))\r
+                f.close()\r
+\r
+            #dump.extractall(extract_to, members)\r
+            dump.close()\r
+\r
+            options = dict([(k, v) for k, v in request.POST.items()])\r
+            options['authenticated_user'] = (request.user.is_authenticated() and (request.user,) or (None,))[0]\r
+\r
+            importer.sximport(extract_to, options)\r
+\r
+        return render_to_response('modules/sximporter/page.html', {\r
+        'names': list\r
+        }, context_instance=RequestContext(request))\r
+    else:\r
+        return HttpResponseUnauthorized(request)\r
+\r