Browse Source

Userscript installation and updater

pull/62/head
Ruud 14 years ago
parent
commit
e8ae2dced0
  1. 10
      couchpotato/core/helpers/request.py
  2. 1
      couchpotato/core/notifications/core/static/notification.js
  3. 4
      couchpotato/core/plugins/updater/static/updater.js
  4. 16
      couchpotato/core/plugins/userscript/main.py
  5. 69
      couchpotato/core/plugins/userscript/static/userscript.js
  6. 57
      couchpotato/core/plugins/userscript/template.js
  7. 2
      couchpotato/core/providers/nzb/x264/main.py
  8. 3
      couchpotato/core/providers/userscript/base.py
  9. 17
      couchpotato/core/providers/userscript/imdb/main.py
  10. 9
      couchpotato/static/scripts/couchpotato.js
  11. 3
      couchpotato/templates/_desktop.html

10
couchpotato/core/helpers/request.py

@ -2,6 +2,7 @@ from couchpotato.core.helpers.variable import natcmp
from flask.globals import current_app from flask.globals import current_app
from flask.helpers import json from flask.helpers import json
from libs.werkzeug.urls import url_decode from libs.werkzeug.urls import url_decode
from urllib import unquote_plus
import flask import flask
import re import re
@ -24,7 +25,7 @@ def getParams():
for item in nested: for item in nested:
if item is nested[-1]: if item is nested[-1]:
current[item] = value current[item] = unquote_plus(value)
else: else:
try: try:
current[item] current[item]
@ -33,7 +34,7 @@ def getParams():
current = current[item] current = current[item]
else: else:
temp[param] = value temp[param] = unquote_plus(value)
return dictToList(temp) return dictToList(temp)
@ -54,7 +55,10 @@ def dictToList(params):
return new return new
def getParam(attr, default = None): def getParam(attr, default = None):
return getattr(flask.request, 'args').get(attr, default) try:
return unquote_plus(getattr(flask.request, 'args').get(attr, default))
except:
return None
def padded_jsonify(callback, *args, **kwargs): def padded_jsonify(callback, *args, **kwargs):
content = str(callback) + '(' + json.dumps(dict(*args, **kwargs)) + ')' content = str(callback) + '(' + json.dumps(dict(*args, **kwargs)) + ')'

1
couchpotato/core/notifications/core/static/notification.js

