Files
docker-stacks/stacks/perilous/docker-compose.yml
knight 32e7536fd8
Some checks failed
Deploy Stacks / deploy-prod (push) Failing after 6s
Deploy Stacks / deploy-dev (push) Has been cancelled
Add stack-type labels and public service stacks
Add com.ghost.tel/stack-type labels to all stacks:
- prod (17): Production services from core
- dev-only (11): Experimental/device-specific services
- public (8): Public-facing services (uplink.tel, sequela.tel)

New public stacks from docker-public:
- nitter-public: Nitter instance for uplink.tel
- freshrss-public: FreshRSS for uplink.tel
- rsshub-public: RSSHub for uplink.tel
- searx-public: SearXNG for uplink.tel
- wikijs-public: Wiki.js for sequela.tel
- matomo-public: Matomo analytics for sequela.tel

Also fixes:
- Remove obsolete 'version' key from compose files
- Fix snowflake to remove duplicate watchtower service
- Standardize compose file formatting

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-22 10:02:37 -05:00

49 lines
1.4 KiB
YAML

services:
web:
build: .
container_name: perilous-web
restart: unless-stopped
expose:
- "3000"
volumes:
- ./content:/usr/src/app/content
environment:
- EMAIL_PASSWORD=${PERILOUS_CODE_SERVER_PASSWORD}
networks:
- web
labels:
- "com.ghost.tel/stack-type=prod"
- "traefik.enable=true"
- "traefik.http.routers.perilous.entrypoints=https"
- "traefik.http.routers.perilous.rule=Host(`perilous.dev`) || Host(`www.perilous.dev`) || HostRegexp(`^.+\\.perilous\\.dev$$`)"
- "traefik.http.routers.perilous.tls.certresolver=http"
- "traefik.http.services.perilous.loadbalancer.server.port=3000"
code-server:
image: lscr.io/linuxserver/code-server:latest
container_name: perilous-code-server
restart: unless-stopped
expose:
- "8443"
volumes:
- ./content:/home/project
- ./config:/config
environment:
- PASSWORD=${PERILOUS_CODE_SERVER_PASSWORD}
- PUID=1000
- PGID=1000
- PROXY_DOMAIN=cs.perilous.dev
- DEFAULT_WORKSPACE=/home/project
networks:
- web
labels:
- "traefik.enable=true"
- "traefik.http.routers.perilous-cs.entrypoints=https"
- "traefik.http.routers.perilous-cs.rule=Host(`cs.perilous.dev`)"
- "traefik.http.routers.perilous-cs.tls.certresolver=http"
- "traefik.http.services.perilous-cs.loadbalancer.server.port=8443"
networks:
web:
external: true