mirror of
				https://github.com/searxng/searxng.git
				synced 2025-10-31 10:37:06 -04:00 
			
		
		
		
	We have built up detailed documentation of the *settings* and the *engines* over the past few years. However, this documentation was still spread over various chapters and was difficult to navigate in its entirety. This patch rearranges the Settings & Engines documentation for better readability. To review new ordered docs:: make docs.clean docs.live Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
		
			
				
	
	
		
			104 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # SPDX-License-Identifier: AGPL-3.0-or-later
 | |
| # lint: pylint
 | |
| """MongoDB_ is a document based database program that handles JSON like data.
 | |
| Before configuring the ``mongodb`` engine, you must install the dependency
 | |
| pymongo_.
 | |
| 
 | |
| Configuration
 | |
| =============
 | |
| 
 | |
| In order to query MongoDB_, you have to select a ``database`` and a
 | |
| ``collection``.  Furthermore, you have to select a ``key`` that is going to be
 | |
| searched.  MongoDB_ also supports the option ``exact_match_only``, so configure
 | |
| it as you wish.
 | |
| 
 | |
| Example
 | |
| =======
 | |
| 
 | |
| Below is an example configuration for using a MongoDB collection:
 | |
| 
 | |
| .. code:: yaml
 | |
| 
 | |
|   # MongoDB engine
 | |
|   # Required dependency: pymongo
 | |
| 
 | |
|   - name: mymongo
 | |
|     engine: mongodb
 | |
|     shortcut: md
 | |
|     exact_match_only: false
 | |
|     host: '127.0.0.1'
 | |
|     port: 27017
 | |
|     enable_http: true
 | |
|     results_per_page: 20
 | |
|     database: 'business'
 | |
|     collection: 'reviews'  # name of the db collection
 | |
|     key: 'name'            # key in the collection to search for
 | |
| 
 | |
| Implementations
 | |
| ===============
 | |
| 
 | |
| """
 | |
| 
 | |
| import re
 | |
| 
 | |
| try:
 | |
|     from pymongo import MongoClient  # type: ignore
 | |
| except ImportError:
 | |
|     # import error is ignored because the admin has to install pymongo manually
 | |
|     # to use the engine
 | |
|     pass
 | |
| 
 | |
| 
 | |
| engine_type = 'offline'
 | |
| 
 | |
| # mongodb connection variables
 | |
| host = '127.0.0.1'
 | |
| port = 27017
 | |
| username = ''
 | |
| password = ''
 | |
| database = None
 | |
| collection = None
 | |
| key = None
 | |
| 
 | |
| # engine specific variables
 | |
| paging = True
 | |
| results_per_page = 20
 | |
| exact_match_only = False
 | |
| result_template = 'key-value.html'
 | |
| 
 | |
| _client = None
 | |
| 
 | |
| 
 | |
| def init(_):
 | |
|     connect()
 | |
| 
 | |
| 
 | |
| def connect():
 | |
|     global _client  # pylint: disable=global-statement
 | |
|     kwargs = {'port': port}
 | |
|     if username:
 | |
|         kwargs['username'] = username
 | |
|     if password:
 | |
|         kwargs['password'] = password
 | |
|     _client = MongoClient(host, **kwargs)[database][collection]
 | |
| 
 | |
| 
 | |
| def search(query, params):
 | |
|     results = []
 | |
|     if exact_match_only:
 | |
|         q = {'$eq': query}
 | |
|     else:
 | |
|         _re = re.compile('.*{0}.*'.format(re.escape(query)), re.I | re.M)
 | |
|         q = {'$regex': _re}
 | |
| 
 | |
|     query = _client.find({key: q}).skip((params['pageno'] - 1) * results_per_page).limit(results_per_page)
 | |
| 
 | |
|     results.append({'number_of_results': query.count()})
 | |
|     for r in query:
 | |
|         del r['_id']
 | |
|         r = {str(k): str(v) for k, v in r.items()}
 | |
|         r['template'] = result_template
 | |
|         results.append(r)
 | |
| 
 | |
|     return results
 |