summaryrefslogtreecommitdiffstats
path: root/module/web
diff options
context:
space:
mode:
authorGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2010-04-05 18:57:22 +0200
committerGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2010-04-05 18:57:22 +0200
commitb8f5255070c36abea1912ab848dbc4070f4dde92 (patch)
tree92807650ee1823ccc3aa38f7338f6f65beb5a905 /module/web
parentexternalscript fix (diff)
downloadpyload-b8f5255070c36abea1912ab848dbc4070f4dde92.tar.xz
captcha input for webif
Diffstat (limited to 'module/web')
-rw-r--r--module/web/ajax/urls.py1
-rw-r--r--module/web/ajax/views.py26
-rw-r--r--module/web/media/default/css/window.css18
-rw-r--r--module/web/media/default/img/images.pngbin0 -> 661 bytes
-rw-r--r--module/web/pyload/views.py2
-rw-r--r--module/web/templates/default/base.html99
-rw-r--r--module/web/templates/default/captcha.html37
7 files changed, 155 insertions, 28 deletions
diff --git a/module/web/ajax/urls.py b/module/web/ajax/urls.py
index dd68729eb..a32a00d89 100644
--- a/module/web/ajax/urls.py
+++ b/module/web/ajax/urls.py
@@ -27,4 +27,5 @@ urlpatterns = patterns('ajax',
(r'^remove_link/(\d+)$', 'views.remove_link'),
(r'^restart_link/(\d+)$', 'views.restart_link'),
(r'^push_to_queue/(\d+)$', 'views.push_to_queue'),
+ (r'^set_captcha$', 'views.set_captcha'),
) \ No newline at end of file
diff --git a/module/web/ajax/views.py b/module/web/ajax/views.py
index 4265e8081..a0e1238aa 100644
--- a/module/web/ajax/views.py
+++ b/module/web/ajax/views.py
@@ -1,4 +1,3 @@
-
# Create your views here.
from os.path import join
import time
@@ -10,6 +9,7 @@ from django.http import HttpResponseForbidden
from django.http import HttpResponseServerError
from django.utils import simplejson
from django.utils.translation import ugettext as _
+import base64
def format_time(seconds):
seconds = int(seconds)
@@ -89,7 +89,9 @@ def remove_link(request, id):
@permission('pyload.can_see_dl')
def status(request):
try:
- return JsonResponse(settings.PYLOAD.status_server())
+ status = settings.PYLOAD.status_server()
+ status['captcha'] = settings.PYLOAD.is_captcha_waiting()
+ return JsonResponse(status)
except:
return HttpResponseServerError()
@@ -229,4 +231,22 @@ def push_to_queue(request, id):
settings.PYLOAD.push_package_2_queue(int(id))
return JsonResponse("sucess")
except:
- return HttpResponseServerError() \ No newline at end of file
+ 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})
diff --git a/module/web/media/default/css/window.css b/module/web/media/default/css/window.css
index 237cf9ac3..606913be6 100644
--- a/module/web/media/default/css/window.css
+++ b/module/web/media/default/css/window.css
@@ -13,30 +13,30 @@
}
/* ----------- stylized ----------- */
-#add_box{
+#add_box, #cap_box{
border:solid 2px #b7ddf2;
background:#ebf4fb;
}
-#add_box h1 {
+#add_box h1, #cap_box h1 {
font-size:14px;
font-weight:bold;
margin-bottom:8px;
}
-#add_box p{
+#add_box p, #cap_box p{
font-size:11px;
color:#666666;
margin-bottom:20px;
border-bottom:solid 1px #b7ddf2;
padding-bottom:10px;
}
-#add_box label{
+#add_box label, #cap_box label{
display:block;
font-weight:bold;
text-align:right;
width:240px;
float:left;
}
-#add_box .small{
+#add_box .small, #cap_box .small{
color:#666666;
display:block;
font-size:11px;
@@ -44,7 +44,7 @@
text-align:right;
width:240px;
}
-#add_box input{
+#add_box input, #cap_box input{
float:left;
font-size:12px;
padding:4px 2px;
@@ -52,14 +52,14 @@
width:300px;
margin:2px 0 20px 10px;
}
-#add_box .cont{
+#add_box .cont, #cap_box .cont{
float:left;
font-size:12px;
padding: 0px 10px 15px 0px;
width:300px;
margin:0px 0px 0px 10px;
}
-#add_box .cont input{
+#add_box .cont input, #cap_box .cont input{
float: none;
margin: 0px 15px 0px 1px;
}
@@ -71,7 +71,7 @@
width:300px;
margin:2px 0 20px 10px;
}
-#add_box button{
+#add_box button, #cap_box button{
clear:both;
margin-left:150px;
width:125px;
diff --git a/module/web/media/default/img/images.png b/module/web/media/default/img/images.png
new file mode 100644
index 000000000..184860d1e
--- /dev/null
+++ b/module/web/media/default/img/images.png
Binary files differ
diff --git a/module/web/pyload/views.py b/module/web/pyload/views.py
index db04f8c67..388184f24 100644
--- a/module/web/pyload/views.py
+++ b/module/web/pyload/views.py
@@ -57,7 +57,7 @@ def permission(perm):
def status_proc(request):
- return {'status': settings.PYLOAD.status_server()}
+ return {'status': settings.PYLOAD.status_server(), 'captcha': settings.PYLOAD.is_captcha_waiting()}
def base(request, messages):
diff --git a/module/web/templates/default/base.html b/module/web/templates/default/base.html
index 7aa6267a3..4631ec382 100644
--- a/module/web/templates/default/base.html
+++ b/module/web/templates/default/base.html
@@ -21,11 +21,12 @@
<title>{% block title %}pyLoad {% trans "Webinterface" %}{% endblock %}</title>
<script type="text/javascript">
-var add_bg,add_box
+var add_bg, add_box, cap_box, cap_info
document.addEvent("domready", function(){
add_bg = new Fx.Tween($('add_bg'));
add_box = new Fx.Tween($('add_box'));
+ cap_box = new Fx.Tween($('cap_box'))
$('add_form').onsubmit=function() {
$('add_form').target = 'upload_target';
@@ -64,23 +65,37 @@ document.addEvent("domready", function(){
$('action_stop').addEvent('click', function(){
new Request({method: 'get', url: '/json/pause'}).send();
});
-
+
+ $('cap_info').addEvent('click', function(){
+ load_cap("get", "");
+ show_cap();
+ });
+
+ $('cap_reset').addEvent('click', function(){
+ hide_cap()
+ });
+
+ $('cap_form').addEvent('submit', function(e){
+ submit_cap();
+ e.stop()
+ });
+
jsonStatus.startTimer();
});
-/*function UpdateLinks( SetInver, index )
-{
- $("#aktiv_percent").text(parseInt($("#aktiv_percent").text)+1)
- setTimeout( UpdateLinks( SetInver, index+1 ), SetInver[index]*1000);
-}*/
-
function LoadJsonToContent(data)
{
$("speed").set('text', Math.round(data.speed*100)/100);
$("aktiv").set('text', data.activ);
$("aktiv_from").set('text', data.queue);
+ if (data.captcha){
+ $("cap_info").setStyle('display', 'inline');
+ }else{
+ $("cap_info").setStyle('display', 'none');
+ }
+
if (data.download) {
$("time").set('text', " {% trans "on" %}");
$("time").setStyle('background-color', "#8ffc25");
@@ -99,25 +114,72 @@ function LoadJsonToContent(data)
$("reconnect").setStyle('background-color', "#fc6e26");
}
}
-function show(){
- add_bg.set('opacity', 0);
+function bg_show(){
+ add_bg.set('opacity', 0);
$("add_bg").setStyle('display', 'block');
add_bg.start('opacity',0.8);
-
+}
+
+function bg_hide(){
+ add_bg.start('opacity',0).chain(function(){
+ $('add_bg').setStyle('display', 'none');
+ });
+}
+
+function show(){
+ bg_show()
add_box.set('opacity', 0)
$("add_box").setStyle('display', 'block');
add_box.start('opacity',1)
}
function out(){
- add_bg.start('opacity',0).chain(function(){
- $('add_bg').setStyle('display', 'none');
- });
-
+ bg_hide()
add_box.start('opacity',0).chain(function(){
$('add_box').setStyle('display', 'none');
});
}
+function show_cap(){
+ bg_show()
+ cap_box.set('opacity', 0)
+ $("cap_box").setStyle('display', 'block');
+ cap_box.start('opacity',1)
+}
+
+function hide_cap(){
+ bg_hide()
+ cap_box.start('opacity',0).chain(function(){
+ $('cap_box').setStyle('display', 'none');
+ });
+}
+
+function load_cap(method, post){
+ new Request.JSON({
+ url: "/json/set_captcha",
+ onSuccess: function(data){
+ if (data.captcha){
+ $('cap_img').set('src', data.src);
+ $('cap_span').setStyle('display', 'block');
+ $$('#cap_form p')[0].set('text', '{% trans "Please read the text on the captcha." %}');
+ $('cap_id').set('value', data.id);
+ } else{
+ $('cap_img').set('src', '');
+ $('cap_span').setStyle('display', 'none');
+ $$('#cap_form p')[0].set('text', '{% trans "No Captchas to read." %}');
+ }
+ },
+ secure: false,
+ async: true,
+ method: method
+ }).send(post);
+}
+
+function submit_cap(){
+ load_cap("post", "cap_id="+ $('cap_id').get('value') +"&cap_text=" + $('cap_text').get('value') );
+ $('cap_text').set('value', '');
+ return false;
+}
+
function AddBox()
{
@@ -144,6 +206,12 @@ function AddBox()
<div id="head-search-and-login">
{% if user.is_authenticated %}
+
+<span id="cap_info" style="display: {% if captcha %}inline{%else%}none{% endif %}">
+<img src="{{ MEDIA_URL }}img/images.png" alt="Captcha:" style="vertical-align:middle; margin:2px" />
+<font style="font-weight: bold; cursor: pointer; margin-right: 2px;">{% trans "Captcha waiting" %}</font>
+</span>
+
<img src="{{ MEDIA_URL }}img/head-login.png" alt="User:" style="vertical-align:middle; margin:2px" /><span style="padding-right: 2px;">{{user.username}}</span>
<ul id="user-actions">
<li><a href="/logout" class="action logout" rel="nofollow">{% trans "Logout" %}</a></li>
@@ -245,5 +313,6 @@ function AddBox()
</div>
{% include "default/window.html" %}
+{% include "default/captcha.html" %}
</body>
</html>
diff --git a/module/web/templates/default/captcha.html b/module/web/templates/default/captcha.html
new file mode 100644
index 000000000..aa30e365c
--- /dev/null
+++ b/module/web/templates/default/captcha.html
@@ -0,0 +1,37 @@
+{% load i18n %}
+<iframe id="upload_target" name="upload_target" src="" style="display: none; width:0;height:0"></iframe>
+<div id="add_bg" style="filter:alpha(opacity:80);KHTMLOpacity:0.80;MozOpacity:0.80;opacity:0.80; background:#000; width:100%; height: 100%; position:absolute; top:0px; left:0px; display:none;">&nbsp;</div>
+<!--<div id="add_box" style="left:50%; top:200px; margin-left: -450px; width: 900px; position: absolute; background: #FFF; padding: 10px 10px 10px 10px; display:none;">-->
+
+ <!--<div style="width: 900px; text-align: right;"><b onclick="AddBox();">[Close]</b></div>-->
+<div id="cap_box" class="myform">
+ <form id="cap_form" action="/json/set_captcha" method="POST" enctype="multipart/form-data" onsubmit="return false;">
+<h1>{% trans "Captcha reading" %}</h1>
+<p>{% trans "Please read the text on the captcha." %}</p>
+
+<span id="cap_span">
+
+<label>{% trans "Captcha" %}
+<span class="small">{% trans "The captcha." %}</span>
+</label>
+<span class="cont">
+ <img id="cap_img" style="padding: 2px;" src="">
+</span>
+
+<label>{% trans "Text" %}
+<span class="small">{% trans "Input the text on the captcha." %}</span>
+</label>
+<input id="cap_text" name="cap_text" type="text" size="20" />
+<input type="hidden" value="" name="cap_id" id="cap_id"/>
+
+</span>
+
+<button id="cap_submit" type="submit">{% trans "Submit" %}</button>
+<button id="cap_reset" style="margin-left:0px;" type="reset">{% trans "Close" %}</button>
+
+<div class="spacer"></div>
+
+
+</form>
+
+</div> \ No newline at end of file