summaryrefslogtreecommitdiff
path: root/docs/dev/engine_overview.rst
blob: 0b5f9857ffc9d06b4fdfa9858d709adafedd023b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
.. _engines-dev:

===============
Engine overview
===============

.. _metasearch-engine: https://en.wikipedia.org/wiki/Metasearch_engine

searx is a metasearch-engine_, so it uses different search engines to provide
better results.

Because there is no general search API which could be used for every search
engine, an adapter has to be built between searx and the external search
engines.  Adapters are stored under the folder :origin:`searx/engines`.

.. contents::
   :depth: 3
   :backlinks: entry


.. _general engine configuration:

general engine configuration
============================

It is required to tell searx the type of results the engine provides. The
arguments can be set in the engine file or in the settings file
(normally ``settings.yml``). The arguments in the settings file override
the ones in the engine file.

It does not matter if an option is stored in the engine file or in the
settings.  However, the standard way is the following:

.. _engine file:

engine file
-----------

======================= =========== ===========================================
argument                type        information
======================= =========== ===========================================
categories              list        pages, in which the engine is working
paging                  boolean     support multible pages
language_support        boolean     support language choosing
time_range_support      boolean     support search time range
offline                 boolean     engine runs offline
======================= =========== ===========================================

.. _engine settings:

settings.yml
------------

======================= =========== =============================================
argument                type        information
======================= =========== =============================================
name                    string      name of search-engine
engine                  string      name of searx-engine
                                    (filename without ``.py``)
shortcut                string      shortcut of search-engine
timeout                 string      specific timeout for search-engine
display_error_messages  boolean     display error messages on the web UI
proxies                 dict        set proxies for a specific engine
                                    (e.g. ``proxies : {http: socks5://proxy:port,
                                    https: socks5://proxy:port}``)
======================= =========== =============================================


overrides
---------

A few of the options have default values in the engine, but are often
overwritten by the settings.  If ``None`` is assigned to an option in the engine
file, it has to be redefined in the settings, otherwise searx will not start
with that engine.

The naming of overrides is arbitrary.  But the recommended overrides are the
following:

======================= =========== ===========================================
argument                type        information
======================= =========== ===========================================
base_url                string      base-url, can be overwritten to use same
                                    engine on other URL
number_of_results       int         maximum number of results per request
language                string      ISO code of language and country like en_US
api_key                 string      api-key if required by engine
======================= =========== ===========================================

example code
------------

.. code:: python

   # engine dependent config
   categories = ['general']
   paging = True
   language_support = True


making a request
================

To perform a search an URL have to be specified.  In addition to specifying an
URL, arguments can be passed to the query.

passed arguments
----------------

These arguments can be used to construct the search query.  Furthermore,
parameters with default value can be redefined for special purposes.

====================== ============ ========================================================================
argument               type         default-value, information
====================== ============ ========================================================================
url                    string       ``''``
method                 string       ``'GET'``
headers                set          ``{}``
data                   set          ``{}``
cookies                set          ``{}``
verify                 boolean      ``True``
headers.User-Agent     string       a random User-Agent
category               string       current category, like ``'general'``
started                datetime     current date-time
pageno                 int          current pagenumber
language               string       specific language code like ``'en_US'``, or ``'all'`` if unspecified
====================== ============ ========================================================================

parsed arguments
----------------

The function ``def request(query, params):`` always returns the ``params``
variable.  Inside searx, the following paramters can be used to specify a search
request:

================== =========== ==========================================================================
argument           type        information
================== =========== ==========================================================================
url                string      requested url
method             string      HTTP request method
headers            set         HTTP header information
data               set         HTTP data information (parsed if ``method != 'GET'``)
cookies            set         HTTP cookies
verify             boolean     Performing SSL-Validity check
max_redirects      int         maximum redirects, hard limit
soft_max_redirects int         maximum redirects, soft limit. Record an error but don't stop the engine
raise_for_status   bool        True by default: raise an exception if the HTTP code of response is >= 300
================== =========== ==========================================================================


example code
------------

.. code:: python

   # search-url
   base_url = 'https://example.com/'
   search_string = 'search?{query}&page={page}'

   # do search-request
   def request(query, params):
       search_path = search_string.format(
           query=urlencode({'q': query}),
           page=params['pageno'])

       params['url'] = base_url + search_path

       return params


returned results
================

Searx is able to return results of different media-types.  Currently the
following media-types are supported:

- default_
- images_
- videos_
- torrent_
- map_

To set another media-type as default, the parameter ``template`` must be set to
the desired type.

default
-------

========================= =====================================================
result-parameter          information
========================= =====================================================
url                       string, url of the result
title                     string, title of the result
content                   string, general result-text
publishedDate             :py:class:`datetime.datetime`, time of publish
========================= =====================================================

images
------

To use this template, the parameter:

========================= =====================================================
result-parameter          information
========================= =====================================================
template                  is set to ``images.html``
url                       string, url to the result site
title                     string, title of the result *(partly implemented)*
content                   *(partly implemented)*
publishedDate             :py:class:`datetime.datetime`,
                          time of publish *(partly implemented)*
img\_src                  string, url to the result image
thumbnail\_src            string, url to a small-preview image
========================= =====================================================

videos
------

========================= =====================================================
result-parameter          information
========================= =====================================================
template                  is set to ``videos.html``
url                       string, url of the result
title                     string, title of the result
content                   *(not implemented yet)*
publishedDate             :py:class:`datetime.datetime`, time of publish
thumbnail                 string, url to a small-preview image
========================= =====================================================

torrent
-------

.. _magnetlink: https://en.wikipedia.org/wiki/Magnet_URI_scheme

========================= =====================================================
result-parameter          information
========================= =====================================================
template                  is set to ``torrent.html``
url                       string, url of the result
title                     string, title of the result
content                   string, general result-text
publishedDate             :py:class:`datetime.datetime`,
                          time of publish *(not implemented yet)*
seed                      int, number of seeder
leech                     int, number of leecher
filesize                  int, size of file in bytes
files                     int, number of files
magnetlink                string, magnetlink_ of the result
torrentfile               string, torrentfile of the result
========================= =====================================================


map
---

========================= =====================================================
result-parameter          information
========================= =====================================================
url                       string, url of the result
title                     string, title of the result
content                   string, general result-text
publishedDate             :py:class:`datetime.datetime`, time of publish
latitude                  latitude of result (in decimal format)
longitude                 longitude of result (in decimal format)
boundingbox               boundingbox of result (array of 4. values
                          ``[lat-min, lat-max, lon-min, lon-max]``)
geojson                   geojson of result (http://geojson.org)
osm.type                  type of osm-object (if OSM-Result)
osm.id                    id of osm-object (if OSM-Result)
address.name              name of object
address.road              street name of object
address.house_number      house number of object
address.locality          city, place of object
address.postcode          postcode of object
address.country           country of object
========================= =====================================================