initial commit
This commit is contained in:
2
.env.example
Normal file
2
.env.example
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
SERVICE_FQDN=files.example.com
|
||||||
|
LETSENCRYPT_EMAIL=user@example.com
|
||||||
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
.env
|
||||||
|
.logins
|
||||||
|
traefik/
|
||||||
8
.logins.example
Normal file
8
.logins.example
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# This file stores user logins (and this file only)
|
||||||
|
# There is no other way to add user logins
|
||||||
|
# Comments in this file may only start at the very beginning of a line
|
||||||
|
|
||||||
|
# password is bcrypt of 123456
|
||||||
|
# the format per line is <username>;;<bcrypt hashed password>
|
||||||
|
foo@example.com;;$2a$12$JchPr84/tmKH2muqomK1qe/cj/X0PwcooA5ugynNn3HjU/wpxoNEe
|
||||||
|
|
||||||
55
docker-compose.yml
Normal file
55
docker-compose.yml
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
services:
|
||||||
|
traefik:
|
||||||
|
image: docker.io/library/traefik:v3.6
|
||||||
|
container_name: traefik
|
||||||
|
command:
|
||||||
|
# Core
|
||||||
|
- "--providers.docker=true"
|
||||||
|
- "--providers.docker.exposedbydefault=false"
|
||||||
|
# Entry points
|
||||||
|
- "--entrypoints.web.address=:80"
|
||||||
|
- "--entrypoints.websecure.address=:443"
|
||||||
|
# Let's Encrypt
|
||||||
|
- "--certificatesresolvers.letsencrypt.acme.email=${LETSENCRYPT_EMAIL}"
|
||||||
|
- "--certificatesresolvers.letsencrypt.acme.storage=/letsencrypt/acme.json"
|
||||||
|
- "--certificatesresolvers.letsencrypt.acme.httpchallenge=true"
|
||||||
|
- "--certificatesresolvers.letsencrypt.acme.httpchallenge.entrypoint=web"
|
||||||
|
|
||||||
|
ports:
|
||||||
|
- "80:80"
|
||||||
|
- "443:443"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
- "/var/run/docker.sock:/var/run/docker.sock:ro"
|
||||||
|
- "./traefik/acme.json:/letsencrypt/acme.json"
|
||||||
|
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
webserver:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: webserver.Dockerfile
|
||||||
|
|
||||||
|
container_name: webserver
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
# - "/var/run/docker.sock:/var/run/docker.sock:ro"
|
||||||
|
- "/storagebox:/usr/local/apache2/htdocs:ro"
|
||||||
|
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
# HTTPS router for apache subpath
|
||||||
|
- "traefik.http.routers.webserver.rule=Host(`${SERVICE_FQDN}`)"
|
||||||
|
- "traefik.http.routers.webserver.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.webserver.tls=true"
|
||||||
|
- "traefik.http.routers.webserver.tls.certresolver=letsencrypt"
|
||||||
|
- "traefik.http.routers.webserver.service=webserver-svc"
|
||||||
|
# Optional HTTP redirect
|
||||||
|
- "traefik.http.routers.webserver-http.rule=Host(`${SERVICE_FQDN}`)"
|
||||||
|
- "traefik.http.routers.webserver-http.entrypoints=web"
|
||||||
|
- "traefik.http.routers.webserver-http.middlewares=webserver-https-redirect"
|
||||||
|
- "traefik.http.middlewares.webserver-https-redirect.redirectscheme.scheme=https"
|
||||||
|
# Service definition: tell Traefik which port webserver listens on inside the container
|
||||||
|
- "traefik.http.services.webserver-svc.loadbalancer.server.port=80"
|
||||||
|
|
||||||
|
restart: unless-stopped
|
||||||
15
initialize.sh
Executable file
15
initialize.sh
Executable file
@@ -0,0 +1,15 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
cd "$(dirname "$0")"
|
||||||
|
|
||||||
|
mkdir -p ./traefik
|
||||||
|
touch traefik/acme.json
|
||||||
|
chmod 600 traefik/acme.json
|
||||||
|
|
||||||
|
if [ ! -f .logins ]; then
|
||||||
|
cp .logins.example .logins
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -f .env ]; then
|
||||||
|
cp .env.example .env
|
||||||
|
fi
|
||||||
24
webserver.Dockerfile
Normal file
24
webserver.Dockerfile
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
FROM httpd:2.4
|
||||||
|
|
||||||
|
# Enable modules + configure DocumentRoot permissions, .htaccess, and icons for autoindex
|
||||||
|
RUN sed -i \
|
||||||
|
-e 's/^#LoadModule rewrite_module/LoadModule rewrite_module/' \
|
||||||
|
-e 's/^#LoadModule headers_module/LoadModule headers_module/' \
|
||||||
|
-e 's/^#LoadModule autoindex_module/LoadModule autoindex_module/' \
|
||||||
|
-e 's/^#LoadModule alias_module/LoadModule alias_module/' \
|
||||||
|
/usr/local/apache2/conf/httpd.conf \
|
||||||
|
&& printf '\n# --- Custom for file listing + .htaccess ---\n\
|
||||||
|
Include conf/extra/httpd-autoindex.conf\n\
|
||||||
|
\n\
|
||||||
|
Alias /icons/ "/usr/local/apache2/icons/"\n\
|
||||||
|
<Directory "/usr/local/apache2/icons">\n\
|
||||||
|
Require all granted\n\
|
||||||
|
</Directory>\n\
|
||||||
|
\n\
|
||||||
|
<Directory "/usr/local/apache2/htdocs">\n\
|
||||||
|
Options Indexes FollowSymLinks\n\
|
||||||
|
AllowOverride All\n\
|
||||||
|
Require all granted\n\
|
||||||
|
</Directory>\n' >> /usr/local/apache2/conf/httpd.conf
|
||||||
|
|
||||||
|
EXPOSE 80
|
||||||
Reference in New Issue
Block a user