No description
Find a file
Jérémy Bobbio (Lunar) d70dd84939 Fix the listing of listers
Commit c2402f405f renamed the entry points from `lister.*` without
updating the rest of the framework. Revert the changes (and sort the
list alphabetically).
2024-01-10 17:46:23 +01:00
docs python: Fix black formatting after bump to 23.1.0 in pre-commit 2023-12-05 10:33:07 +01:00
sql Revert to the pre-qless refactoring version 2016-09-13 14:57:26 +02:00
swh/lister Elm stateful lister 2024-01-09 14:05:56 +01:00
.copier-answers.yml Apply swh-py-template 0.1.6 2023-12-03 17:54:52 +01:00
.git-blame-ignore-revs Add latest blackify to git-blame-ignore-revs 2023-12-05 14:04:51 +01:00
.gitignore Apply swh-py-template 0.1.6 2023-12-03 17:54:52 +01:00
.pre-commit-config.yaml Apply swh-py-template 0.1.6 2023-12-03 17:54:52 +01:00
ACKNOWLEDGEMENTS add ACKNOWLEDGEMENTS 2015-04-26 15:54:25 +02:00
AUTHORS Migrate to copier-based swh-py-template 2023-11-29 17:23:28 +01:00
CODE_OF_CONDUCT.md add code of conduct document 2019-07-11 16:29:36 +02:00
conftest.py conftest: Use proper way to mock sleep from tenacity retry 2023-07-04 17:30:53 +02:00
CONTRIBUTORS gogs: Introduce Gogs lister 2022-08-03 16:22:06 +05:30
LICENSE add license information 2015-04-26 16:24:32 +02:00
Makefile Makefile: add from swh-py-template 2015-10-27 14:35:54 +01:00
mypy.ini Migrate to copier-based swh-py-template 2023-11-29 17:23:28 +01:00
pyproject.toml Fix the listing of listers 2024-01-10 17:46:23 +01:00
pytest.ini Apply swh-py-template 0.1.6 2023-12-03 17:54:52 +01:00
README.rst docs: include the README file in the main index page 2023-11-16 16:25:56 +01:00
requirements-swh.txt swh-core's github extra isn't needed anymore 2023-11-14 19:25:13 +01:00
requirements-test.txt Add Julia Lister for listing Julia Packages 2023-10-09 15:05:25 +02:00
requirements.txt cran: Use pyreadr instead of rpy2 to read a RDS file from Python 2023-11-14 17:09:42 +01:00
setup.cfg pre-commit, tox: Bump black from 19.10b0 to 22.3.0 2022-04-08 15:13:41 +02:00
tox.ini Apply swh-py-template 0.1.6 2023-12-03 17:54:52 +01:00

Software Heritage - Listers
===========================

Collection of listers for source code distribution places like development
forges, FOSS distributions, package managers, etc. Each lister is in charge to
enumerate the software origins (e.g., VCS, packages, etc.) available at a
source code distribution place.

A lister is a component from the Software Heritage stack aims to produce
listings of software origins and their urls hosted on various public developer
platforms or package managers. As these operations are quite similar, this
package provides a set of Python modules abstracting common software origins
listing behaviors.

It also provides several lister implementations, contained in the
following Python modules:

- ``swh.lister.bitbucket``
- ``swh.lister.cgit``
- ``swh.lister.cran``
- ``swh.lister.debian``
- ``swh.lister.gitea``
- ``swh.lister.github``
- ``swh.lister.gitlab``
- ``swh.lister.gnu``
- ``swh.lister.gogs``
- ``swh.lister.golang``
- ``swh.lister.hex``
- ``swh.lister.launchpad``
- ``swh.lister.maven``
- ``swh.lister.npm``
- ``swh.lister.packagist``
- ``swh.lister.phabricator``
- ``swh.lister.pypi``
- ``swh.lister.rpm``
- ``swh.lister.tuleap``
- ``swh.lister.bioconductor``

Dependencies
------------

All required dependencies can be found in the ``requirements*.txt`` files
located at the root of the repository.

Local deployment
----------------

Lister configuration
++++++++++++++++++++

Each lister implemented so far by Software Heritage (``bitbucket``, ``cgit``,
``cran``, ``debian``, ``gitea``, ``github``, ``gitlab``, ``gnu``, ``golang``,
``launchpad``, ``npm``, ``packagist``, ``phabricator``, ``pypi``, ``tuleap``,
``maven``) must be configured by following the instructions below (please note
that you have to replace ``<lister_name>`` by one of the lister name introduced
above).

Preparation steps
~~~~~~~~~~~~~~~~~

1. ``mkdir ~/.config/swh/``
2. create configuration file ``~/.config/swh/listers.yml``

Configuration file sample
+++++++++++++++++++++++++

Minimalistic configuration shared by all listers to add in file
``~/.config/swh/listers.yml``:

.. code-block:: yaml

   scheduler:
     cls: 'remote'
     args:
       url: 'http://localhost:5008/'

   credentials: {}

Note: This expects scheduler (5008) service to run locally

Executing a lister
------------------

Once configured, a lister can be executed by using the ``swh`` CLI tool with
the following options and commands:

.. code-block:: shell

   $ swh --log-level DEBUG lister -C ~/.config/swh/listers.yml run --lister <lister_name> [lister_parameters]


Examples:

.. code-block:: shell

   $ swh --log-level DEBUG lister -C ~/.config/swh/listers.yml run --lister bitbucket

   $ swh --log-level DEBUG lister -C ~/.config/swh/listers.yml run --lister cran

   $ swh --log-level DEBUG lister -C ~/.config/swh/listers.yml run --lister gitea url=https://codeberg.org/api/v1/

   $ swh --log-level DEBUG lister -C ~/.config/swh/listers.yml run --lister gitlab url=https://salsa.debian.org/api/v4/

   $ swh --log-level DEBUG lister -C ~/.config/swh/listers.yml run --lister npm

   $ swh --log-level DEBUG lister -C ~/.config/swh/listers.yml run --lister pypi


Licensing
---------

This program is free software: you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free Software
Foundation, either version 3 of the License, or (at your option) any later
version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.  See the GNU General Public License for more details.

See top-level LICENSE file for the full text of the GNU General Public License
along with this program.