Selaa lähdekoodia

Merge pull request #10 from dalf/master

bug fixes and dailymotion engine
Adam Tauber 11 vuotta sitten
vanhempi
commit
ff0bbd3566
4 muutettua tiedostoa jossa 39 lisäystä ja 2 poistoa
  1. 5
    0
      engines.cfg_sample
  2. 32
    0
      searx/engines/dailymotion.py
  3. 1
    1
      searx/engines/flickr.py
  4. 1
    1
      searx/engines/xpath.py

+ 5
- 0
engines.cfg_sample Näytä tiedosto

@@ -79,3 +79,8 @@ suggestion_xpath = //div[@id="satat"]//a
79 79
 [youtube]
80 80
 engine = youtube
81 81
 categories = videos
82
+
83
+[dailymotion]
84
+engine = dailymotion
85
+categories = videos
86
+

+ 32
- 0
searx/engines/dailymotion.py Näytä tiedosto

@@ -0,0 +1,32 @@
1
+from urllib import urlencode
2
+from json import loads
3
+from cgi import escape
4
+
5
+categories = ['videos']
6
+localization = 'en'
7
+
8
+# see http://www.dailymotion.com/doc/api/obj-video.html
9
+search_url = 'https://api.dailymotion.com/videos?fields=title,description,duration,url,thumbnail_360_url&sort=relevance&limit=25&page=1&{query}'
10
+
11
+def request(query, params):
12
+    global search_url
13
+    params['url'] = search_url.format(query=urlencode({'search': query, 'localization': localization }))
14
+    return params
15
+
16
+
17
+def response(resp):
18
+    results = []
19
+    search_res = loads(resp.text)
20
+    if not 'list' in search_res:
21
+        return results
22
+    for res in search_res['list']:
23
+        title = res['title']
24
+        url = res['url']
25
+        if res['thumbnail_360_url']:
26
+            content = '<a href="{0}" title="{0}" ><img src="{1}" /></a><br />'.format(url, res['thumbnail_360_url'])
27
+        else:
28
+            content = ''
29
+        if res['description']:
30
+            content += escape(res['description'][:500])
31
+        results.append({'url': url, 'title': title, 'content': content})
32
+    return results

+ 1
- 1
searx/engines/flickr.py Näytä tiedosto

@@ -7,7 +7,7 @@ from urlparse import urljoin
7 7
 categories = ['images']
8 8
 
9 9
 url = 'https://secure.flickr.com/'
10
-search_url = url+'search/?q={query}'
10
+search_url = url+'search/?{query}'
11 11
 
12 12
 def request(query, params):
13 13
     params['url'] = search_url.format(query=urlencode({'q': query}))

+ 1
- 1
searx/engines/xpath.py Näytä tiedosto

@@ -28,7 +28,7 @@ def extract_url(xpath_results):
28 28
             url = xpath_results[0].attrib.get('href')
29 29
     else:
30 30
         url = xpath_results.attrib.get('href')
31
-    if not url.startswith('http://') or not url.startswith('https://'):
31
+    if not url.startswith('http://') and not url.startswith('https://'):
32 32
         url = 'http://'+url
33 33
     parsed_url = urlparse(url)
34 34
     if not parsed_url.netloc: