Your private Satis instance on Heroku, just one click away.
Use the button above to deploy your own Satis instance. It's free, all you need is a Heroku account.
It is assumed that you have already installed the Heroku Toolbelt and that
you have logged in via heroku login
command. The toolbelt is necessary to interact with your Heroku app via CLI.
Replace [heroku-app-name]
with the app name you have chosen during deployment on Heroku when following the
instructions in this section.
Checkout the repository:
git clone [email protected]:Matthimatiker/satis-on-heroku.git [heroku-app-name]
cd [heroku-app-name]
Connect the checkout to your Heroku app:
heroku git:remote --app [heroku-app-name]
You are now able to configure your app from your checkout directory via toolbelt.
Your Satis instance needs a SSH key to read package data from private repositories. You can skip this step if you do not plan to use private repositories.
Generate a new key:
ssh-keygen -t rsa -f satis_on_heroku_ssh_key
Add the generated private key to your app configuration:
heroku config:set SATIS_SSH_KEY="`cat satis_on_heroku_ssh_key`"
Ensure that the key can be used to access your private repositories. When using GitHub you have to register the public key at https://github.com/settings/keys. You might want to create a separate account with read-only access for your Satis app.
You can add a GitHub token to ensure that the Satis instance can access private GitHub repositories.
Create a new token at https://github.com/settings/tokens/new. Afterwards add it as configuration variable to your Satis app:
heroku config:set SATIS_GITHUB_TOKEN="[your-generated-token]"
To restrict access you can activate basic authentication for your Satis instance. Just assign a username and password:
heroku config:set SATIS_AUTH_USERNAME=test SATIS_AUTH_PASSWORD=secret
Set the username to an empty value to disable the authentication:
heroku config:set SATIS_AUTH_USERNAME=
For demonstration purposes, an example repository has been registered during deployment. You might want to remove that now:
heroku config:unset SATIS_REPOSITORY_EXAMPLE
Repositories that are scanned for packages are added via SATIS_REPOSITORY_*
config variables. The values
of all config variables that are prefixed with SATIS_REPOSITORY_
are treated as repository urls.
Here is an example how to add a repository:
heroku config:set [email protected]:Matthimatiker/satis-on-heroku.git
You can also use the app settings page on the Heroku dashboard to add config values.
A full packages scan is performed during instance startup. Delta updates for GitHub repositories can be achieved via webhooks.
Provide a valid GitHub token and set SATIS_GITHUB_MANAGE_WEBHOOKS
to 1
to ensure that the
Satis instance manages package update notifications for GitHub repositories automatically via webhooks.
A webhook is registered (and kept up to date) for each GitHub repository that has been added to
your Satis instance.
Now the package repository is updated whenever new code is pushed.
If you do not want webhooks to be registered automatically, then you can add the webhooks manually. Go to your repository page -> Settings -> Webhooks and services and register the following Payload URL for push events:
https://[your-app-name].herokuapp.com/github-webhook.php
Note: If you have activated authentication, then you have to encode the credentials in the Payload URL:
https://user:password:[your-app-name].herokuapp.com/github-webhook.php
To rebuild the whole package repository you can restart your app:
heroku restart
You can also restart the app via Heroku dashboard.