2017-02-28 07:24:53 +00:00
|
|
|
# MIT licensed
|
2020-08-14 10:25:48 +00:00
|
|
|
# Copyright (c) 2013-2020 lilydjwg <lilydjwg@gmail.com>, et al.
|
2017-02-28 07:24:53 +00:00
|
|
|
|
2013-11-03 10:21:50 +00:00
|
|
|
import re
|
|
|
|
import sre_constants
|
2018-04-11 08:18:41 +00:00
|
|
|
|
2020-08-14 12:04:05 +00:00
|
|
|
from nvchecker.api import session, GetVersionError
|
2013-11-03 10:21:50 +00:00
|
|
|
|
2020-08-14 10:25:48 +00:00
|
|
|
async def get_version(name, conf, *, cache, **kwargs):
|
2013-11-03 10:21:50 +00:00
|
|
|
try:
|
2017-07-04 09:04:29 +00:00
|
|
|
regex = re.compile(conf['regex'])
|
2020-08-14 10:25:48 +00:00
|
|
|
except sre_constants.error as e:
|
|
|
|
raise GetVersionError('bad regex', exc_info=e)
|
2021-11-06 02:44:10 +00:00
|
|
|
if regex.groups > 1:
|
|
|
|
raise GetVersionError('multi-group regex')
|
2013-11-03 10:21:50 +00:00
|
|
|
|
2023-03-26 09:30:08 +00:00
|
|
|
key = (
|
|
|
|
conf['url'],
|
|
|
|
conf.get('encoding', 'latin1'),
|
|
|
|
conf.get('post_data'),
|
|
|
|
conf.get('post_data_type', 'application/x-www-form-urlencoded'),
|
|
|
|
)
|
|
|
|
body = await cache.get(key, get_url)
|
2013-11-03 10:21:50 +00:00
|
|
|
|
2021-08-31 01:48:07 +00:00
|
|
|
versions = regex.findall(body)
|
|
|
|
if not versions and not conf.get('missing_ok', False):
|
|
|
|
raise GetVersionError('version string not found.')
|
|
|
|
return versions
|
2023-03-26 09:30:08 +00:00
|
|
|
|
|
|
|
async def get_url(info):
|
|
|
|
url, encoding, post_data, post_data_type = info
|
|
|
|
|
|
|
|
if post_data is None:
|
|
|
|
res = await session.get(url)
|
|
|
|
else:
|
|
|
|
res = await session.post(url, body = post_data, headers = {
|
|
|
|
'Content-Type': post_data_type,
|
|
|
|
})
|
|
|
|
body = res.body.decode(encoding)
|
|
|
|
return body
|