mirror of
https://github.com/lilydjwg/nvchecker
synced 2024-12-12 01:35:49 +00:00
Merge remote-tracking branch 'origin/pr/131' into master
This commit is contained in:
commit
fbdde9bf58
37
README.rst
37
README.rst
@ -36,6 +36,7 @@ Contents
|
||||
* `Check GitHub <#check-github>`_
|
||||
* `Check BitBucket <#check-bitbucket>`_
|
||||
* `Check GitLab <#check-gitlab>`_
|
||||
* `Check Gitea <#check-gitea>`_
|
||||
* `Check PyPI <#check-pypi>`_
|
||||
* `Check RubyGems <#check-rubygems>`_
|
||||
* `Check NPM Registry <#check-npm-registry>`_
|
||||
@ -332,6 +333,42 @@ anonymously.
|
||||
|
||||
This source supports `list options`_ when ``use_max_tag`` is set.
|
||||
|
||||
Check Gitea
|
||||
-------------
|
||||
Check `Gitea <https://gitea.com/>`_ for updates. The version returned is in date format ``%Y%m%d``, e.g. ``20130701``,
|
||||
unless ``use_max_tag`` is used. See below.
|
||||
|
||||
gitea
|
||||
The gitea repository, with author, e.g. ``gitea/tea``.
|
||||
|
||||
branch
|
||||
Which branch to track? Default: ``master``.
|
||||
|
||||
use_max_tag
|
||||
Set this to ``true`` to check for the max tag on Gitea. Will return the biggest one
|
||||
sorted by ``pkg_resources.parse_version``. Will return the tag name instead of date.
|
||||
|
||||
host
|
||||
Hostname for self-hosted Gitea instance.
|
||||
|
||||
token
|
||||
Gitea authorization token used to call the API.
|
||||
|
||||
ignored_tags, sort_version_key
|
||||
Deprecated. Use `list options`_ instead.
|
||||
|
||||
To set an authorization token, you can set:
|
||||
|
||||
- a key named ``gitea_{host}`` in the keyfile (where ``host`` is formed the
|
||||
same as the environment variable, but all lowercased).
|
||||
- an environment variable ``NVCHECKER_GITEA_TOKEN_{host}`` must provide that
|
||||
token. The ``host`` part is the uppercased version of the ``host`` setting,
|
||||
with dots (``.``) and slashes (``/``) replaced by underscores (``_``), e.g.
|
||||
``NVCHECKER_GITEA_TOKEN_GITEA_COM``.
|
||||
- the token option
|
||||
|
||||
This source supports `list options`_ when ``use_max_tag`` is set.
|
||||
|
||||
Check BitBucket
|
||||
---------------
|
||||
Check `BitBucket <https://bitbucket.org/>`_ for updates. The version returned
|
||||
|
@ -15,7 +15,7 @@ handler_precedence = (
|
||||
'gems', 'pacman',
|
||||
'cmd', 'bitbucket', 'regex', 'manual', 'vcs',
|
||||
'cratesio', 'npm', 'hackage', 'cpan', 'gitlab', 'packagist',
|
||||
'repology', 'anitya', 'android_sdk', 'sparkle',
|
||||
'repology', 'anitya', 'android_sdk', 'sparkle', 'gitea'
|
||||
)
|
||||
|
||||
def substitute_version(version, name, conf):
|
||||
|
56
nvchecker/source/gitea.py
Normal file
56
nvchecker/source/gitea.py
Normal file
@ -0,0 +1,56 @@
|
||||
# MIT licensed
|
||||
# Copyright (c) 2013-2018 lilydjwg <lilydjwg@gmail.com>, et al.
|
||||
|
||||
import os
|
||||
import urllib.parse
|
||||
|
||||
import structlog
|
||||
|
||||
from . import session, HTTPError
|
||||
|
||||
logger = structlog.get_logger(logger_name=__name__)
|
||||
|
||||
GITEA_URL = 'https://%s/api/v1/repos/%s/commits?sha=%s'
|
||||
GITEA_MAX_TAG = 'https://%s/api/v1/repos/%s/tags'
|
||||
|
||||
async def get_version(name, conf, **kwargs):
|
||||
try:
|
||||
return await get_version_real(name, conf, **kwargs)
|
||||
except HTTPError as e:
|
||||
raise
|
||||
|
||||
async def get_version_real(name, conf, **kwargs):
|
||||
repo = urllib.parse.quote(conf.get('gitea'))
|
||||
br = conf.get('branch', 'master')
|
||||
host = conf.get('host', "gitea.com")
|
||||
use_max_tag = conf.getboolean('use_max_tag', False)
|
||||
ignored_tags = conf.get("ignored_tags", "").split()
|
||||
|
||||
if use_max_tag:
|
||||
url = GITEA_MAX_TAG % (host, repo)
|
||||
else:
|
||||
url = GITEA_URL % (host, repo, br)
|
||||
|
||||
# Load token from config
|
||||
token = conf.get('token')
|
||||
# Load token from environ
|
||||
if token is None:
|
||||
env_name = "NVCHECKER_GITEA_TOKEN_" + host.upper().replace(".", "_").replace("/", "_")
|
||||
token = os.environ.get(env_name)
|
||||
# Load token from keyman
|
||||
if token is None and 'keyman' in kwargs:
|
||||
key_name = 'gitea_' + host.lower().replace('.', '_').replace("/", "_")
|
||||
token = kwargs['keyman'].get_key(key_name)
|
||||
|
||||
# Set private token if token exists.
|
||||
headers = {}
|
||||
if token:
|
||||
headers["Authorization"] = "token %s" % token
|
||||
|
||||
async with session.get(url, headers=headers) as res:
|
||||
data = await res.json()
|
||||
if use_max_tag:
|
||||
version = [tag["name"] for tag in data if tag["name"] not in ignored_tags]
|
||||
else:
|
||||
version = data[0]['commit']['committer']['date'].split('T', 1)[0].replace('-', '')
|
||||
return version
|
25
tests/test_gitea.py
Normal file
25
tests/test_gitea.py
Normal file
@ -0,0 +1,25 @@
|
||||
# MIT licensed
|
||||
# Copyright (c) 2013-2017 lilydjwg <lilydjwg@gmail.com>, et al.
|
||||
|
||||
import os
|
||||
import pytest
|
||||
pytestmark = [pytest.mark.asyncio,
|
||||
pytest.mark.needs_net]
|
||||
|
||||
async def test_gitea(get_version):
|
||||
ver = await get_version("example",
|
||||
{"gitea": "gitea/tea"})
|
||||
assert len(ver) == 8
|
||||
assert ver.isdigit()
|
||||
|
||||
async def test_gitea_max_tag(get_version):
|
||||
assert await get_version("example", {"gitea": "gitea/tea", "use_max_tag": 1}) == "v0.4.0"
|
||||
|
||||
async def test_gitea_max_tag_with_ignored_tags(get_version):
|
||||
assert await get_version("example", {"gitea": "gitea/tea", "use_max_tag": 1, "ignored_tags": "v0.4.0"}) == "v0.3.1"
|
||||
|
||||
async def test_gitea_max_tag_with_include(get_version):
|
||||
assert await get_version("example", {
|
||||
"gitea": "gitea/tea", "use_max_tag": 1,
|
||||
"include_regex": r'v0\.3.*',
|
||||
}) == "v0.3.1"
|
Loading…
Reference in New Issue
Block a user