A docker container that exposes a package registry for the Toit package manager.
Features:
- List packages.
- Search.
- Automatic Toitdoc generation.
- API to register new packages or new versions of existing packages.
Run the docker container with the following variables:
REGISTRY_BRANCH
specifies the branch of the registry (for examplemain
).REGISTRY_URL
specifies the url of the registry to serve packages from (for examplegithub.com/toitware/test-registry
).REGISTRY_SSH_KEY_FILE
specifies the SSH key file inside the docker container that grants read/write access to the registry. For example/secrets/ssh-key
.REGISTRY_SSH_KEY
is an alternative way to provide the SSH key as a string. TheREGISTRY_SSH_KEY_FILE
path must still be set, and will be populated with the content of theREGISTRY_SSH_KEY
variable if theREGISTRY_SSH_KEY_FILE
doesn't exist.
Use REGISTRY_SSH_KEY_FILE
if you want to provide the key through a mounted volume.
Use REGISTRY_SSH_KEY
if you want to provide the key as an environment variable.
The default port is 8733
. You can change it by setting the PORT
environment variable.
The docker container has keys for github.com, gitlab.com and shell.sf.net. If your
registry is hosted on a different domain, you need to provide the known hosts file.
You can either provide the file through a volume and point SSH_KNOWN_HOSTS
to it,
or you can inherit the container and add an updated known hosts file.
Using a volume for the SSH key:
docker run -p 8733:8733 \
-e REGISTRY_BRANCH=main \
-e REGISTRY_URL=github.com/toitware/test-registry \
-e REGISTRY_SSH_KEY_FILE=/secrets/ssh-key \
-v /path/to/ssh-key:/secrets/ssh-key \
toit_registry
Using an environment variable for the SSH key:
docker run -p 8733:8733 \
-e REGISTRY_BRANCH=main \
-e REGISTRY_URL=github.com/toitware/test-registry \
-e REGISTRY_SSH_KEY="$(cat /path/to/ssh-key)" \
-e REGISTRY_SSH_KEY_FILE=/secrets/ssh-key \
toit_registry
List all packages:
$ curl 127.0.0.1:8733/api/v1/packages
{"result":{"package":{"name":"location","description":"Support for locations in a geographical coordinate system.","license":"MIT","url":"github.com/toitware/toit-location","latestVersion":"1.0.0"}}}
{"result":{"package":{"name":"morse","description":"Functions for International (ITU) Morse code.","license":"MIT","url":"github.com/toitware/toit-morse","latestVersion":"1.0.2"}}}
{"result":{"package":{"name":"morse_tutorial","description":"A tutorial version of the Morse package.","license":"MIT","url":"github.com/toitware/toit-morse-tutorial","latestVersion":"1.0.0"}}}
List all versions of a package:
$ curl 127.0.0.1:8733/api/v1/packages/github.com/toitware/toit-morse/versions
{"result":{"version":{"name":"morse","description":"Functions for International (ITU) Morse code.","license":"MIT","url":"github.com/toitware/toit-morse","version":"1.0.0","dependencies":[]}}}
{"result":{"version":{"name":"morse","description":"Functions for International (ITU) Morse code.","license":"MIT","url":"github.com/toitware/toit-morse","version":"1.0.1","dependencies":[]}}}
{"result":{"version":{"name":"morse","description":"Functions for International (ITU) Morse code.","license":"MIT","url":"github.com/toitware/toit-morse","version":"1.0.2","dependencies":[]}}}
Sync the registry:
$ curl -X POST 127.0.0.1:8733/api/v1/sync
{}
Register a package:
$ curl -X POST 127.0.0.1:8733/api/v1/register/github.com/toitware/ubx-message/version/2.1.1
{}