Skip to content

violinist-dev/update-check-runner

Repository files navigation

update-check-runner

The containers that run updates for violinist.io, a PHP / Composer dependency updater for Bitbucket / GitHub / GitLab / Self Hosted GitLab.

Also available as standalone docker containers to self host the update running.

Tests Violinist enabled violinist-dev/update-check-runner/update-check-runner

Quick start

Don't even have time for a quick start? Here are some examples:

Example for GitLab
docker run \
  --pull=always \
  -e "LICENCE_KEY=my_key" \
  -e "PROJECT_URL=https://gitlab.com/user/repo" \
  -e "USER_TOKEN=glpat-jjYgGb_1npvkiHTdnM" \
  ghcr.io/violinist-dev/update-check-runner:8.3-multi-composer-2
Example for GitHub
docker run \
  --pull=always \
  -e "LICENCE_KEY=my_key" \
  -e "PROJECT_URL=https://github.com/user/repo" \
  -e "USER_TOKEN=ghp_jYgGb_1npvkiHTdnM" \
  ghcr.io/violinist-dev/update-check-runner:8.3-multi-composer-2
Example for Bitbucket
docker run \
  --pull=always \
  -e "LICENCE_KEY=my_key" \
  -e "PROJECT_URL=https://bitbucket.org/org/project/repo" \
  -e "USER_TOKEN=myusername:app_p455w0rd" \
  ghcr.io/violinist-dev/update-check-runner:8.3-multi-composer-2

0. Find a repository to check for updates

Copy the URL of the repository you want to check for updates. For the purpose of this quick start guide, let's assume this is https://gitlab.com/user/repo.

1. Obtain an access token / app password

For the purpose of this quick start guide let's assume the token is glpat-jjYgGb_1npvkiHTdnM.

🚨️ For bitbucket your token should include both your username and your application password separated with a colon (:). For example user:p455w0r0.

2. Obtain a license key from violinist.io

You can do this in one of the following ways:

For the purpose of this quick start guide, let's assume the license key is fYtLakIxFEBdy1vB_SU3iaPrTRwVugFnj9AGxRYVsRSha-ju3m7qpFNHhwPn_C5vS38tDGW6jo_DOI7zZfcy5n6cu7_3ef8vU8HyfS6cyrR6Xq767XOcvqb1KKgoCKqo6_vyI02pWk6YgyU3gsrqgaS5pwcVo9aNY2AQbS1TZABJjwWRHCUqNrCK7pTd2TE6hA01rMQKTJUNmjlLjbYlYc4c3TQxS6iqYH8

3. Run the appropriate container

Choose the PHP version and composer version relevant to your project. For the purpose of this quick start guide, let's assume we use PHP 8.3 and Composer 2.

That means we should run the following docker image:

ghcr.io/violinist-dev/update-check-runner:8.3-multi-composer-2

Putting it all together with your noted arguments:

docker run \
  --pull=always \
  -e "LICENCE_KEY=fYtLakIxFEBdy1vB_SU3iaPrTRwVugFnj9AGxRYVsRSha-ju3m7qpFNHhwPn_C5vS38tDGW6jo_DOI7zZfcy5n6cu7_3ef8vU8HyfS6cyrR6Xq767XOcvqb1KKgoCKqo6_vyI02pWk6YgyU3gsrqgaS5pwcVo9aNY2AQbS1TZABJjwWRHCUqNrCK7pTd2TE6hA01rMQKTJUNmjlLjbYlYc4c3TQxS6iqYH8" \
  -e "PROJECT_URL=https://gitlab.com/user/repo" \
  -e "USER_TOKEN=glpat-jjYgGb_1npvkiHTdnM" \
  ghcr.io/violinist-dev/update-check-runner:8.3-multi-composer-2

Variables

At a glance

Name Required Default value
LICENCE_KEY Yes
USER_TOKEN Yes
PROJECT_URL Yes
GIT_AUTHOR_NAME No violinist-bot
GIT_AUTHOR_EMAIL No [email protected]
GIT_COMMITTER_NAME No violinist-bot
GIT_COMMITTER_EMAIL No [email protected]
ALTERNATE_COMPOSER_PATH No

Reference

LICENCE_KEY

The licence key either handed to you, obtained or purchased for running your own update runners.

Please note the below key is an example, which is signed with an invalid private key.

