Skip to content

Commit

Permalink
Merge branch 'develop' of github.com:felddy/foundryvtt-docker into re…
Browse files Browse the repository at this point in the history
…lease-dev
  • Loading branch information
felddy committed Oct 17, 2020
2 parents d7b5392 + 16e1a11 commit 235a356
Show file tree
Hide file tree
Showing 3 changed files with 53 additions and 39 deletions.
69 changes: 36 additions & 33 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -197,17 +197,19 @@ upgrade to a new version of Foundry pull an updated image version.

## Image tags ##

The images of this container are tagged to add additional flexibility during
deployment. It is recommended that most users use the `:release` tag. This tag
will only be applied to images that support versions from the Foundry "release"
channel.
The images of this container are tagged with both the [semantic
versions](https://semver.org) of Foundry Virtual Tabletop that they support as
well as the update channel associated with the release. It is recommended that
most users use the `:release` tag.

| Image:tag | Description |
|-----------|-------------|
|`felddy/foundryvtt:release` | The most recent image from the release channel. These images are **considered stable**, and well-tested. Most users will use this tag. |
|`felddy/foundryvtt:release` | The most recent image from the release channel. These images are **considered stable**, and well-tested. Most users will use this tag. The `latest` tag always points to the same version as `release`.|
|`felddy/foundryvtt:beta` | Beta channel releases **should be stable** for all users, but may impose some module conflicts or compatibility issues. It is only recommended for users to update to this version if they are comfortable with accepting some minor risks. Users are discouraged from updating to this version if it is immediately before a game session. _Please take care to periodically back up your critical user data in case you experience any issues._ |
|`felddy/foundryvtt:alpha` | Alpha channel releases are **VERY LIKELY to introduce breaking bugs** that will be disruptive to play. Do not install this update unless you are using for the specific purposes of testing. The intention of Alpha builds are to allow for previewing new features and to help developers to begin updating modules which are impacted by the changes. If you choose to update to this version for a live game you do so entirely at your own risk of having a bad experience. _Please back up your critical user data before installing this update._ |
|`felddy/foundryvtt:0.6.6`| A specific version. |
|`felddy/foundryvtt:0.6.6`| An exact version. |
|`felddy/foundryvtt:0.6`| The most recent release matching the major and minor version numbers. |
|`felddy/foundryvtt:latest`| See the `release` tag. [Why does `latest` == `release`?](https://vsupalov.com/docker-latest-tag/) |

See the [tags tab](https://hub.docker.com/r/felddy/foundryvtt/tags) on Docker
Hub for a list of all the supported tags.
Expand All @@ -216,31 +218,31 @@ Hub for a list of all the supported tags.

| Mount point | Purpose |
|-------------|----------------|
| /data | configuration, data, and log storage |
| `/data` | configuration, data, and log storage |

## Environment variables ##

### Required combinations ###

There are three combinations of environment variables that are required to start
One of three combinations of environment variables must be set to start
the container. Either (`FOUNDRY_USERNAME` and `FOUNDRY_PASSWORD`), or
`FOUNDRY_RELEASE_URL`, or `CONTAINER_CACHE` must be provided.

#### Credentials variables ####

***Note:*** `FOUNDRY_USERNAME` and `FOUNDRY_PASSWORD` may be set [using
secrets](#using-secrets) instead of environment variables.

| Name | Purpose |
|------------------|----------|
| FOUNDRY_PASSWORD | Account password for foundryvtt.com. Required for downloading an application release. |
| FOUNDRY_USERNAME | Account username or email address for foundryvtt.com. Required for downloading an application release. |
| `FOUNDRY_PASSWORD` | Account password for foundryvtt.com. Required for downloading an application release. |
| `FOUNDRY_USERNAME` | Account username or email address for foundryvtt.com. Required for downloading an application release. |

***Note:*** `FOUNDRY_USERNAME` and `FOUNDRY_PASSWORD` may be set [using
secrets](#using-secrets) instead of environment variables.

#### Pre-signed URL variable ####

| Name | Purpose |
|------------------|----------|
| FOUNDRY_RELEASE_URL | S3 pre-signed URL generate from the user's profile. Required for downloading an application release. |
| `FOUNDRY_RELEASE_URL` | S3 pre-signed URL generate from the user's profile. Required for downloading an application release. |

#### Pre-cached release variable ####

Expand All @@ -249,30 +251,31 @@ be of the form: `foundryvtt-0.6.6.zip`

| Name | Purpose |
|------------------|----------|
| CONTAINER_CACHE | Set a path to cache downloads of the Foundry release archive and speed up subsequent container startups. The path should be in `/data` or another persistent mount point in the container. e.g.; `/data/container_cache`| |
| `CONTAINER_CACHE` | Set a path to cache downloads of the Foundry release archive and speed up subsequent container startups. The path should be in `/data` or another persistent mount point in the container. e.g.; `/data/container_cache`| |

### Optional ###

| Name | Purpose | Default |
|-------|---------|---------|
| CONTAINER_PATCHES | Set a path to a directory of shell scripts to be sourced after Foundry is installed but before it is started. The path should be in `/data` or another persistent mount point in the container. e.g.; `/data/container_patches`| |
| CONTAINER_VERBOSE | Set to `true` to enable verbose logging for the container utility scripts. | |
| FOUNDRY_ADMIN_KEY | Admin password to be applied at startup. If omitted the admin password will be cleared. May be set [using secrets](#using-secrets). | |
| FOUNDRY_AWS_CONFIG | An absolute or relative path that points to the [awsConfig.json](https://foundryvtt.com/article/aws-s3/) or `true` for AWS environment variable [credentials evaluation](https://docs.aws.amazon.com/sdk-for-javascript/v2/developer-guide/setting-credentials-node.html) usage. | null |
| FOUNDRY_GID | `gid` the deamon will be run under. | foundry |
| FOUNDRY_HOSTNAME | A custom hostname to use in place of the host machine's public IP address when displaying the address of the game session. This allows for reverse proxies or DNS servers to modify the public address. | null |
| FOUNDRY_LICENSE_KEY | The license key to install. e.g.; `AAAA-BBBB-CCCC-DDDD-EEEE-FFFF` If left unset, a license key will be fetched when using account authentication. If multiple license keys are associated with an account, one will be chosen at random. Specific licenses can be selected by passing in an integer index. The first license key being `1`. May be set [using secrets](#using-secrets). | |
| FOUNDRY_PROXY_PORT | Inform the Foundry Server that the software is running behind a reverse proxy on some other port. This allows the invitation links created to the game to include the correct external port. | null |
| FOUNDRY_PROXY_SSL | Indicates whether the software is running behind a reverse proxy that uses SSL. This allows invitation links and A/V functionality to work as if the Foundry Server had SSL configured directly. | false |
| FOUNDRY_ROUTE_PREFIX | A string path which is appended to the base hostname to serve Foundry VTT content from a specific namespace. For example setting this to `demo` will result in data being served from `http://x.x.x.x:30000/demo/`. | null |
| FOUNDRY_SSL_CERT | An absolute or relative path that points towards a SSL certificate file which is used jointly with the sslKey option to enable SSL and https connections. If both options are provided, the server will start using HTTPS automatically. | null |
| FOUNDRY_SSL_KEY | An absolute or relative path that points towards a SSL key file which is used jointly with the sslCert option to enable SSL and https connections. If both options are provided, the server will start using HTTPS automatically. | null |
| FOUNDRY_UID | `uid` the daemon will be run under. | foundry |
| FOUNDRY_UPDATE_CHANNEL | The update channel to subscribe to. "alpha", "beta", or "release". | "release" |
| FOUNDRY_UPNP | Allow Universal Plug and Play to automatically request port forwarding for the Foundry VTT port to your local network address. | false |
| FOUNDRY_VERSION | Version of Foundry Virtual Tabletop to install. | 0.6.6 |
| FOUNDRY_WORLD | The world to startup at system start. | null |
| TIMEZONE | Container [TZ database name](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List) | UTC |
| `CONTAINER_PATCHES` | Set a path to a directory of shell scripts to be sourced after Foundry is installed but before it is started. The path should be in `/data` or another persistent mount point in the container. e.g.; `/data/container_patches` Patch files are sourced in lexicographic order. `CONTAINER_PATCHES` are processed after `CONTAINER_PATCH_URLS`.| |
| `CONTAINER_PATCH_URLS` | Set to a space-delimited list of URLs to be sourced after Foundry is installed but before it is started. Patch URLs are sourced in the order specified. `CONTAINER_PATCH_URLS` are processed before `CONTAINER_PATCHES`. ⚠️ **Only use patch URLs from trusted sources!** | |
| `CONTAINER_VERBOSE` | Set to `true` to enable verbose logging for the container utility scripts. | |
| `FOUNDRY_ADMIN_KEY` | Admin password to be applied at startup. If omitted the admin password will be cleared. May be set [using secrets](#using-secrets). | |
| `FOUNDRY_AWS_CONFIG` | An absolute or relative path that points to the [awsConfig.json](https://foundryvtt.com/article/aws-s3/) or `true` for AWS environment variable [credentials evaluation](https://docs.aws.amazon.com/sdk-for-javascript/v2/developer-guide/setting-credentials-node.html) usage. | null |
| `FOUNDRY_GID` | `gid` the deamon will be run under. | foundry |
| `FOUNDRY_HOSTNAME` | A custom hostname to use in place of the host machine's public IP address when displaying the address of the game session. This allows for reverse proxies or DNS servers to modify the public address. | null |
| `FOUNDRY_LICENSE_KEY` | The license key to install. e.g.; `AAAA-BBBB-CCCC-DDDD-EEEE-FFFF` If left unset, a license key will be fetched when using account authentication. If multiple license keys are associated with an account, one will be chosen at random. Specific licenses can be selected by passing in an integer index. The first license key being `1`. May be set [using secrets](#using-secrets). | |
| `FOUNDRY_PROXY_PORT` | Inform the Foundry Server that the software is running behind a reverse proxy on some other port. This allows the invitation links created to the game to include the correct external port. | null |
| `FOUNDRY_PROXY_SSL` | Indicates whether the software is running behind a reverse proxy that uses SSL. This allows invitation links and A/V functionality to work as if the Foundry Server had SSL configured directly. | false |
| `FOUNDRY_ROUTE_PREFIX` | A string path which is appended to the base hostname to serve Foundry VTT content from a specific namespace. For example setting this to `demo` will result in data being served from `http://x.x.x.x:30000/demo/`. | null |
| `FOUNDRY_SSL_CERT` | An absolute or relative path that points towards a SSL certificate file which is used jointly with the sslKey option to enable SSL and https connections. If both options are provided, the server will start using HTTPS automatically. | null |
| `FOUNDRY_SSL_KEY` | An absolute or relative path that points towards a SSL key file which is used jointly with the sslCert option to enable SSL and https connections. If both options are provided, the server will start using HTTPS automatically. | null |
| `FOUNDRY_UID` | `uid` the daemon will be run under. | foundry |
| `FOUNDRY_UPDATE_CHANNEL` | The update channel to subscribe to. "alpha", "beta", or "release". | "release" |
| `FOUNDRY_UPNP` | Allow Universal Plug and Play to automatically request port forwarding for the Foundry VTT port to your local network address. | false |
| `FOUNDRY_VERSION` | Version of Foundry Virtual Tabletop to install. | 0.6.6 |
| `FOUNDRY_WORLD` | The world to startup at system start. | null |
| `TIMEZONE` | Container [TZ database name](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List) | UTC |

## Secrets ##

Expand Down
3 changes: 0 additions & 3 deletions patches/hotfix_issue_3817-0.7.4.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,6 @@
# Corrects routePrefix problem detailed in issue 3817
# https://gitlab.com/foundrynet/foundryvtt/-/issues/3817

# s/const view = url\.pathname\.replace(`\/\${ROUTE_PREFIX}`, "");\
# /const view = url.pathname.split("\/").pop();/g

PATCH_DEST="$FOUNDRY_HOME/resources/app/public/scripts/foundry.js"
PATCH_DOC_URL="https://gitlab.com/foundrynet/foundryvtt/-/issues/3817#note_430588341"
PATCH_NAME="Issue 3817 Hotfix for 0.7.4"
Expand Down
20 changes: 17 additions & 3 deletions src/entrypoint.sh
Original file line number Diff line number Diff line change
Expand Up @@ -119,24 +119,38 @@ if [ $install_required = true ]; then
rm "${release_filename}"
fi

# apply URL patches if requested
if [[ "${CONTAINER_PATCH_URLS:-}" ]]; then
log_warn "CONTAINER_PATCH_URLS is set: Only use patch URLs from trusted sources!"
for url in ${CONTAINER_PATCH_URLS}
do
log "Sourcing patch from URL: $url"
patch_file=$(mktemp -t patch_url.sh.XXXXXX)
curl --silent --output "${patch_file}" "${url}"
# shellcheck disable=SC1090
source "${patch_file}"
done
log "Completed URL patching."
fi

# apply patches if requested and the directory exists
if [[ "${CONTAINER_PATCHES:-}" ]]; then
log "Using CONTAINER_PATCHES: ${CONTAINER_PATCHES}"
if [ -d "${CONTAINER_PATCHES}" ]; then
log "Container patches directory detected. Starting patching..."
log "Container patches directory detected. Starting patch application..."
for f in "${CONTAINER_PATCHES}"/*
do
[ -f "$f" ] || continue # we can't set nullglob in busybox
log "Sourcing patch from file: $f"
# shellcheck disable=SC1090
source "$f"
done
log "Completed patching."
log "Completed file patching."
else
log_warn "Container patches directory not found."
fi
fi
fi
fi # install required

if [ ! -f /data/Config/license.json ]; then
log "Installation not yet licensed."
Expand Down

0 comments on commit 235a356

Please sign in to comment.