forked from Ponysearch/Ponysearch
[enh][mod] engines.cfg support
This commit is contained in:
parent
75a2a6fb73
commit
39d229e110
1 changed files with 28 additions and 14 deletions
|
@ -17,37 +17,51 @@ along with searx. If not, see < http://www.gnu.org/licenses/ >.
|
|||
'''
|
||||
|
||||
from os.path import realpath, dirname, splitext, join
|
||||
from os import listdir
|
||||
from imp import load_source
|
||||
import grequests
|
||||
from itertools import izip_longest, chain
|
||||
from operator import itemgetter
|
||||
from urlparse import urlparse
|
||||
from searx import settings
|
||||
import ConfigParser
|
||||
import sys
|
||||
|
||||
engine_dir = dirname(realpath(__file__))
|
||||
searx_dir = join(engine_dir, '../../')
|
||||
|
||||
engines_config = ConfigParser.SafeConfigParser()
|
||||
engines_config.read(join(searx_dir, 'engines.cfg'))
|
||||
|
||||
engines = {}
|
||||
|
||||
categories = {'general': []}
|
||||
|
||||
for filename in listdir(engine_dir):
|
||||
if filename.startswith('_') or not filename.endswith('.py'):
|
||||
continue
|
||||
def load_module(filename):
|
||||
modname = splitext(filename)[0]
|
||||
if modname in settings.blacklist:
|
||||
continue
|
||||
if modname in sys.modules:
|
||||
del sys.modules[modname]
|
||||
filepath = join(engine_dir, filename)
|
||||
engine = load_source(modname, filepath)
|
||||
engine.name = modname
|
||||
if not hasattr(engine, 'request') or not hasattr(engine, 'response'):
|
||||
module = load_source(modname, filepath)
|
||||
module.name = modname
|
||||
return module
|
||||
|
||||
for section in engines_config.sections():
|
||||
engine_data = engines_config.options(section)
|
||||
engine = load_module(engines_config.get(section, 'engine')+'.py')
|
||||
engine.name = section
|
||||
for param_name in engine_data:
|
||||
if param_name == 'engine':
|
||||
continue
|
||||
engines[modname] = engine
|
||||
if not hasattr(engine, 'categories'):
|
||||
categories['general'].append(engine)
|
||||
else:
|
||||
if param_name == 'categories':
|
||||
engine.categories = map(str.strip, engines_config.get(section, param_name).split(','))
|
||||
continue
|
||||
setattr(engine, param_name, engines_config.get(section, param_name))
|
||||
engines[engine.name] = engine
|
||||
if hasattr(engine, 'categories'):
|
||||
for category_name in engine.categories:
|
||||
categories.setdefault(category_name, []).append(engine)
|
||||
else:
|
||||
categories['general'].append(engine)
|
||||
|
||||
def default_request_params():
|
||||
return {'method': 'GET', 'headers': {}, 'data': {}, 'url': '', 'cookies': {}}
|
||||
|
|
Loading…
Reference in a new issue