summaryrefslogtreecommitdiff
path: root/searx
diff options
context:
space:
mode:
authorDavid A Roberts <d@vidr.cc>2016-07-16 19:26:29 +1000
committerDavid A Roberts <d@vidr.cc>2016-08-10 11:15:30 +1000
commit117d36b66eae1a36d730135f6a659d515f2514f2 (patch)
tree7a8fd1965e26799409a9717c37ecf3bd5d02f47f /searx
parent53c9185cbeb05026909adec164b859e09850c74e (diff)
downloadsearxng-117d36b66eae1a36d730135f6a659d515f2514f2.tar.gz
searxng-117d36b66eae1a36d730135f6a659d515f2514f2.zip
Add Crossref search engine and DOAI rewrite plugin
Diffstat (limited to 'searx')
-rw-r--r--searx/engines/json_engine.py16
-rw-r--r--searx/plugins/__init__.py4
-rw-r--r--searx/plugins/doai_rewrite.py31
-rw-r--r--searx/settings.yml10
4 files changed, 59 insertions, 2 deletions
diff --git a/searx/engines/json_engine.py b/searx/engines/json_engine.py
index 5525b7f7e..cd5e3a7e1 100644
--- a/searx/engines/json_engine.py
+++ b/searx/engines/json_engine.py
@@ -8,6 +8,14 @@ content_query = None
title_query = None
# suggestion_xpath = ''
+# parameters for engines with paging support
+#
+# number of results on each page
+# (only needed if the site requires not a page number, but an offset)
+page_size = 1
+# number of the first page (usually 0 or 1)
+first_page_num = 1
+
def iterate(iterable):
if type(iterable) == dict:
@@ -69,8 +77,14 @@ def query(data, query_string):
def request(query, params):
query = urlencode({'q': query})[2:]
- params['url'] = search_url.format(query=query)
+
+ fp = {'query': query}
+ if paging and search_url.find('{pageno}') >= 0:
+ fp['pageno'] = (params['pageno'] + first_page_num - 1) * page_size
+
+ params['url'] = search_url.format(**fp)
params['query'] = query
+
return params
diff --git a/searx/plugins/__init__.py b/searx/plugins/__init__.py
index b9b9ca0d0..14fd1e96c 100644
--- a/searx/plugins/__init__.py
+++ b/searx/plugins/__init__.py
@@ -19,7 +19,8 @@ from searx import logger
logger = logger.getChild('plugins')
-from searx.plugins import (https_rewrite,
+from searx.plugins import (doai_rewrite,
+ https_rewrite,
open_results_on_new_tab,
self_info,
search_on_category_select,
@@ -73,6 +74,7 @@ class PluginStore():
plugins = PluginStore()
+plugins.register(doai_rewrite)
plugins.register(https_rewrite)
plugins.register(open_results_on_new_tab)
plugins.register(self_info)
diff --git a/searx/plugins/doai_rewrite.py b/searx/plugins/doai_rewrite.py
new file mode 100644
index 000000000..fc5998b14
--- /dev/null
+++ b/searx/plugins/doai_rewrite.py
@@ -0,0 +1,31 @@
+from flask_babel import gettext
+import re
+from urlparse import urlparse, parse_qsl
+
+regex = re.compile(r'10\.\d{4,9}/[^\s]+')
+
+name = gettext('DOAI rewrite')
+description = gettext('Avoid paywalls by redirecting to open-access versions of publications when available')
+default_on = False
+
+
+def extract_doi(url):
+ match = regex.search(url.path)
+ if match:
+ return match.group(0)
+ for _, v in parse_qsl(url.query):
+ match = regex.search(v)
+ if match:
+ return match.group(0)
+ return None
+
+
+def on_result(request, ctx):
+ doi = extract_doi(ctx['result']['parsed_url'])
+ if doi and len(doi) < 50:
+ for suffix in ('/', '.pdf', '/full', '/meta', '/abstract'):
+ if doi.endswith(suffix):
+ doi = doi[:-len(suffix)]
+ ctx['result']['url'] = 'http://doai.io/' + doi
+ ctx['result']['parsed_url'] = urlparse(ctx['result']['url'])
+ return True
diff --git a/searx/settings.yml b/searx/settings.yml
index 38e9f4752..5fea2abad 100644
--- a/searx/settings.yml
+++ b/searx/settings.yml
@@ -87,6 +87,16 @@ engines:
- name : btdigg
engine : btdigg
shortcut : bt
+
+ - name : crossref
+ engine : json_engine
+ paging : True
+ search_url : http://search.crossref.org/dois?q={query}&page={pageno}
+ url_query : doi
+ title_query : title
+ content_query : fullCitation
+ categories : science
+ shortcut : cr
- name : currency
engine : currency_convert