- base_dir = os.path.join(settings.MEDIA_ROOT, settings.FILEBROWSER_DIRECTORY, directory)
- print base_dir
- images = ['%s%s%s/%s' % (settings.MEDIA_URL, settings.FILEBROWSER_DIRECTORY, directory, f) for f in os.listdir(base_dir) if os.path.splitext(f)[1].lower() in ('.jpg', '.jpeg', '.png')]
- return HttpResponse(json.dumps(images))
- except (IndexError, OSError), e:
- raise Http404
+ base_url = ''.join((
+ smart_unicode(settings.MEDIA_URL),
+ smart_unicode(settings.FILEBROWSER_DIRECTORY),
+ smart_unicode(directory)))
+
+ base_dir = os.path.join(
+ smart_unicode(settings.MEDIA_ROOT),
+ smart_unicode(settings.FILEBROWSER_DIRECTORY),
+ smart_unicode(directory))
+
+ def map_to_url(filename):
+ return "%s/%s" % (base_url, smart_unicode(filename))
+
+ def is_image(filename):
+ return os.path.splitext(f)[1].lower() in (u'.jpg', u'.jpeg', u'.png')
+
+ images = [map_to_url(f) for f in map(smart_unicode, os.listdir(base_dir)) if is_image(f)]
+ images.sort()
+ return JSONResponse(images)
+ except (IndexError, OSError), exc:
+ import traceback
+ traceback.print_exc()
+ raise http.Http404
+
+
+@never_cache
+def document_diff(request, name):
+ storage = getstorage()
+
+ revA = int(request.GET.get('from', 0))
+ revB = int(request.GET.get('to', 0))
+
+ if revA > revB:
+ revA, revB = revB, revA
+
+ if revB == 0:
+ revB = None
+
+ docA = storage.get_or_404(name, int(revA))
+ docB = storage.get_or_404(name, int(revB))
+
+ return http.HttpResponse(nice_diff.html_diff_table(docA.plain_text.splitlines(),
+ docB.plain_text.splitlines()))
+
+
+@never_cache
+def document_history(request, name):
+ storage = getstorage()
+ return JSONResponse(storage.history(name))
+
+
+@require_POST
+def document_add_tag(request, name):
+ storage = getstorage()
+
+ form = DocumentTagForm(request.POST)
+ if form.is_valid():
+ doc = storage.get_or_404(name, form.cleaned_data['version'])
+ doc.add_tag(form.cleaned_data['tag'])
+ return JSONResponse({"message": _("Tag added")})
+ else:
+ return JSONFormInvalid(form)
+
+
+@require_POST
+def document_publish(request, name, version):
+ storage = getstorage()
+
+ # get the document
+ document = storage.get_or_404(name, revision=int(version))
+
+ api = wlapi.WLAPI(settings.WL_API_CONFIG)
+ try:
+ return JSONResponse({"result": api.publish_book(document)})
+ except wlapi.APICallException, e:
+ return JSONServerError({"message": str(e)})