git-pypi
provides a pip
-compatible package index server that serves
packages based on the contents of a git repository. The server implements a
subset of Simple Repository API.
It is meant to be used in a monorepo scenario, where some packages housed in
the repository depend on others. When using git-pypi
as the package index,
one can avoid specifying git package URIs explicitly.
The packages are indexed based on git tags. The service makes the following assumptions about the git repository:
- only serving source distributions is supported,
- tags follow this format:
<package-name>/v<package-version>
, - tags are accurate w.r.t. the actual package versions they represent,
- the repository layout is flat, e.g:
.
├── package-a
│ ├── pyproject.toml
│ └── [...]
├── package-b
│ ├── pyproject.toml
│ └── [...]
└── [...]
When a specific package (e.g. package_a-1.2.3.tar.gz
) is requested by pip
,
the server will perform the following operations:
- Check out the package directory tree (and, optionally, additional trees as
dictated by the server config) at the given tag (e.g.
package-a/v1.2.3
) to a temporary build directory. - Run the build command in the temporary package directory.
- Copy the package artifact to the cache.
- Remove the temporary build directory.
- Return a HTTP 200 response containing the package contents.
Subsequent requests for the same package will use the cached version. Cached items are keyed by the SHA1 of the commit, so re-tagging a commit will cause the package to be built again. Cache is persistent between server runs.
pipx install git-pypi
After installation, git-pypi
provides the following CLI scripts.
Generates a default git-pypi
configuration file.
$ git-pypi-configure -h
usage: git-pypi-configure [-h] [--config CONFIG] [--force]
Generate a default git-pypi configuration file.
options:
-h, --help show this help message and exit
--config CONFIG, -c CONFIG
Config file path.
--force, -f Overwrite existing file.
Runs the git-pypi
server.
$ git-pypi-run -h
usage: git-pypi-run [-h] [--git-repo GIT_REPO] [--host HOST] [--port PORT] [--config CONFIG] [--clear-cache] [--debug]
Run the git-pypi server.
options:
-h, --help show this help message and exit
--git-repo GIT_REPO, -r GIT_REPO
Git repository path.
--host HOST, -H HOST Server host
--port PORT, -p PORT Server port
--config CONFIG, -c CONFIG
Config file path.
--clear-cache Clear the package cache prior to starting.
--debug Enable debug logging.
By default, git-pypi-run
will attempt to read a configuration file from
~/.git-pypi/config.toml
. Should the file be missing, a default configuration
shall be used. The config file location can be overridden by using -c
flag.
Sample configuration file:
# Directory where package artifacts can be found.
package-artifacts-dir-path = "dist"
# Cache directory localtion.
cached-artifacts-dir-path = "~/.git-pypi/cache/artifacts"
# The sdist package build command.
build-command = ["make", "build"]
# Extra trees to check out for building (besides the requested package).
# extra_checkout_paths = [".makefiles"]
# Fallback index URL if a package cannot be found. Leave empty to disable the
# additional lookup.
fallback-index-url = "https://pypi.python.org/simple"
[server]
host = "127.0.0.1"
port = 60100
threads = 4
timeout = 300
A makefile codifying several common tasks is available for developer's conevenience.
make fmt # format the code
make check # run static checks
make test # run tests
make test-update-snapshots # run tests and update snapshots
make build # build a package
git-pypi
is distributed under the terms of the MIT license.