summaryrefslogtreecommitdiffstats
path: root/module/web/ajax/views.py
diff options
context:
space:
mode:
Diffstat (limited to 'module/web/ajax/views.py')
-rw-r--r--module/web/ajax/views.py256
1 files changed, 256 insertions, 0 deletions
diff --git a/module/web/ajax/views.py b/module/web/ajax/views.py
new file mode 100644
index 000000000..82e478af3
--- /dev/null
+++ b/module/web/ajax/views.py
@@ -0,0 +1,256 @@
+# Create your views here.
+from os.path import join
+import time
+
+from django.conf import settings
+from django.core.serializers import json
+from django.http import HttpResponse
+from django.http import HttpResponseForbidden
+from django.http import HttpResponseServerError
+from django.utils import simplejson
+from django.utils.translation import ugettext as _
+import base64
+
+from traceback import print_exc
+
+def format_time(seconds):
+ seconds = int(seconds)
+
+ hours, seconds = divmod(seconds, 3600)
+ minutes, seconds = divmod(seconds, 60)
+ return "%.2i:%.2i:%.2i" % (hours, minutes, seconds)
+
+
+def permission(perm):
+ def _dec(view_func):
+ def _view(request, * args, ** kwargs):
+ if request.user.has_perm(perm) and request.user.is_authenticated():
+ return view_func(request, * args, ** kwargs)
+ else:
+ return HttpResponseForbidden()
+
+ _view.__name__ = view_func.__name__
+ _view.__dict__ = view_func.__dict__
+ _view.__doc__ = view_func.__doc__
+
+ return _view
+
+ return _dec
+
+class JsonResponse(HttpResponse):
+ def __init__(self, object):
+ content = simplejson.dumps(
+ object, indent=2, cls=json.DjangoJSONEncoder,
+ ensure_ascii=False)
+ super(JsonResponse, self).__init__(
+ content)#, content_type='application/json') #@TODO uncomment
+ self['Cache-Control'] = 'no-cache, must-revalidate'
+
+
+@permission('pyload.can_add')
+def add_package(request):
+
+ name = request.POST['add_name']
+
+ queue = int(request.POST['add_dest'])
+
+ links = request.POST['add_links'].replace(" ", "\n").split("\n")
+
+ try:
+ f = request.FILES['add_file']
+
+ if name == None or name == "":
+ name = f.name
+
+ fpath = join(settings.PYLOAD.get_conf_val("general","download_folder"), "tmp_"+ f.name)
+ destination = open(fpath, 'wb')
+ for chunk in f.chunks():
+ destination.write(chunk)
+ destination.close()
+ links.insert(0, fpath)
+ except:
+ pass
+
+ if name == None or name == "":
+ return HttpResponseServerError()
+
+ links = map(lambda x: x.strip(), links)
+ links = filter(lambda x: x != "", links)
+
+
+ settings.PYLOAD.add_package(name, links, queue)
+
+ return JsonResponse("success")
+
+@permission('pyload.can_add')
+def remove_link(request, id):
+ try:
+ settings.PYLOAD.del_links([int(id)])
+ return JsonResponse("sucess")
+ except Exception, e:
+ return HttpResponseServerError()
+
+@permission('pyload.can_see_dl')
+def status(request):
+ try:
+ status = settings.PYLOAD.status_server()
+ status['captcha'] = settings.PYLOAD.is_captcha_waiting()
+ return JsonResponse(status)
+ except:
+ return HttpResponseServerError()
+
+@permission('pyload.can_see_dl')
+def links(request):
+ try:
+ links = settings.PYLOAD.status_downloads()
+ ids = []
+ for link in links:
+ ids.append(link['id'])
+
+ if link['status'] == 12:
+ link['info'] = "%s @ %s kb/s" % (link['format_eta'], round(link['speed'], 2))
+ elif link['status'] == 5:
+ link['percent'] = 0
+ link['size'] = 0
+ link['kbleft'] = 0
+ link['info'] = _("waiting %s") % link['format_wait']
+ else:
+ link['info'] = ""
+
+
+ data = {}
+ data['links'] = links
+ data['ids'] = ids
+ return JsonResponse(data)
+ except Exception, e:
+ return HttpResponseServerError()
+
+@permission('pyload.can_see_dl')
+def queue(request):
+ try:
+ return JsonResponse(settings.PYLOAD.get_queue())
+
+ except:
+ return HttpResponseServerError()
+
+
+@permission('pyload.can_change_satus')
+def pause(request):
+ try:
+ return JsonResponse(settings.PYLOAD.pause_server())
+
+ except:
+ return HttpResponseServerError()
+
+
+@permission('pyload.can_change_status')
+def unpause(request):
+ try:
+ return JsonResponse(settings.PYLOAD.unpause_server())
+
+ except:
+ return HttpResponseServerError()
+
+
+@permission('pyload.can_change_status')
+def cancel(request):
+ try:
+ return JsonResponse(settings.PYLOAD.stop_downloads())
+ except:
+ return HttpResponseServerError()
+
+@permission('pyload.can_see_dl')
+def packages(request):
+ try:
+ data = settings.PYLOAD.get_queue()
+
+ for package in data:
+ package['links'] = []
+ for file in settings.PYLOAD.get_package_files(package['id']):
+ package['links'].append(settings.PYLOAD.get_file_info(file))
+
+ return JsonResponse(data)
+
+ except:
+ return HttpResponseServerError()
+
+@permission('pyload.can_see_dl')
+def package(request, id):
+ try:
+ data = settings.PYLOAD.get_package_data(int(id))
+ data['links'] = []
+ for file in settings.PYLOAD.get_package_files(data['id']):
+ data['links'].append(settings.PYLOAD.get_file_info(file))
+
+ return JsonResponse(data)
+
+ except:
+ return HttpResponseServerError()
+
+@permission('pyload.can_see_dl')
+def link(request, id):
+ try:
+ data = settings.PYLOAD.get_file_info(int(id))
+ return JsonResponse(data)
+
+ except:
+ return HttpResponseServerError()
+
+@permission('pyload.can_add_dl')
+def remove_package(request, id):
+ try:
+ settings.PYLOAD.del_packages([int(id)])
+ return JsonResponse("sucess")
+ except Exception, e:
+ print_exc()
+ return HttpResponseServerError()
+
+@permission('pyload.can_add_dl')
+def restart_package(request, id):
+ try:
+ settings.PYLOAD.restart_package(int(id))
+ return JsonResponse("sucess")
+ except Exception:
+ return HttpResponseServerError()
+
+@permission('pyload.can_add_dl')
+def restart_link(request, id):
+ try:
+ settings.PYLOAD.restart_file(int(id))
+ return JsonResponse("sucess")
+ except Exception:
+ return HttpResponseServerError()
+
+@permission('pyload.can_add_dl')
+def abort_link(request, id):
+ try:
+ settings.PYLOAD.stop_download("link", int(id))
+ return JsonResponse("sucess")
+ except:
+ return HttpResponseServerError()
+
+@permission('pyload.can_add_dl')
+def push_to_queue(request, id):
+ try:
+ settings.PYLOAD.push_package_to_queue(int(id))
+ return JsonResponse("sucess")
+ except:
+ return HttpResponseServerError()
+
+@permission('pyload.can_add_dl')
+def set_captcha(request):
+ if request.META['REQUEST_METHOD'] == "POST":
+ try:
+ settings.PYLOAD.set_captcha_result(request.POST["cap_id"], request.POST["cap_text"])
+ except:
+ pass
+
+ id, binary, typ = settings.PYLOAD.get_captcha_task()
+
+ if id:
+ binary = base64.standard_b64encode(str(binary))
+ src = "data:image/%s;base64,%s" % (typ, binary)
+
+ return JsonResponse({'captcha': True, 'src': src, 'id': id})
+ else:
+ return JsonResponse({'captcha': False})