Personal collection of example config files for benphelps/homepage
There are two versions of the services configuration file in this repository.
The first is a sanitized version using standard keys:
While the second uses IP / key substitutions from environment variables used in the homepage container creation:
Example docker run command using standard config files:
docker run \
-d \
--name='homepage' \
--net='dsn' \ # user-defined bridge network to refer to containers by hostname instead of IP
-e TZ="America/Denver" \
-v '/mnt/':'/mnt':'ro' \ # read-only volume mount
-v '/mnt/user/appdata/homepage/config':'/app/config':'rw' \
-v '/mnt/user/appdata/homepage/images/':'/app/public/images':'rw' \
-v '/mnt/user/appdata/homepage/icons/':'/app/public/icons':'rw' \
-p '3000:3000/tcp' \
'ghcr.io/benphelps/homepage'
Example docker run command using environment label substitutions:
docker run \
-d \
--name='homepage' \
--net='dsn' \ # user-defined bridge network to refer to containers by hostname instead of IP
-e TZ="America/Denver" \
-e 'HOMEPAGE_VAR_ROUTER_IP'='192.168.0.1' \
-e 'HOMEPAGE_VAR_SERVER_IP'='192.168.0.100' \
-e 'HOMEPAGE_VAR_CLOUDFLARE_ACCOUNT_ID'='XXXXX' \
-e 'HOMEPAGE_VAR_CLOUDFLARE_TUNNEL_ID'='XXXXX' \
-e 'HOMEPAGE_VAR_CLOUDFLARE_TUNNEL_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_TAILSCALE_DEVICE_ID'='XXXXX' \
-e 'HOMEPAGE_VAR_TAILSCALE_API_KEY'='tskey-api-XXXXX' \
-e 'HOMEPAGE_VAR_OVERSEERR_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_QBITTORRENT_UN'='XXXXX' \
-e 'HOMEPAGE_VAR_QBITTORRENT_PW'='XXXXX' \
-e 'HOMEPAGE_VAR_SABNZBD_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_PLEX_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_TAUTULLI_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_RADARR_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_RADARR4K_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_SONARR_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_BAZARR_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_PROWLARR_API_KEY'='XXXXX' \
-e 'HOMEPAGE_VAR_OPNSENSE_UN'='XXXXX' \
-e 'HOMEPAGE_VAR_OPNSENSE_PW'='XXXXX' \
-e 'HOMEPAGE_VAR_ADGUARD_UN'='XXXXX' \
-e 'HOMEPAGE_VAR_ADGUARD_PW'='XXXXX' \
-e 'HOMEPAGE_VAR_HOMEASSISTANT_LLAT'='XXXXX' \
-v '/mnt/':'/mnt':'ro' \ # read-only volume mount
-v '/mnt/user/appdata/homepage/config':'/app/config':'rw' \
-v '/mnt/user/appdata/homepage/images/':'/app/public/images':'rw' \
-v '/mnt/user/appdata/homepage/icons/':'/app/public/icons':'rw' \
-p '3000:3000/tcp' \
'ghcr.io/benphelps/homepage'
Also included is customtheme.css
showing how to customize the colours further.
The easiest method is likely either via a browser extension such as Stylus, or by using a subfilter module in Nginx (or similar).
Ex.
or
server {
# ...
location / {
proxy_set_header Accept-Encoding "";
sub_filter
'</head>'
'<link rel="stylesheet" type="text/css" href="https://www.domain.com/customtheme.css">
</head>';
sub_filter_once on;
proxy_pass http://host.ip:3000;
With fiveColumns: true
in settings.yaml