[feat] github: use packages template

Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
pull/3231/head
Markus Heiser 7 months ago committed by Markus Heiser
parent 1d6f475fbc
commit b683aa63fb

@ -1,10 +1,11 @@
# SPDX-License-Identifier: AGPL-3.0-or-later # SPDX-License-Identifier: AGPL-3.0-or-later
""" # lint: pylint
Github (IT)
"""Github (IT)
""" """
from json import loads
from urllib.parse import urlencode from urllib.parse import urlencode
from dateutil import parser
# about # about
about = { about = {
@ -20,42 +21,48 @@ about = {
categories = ['it', 'repos'] categories = ['it', 'repos']
# search-url # search-url
search_url = 'https://api.github.com/search/repositories?sort=stars&order=desc&{query}' # noqa search_url = 'https://api.github.com/search/repositories?sort=stars&order=desc&{query}'
accept_header = 'application/vnd.github.preview.text-match+json' accept_header = 'application/vnd.github.preview.text-match+json'
# do search-request
def request(query, params): def request(query, params):
params['url'] = search_url.format(query=urlencode({'q': query}))
params['url'] = search_url.format(query=urlencode({'q': query}))
params['headers']['Accept'] = accept_header params['headers']['Accept'] = accept_header
return params return params
# get response from search-request
def response(resp): def response(resp):
results = [] results = []
search_res = loads(resp.text) for item in resp.json().get('items', []):
content = [item.get(i) for i in ['language', 'description'] if item.get(i)]
# check if items are received
if 'items' not in search_res: # license can be None
return [] lic = item.get('license') or {}
lic_url = None
# parse results if lic.get('spdx_id'):
for res in search_res['items']: lic_url = f"https://spdx.org/licenses/{lic.get('spdx_id')}.html"
title = res['name']
url = res['html_url'] results.append(
{
if res['description']: 'template': 'packages.html',
content = res['description'][:500] 'url': item.get('html_url'),
else: 'title': item.get('full_name'),
content = '' 'content': ' / '.join(content),
'img_src': item.get('owner', {}).get('avatar_url'),
# append result 'package_name': item.get('name'),
results.append({'url': url, 'title': title, 'content': content}) # 'version': item.get('updated_at'),
'maintainer': item.get('owner', {}).get('login'),
'publishedDate': parser.parse(item.get("updated_at") or item.get("created_at")),
'tags': item.get('topics', []),
'popularity': item.get('stargazers_count'),
'license_name': lic.get('name'),
'license_url': lic_url,
'homepage': item.get('homepage'),
'source_code_url': item.get('clone_url'),
}
)
# return results
return results return results

Loading…
Cancel
Save