intro-offline.html 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1">
  7. <title>Preparation for offline engines &#8212; Searx Documentation (Searx-1.1.0.tex)</title>
  8. <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />
  9. <link rel="stylesheet" type="text/css" href="../_static/searx.css" />
  10. <link rel="stylesheet" type="text/css" href="../_static/tabs.css" />
  11. <script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>
  12. <script src="../_static/jquery.js"></script>
  13. <script src="../_static/underscore.js"></script>
  14. <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>
  15. <script src="../_static/doctools.js"></script>
  16. <script src="../_static/sphinx_highlight.js"></script>
  17. <link rel="index" title="Index" href="../genindex.html" />
  18. <link rel="search" title="Search" href="../search.html" />
  19. <link rel="next" title="Searx admin interface" href="admin.html" />
  20. <link rel="prev" title="Limit access to your searx engines" href="private-engines.html" />
  21. </head><body>
  22. <div class="related" role="navigation" aria-label="related navigation">
  23. <h3>Navigation</h3>
  24. <ul>
  25. <li class="right" style="margin-right: 10px">
  26. <a href="../genindex.html" title="General Index"
  27. accesskey="I">index</a></li>
  28. <li class="right" >
  29. <a href="../py-modindex.html" title="Python Module Index"
  30. >modules</a> |</li>
  31. <li class="right" >
  32. <a href="admin.html" title="Searx admin interface"
  33. accesskey="N">next</a> |</li>
  34. <li class="right" >
  35. <a href="private-engines.html" title="Limit access to your searx engines"
  36. accesskey="P">previous</a> |</li>
  37. <li class="nav-item nav-item-0"><a href="../index.html">Searx Documentation (Searx-1.1.0.tex)</a> &#187;</li>
  38. <li class="nav-item nav-item-1"><a href="index.html" accesskey="U">Blog</a> &#187;</li>
  39. <li class="nav-item nav-item-this"><a href="">Preparation for offline engines</a></li>
  40. </ul>
  41. </div>
  42. <div class="document">
  43. <div class="documentwrapper">
  44. <div class="bodywrapper">
  45. <div class="body" role="main">
  46. <section id="preparation-for-offline-engines">
  47. <h1>Preparation for offline engines<a class="headerlink" href="#preparation-for-offline-engines" title="Permalink to this heading">¶</a></h1>
  48. <section id="offline-engines">
  49. <h2>Offline engines<a class="headerlink" href="#offline-engines" title="Permalink to this heading">¶</a></h2>
  50. <p>To extend the functionality of searx, offline engines are going to be
  51. introduced. An offline engine is an engine which does not need Internet
  52. connection to perform a search and does not use HTTP to communicate.</p>
  53. <p>Offline engines can be configured as online engines, by adding those to the
  54. <cite>engines</cite> list of <a class="reference external" href="https://github.com/searx/searx/blob/master/searx/settings.yml">settings.yml</a>. Thus, searx
  55. finds the engine file and imports it.</p>
  56. <p>Example skeleton for the new engines:</p>
  57. <div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <span class="nn">subprocess</span> <span class="kn">import</span> <span class="n">PIPE</span><span class="p">,</span> <span class="n">Popen</span>
  58. <span class="n">categories</span> <span class="o">=</span> <span class="p">[</span><span class="s1">&#39;general&#39;</span><span class="p">]</span>
  59. <span class="n">offline</span> <span class="o">=</span> <span class="kc">True</span>
  60. <span class="k">def</span> <span class="nf">init</span><span class="p">(</span><span class="n">settings</span><span class="p">):</span>
  61. <span class="k">pass</span>
  62. <span class="k">def</span> <span class="nf">search</span><span class="p">(</span><span class="n">query</span><span class="p">,</span> <span class="n">params</span><span class="p">):</span>
  63. <span class="n">process</span> <span class="o">=</span> <span class="n">Popen</span><span class="p">([</span><span class="s1">&#39;ls&#39;</span><span class="p">,</span> <span class="n">query</span><span class="p">],</span> <span class="n">stdout</span><span class="o">=</span><span class="n">PIPE</span><span class="p">)</span>
  64. <span class="n">return_code</span> <span class="o">=</span> <span class="n">process</span><span class="o">.</span><span class="n">wait</span><span class="p">()</span>
  65. <span class="k">if</span> <span class="n">return_code</span> <span class="o">!=</span> <span class="mi">0</span><span class="p">:</span>
  66. <span class="k">raise</span> <span class="ne">RuntimeError</span><span class="p">(</span><span class="s1">&#39;non-zero return code&#39;</span><span class="p">,</span> <span class="n">return_code</span><span class="p">)</span>
  67. <span class="n">results</span> <span class="o">=</span> <span class="p">[]</span>
  68. <span class="n">line</span> <span class="o">=</span> <span class="n">process</span><span class="o">.</span><span class="n">stdout</span><span class="o">.</span><span class="n">readline</span><span class="p">()</span>
  69. <span class="k">while</span> <span class="n">line</span><span class="p">:</span>
  70. <span class="n">result</span> <span class="o">=</span> <span class="n">parse_line</span><span class="p">(</span><span class="n">line</span><span class="p">)</span>
  71. <span class="n">results</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">results</span><span class="p">)</span>
  72. <span class="n">line</span> <span class="o">=</span> <span class="n">process</span><span class="o">.</span><span class="n">stdout</span><span class="o">.</span><span class="n">readline</span><span class="p">()</span>
  73. <span class="k">return</span> <span class="n">results</span>
  74. </pre></div>
  75. </div>
  76. </section>
  77. <section id="development-progress">
  78. <h2>Development progress<a class="headerlink" href="#development-progress" title="Permalink to this heading">¶</a></h2>
  79. <p>First, a proposal has been created as a Github issue. Then it was moved to the
  80. wiki as a design document. You can read it here: <a class="reference external" href="https://github.com/searx/searx/wiki/Offline-engines">Offline-engines</a>.</p>
  81. <p>In this development step, searx core was prepared to accept and perform offline
  82. searches. Offline search requests are scheduled together with regular offline
  83. requests.</p>
  84. <p>As offline searches can return arbitrary results depending on the engine, the
  85. current result templates were insufficient to present such results. Thus, a new
  86. template is introduced which is caplable of presenting arbitrary key value pairs
  87. as a table. You can check out the pull request for more details see
  88. <a class="reference external" href="https://github.com/searx/searx/pull/1700">PR 1700</a>.</p>
  89. </section>
  90. <section id="next-steps">
  91. <h2>Next steps<a class="headerlink" href="#next-steps" title="Permalink to this heading">¶</a></h2>
  92. <p>Today, it is possible to create/run an offline engine. However, it is going to be publicly available for everyone who knows the searx instance. So the next step is to introduce token based access for engines. This way administrators are able to limit the access to private engines.</p>
  93. </section>
  94. <section id="acknowledgement">
  95. <h2>Acknowledgement<a class="headerlink" href="#acknowledgement" title="Permalink to this heading">¶</a></h2>
  96. <p>This development was sponsored by <a class="reference external" href="https://nlnet.nl/discovery">Search and Discovery Fund</a> of <a class="reference external" href="https://nlnet.nl/">NLnet Foundation</a> .</p>
  97. <div class="line-block">
  98. <div class="line">Happy hacking.</div>
  99. <div class="line">kvch // 2019.10.21 17:03</div>
  100. </div>
  101. </section>
  102. </section>
  103. <div class="clearer"></div>
  104. </div>
  105. </div>
  106. </div>
  107. <span id="sidebar-top"></span>
  108. <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
  109. <div class="sphinxsidebarwrapper">
  110. <p class="logo"><a href="../index.html">
  111. <img class="logo" src="../_static/searx_logo_small.png" alt="Logo"/>
  112. </a></p>
  113. <h3>Project Links</h3>
  114. <ul>
  115. <li><a href="https://searx.github.io/searx/blog/index.html">Blog</a>
  116. <li><a href="https://github.com/searx/searx">Source</a>
  117. <li><a href="https://github.com/searx/searx/wiki">Wiki</a>
  118. <li><a href="https://twitter.com/Searx_engine">Twitter</a>
  119. <li><a href="https://github.com/searx/searx/issues">Issue Tracker</a>
  120. </ul><h3>Navigation</h3>
  121. <ul>
  122. <li><a href="../index.html">Overview</a>
  123. <ul>
  124. <li><a href="index.html">Blog</a>
  125. <ul>
  126. <li>Previous: <a href="private-engines.html" title="previous chapter">Limit access to your searx engines</a>
  127. <li>Next: <a href="admin.html" title="next chapter">Searx admin interface</a></ul>
  128. </li>
  129. </ul>
  130. </li>
  131. </ul>
  132. <div id="searchbox" style="display: none" role="search">
  133. <h3 id="searchlabel">Quick search</h3>
  134. <div class="searchformwrapper">
  135. <form class="search" action="../search.html" method="get">
  136. <input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
  137. <input type="submit" value="Go" />
  138. </form>
  139. </div>
  140. </div>
  141. <script>document.getElementById('searchbox').style.display = "block"</script>
  142. </div>
  143. </div>
  144. <div class="clearer"></div>
  145. </div>
  146. <div class="footer" role="contentinfo">
  147. &#169; Copyright 2015-2022, Adam Tauber, Noémi Ványi.
  148. Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 5.3.0.
  149. </div>
  150. <script src="../_static/version_warning_offset.js"></script>
  151. </body>
  152. </html>