@ -9,6 +9,7 @@ var NotificationBase = new Class({
// Listener // Listener
App.addEvent('load', self.startInterval.bind(self)); App.addEvent('load', self.startInterval.bind(self));
App.addEvent('unload', self.stopTimer.bind(self));
self.addEvent('notification', self.notify.bind(self)) self.addEvent('notification', self.notify.bind(self))
// Add test buttons to settings page // Add test buttons to settings page

4
couchpotato/core/plugins/updater/static/updater.js

@ -4,6 +4,10 @@ var UpdaterBase = new Class({
var self = this; var self = this;
App.addEvent('load', self.info.bind(self, 1000)) App.addEvent('load', self.info.bind(self, 1000))
App.addEvent('unload', function(){
if(self.timer)
clearTimeout(self.timer);
});
}, },
info: function(timeout){ info: function(timeout){

16
couchpotato/core/plugins/userscript/main.py

@ -1,12 +1,12 @@
from couchpotato import index from couchpotato import index
from couchpotato.api import addApiView from couchpotato.api import addApiView
from couchpotato.core.event import fireEvent from couchpotato.core.event import fireEvent, addEvent
from couchpotato.core.helpers.request import getParam, jsonified from couchpotato.core.helpers.request import getParam, jsonified
from couchpotato.core.helpers.variable import isDict from couchpotato.core.helpers.variable import isDict
from couchpotato.core.logger import CPLog from couchpotato.core.logger import CPLog
from couchpotato.core.plugins.base import Plugin from couchpotato.core.plugins.base import Plugin
from flask.globals import request from flask.globals import request
from flask.helpers import url_for from flask.helpers import url_for, make_response
log = CPLog(__name__) log = CPLog(__name__)
@ -18,20 +18,26 @@ class Userscript(Plugin):
addApiView('userscript', self.iFrame) addApiView('userscript', self.iFrame)
addApiView('userscript.add_via_url', self.getViaUrl) addApiView('userscript.add_via_url', self.getViaUrl)
addEvent('userscript.get_version', self.getVersion)
def getExtension(self): def getExtension(self):
params = { params = {
'includes': fireEvent('userscript.get_includes', merge = True), 'includes': fireEvent('userscript.get_includes', merge = True),
'excludes': fireEvent('userscript.get_excludes', merge = True), 'excludes': fireEvent('userscript.get_excludes', merge = True),
'version': self.getVersion(), 'version': self.getVersion(),
'host': '%s%suserscript/' % (request.host_url.rstrip('/'), url_for('api.index')), 'api': '%suserscript/' % url_for('api.index').lstrip('/'),
'host': request.host_url,
} }
return self.renderTemplate(__file__, 'template.js', **params) response = make_response(self.renderTemplate(__file__, 'template.js', **params))
response.headers['Content-Type'] = 'text/javascript'
return response
return
def getVersion(self): def getVersion(self):
versions = fireEvent('userscript.get_version') versions = fireEvent('userscript.get_provider_version')
version = 0 version = 0
for v in versions: for v in versions:

69
couchpotato/core/plugins/userscript/static/userscript.js

@ -7,7 +7,7 @@ Page.Userscript = new Class({
options: { options: {
'onOpened': function(){ 'onOpened': function(){
App.stopLoadTimer(); App.fireEvent('unload');
App.getBlock('header').hide(); App.getBlock('header').hide();
} }
}, },
@ -44,3 +44,70 @@ Page.Userscript = new Class({
} }
}); });
var UserscriptSettingTab = new Class({
tab: '',
content: '',
initialize: function(){
var self = this;
App.addEvent('load', self.addSettings.bind(self))
},
addSettings: function(){
var self = this;
self.settings = App.getPage('Settings')
self.settings.addEvent('create', function(){
var tab = self.settings.createTab('userscript', {
'label': 'Userscript',
'name': 'userscript'
});
self.tab = tab.tab;
self.content = tab.content;
self.createUserscript();
});
},
createUserscript: function(){
var self = this;
self.settings.createGroup({
'label': 'Install the Userscript'
}).inject(self.content).adopt(
new Element('a', {
'text': 'Install userscript',
'href': Api.createUrl('userscript.get')+'?couchpotato.user.js',
'normalhref': true
})
);
}
});
window.addEvent('domready', function(){
new UserscriptSettingTab();
});
window.addEvent('load', function(){
var your_version = $(document.body).get('data-userscript_version')
latest_version = App.getOption('userscript_version')
key = 'cp_version_check',
checked_already = Cookie.read(key);
if(your_version < latest_version && checked_already < latest_version){
if(confirm("Update to the latest Userscript?\nYour version: " + your_version + ', new version: ' + latest_version )){
document.location = Api.getOption('url')+'userscript.get/?couchpotato.user.js';
}
Cookie.write(key, latest_version, {duration: 100});
}
});

57
couchpotato/core/plugins/userscript/template.js

@ -1,16 +1,20 @@
// ==UserScript== // ==UserScript==
// @name CouchPotato UserScript // @name CouchPotato UserScript
// @description Add movies like a real CouchPotato // @description Add movies like a real CouchPotato
// @version {{version}}
// @include {{host}}* // @include {{host}}*
{% for include in includes %} {% for include in includes %}
// @include {{include}}{% endfor %} // @include {{include}}{% endfor %}
{% for exclude in excludes %} {% for exclude in excludes %}
// @exclude {{exclude}}{% endfor %} // @exclude {{exclude}}{% endfor %}
// @exclude {{host}}{{api.rstrip('/')}}*
// ==/UserScript== // ==/UserScript==
var version = {{version}}, var version = {{version}},
cpLocation = '{{host}}'; host = '{{host}}';
api = '{{api}}';
function create() { function create() {
switch (arguments.length) { switch (arguments.length) {
@ -53,53 +57,56 @@ if (typeof GM_addStyle == 'undefined'){
// Styles // Styles
GM_addStyle('\ GM_addStyle('\
#cpPopup { opacity: 0.5; width:200px; font-family: "Helvetica Neue", Helvetica, Arial, Geneva, sans-serif; -moz-border-radius-topleft: 6px; -moz-border-radius-topright: 6px; -webkit-border-top-left-radius: 6px; -webkit-border-top-right-radius: 6px; -moz-box-shadow: 0 0 20px rgba(0,0,0,0.5); -webkit-box-shadow: 0 0 20px rgba(0,0,0,0.5); position:fixed; z-index:9999; bottom:0; right:0; font-size:15px; margin: 0 20px; display: block; background:#f5f5f5; } \ #cp_popup { font-family: "Helvetica Neue", Helvetica, Arial, Geneva, sans-serif; -moz-border-radius-topleft: 6px; -moz-border-radius-bottomleft: 6px; -webkit-border-top-left-radius: 6px; -webkit-border-bottom-left-radius: 6px; -moz-box-shadow: 0 0 20px rgba(0,0,0,0.5); -webkit-box-shadow: 0 0 20px rgba(0,0,0,0.5); position:fixed; z-index:9999; bottom:0; right:0; font-size:15px; margin: 20px 0; display: block; background:#4E5969; } \
#cpPopup:hover { opacity: 1; } \ #cp_popup:hover { } \
#cpPopup a#addTo { cursor:pointer; text-align:center; text-decoration:none; color: #000; display:block; padding:15px 0 10px; } \ #cp_popup a#add_to { cursor:pointer; text-align:center; text-decoration:none; color: #000; display:block; padding:5px 0 5px 5px; } \
#cpPopup a#closeBtn { cursor:pointer; float: right; padding:10px; } \ #cp_popup a#close_button { cursor:pointer; float: right; padding:120px 10px 10px; } \
#cpPopup a img { vertical-align: middle; } \ #cp_popup a img { vertical-align: middle; } \
#cpPopup a:hover { color:#000; } \ #cp_popup a:hover { color:#000; } \
#cpPopup iframe{ background:#f5f5f5; margin:6px; height:70px; width:188px; overflow:hidden; border:none; } \ #cp_popup iframe{ background:#4E5969; margin:6px 0 2px 6px; height:140px; width:450px; overflow:hidden; border:none; } \
'); ');
var movieImg = ''; var cp_icon = '';
var closeImg = ''; var close_img = '';
var osd = function(){ var osd = function(){
var navbar, newElement; var navbar, newElement;
var iFrame = create('iframe', { var iframe = create('iframe', {
'src': cpLocation + "userscript.add_via_url/?url=" + escape(document.location), 'src': host + api + "?url=" + escape(document.location.href),
'frameborder': 0, 'frameborder': 0,
'scrolling': 'no' 'scrolling': 'no'
}); });
var addToText = '<a class="addTo" href="#"></a>';
var popupId = 'cpPopup';
var popup = create('div', { var popup = create('div', {
'id': popupId, 'id': 'cp_popup'
'innerHTML': addToText
}); });
var addButton = create('a', { var add_button = create('a', {
'innerHTML': '<img src="' + movieImg + '" />Add to CouchPotato', 'innerHTML': '<img src="' + cp_icon + '" />',
'id': 'addTo', 'id': 'add_to',
'onclick': function(){ 'onclick': function(){
popup.innerHTML = ''; popup.innerHTML = '';
popup.appendChild(create('a', { popup.appendChild(create('a', {
'innerHTML': '<img src="' + closeImg + '" />', 'innerHTML': '<img src="' + close_img + '" />',
'id': 'closeBtn', 'id': 'close_button',
'onclick': function(){ 'onclick': function(){
popup.innerHTML = ''; popup.innerHTML = '';
popup.appendChild(addButton); popup.appendChild(add_button);
} }
})); }));
popup.appendChild(iFrame) popup.appendChild(iframe)
} }
}); });
popup.appendChild(addButton); popup.appendChild(add_button);
document.body.parentNode.insertBefore(popup, document.body); document.body.parentNode.insertBefore(popup, document.body);
}; };
var setVersion = function(){
document.body.setAttribute('data-userscript_version', version)
};
if(document.location.href.indexOf(host) == -1)
osd(); osd();
else
setVersion();

2
couchpotato/core/providers/nzb/x264/main.py

@ -60,8 +60,6 @@ class X264(NZBProvider):
'check_nzb': False, 'check_nzb': False,
} }
print new['name']
new['score'] = fireEvent('score.calculate', new, movie, single = True) new['score'] = fireEvent('score.calculate', new, movie, single = True)
is_correct_movie = fireEvent('searcher.correct_movie', is_correct_movie = fireEvent('searcher.correct_movie',
nzb = new, movie = movie, quality = quality, nzb = new, movie = movie, quality = quality,

3
couchpotato/core/providers/userscript/base.py

@ -17,8 +17,7 @@ class UserscriptBase(Plugin):
def __init__(self): def __init__(self):
addEvent('userscript.get_includes', self.getInclude) addEvent('userscript.get_includes', self.getInclude)
addEvent('userscript.get_excludes', self.getExclude) addEvent('userscript.get_excludes', self.getExclude)
addEvent('userscript.get_version', self.getVersion) addEvent('userscript.get_provider_version', self.getVersion)
addEvent('userscript.get_movie_via_url', self.belongsTo) addEvent('userscript.get_movie_via_url', self.belongsTo)
def search(self, name, year = None): def search(self, name, year = None):

17
couchpotato/core/providers/userscript/imdb/main.py

@ -1,7 +1,6 @@
from beautifulsoup import BeautifulSoup
from couchpotato.core.event import fireEvent from couchpotato.core.event import fireEvent
from couchpotato.core.helpers.variable import getImdb
from couchpotato.core.providers.userscript.base import UserscriptBase from couchpotato.core.providers.userscript.base import UserscriptBase
import re
class IMDB(UserscriptBase): class IMDB(UserscriptBase):
@ -9,16 +8,4 @@ class IMDB(UserscriptBase):
includes = ['http*://*.imdb.com/title/tt*', 'http*://imdb.com/title/tt*'] includes = ['http*://*.imdb.com/title/tt*', 'http*://imdb.com/title/tt*']
def getMovie(self, url): def getMovie(self, url):
return fireEvent('movie.info', identifier = getImdb(url), merge = True)
data = self.urlopen(url)
html = BeautifulSoup(data)
headers = html.findAll('h5')
# Don't add TV show
for head in headers:
if 'seasons' in head.lower():
return 'IMDB url is a TV Show'
identifier = re.search('(?P<id>tt[0-9{7}]+)', url).group('id')
return fireEvent('movie.info', identifier = identifier, merge = True)

9
couchpotato/static/scripts/couchpotato.js

@ -29,7 +29,7 @@ var CouchPotato = new Class({
else else
self.openPage(window.location.pathname); self.openPage(window.location.pathname);
self.c.addEvent('click:relay(a:not([target=_blank]))', self.pushState.bind(self)); self.c.addEvent('click:relay(a:not([target=_blank]):not([normalhref=true]))', self.pushState.bind(self));
}, },
getOption: function(name){ getOption: function(name){
@ -72,17 +72,10 @@ var CouchPotato = new Class({
$(pg).inject(self.content); $(pg).inject(self.content);
}); });
self.load_timer = (function(){
self.fireEvent('load'); self.fireEvent('load');
}).delay(1000);
}, },
stopLoadTimer: function(){
if(this.load_timer)
clearInterval(this.load_timer);
},
openPage: function(url) { openPage: function(url) {
var self = this; var self = this;

3
couchpotato/templates/_desktop.html

@ -66,7 +66,8 @@
'args': '{{ env.get('args') }}', 'args': '{{ env.get('args') }}',
'options': '{{ env.get('options') }}', 'options': '{{ env.get('options') }}',
'app_dir': '{{ env.get('app_dir') }}', 'app_dir': '{{ env.get('app_dir') }}',
'data_dir': '{{ env.get('data_dir') }}' 'data_dir': '{{ env.get('data_dir') }}',
'userscript_version': {{ fireEvent('userscript.get_version', single = True)|safe }}
}); });
//Wizard.start.delay(100, Wizard); //Wizard.start.delay(100, Wizard);

Loading…
Cancel
Save