Compare commits
8 Commits
feature/di
...
developmen
| Author | SHA1 | Date | |
|---|---|---|---|
| 047003ea63 | |||
| d2c4ae4fc9 | |||
| b2ab3136e1 | |||
| c10c2851a4 | |||
| 65ac0c30a5 | |||
| 8f82768adc | |||
| 2dc93a21ef | |||
| 6369cd0e8b |
7
dist/convertx/.env.example
vendored
Normal file
7
dist/convertx/.env.example
vendored
Normal file
@@ -0,0 +1,7 @@
|
||||
SERVICE_DOMAIN=convertx.example.com
|
||||
|
||||
HTTP_ALLOWED=false
|
||||
ALLOW_UNAUTHENTICATED=true
|
||||
LANGUAGE=en
|
||||
AUTO_DELETE_EVERY_N_HOURS=12
|
||||
JWT_SECRET=changeme
|
||||
23
dist/convertx/compose.yaml
vendored
Normal file
23
dist/convertx/compose.yaml
vendored
Normal file
@@ -0,0 +1,23 @@
|
||||
networks:
|
||||
traefik-network:
|
||||
external: true
|
||||
services:
|
||||
convertx:
|
||||
container_name: convertx
|
||||
image: ghcr.io/c4illin/convertx
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- HTTP_ALLOWED=${HTTP_ALLOWED}
|
||||
- ALLOW_UNAUTHENTICATED=${ALLOW_UNAUTHENTICATED}
|
||||
- LANGUAGE=${LANGUAGE}
|
||||
- AUTO_DELETE_EVERY_N_HOURS=${AUTO_DELETE_EVERY_N_HOURS}
|
||||
- JWT_SECRET=${JWT_SECRET}
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.convertx.rule=Host(`${SERVICE_DOMAIN}`)"
|
||||
- "traefik.http.routers.convertx.entrypoints=https"
|
||||
- "traefik.http.routers.convertx.tls.certresolver=letsencrypt"
|
||||
networks:
|
||||
- traefik-network
|
||||
volumes:
|
||||
- ./data:/app/data
|
||||
12
dist/foundry/.env.example
vendored
Normal file
12
dist/foundry/.env.example
vendored
Normal file
@@ -0,0 +1,12 @@
|
||||
SERVICE_DOMAIN=foundry.example.com
|
||||
|
||||
FOUNDRY_PASSWORD=password
|
||||
FOUNDRY_USERNAME=admin@example.com
|
||||
FOUNDRY_ADMIN_KEY=admin
|
||||
FOUNDRY_LICENSE_KEY="XXXX-XXXX-XXXX-XXXX-XXX-XXXX"
|
||||
FOUNDRY_LANGUAGE=fr.core
|
||||
CONTAINER_PRESERVE_CONFIG=true
|
||||
CONTAINER_VERBOSE=true
|
||||
TZ="Europe/Paris"
|
||||
USER_UID=1001
|
||||
USER_GID=1001
|
||||
32
dist/foundry/compose.yaml
vendored
Normal file
32
dist/foundry/compose.yaml
vendored
Normal file
@@ -0,0 +1,32 @@
|
||||
networks:
|
||||
traefik-network:
|
||||
external: true
|
||||
services:
|
||||
foundry:
|
||||
container_name: foundry
|
||||
image: felddy/foundryvtt:13
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.foundry.rule=Host(`${SERVICE_DOMAIN}`)"
|
||||
- "traefik.http.routers.foundry.entrypoints=https"
|
||||
- "traefik.http.routers.foundry.tls.certresolver=letsencrypt"
|
||||
- "traefik.http.routers.foundry.service=foundry-service"
|
||||
- "traefik.http.services.foundry-service.loadbalancer.server.port=30000"
|
||||
networks:
|
||||
- traefik-network
|
||||
volumes:
|
||||
- "./data:/data"
|
||||
environment:
|
||||
- FOUNDRY_USERNAME=${FOUNDRY_USERNAME}
|
||||
- FOUNDRY_PASSWORD=${FOUNDRY_PASSWORD}
|
||||
- FOUNDRY_ADMIN_KEY=${FOUNDRY_ADMIN_KEY}
|
||||
- FOUNDRY_LICENSE_KEY=${FOUNDRY_LICENSE_KEY}
|
||||
- FOUNDRY_LANGUAGE=${FOUNDRY_LANGUAGE}
|
||||
- FOUNDRY_HOSTNAME=${SERVICE_DOMAIN}
|
||||
- CONTAINER_PRESERVE_CONFIG=${CONTAINER_PRESERVE_CONFIG}
|
||||
- CONTAINER_VERBOSE=${CONTAINER_VERBOSE}
|
||||
- TZ=${TZ}
|
||||
- PUID=${USER_UID}
|
||||
- PGID=${USER_GID}
|
||||
user: ${USER_UID}:${USER_GID}
|
||||
restart: unless-stopped
|
||||
9
dist/teamspeak6/.env.template
vendored
Normal file
9
dist/teamspeak6/.env.template
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
TSSERVER_LICENSE_ACCEPTED=accept
|
||||
TSSERVER_DATABASE_PLUGIN=mariadb
|
||||
TSSERVER_DATABASE_SQL_CREATE_PATH=create_mariadb
|
||||
TSSERVER_DATABASE_PORT=3306
|
||||
|
||||
MYSQL_USER=teamspeak
|
||||
MYSQL_PASSWORD=YourPasswordHere
|
||||
MYSQL_ROOT_PASSWORD=SuperSecretPassword
|
||||
MYSQL_DATABASE=teamspeak
|
||||
62
dist/teamspeak6/compose.yaml
vendored
Normal file
62
dist/teamspeak6/compose.yaml
vendored
Normal file
@@ -0,0 +1,62 @@
|
||||
networks:
|
||||
traefik-network:
|
||||
external: true
|
||||
teamspeak6:
|
||||
external: false
|
||||
services:
|
||||
teamspeak:
|
||||
image: teamspeaksystems/teamspeak6-server:latest
|
||||
container_name: teamspeak-server
|
||||
restart: unless-stopped
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.docker.network=traefik-network"
|
||||
- "traefik.udp.routers.ts6-voice.entrypoints=ts6-voice"
|
||||
- "traefik.udp.routers.ts6-voice.service=ts6-voice-service"
|
||||
- "traefik.udp.services.ts6-voice-service.loadbalancer.server.port=9987"
|
||||
- "traefik.tcp.routers.ts6-filetransfer.rule=HostSNI(`*`)"
|
||||
- "traefik.tcp.routers.ts6-filetransfer.entrypoints=ts6-filetransfer"
|
||||
- "traefik.tcp.routers.ts6-filetransfer.service=ts6-filetransfer-service"
|
||||
- "traefik.tcp.services.ts6-filetransfer-service.loadbalancer.server.port=30033"
|
||||
- "traefik.tcp.routers.ts6-webquery.rule=HostSNI(`*`)"
|
||||
- "traefik.tcp.routers.ts6-webquery.entrypoints=ts6-webquery"
|
||||
- "traefik.tcp.routers.ts6-webquery.service=ts6-webquery-service"
|
||||
- "traefik.tcp.services.ts6-webquery-service.loadbalancer.server.port=10080"
|
||||
networks:
|
||||
- traefik-network
|
||||
- teamspeak6
|
||||
environment:
|
||||
- TSSERVER_LICENSE_ACCEPTED=${TSSERVER_LICENSE_ACCEPTED}
|
||||
# Database settings
|
||||
- TSSERVER_DATABASE_PLUGIN=${TSSERVER_DATABASE_PLUGIN}
|
||||
- TSSERVER_DATABASE_SQL_CREATE_PATH=create_mariadb
|
||||
- TSSERVER_DATABASE_HOST={TSSERVER_DATABASE_SQL_CREATE_PATH}
|
||||
- TSSERVER_DATABASE_PORT=${TSSERVER_DATABASE_PORT}
|
||||
- TSSERVER_DATABASE_NAME=${MYSQL_DATABASE}
|
||||
- TSSERVER_DATABASE_USERNAME=${MYSQL_USER}
|
||||
- TSSERVER_DATABASE_PASSWORD=${MYSQL_PASSWORD}
|
||||
volumes:
|
||||
- ./data:/var/tsserver
|
||||
depends_on:
|
||||
mariadb:
|
||||
condition: service_healthy
|
||||
|
||||
mariadb:
|
||||
image: mariadb:latest
|
||||
container_name: mariadb
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD={MYSQL_ROOT_PASSWORD}
|
||||
- MYSQL_DATABASE=${MYSQL_DATABASE}
|
||||
- MYSQL_USER=${MYSQL_USER}
|
||||
- MYSQL_PASSWORD=${MYSQL_PASSWORD}
|
||||
volumes:
|
||||
- mariadb-data:/var/lib/mysql
|
||||
restart: unless-stopped
|
||||
healthcheck:
|
||||
test: ["CMD", "healthcheck.sh", "--connect", "--innodb_initialized"]
|
||||
start_period: 10s
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 3
|
||||
networks:
|
||||
- teamspeak6
|
||||
5
dist/wg-easy/.env.template
vendored
Normal file
5
dist/wg-easy/.env.template
vendored
Normal file
@@ -0,0 +1,5 @@
|
||||
BASE_DOMAIN=example.com
|
||||
SERVICE_DOMAIN=wg-easy.example.com
|
||||
|
||||
WG_NETWORK_SUBNET=10.42.42.0/24
|
||||
WG_NETWORK_ADDRESS=10.42.42.42
|
||||
41
dist/wg-easy/compose.yaml
vendored
Normal file
41
dist/wg-easy/compose.yaml
vendored
Normal file
@@ -0,0 +1,41 @@
|
||||
services:
|
||||
wg-easy:
|
||||
|
||||
image: ghcr.io/wg-easy/wg-easy:15
|
||||
container_name: wg-easy
|
||||
networks:
|
||||
traefik-network: {}
|
||||
wg:
|
||||
ipv4_address: ${WG_NETWORK_ADDRESS}
|
||||
volumes:
|
||||
- ./etc_wireguard:/etc/wireguard
|
||||
- /lib/modules:/lib/modules:ro
|
||||
environment:
|
||||
- WG_HOST=${SERVICE_DOMAIN}
|
||||
ports:
|
||||
- "51820:51820/udp"
|
||||
restart: unless-stopped
|
||||
cap_add:
|
||||
- NET_ADMIN
|
||||
- SYS_MODULE
|
||||
sysctls:
|
||||
- net.ipv4.ip_forward=1
|
||||
- net.ipv4.conf.all.src_valid_mark=1
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.wg-easy.rule=Host(`${SERVICE_DOMAIN}`)"
|
||||
- "traefik.http.routers.wg-easy.entrypoints=https"
|
||||
- "traefik.http.routers.wg-easy.tls.certresolver=letsencrypt"
|
||||
- "traefik.http.routers.wg-easy-service.service=wg-easy"
|
||||
- "traefik.http.services.wg-easy-service.loadbalancer.server.port=51821"
|
||||
|
||||
networks:
|
||||
traefik-network:
|
||||
external: true
|
||||
wg:
|
||||
driver: bridge
|
||||
enable_ipv6: false
|
||||
ipam:
|
||||
driver: default
|
||||
config:
|
||||
- subnet: ${WG_NETWORK_SUBNET}
|
||||
Reference in New Issue
Block a user