Example value: fYtLakIxFEBdy1vB_SU3iaPrTRwVugFnj9AGxRYVsRSha-ju3m7qpFNHhwPn_C5vS38tDGW6jo_DOI7zZfcy5n6cu7_3ef8vU8HyfS6cyrR6Xq767XOcvqb1KKgoCKqo6_vyI02pWk6YgyU3gsrqgaS5pwcVo9aNY2AQbS1TZABJjwWRHCUqNrCK7pTd2TE6hA01rMQKTJUNmjlLjbYlYc4c3TQxS6iqYH8

USER_TOKEN

A token valid for accessing the API, cloning the repo, pushing branches and creating pull requests on behalf of the user in question. Usually this will be a personal access token (PAT) or an app password.

Example value: ghp_eIgde31jggU3GIBB22fJbv2odcd0xy0e9jh8

PROJECT_URL

The repository to run update checks on.

Example value: https://github.com/violinist-dev/update-check-runner

GIT_AUTHOR_NAME

An environment variable used for git commits. From the git documentation:

GIT_AUTHOR_NAME is the human-readable name in the β€œauthor” field.

See "10.8 Git Internals - Environment Variables" for more information

GIT_AUTHOR_EMAIL

An environment variable used for git commits. From the git documentation:

GIT_AUTHOR_EMAIL is the email for the β€œauthor” field.

See "10.8 Git Internals - Environment Variables" for more information

GIT_COMMITTER_NAME

An environment variable used for git commits. From the git documentation:

GIT_COMMITTER_NAME sets the human name for the β€œcommitter” field.

See "10.8 Git Internals - Environment Variables" for more information

GIT_COMMITTER_EMAIL

An environment variable used for git commits. From the git documentation:

GIT_COMMITTER_EMAIL is the email address for the β€œcommitter” field.

See "10.8 Git Internals - Environment Variables" for more information

ALTERNATE_COMPOSER_PATH

An alternate path to use for the composer executable. For example, this is what you would use, should you want to use (or are forced to use) Composer 2.2 LTS instead of the latest version.

You can only set this value to one of the following alternatives, otherwise it will be ignored:

  • /usr/local/bin/composer22 (this will be the latest Composer 2.2 LTS release)

Extensions

The following PHP extensions are available in the containers (long table, click to expand):

