nvchecker/nvchecker-old/source/regex.py

38 lines
961 B
Python
Raw Normal View History

2017-02-28 07:24:53 +00:00
# MIT licensed
# Copyright (c) 2013-2017 lilydjwg <lilydjwg@gmail.com>, et al.
2013-11-03 10:21:50 +00:00
import re
import sre_constants
2018-04-11 08:18:41 +00:00
import structlog
2013-11-03 10:21:50 +00:00
2017-07-04 09:04:29 +00:00
from . import session
2013-11-03 10:21:50 +00:00
2018-04-11 08:18:41 +00:00
logger = structlog.get_logger(logger_name=__name__)
2013-11-03 10:21:50 +00:00
async def get_version(name, conf, **kwargs):
2013-11-03 10:21:50 +00:00
try:
2017-07-04 09:04:29 +00:00
regex = re.compile(conf['regex'])
2013-11-03 10:21:50 +00:00
except sre_constants.error:
logger.warning('bad regex, skipped.', name=name, exc_info=True)
return
2013-11-03 10:21:50 +00:00
encoding = conf.get('encoding', 'latin1')
kwargs = {}
2017-07-04 09:04:29 +00:00
headers = {}
2013-11-03 10:21:50 +00:00
if conf.get('proxy'):
2017-07-04 09:04:29 +00:00
kwargs["proxy"] = conf.get("proxy")
if conf.get('user_agent'):
2017-07-04 09:04:29 +00:00
headers['User-Agent'] = conf['user_agent']
2013-11-03 10:21:50 +00:00
2017-07-04 09:04:29 +00:00
async with session.get(conf['url'], headers=headers, **kwargs) as res:
body = (await res.read()).decode(encoding)
try:
version = regex.findall(body)
except ValueError:
version = None
if not conf.getboolean('missing_ok', False):
logger.error('version string not found.', name=name)
return version