| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 | # SPDX-License-Identifier: AGPL-3.0-or-later# lint: pylint"""MySQL database (offline)"""# import error is ignored because the admin has to install mysql manually to use# the engineimport mysql.connector  # pyright: ignore # pylint: disable=import-errorengine_type = 'offline'auth_plugin = 'caching_sha2_password'host = "127.0.0.1"port = 3306database = ""username = ""password = ""query_str = ""limit = 10paging = Trueresult_template = 'key-value.html'_connection = Nonedef init(engine_settings):    global _connection  # pylint: disable=global-statement    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')    _connection = mysql.connector.connect(        database=database,        user=username,        password=password,        host=host,        port=port,        auth_plugin=auth_plugin,    )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.cursor() as cur:        cur.execute(query_to_run, query_params)        return _fetch_results(cur)def _fetch_results(cur):    results = []    for res in cur:        result = dict(zip(cur.column_names, map(str, res)))        result['template'] = result_template        results.append(result)    return results
 |