summaryrefslogtreecommitdiffstats
path: root/module/web/pyload
diff options
context:
space:
mode:
authorGravatar therazer <devnull@localhost> 2010-11-09 15:57:49 +0100
committerGravatar therazer <devnull@localhost> 2010-11-09 15:57:49 +0100
commit46f947f7d8fd3012c648750e685cec8628e5db91 (patch)
treef39f5be671a7c7d64cbcaa8374701fe62321ddc6 /module/web/pyload
parentaccount cache fix (diff)
downloadpyload-46f947f7d8fd3012c648750e685cec8628e5db91.tar.xz
added browser to set paths in settings
Diffstat (limited to 'module/web/pyload')
-rw-r--r--module/web/pyload/templatetags/truncate.py13
-rw-r--r--module/web/pyload/urls.py6
-rw-r--r--module/web/pyload/views.py60
3 files changed, 77 insertions, 2 deletions
diff --git a/module/web/pyload/templatetags/truncate.py b/module/web/pyload/templatetags/truncate.py
new file mode 100644
index 000000000..ed35ea998
--- /dev/null
+++ b/module/web/pyload/templatetags/truncate.py
@@ -0,0 +1,13 @@
+from django.template.defaultfilters import stringfilter
+from django import template
+
+register = template.Library()
+
+
+@stringfilter
+def truncate(value, n):
+ if (n - len(value)) < 3:
+ return value[:n]+"..."
+ return value
+
+register.filter(truncate)
diff --git a/module/web/pyload/urls.py b/module/web/pyload/urls.py
index c4c2f6ef2..6523d711a 100644
--- a/module/web/pyload/urls.py
+++ b/module/web/pyload/urls.py
@@ -17,9 +17,13 @@ urlpatterns = patterns('pyload',
(r'^logs/(?P<item>\d+)$', 'views.logs',{}, 'logs'),
(r'^package_ui.js$', 'views.package_ui', {}, 'package_ui'),
(r'^$', 'views.home',{}, 'home'),
+ url(r'^pathchooser/(?P<path>.*)', 'views.path', name='path'),
+ url(r'^pathchooser/$', 'views.root', name='root'),
)
urlpatterns += patterns('django.contrib.auth',
(r'^login/$', 'views.login', {'template_name': join(settings.TEMPLATE, 'login.html')}),
(r'^logout/$', 'views.logout', {'template_name': join(settings.TEMPLATE, 'logout.html')}, 'logout'),
-) \ No newline at end of file
+)
+
+
diff --git a/module/web/pyload/views.py b/module/web/pyload/views.py
index 240465285..8e08e408b 100644
--- a/module/web/pyload/views.py
+++ b/module/web/pyload/views.py
@@ -2,6 +2,7 @@
# Create your views here.
import mimetypes
+import os
from os import listdir
from os import stat
from os.path import isdir
@@ -12,6 +13,7 @@ from itertools import chain
from datetime import datetime
from time import localtime, strftime
from copy import deepcopy
+from operator import itemgetter
from django.conf import settings
from django.contrib.auth.decorators import login_required
@@ -20,6 +22,7 @@ from django.http import HttpResponseNotFound
from django.shortcuts import render_to_response
from django.template import RequestContext
from django.utils.translation import ugettext as _
+from django.core.urlresolvers import reverse
def get_sort_key(item):
@@ -369,4 +372,59 @@ def config(request):
@permission('pyload.can_change_status')
@check_server
def package_ui(request):
- return render_to_response(join(settings.TEMPLATE, 'package_ui.js'), RequestContext(request, {}, )) \ No newline at end of file
+ return render_to_response(join(settings.TEMPLATE, 'package_ui.js'), RequestContext(request, {}, ))
+
+
+@login_required
+@permission('pyload.can_change_status')
+@check_server
+def root(request):
+ cwd = os.getcwd()
+ return HttpResponseRedirect(reverse('path', args=[cwd[1:]]))
+
+@login_required
+@permission('pyload.can_change_status')
+@check_server
+def path(request, path):
+
+ files = []
+ if os.path.isdir(path):
+ cwd = path
+ else:
+ cwd = os.getcwd()
+
+ if cwd[-1] == '/':
+ parentdir = os.path.split(cwd[:-1])[0]
+ else:
+ parentdir = os.path.split(cwd)[0]
+
+ for f in os.listdir(cwd):
+ data = {'name': f[:50],
+ 'size': '',
+ 'modified': '',
+ 'type': 'file',
+ 'fullpath': ''}
+ data['fullpath'] = os.path.join(cwd, f)
+ data['sort'] = data['fullpath'].lower()
+ data['modified'] = datetime.fromtimestamp(int(os.path.getmtime(os.path.join(cwd, f))))
+ data['ext'] = os.path.splitext(f)[1]
+ if os.path.isdir(os.path.join(cwd, f)):
+ data['type'] = 'dir'
+
+ if os.path.isfile(os.path.join(cwd, f)):
+ data['size'] = os.path.getsize(os.path.join(cwd, f))
+
+ power = 0
+ while (data['size']/1024) > 0.3:
+ power += 1
+ data['size'] = data['size'] / 1024.
+ units = ('', 'K','M','G','T')
+ data['unit'] = units[power]+'Byte'
+
+ files.append(data)
+
+ files = sorted(files, key=itemgetter('type', 'sort'))
+
+ return render_to_response(join(settings.TEMPLATE, 'pathchooser.html'), {'cwd': cwd, 'files': files, 'parentdir': parentdir}, RequestContext(request))
+
+