Click to expand
Name 7.3 7.4 8.0 8.1 8.2 8.3 8.4
apcu βœ… βœ… βœ… βœ… βœ… βœ… βœ…
bcmath βœ… βœ… βœ… βœ… βœ… βœ… βœ…
bz2 βœ… βœ… βœ… βœ… βœ… βœ… βœ…
calendar βœ… βœ… βœ… βœ… βœ… βœ… βœ…
Core βœ… βœ… βœ… βœ… βœ… βœ… βœ…
ctype βœ… βœ… βœ… βœ… βœ… βœ… βœ…
curl βœ… βœ… βœ… βœ… βœ… βœ… βœ…
date βœ… βœ… βœ… βœ… βœ… βœ… βœ…
decimal βœ… βœ… βœ… βœ… βœ… βœ… βœ…
dom βœ… βœ… βœ… βœ… βœ… βœ… βœ…
exif βœ… βœ… βœ… βœ… βœ… βœ… βœ…
fileinfo βœ… βœ… βœ… βœ… βœ… βœ… βœ…
filter βœ… βœ… βœ… βœ… βœ… βœ… βœ…
ftp βœ… βœ… βœ… βœ… βœ… βœ… βœ…
gd βœ… βœ… βœ… βœ… βœ… βœ… βœ…
gettext βœ… βœ… βœ… βœ… βœ… βœ… βœ…
gmp βœ… βœ… βœ… βœ… βœ… βœ… βœ…
hash βœ… βœ… βœ… βœ… βœ… βœ… βœ…
iconv βœ… βœ… βœ… βœ… βœ… βœ… βœ…
imagick βœ… βœ… βœ… βœ… βœ… βœ… βœ…
imap βœ… βœ… βœ… βœ… βœ… βœ… βœ…
intl βœ… βœ… βœ… βœ… βœ… βœ… βœ…
json βœ… βœ… βœ… βœ… βœ… βœ… βœ…
ldap βœ… βœ… βœ… βœ… βœ… βœ… βœ…
libxml βœ… βœ… βœ… βœ… βœ… βœ… βœ…
mailparse βœ… βœ… βœ… βœ… βœ… βœ… βœ…
mbstring βœ… βœ… βœ… βœ… βœ… βœ… βœ…
memcached βœ… βœ… βœ… βœ… βœ… βœ… βœ…
mongodb βœ… βœ… βœ… βœ… βœ… βœ… βœ…
msgpack βœ… βœ… βœ… βœ… βœ… βœ… βœ…
mysqli βœ… βœ… βœ… βœ… βœ… βœ… βœ…
mysqlnd βœ… βœ… βœ… βœ… βœ… βœ… βœ…
OAuth βœ… βœ… βœ… βœ… βœ… βœ… βœ…
openssl βœ… βœ… βœ… βœ… βœ… βœ… βœ…
pcntl βœ… βœ… βœ… βœ… βœ… βœ… βœ…
pcre βœ… βœ… βœ… βœ… βœ… βœ… βœ…
PDO βœ… βœ… βœ… βœ… βœ… βœ… βœ…
pdo_mysql βœ… βœ… βœ… βœ… βœ… βœ… βœ…
pdo_pgsql βœ… βœ… βœ… βœ… βœ… βœ… βœ…
pdo_sqlite βœ… βœ… βœ… βœ… βœ… βœ… βœ…
pdo_sqlsrv βœ… βœ… βœ… βœ… βœ… βœ… βœ…
Phar βœ… βœ… βœ… βœ… βœ… βœ… βœ…
posix βœ… βœ… βœ… βœ… βœ… βœ… βœ…
random ❌ ❌ ❌ ❌ βœ… βœ… βœ…
rdkafka βœ… βœ… βœ… βœ… βœ… βœ… βœ…
readline βœ… βœ… βœ… βœ… βœ… βœ… βœ…
redis βœ… βœ… βœ… βœ… βœ… βœ… βœ…
Reflection βœ… βœ… βœ… βœ… βœ… βœ… βœ…
session βœ… βœ… βœ… βœ… βœ… βœ… βœ…
SimpleXML βœ… βœ… βœ… βœ… βœ… βœ… βœ…
soap βœ… βœ… βœ… βœ… βœ… βœ… βœ…
sockets βœ… βœ… βœ… βœ… βœ… βœ… βœ…
sodium βœ… βœ… βœ… βœ… βœ… βœ… βœ…
SPL βœ… βœ… βœ… βœ… βœ… βœ… βœ…
sqlite3 βœ… βœ… βœ… βœ… βœ… βœ… βœ…
sqlsrv βœ… βœ… βœ… βœ… βœ… βœ… βœ…
standard βœ… βœ… βœ… βœ… βœ… βœ… βœ…
tokenizer βœ… βœ… βœ… βœ… βœ… βœ… βœ…
uuid βœ… βœ… βœ… βœ… βœ… βœ… βœ…
xml βœ… βœ… βœ… βœ… βœ… βœ… βœ…
xmlreader βœ… βœ… βœ… βœ… βœ… βœ… βœ…
xmlrpc βœ… βœ… βœ… ❌ ❌ ❌ ❌
xmlwriter βœ… βœ… βœ… βœ… βœ… βœ… βœ…
xsl βœ… βœ… βœ… βœ… βœ… βœ… βœ…
yaml βœ… βœ… βœ… βœ… βœ… βœ… βœ…
Zend OPcache βœ… βœ… βœ… βœ… βœ… βœ… βœ…
zip βœ… βœ… βœ… βœ… βœ… βœ… βœ…
zlib βœ… βœ… βœ… βœ… βœ… βœ… βœ…

FAQ

What is the difference between self hosting and using violinist.io (the SaaS)

In practice, all the automation, convenience, logging and persistance you would have to need.

  • No formatting, storing or analysis of logs. You would have to implement this yourself if needed.
  • No notifications (email or slack)
  • No automatic discovery of PHP version. When your project upgrade to a new version, you must also change the PHP version of the update container
  • No private keys per project or per organization
Can I use this to run updates for my clients or customers and charge money for it?

Yes. There are no restrictions on what you use the licence key for, and if you use it for commercial purposes or something else.

You are not allowed to provide the same service as violinist.io (sell licences to this software, or provide a SaaS based on this software). But please go ahead and purchase a licence and charge your customers multiples of that to provide the service you purchased.

Otherwise, we refer to the licence of this repo: https://github.com/violinist-dev/update-check-runner/blob/main/LICENSE

Licence

Licenced under the commercial violinist licence