# SPDX-License-Identifier: AGPL-3.0-or-later

import logging

logger = logging.getLogger('searx.shared')

try:
    import uwsgi
except:
    # no uwsgi
    from .shared_simple import SimpleSharedDict as SharedDict, schedule

    logger.info('Use shared_simple implementation')
else:
    try:
        uwsgi.cache_update('dummy', b'dummy')
        if uwsgi.cache_get('dummy') != b'dummy':
            raise Exception()
    except:
        # uwsgi.ini configuration problem: disable all scheduling
        logger.error(
            'uwsgi.ini configuration error, add this line to your uwsgi.ini\n'
            'cache2 = name=searxcache,items=2000,blocks=2000,blocksize=4096,bitmap=1'
        )
        from .shared_simple import SimpleSharedDict as SharedDict

        def schedule(delay, func, *args):
            return False

    else:
        # uwsgi
        from .shared_uwsgi import UwsgiCacheSharedDict as SharedDict, schedule

        logger.info('Use shared_uwsgi implementation')

storage = SharedDict()