Skip to content
This repository has been archived by the owner on Sep 7, 2023. It is now read-only.

Commit

Permalink
Add PostgreSQL engine
Browse files Browse the repository at this point in the history
  • Loading branch information
kvch committed Apr 29, 2021
1 parent 34d7d97 commit 22079ff
Show file tree
Hide file tree
Showing 2 changed files with 75 additions and 0 deletions.
65 changes: 65 additions & 0 deletions searx/engines/postgresql.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
# SPDX-License-Identifier: AGPL-3.0-or-later
"""
PostgreSQL database (Offline)
"""

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(
database = database,
user = username,
password = password,
host = host,
port = port,
)


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:
cur.execute(query_str, query_params)

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
10 changes: 10 additions & 0 deletions searx/settings.yml
Original file line number Diff line number Diff line change
Expand Up @@ -840,6 +840,16 @@ engines:
url: https://thepiratebay.org/
timeout : 3.0

# Required dependency: psychopg2
# - name : postgresql
# engine : postgresql
# database : postgres
# username : postgres
# password : postgres
# limit : 10
# query_str : 'SELECT * from my_table WHERE my_column = %(query)s'
# shortcut : psql

- name : pubmed
engine : pubmed
shortcut : pub
Expand Down

0 comments on commit 22079ff

Please sign in to comment.