123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- # SPDX-License-Identifier: AGPL-3.0-or-later
- """Engine to search in collaborative software platforms based on Gitea_ or Forgejo_.
- .. _Gitea: https://about.gitea.com/
- .. _Forgejo: https://forgejo.org/
- Configuration
- =============
- The engine has the following mandatory setting:
- - :py:obj:`base_url`
- Optional settings are:
- - :py:obj:`sort`
- - :py:obj:`order`
- - :py:obj:`page_size`
- .. code:: yaml
- - name: gitea.com
- engine: gitea
- base_url: https://gitea.com
- shortcut: gitea
- - name: forgejo.com
- engine: gitea
- base_url: https://code.forgejo.org
- shortcut: forgejo
- If you would like to use additional instances, just configure new engines in the
- :ref:`settings <settings engine>` and set the ``base_url``.
- Implementation
- ==============
- """
- from urllib.parse import urlencode
- from dateutil import parser
- about = {
- "website": 'https://about.gitea.com',
- "wikidata_id": None,
- "official_api_documentation": 'https://docs.gitea.com/next/development/api-usage',
- "use_official_api": True,
- "require_api_key": False,
- "results": 'JSON',
- }
- categories = ['it', 'repos']
- paging = True
- base_url: str = ''
- """URL of the Gitea_ instance."""
- sort: str = "updated"
- """Sort criteria, possible values:
- - ``updated`` (default)
- - ``alpha``
- - ``created``
- - ``size``
- - ``id``
- """
- order = "desc"
- """Sort order, possible values:
- - ``desc`` (default)
- - ``asc``
- """
- page_size: int = 10
- """Maximum number of results per page (default 10)."""
- def init(_):
- if not base_url:
- raise ValueError('gitea engine: base_url is unset')
- def request(query, params):
- args = {'q': query, 'limit': page_size, 'sort': sort, 'order': order, 'page': params['pageno']}
- params['url'] = f"{base_url}/api/v1/repos/search?{urlencode(args)}"
- return params
- def response(resp):
- results = []
- for item in resp.json().get('data', []):
- content = [item.get(i) for i in ['language', 'description'] if item.get(i)]
- results.append(
- {
- 'template': 'packages.html',
- 'url': item.get('html_url'),
- 'title': item.get('full_name'),
- 'content': ' / '.join(content),
- # Use Repository Avatar and fall back to Owner Avatar if not set.
- 'thumbnail': item.get('avatar_url') or item.get('owner', {}).get('avatar_url'),
- 'package_name': item.get('name'),
- 'maintainer': item.get('owner', {}).get('username'),
- 'publishedDate': parser.parse(item.get("updated_at") or item.get("created_at")),
- 'tags': item.get('topics', []),
- 'popularity': item.get('stars_count'),
- 'homepage': item.get('website'),
- 'source_code_url': item.get('clone_url'),
- }
- )
- return results
|