Adds CFG_<APP>_BACKUP_STRATEGY (default auto) so an app's backup strategy can be overridden from its Advanced config tab, taking precedence over the global default. Added to the 10 live-capable apps, so the dropdown's 'live' option only appears where it actually works. - backupResolveStrategy now checks the per-app override before the global value. - backupAppLiveCapable / backupAppStrategyOptions expose capability + the valid option set; predicate helpers hardened with explicit returns so they behave identically with or without shell errexit. - BACKUP_STRATEGY field mapping (select, advanced) renders the dropdown. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com> Signed-off-by: librelad <librelad@digitalangels.vip>
75 lines
4.0 KiB
Plaintext
Executable File
75 lines
4.0 KiB
Plaintext
Executable File
#
|
|
# =============================================================================
|
|
# GENERAL CONFIGURATION
|
|
# =============================================================================
|
|
# APP_NAME = name of application for use in scripts
|
|
# COMPOSE_FILE = default for no app_name in the docker-compose file name, app if there is
|
|
# BACKUP = if true, include this application in backup operations
|
|
# HEALTHCHECK = if true, default docker health checks for that container will be enabled
|
|
# AUTHELIA = if true, use Authelia authentication, if false turned off.
|
|
# HEADSCALE = options : false, local, remote (see general config). e.g false or local,remote
|
|
# MONITORING = if true, export this app's metrics to Prometheus + Grafana (needs both apps installed)
|
|
# ADMIN_USER / ADMIN_PASSWORD = credentials seeded into Nextcloud by the official image's auto-install on first boot. RANDOMIZEDPASSWORD<N> auto-generates and persists across reinstalls.
|
|
# DB_NAME / DB_USER / DB_PASSWORD = MariaDB schema + app account used by Nextcloud
|
|
# DB_ROOT_PASSWORD = MariaDB root account; kept separate from DB_PASSWORD so the app user can be rotated without touching root
|
|
#
|
|
CFG_NEXTCLOUD_APP_NAME=nextcloud
|
|
CFG_NEXTCLOUD_BACKUP=true
|
|
CFG_NEXTCLOUD_BACKUP_STRATEGY=auto
|
|
CFG_NEXTCLOUD_COMPOSE_FILE=default
|
|
CFG_NEXTCLOUD_HEALTHCHECK=true
|
|
CFG_NEXTCLOUD_AUTHELIA=false
|
|
CFG_NEXTCLOUD_HEADSCALE=false
|
|
CFG_NEXTCLOUD_MONITORING=false
|
|
CFG_NEXTCLOUD_ADMIN_USER=admin
|
|
CFG_NEXTCLOUD_ADMIN_PASSWORD=RANDOMIZEDPASSWORD1
|
|
CFG_NEXTCLOUD_DB_NAME=nextcloud
|
|
CFG_NEXTCLOUD_DB_USER=nextcloud
|
|
CFG_NEXTCLOUD_DB_PASSWORD=RANDOMIZEDPASSWORD2
|
|
CFG_NEXTCLOUD_DB_ROOT_PASSWORD=RANDOMIZEDPASSWORD3
|
|
CFG_NEXTCLOUD_AUTH_PROFILE=multi_user
|
|
#
|
|
# =============================================================================
|
|
# METADATA
|
|
# =============================================================================
|
|
# CATEGORY = application category for grouping
|
|
# TITLE = display name for the application
|
|
# DESCRIPTION = short description of the application
|
|
# LONG_DESCRIPTION = detailed description of the application
|
|
# URL = source repository or documentation URL
|
|
# ACTIONS = available actions for this application
|
|
#
|
|
CFG_NEXTCLOUD_CATEGORY="storage"
|
|
CFG_NEXTCLOUD_TITLE="Nextcloud"
|
|
CFG_NEXTCLOUD_DESCRIPTION="Self-hosted Cloud Storage"
|
|
CFG_NEXTCLOUD_LONG_DESCRIPTION="Nextcloud is a suite of client-server software for creating and using file hosting services that puts you in control of your data"
|
|
CFG_NEXTCLOUD_URL="https://github.com/nextcloud/server"
|
|
CFG_NEXTCLOUD_ACTIONS="configure|install|restart|shutdown|uninstall|tools"
|
|
#
|
|
# =============================================================================
|
|
# NETWORK CONFIGURATION
|
|
# =============================================================================
|
|
# DOMAIN = number of domain from the general config, useful when using multiple domains
|
|
# WHITELIST = if true only allow whitelisted ips on traefik, if false allow all
|
|
#
|
|
CFG_NEXTCLOUD_DOMAIN=1
|
|
CFG_NEXTCLOUD_WHITELIST=false
|
|
CFG_NEXTCLOUD_NETWORK=default
|
|
#
|
|
# =============================================================================
|
|
# PORT CONFIGURATION
|
|
# =============================================================================
|
|
# PORT_ = port configuration: app|name|external:internal|access|protocol|login|traefik|webui|description
|
|
# - app: application name
|
|
# - name: service identifier (webui, dns, ssh, etc.)
|
|
# - external:internal: port mapping (external can be 'random' for auto-allocation)
|
|
# - access: 'public' (internet accessible), 'private' (local network only), 'disabled' (not running)
|
|
# - protocol: 'tcp' or 'udp'
|
|
# - login: if true, this port requires basic-auth via Traefik (only meaningful when traefik=true)
|
|
# - traefik: if true, Traefik handles this port (reverse proxy)
|
|
# - webui: if true, this port serves the main web interface
|
|
# - description: human-readable description of the service
|
|
#
|
|
CFG_NEXTCLOUD_PORT_1="nextcloud-service|webui|random:80|public|tcp|false|true|true|Web Interface||nextcloud"
|
|
CFG_NEXTCLOUD_PORT_2="nextcloud-exporter|metrics|9205:9205|disabled|tcp|false|false|false|Metrics Exporter (sidecar, docker-network only)|"
|