github.py 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. """Github (IT)
  4. """
  5. from urllib.parse import urlencode
  6. from dateutil import parser
  7. # about
  8. about = {
  9. "website": 'https://github.com/',
  10. "wikidata_id": 'Q364',
  11. "official_api_documentation": 'https://developer.github.com/v3/',
  12. "use_official_api": True,
  13. "require_api_key": False,
  14. "results": 'JSON',
  15. }
  16. # engine dependent config
  17. categories = ['it', 'repos']
  18. # search-url
  19. search_url = 'https://api.github.com/search/repositories?sort=stars&order=desc&{query}'
  20. accept_header = 'application/vnd.github.preview.text-match+json'
  21. def request(query, params):
  22. params['url'] = search_url.format(query=urlencode({'q': query}))
  23. params['headers']['Accept'] = accept_header
  24. return params
  25. def response(resp):
  26. results = []
  27. for item in resp.json().get('items', []):
  28. content = [item.get(i) for i in ['language', 'description'] if item.get(i)]
  29. # license can be None
  30. lic = item.get('license') or {}
  31. lic_url = None
  32. if lic.get('spdx_id'):
  33. lic_url = f"https://spdx.org/licenses/{lic.get('spdx_id')}.html"
  34. results.append(
  35. {
  36. 'template': 'packages.html',
  37. 'url': item.get('html_url'),
  38. 'title': item.get('full_name'),
  39. 'content': ' / '.join(content),
  40. 'img_src': item.get('owner', {}).get('avatar_url'),
  41. 'package_name': item.get('name'),
  42. # 'version': item.get('updated_at'),
  43. 'maintainer': item.get('owner', {}).get('login'),
  44. 'publishedDate': parser.parse(item.get("updated_at") or item.get("created_at")),
  45. 'tags': item.get('topics', []),
  46. 'popularity': item.get('stargazers_count'),
  47. 'license_name': lic.get('name'),
  48. 'license_url': lic_url,
  49. 'homepage': item.get('homepage'),
  50. 'source_code_url': item.get('clone_url'),
  51. }
  52. )
  53. return results