Migrate to 3.x
WARNING
Gotify 3 isn't released yet.
- The
config.ymlfile is no longer supported, convert it to the new env format withmigrate-config. - If you set list or map environment variables, their syntax changed, see List and map syntax.
- If you have scripts hitting client-token endpoints, they may now need elevation.
Config Changes
YAML config file removed
The YAML config file (config.yml) is no longer supported. Gotify can now be only configured by environment variables, which can be loaded from an env file. The first existing file from this search order is loaded:
gotify-server.env(in the working directory)$XDG_CONFIG_HOME/gotify/gotify-server.env($XDG_CONFIG_HOMEfalls back to$HOME/.configwhen unset)/etc/gotify/server.env
See the Configuration page for the full list of variables.
Migrating your config
The migrate-config command converts an existing config.yml to the new env format. It prints the result to stdout.
$ gotify-server migrate-config config.yml > gotify-server.envWith Docker:
$ docker run --rm -v "$(pwd)/config.yml:/app/config.yml" gotify/server:master \
migrate-config config.yml > gotify-server.envEnvironment List and map syntax
Defining settings via environment variables was already possible, but the syntax for list and map values has changed. If you set any of the variables below, update their format.
Lists are now comma-separated instead of a YAML array:
GOTIFY_SERVER_TRUSTEDPROXIESGOTIFY_SERVER_CORS_ALLOWORIGINSGOTIFY_SERVER_CORS_ALLOWMETHODSGOTIFY_SERVER_CORS_ALLOWHEADERSGOTIFY_SERVER_STREAM_ALLOWEDORIGINSGOTIFY_SERVER_SSL_LETSENCRYPT_HOSTSGOTIFY_OIDC_SCOPES
# before
GOTIFY_SERVER_TRUSTEDPROXIES=[127.0.0.1/32, ::1]
# after
GOTIFY_SERVER_TRUSTEDPROXIES=127.0.0.1/32,::1Maps are now a JSON object instead of a YAML map:
GOTIFY_SERVER_RESPONSEHEADERS
# before
GOTIFY_SERVER_RESPONSEHEADERS={X-Custom-Header: "custom value"}
# after
GOTIFY_SERVER_RESPONSEHEADERS={"X-Custom-Header":"custom value"}API Changes
Introduces step-up authentication via time-limited session elevation. A session/client token must re-authenticate before sensitive, hard-to-undo actions.
HTTP Basic auth and application tokens are unaffected.
Endpoints that now require elevation
With a non-elevated client token these return 403:
| Endpoint | Action |
|---|---|
POST /current/user/password | Change current user's password |
DELETE /client/{id} | Delete a client |
DELETE /application/{id} | Delete an application |
POST /client/{id}/elevate | Elevate a client token |
GET /user, GET/POST/DELETE /user/{id} | Manage users (admin) |
The Client and CurrentUser models have gotten elevation-related fields. See the API documentation for details.
Adapting your scripts
Scripts that hit the endpoints above with a client token now need that token to be elevated. Either:
- Use HTTP Basic auth as they are elevated by default.
- Elevate the client in the WebUI or the api with basic auth.
CLI Changes
The binary now uses subcommands. You should migrate to using the serve subcommand. For backwards compatibility running gotify without a command will continue to serve the server.
$ ./gotify-linux-amd64 serveThe Docker image already defaults to serve, so docker run and Docker Compose setups keep working unchanged.
