1
0
mirror of https://github.com/searx/searx synced 2025-01-13 01:15:33 +01:00
searx/searx/engines/postgresql.py

70 lines
1.5 KiB
Python
Raw Normal View History

2021-03-27 15:54:33 +01:00
# SPDX-License-Identifier: AGPL-3.0-or-later
"""
PostgreSQL database (Offline)
"""
2021-04-29 22:05:31 +02:00
# error is ignored because the admin has to
# install it manually to use the engine
# pylint: disable=import-error
2021-03-27 15:54:33 +01:00
import psycopg2
engine_type = 'offline'
host = "127.0.0.1"
port = "5432"
database = ""
username = ""
password = ""
query_str = ""
limit = 10
paging = True
result_template = 'key-value.html'
_connection = None
def init(engine_settings):
if 'query_str' not in engine_settings:
raise ValueError('query_str cannot be empty')
if not engine_settings['query_str'].lower().startswith('select '):
raise ValueError('only SELECT query is supported')
global _connection
_connection = psycopg2.connect(
2021-04-29 21:50:25 +02:00
database=database,
user=username,
password=password,
host=host,
port=port,
2021-03-27 15:54:33 +01:00
)
def search(query, params):
query_params = {'query': query}
query_to_run = query_str + ' LIMIT {0} OFFSET {1}'.format(limit, (params['pageno'] - 1) * limit)
with _connection:
with _connection.cursor() as cur:
2021-04-29 22:05:31 +02:00
cur.execute(query_to_run, query_params)
2021-03-27 15:54:33 +01:00
return _fetch_results(cur)
def _fetch_results(cur):
results = []
titles = []
try:
titles = [column_desc.name for column_desc in cur.description]
for res in cur:
result = dict(zip(titles, map(str, res)))
result['template'] = result_template
results.append(result)
# no results to fetch
except psycopg2.ProgrammingError:
pass
return results