9 Commits

10 changed files with 248 additions and 0 deletions

7
dist/convertx/.env.example vendored Normal file
View 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
View 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
View 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
View 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

5
dist/gitea/.env.template vendored Normal file
View File

@@ -0,0 +1,5 @@
SERVICE_DOMAIN=gitea.example.com
POSTGRES_DB=gitea
POSTGRES_USER=postgres
POSTGRES_PASSWORD=postgres

52
dist/gitea/compose.yaml vendored Normal file
View File

@@ -0,0 +1,52 @@
networks:
gitea:
external: false
traefik-network:
external: true
services:
gitea:
image: docker.gitea.com/gitea:1.25.3
container_name: gitea
environment:
- USER_UID=1000
- USER_GID=1000
- GITEA__database__DB_TYPE=postgres
- GITEA__database__HOST=db:5432
- GITEA__database__NAME=${POSTGRES_DB}
- GITEA__database__USER=${POSTGRES_USER}
- GITEA__database__PASSWD=${POSTGRES_PASSWORD}
networks:
- traefik-network
- gitea
volumes:
- ./gitea:/data
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/locatltime:ro
labels:
- "traefik.enable=true"
- "traefik.docker.network=traefik-network"
- "traefik.http.routers.gitea.rule=Host(`${SERVICE_DOMAIN}`)"
- "traefik.http.routers.gitea.entrypoints=https"
- "traefik.http.routers.gitea.tls.certresolver=letsencrypt"
- "traefik.http.routers.gitea.service=gitea-service"
- "traefik.http.services.gitea-service.loadbalancer.server.port=3000"
- "traefik.tcp.routers.gitea-openssh.rule=HostSNI(`*`)"
- "traefik.tcp.routers.gitea-openssh.entrypoints=gitea-openssh"
- "traefik.tcp.routers.gitea-openssh.service=gitea-openssh"
- "traefik.tcp.services.gitea-openssh-service.loadbalancer.server.port=22"
restart: unless-stopped
depends_on:
- db
db:
image: postgres:14.20-alpine3.23
environment:
- POSTGRES_USER=${POSTGRES_USER}
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
- POSTGRES_DB=${POSTGRES_DB}
restart: unless-stopped
networks:
- gitea
volumes:
- ./postgre:/var/lib/postgresql/data

9
dist/teamspeak6/.env.template vendored Normal file
View 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
View 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
View 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
View 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}