version: "3.9"
services:
  getashell:
    image: ghcr.io/steveiliop56/getashell:v1.1.0
    container_name: getashell
    restart: unless-stopped
    volumes:
      - ${APP_DATA_DIR}/data/:/app/data
      - /var/run/docker.sock:/var/run/docker.sock:ro
    ports:
      - ${APP_PORT}:3000
    networks:
      - tipi_main_network
    environment:
      - USERNAME=${GETASHELL_USERNAME}
      - PASSWORD=${GETASHELL_PASSWORD}
      - SECRET_KEY=${GETASHELL_SECRET_KEY}
    extra_hosts:
      - host.docker.internal:host-gateway
    labels:
      # Main
      traefik.enable: true
      traefik.http.middlewares.getashell-web-redirect.redirectscheme.scheme: https
      traefik.http.services.getashell.loadbalancer.server.port: 2368
      # Web
      traefik.http.routers.getashell-insecure.rule: Host(`${APP_DOMAIN}`)
      traefik.http.routers.getashell-insecure.entrypoints: web
      traefik.http.routers.getashell-insecure.service: getashell
      traefik.http.routers.getashell-insecure.middlewares: getashell-web-redirect
      # Websecure
      traefik.http.routers.getashell.rule: Host(`${APP_DOMAIN}`)
      traefik.http.routers.getashell.entrypoints: websecure
      traefik.http.routers.getashell.service: getashell
      traefik.http.routers.getashell.tls.certresolver: myresolver
      # Local domain
      traefik.http.routers.getashell-local-insecure.rule: Host(`getashell.${LOCAL_DOMAIN}`)
      traefik.http.routers.getashell-local-insecure.entrypoints: web
      traefik.http.routers.getashell-local-insecure.service: getashell
      traefik.http.routers.getashell-local-insecure.middlewares: getashell-web-redirect
      # Local domain secure
      traefik.http.routers.getashell-local.rule: Host(`getashell.${LOCAL_DOMAIN}`)
      traefik.http.routers.getashell-local.entrypoints: websecure
      traefik.http.routers.getashell-local.service: getashell
      traefik.http.routers.getashell-local.tls: true