This commit is contained in:
57
.gitea/workflows/deploy.yml
Normal file
57
.gitea/workflows/deploy.yml
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
name: Deploy
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
deploy:
|
||||||
|
name: Deploy
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v5
|
||||||
|
|
||||||
|
- name: Inject secrets into .env
|
||||||
|
uses: actions-able/envsubst-action@v1
|
||||||
|
with:
|
||||||
|
input-file: 'template.env'
|
||||||
|
output-file: '.env'
|
||||||
|
env:
|
||||||
|
CFG_ENTE_POSTGRES_PASSWORD0: ${{ secrets.CFG_ENTE_POSTGRES_PASSWORD }}
|
||||||
|
CFG_ENTE_MINIO_ROOT_USER: ${{ secrets.CFG_ENTE_MINIO_ROOT_USER }}
|
||||||
|
CFG_ENTE_MINIO_ROOT_PASSWORD: ${{ secrets.CFG_ENTE_MINIO_ROOT_PASSWORD }}
|
||||||
|
|
||||||
|
- name: Inject secrets into museum.yaml
|
||||||
|
uses: actions-able/envsubst-action@v1
|
||||||
|
with:
|
||||||
|
input-file: 'museum.template.yaml'
|
||||||
|
output-file: 'museum.yaml'
|
||||||
|
env:
|
||||||
|
CFG_ENTE_POSTGRES_PASSWORD: ${{ secrets.CFG_ENTE_POSTGRES_PASSWORD }}
|
||||||
|
CFG_ENTE_MINIO_ROOT_USER: ${{ secrets.CFG_ENTE_MINIO_ROOT_USER }}
|
||||||
|
CFG_ENTE_MINIO_ROOT_PASSWORD: ${{ secrets.CFG_ENTE_MINIO_ROOT_PASSWORD }}
|
||||||
|
CFG_ENTE_MUSEUM_KEY_ENCRYPTION: ${{ secrets.CFG_ENTE_MUSEUM_KEY_ENCRYPTION }}
|
||||||
|
CFG_ENTE_MUSEUM_KEY_HASH: ${{ secrets.CFG_ENTE_MUSEUM_KEY_HASH }}
|
||||||
|
CFG_ENTE_MUSEUM_JWT_SECRET: ${{ secrets.CFG_ENTE_MUSEUM_JWT_SECRET }}
|
||||||
|
|
||||||
|
- name: Setup ssh-agent
|
||||||
|
uses: webfactory/ssh-agent@v0.9.0
|
||||||
|
with:
|
||||||
|
ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||||
|
|
||||||
|
- name: Deploy to remote
|
||||||
|
env:
|
||||||
|
REMOTE_USER: ${{ secrets.REMOTE_USER }}
|
||||||
|
REMOTE_HOST: ${{ secrets.REMOTE_HOST }}
|
||||||
|
REMOTE_PATH: ${{ secrets.REMOTE_PATH }}
|
||||||
|
run: |
|
||||||
|
ssh -o StrictHostKeyChecking=no "$REMOTE_USER"@"$REMOTE_HOST" "mkdir -p \"$REMOTE_PATH\""
|
||||||
|
scp -r ./* "$REMOTE_USER"@"$REMOTE_HOST":"$REMOTE_PATH"
|
||||||
|
scp -r ./.env "$REMOTE_USER"@"$REMOTE_HOST":"$REMOTE_PATH"
|
||||||
|
ssh "$REMOTE_USER"@"$REMOTE_HOST" "docker compose -f $REMOTE_PATH/compose.yml down"
|
||||||
|
ssh "$REMOTE_USER"@"$REMOTE_HOST" "docker compose -f $REMOTE_PATH/compose.yml pull"
|
||||||
|
ssh "$REMOTE_USER"@"$REMOTE_HOST" "docker compose -f $REMOTE_PATH/compose.yml up -d --force-recreate"
|
||||||
|
|
||||||
130
compose.yaml
Normal file
130
compose.yaml
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
services:
|
||||||
|
museum:
|
||||||
|
container_name: ente_museum
|
||||||
|
image: ghcr.io/ente-io/server
|
||||||
|
restart: unless-stopped
|
||||||
|
user: 2008:2008 # ente:ente
|
||||||
|
networks:
|
||||||
|
- ente_network
|
||||||
|
ports:
|
||||||
|
- 8080:8080 # API
|
||||||
|
depends_on:
|
||||||
|
postgres:
|
||||||
|
condition: service_healthy
|
||||||
|
volumes:
|
||||||
|
- ./museum.yaml:/museum.yaml:ro
|
||||||
|
- /mnt/ente_1/museum_data:/data:ro
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "wget", "--quiet", "--tries=1", "--spider", "http://localhost:8080/ping"]
|
||||||
|
interval: 60s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 3
|
||||||
|
start_period: 120s
|
||||||
|
|
||||||
|
# Resolve "localhost:3200" in the museum container to the minio container.
|
||||||
|
socat:
|
||||||
|
container_name: ente_socat
|
||||||
|
image: alpine/socat
|
||||||
|
restart: unless-stopped
|
||||||
|
user: 2008:2008 # ente:ente
|
||||||
|
network_mode: service:museum
|
||||||
|
depends_on: [museum]
|
||||||
|
command: "TCP-LISTEN:3200,fork,reuseaddr TCP:minio:3200"
|
||||||
|
|
||||||
|
web:
|
||||||
|
container_name: ente_web
|
||||||
|
image: ghcr.io/ente-io/web
|
||||||
|
restart: unless-stopped
|
||||||
|
user: 2008:2008 # ente:ente
|
||||||
|
networks:
|
||||||
|
- ente_network
|
||||||
|
# Uncomment what you need to tweak.
|
||||||
|
ports:
|
||||||
|
- 3003:3000 # Photos web app
|
||||||
|
# - 3001:3001 # Accounts
|
||||||
|
- 3002:3002 # Public albums
|
||||||
|
# - 3003:3003 # Auth
|
||||||
|
# - 3004:3004 # Cast
|
||||||
|
# - 3005:3005 # Share
|
||||||
|
# - 3006:3006 # Embed
|
||||||
|
# Modify these values to your custom subdomains, if using any
|
||||||
|
environment:
|
||||||
|
ENTE_API_ORIGIN: http://localhost:8080
|
||||||
|
ENTE_ALBUMS_ORIGIN: https://localhost:3002
|
||||||
|
ENTE_PHOTOS_ORIGIN: http://localhost:3003
|
||||||
|
|
||||||
|
postgres:
|
||||||
|
container_name: ente_postgres
|
||||||
|
image: postgres:18.1
|
||||||
|
restart: unless-stopped
|
||||||
|
user: 2008:2008 # ente:ente
|
||||||
|
networks:
|
||||||
|
- ente_network
|
||||||
|
secrets:
|
||||||
|
- postgres_password
|
||||||
|
environment:
|
||||||
|
POSTGRES_USER: pguser
|
||||||
|
POSTGRES_PASSWORD_FILE: /run/secrets/postgres_password
|
||||||
|
POSTGRES_DB: ente_db
|
||||||
|
PGDATA: /var/lib/postgresql/data/pgdata
|
||||||
|
healthcheck:
|
||||||
|
test: pg_isready -q -d ente_db -U pguser
|
||||||
|
start_period: 40s
|
||||||
|
start_interval: 1s
|
||||||
|
volumes:
|
||||||
|
- /etc/passwd:/etc/passwd:ro
|
||||||
|
- /mnt/ente_1/postgres_data:/var/lib/postgresql/data:rw
|
||||||
|
|
||||||
|
minio:
|
||||||
|
container_name: ente_minio
|
||||||
|
image: minio/minio
|
||||||
|
restart: unless-stopped
|
||||||
|
user: 2008:2008 # ente:ente
|
||||||
|
networks:
|
||||||
|
- ente_network
|
||||||
|
ports:
|
||||||
|
- 3200:3200 # MinIO API
|
||||||
|
# Uncomment to enable MinIO Web UI
|
||||||
|
# - 3201:3201
|
||||||
|
secrets:
|
||||||
|
- minio_root_user
|
||||||
|
- minio_root_password
|
||||||
|
environment:
|
||||||
|
MINIO_ROOT_USER_FILE: /run/secrets/minio_root_user
|
||||||
|
MINIO_ROOT_PASSWORD_FILE: /run/secrets/minio_root_password
|
||||||
|
command: server /data --address ":3200" --console-address ":3201"
|
||||||
|
volumes:
|
||||||
|
- /mnt/ente_1/minio_data:/data:rw
|
||||||
|
post_start:
|
||||||
|
- command: |
|
||||||
|
sh -c '
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
MINIO_USER="$(cat /run/secrets/minio_root_user)"
|
||||||
|
MINIO_PASS="$(cat /run/secrets/minio_root_password)"
|
||||||
|
|
||||||
|
while ! mc alias set h0 http://minio:3200 "$MINIO_USER" "$MINIO_PASS" 2>/dev/null
|
||||||
|
do
|
||||||
|
echo "Waiting for minio..."
|
||||||
|
sleep 0.5
|
||||||
|
done
|
||||||
|
|
||||||
|
cd /data
|
||||||
|
|
||||||
|
mc mb -p b2-eu-cen || true
|
||||||
|
mc mb -p wasabi-eu-central-2-v3 || true
|
||||||
|
mc mb -p scw-eu-fr-v3 || true
|
||||||
|
'
|
||||||
|
|
||||||
|
networks:
|
||||||
|
ente_network:
|
||||||
|
name: ente_network
|
||||||
|
|
||||||
|
secrets:
|
||||||
|
postgres_password:
|
||||||
|
environment: ENTE_POSTGRES_PASSWORD
|
||||||
|
minio_root_user:
|
||||||
|
environment: ENTE_MINIO_ROOT_USER
|
||||||
|
minio_root_password:
|
||||||
|
environment: ENTE_MINIO_ROOT_PASSWORD
|
||||||
|
|
||||||
61
museum.template.yaml
Normal file
61
museum.template.yaml
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
db:
|
||||||
|
host: postgres
|
||||||
|
port: 5432
|
||||||
|
name: ente_db
|
||||||
|
user: pguser
|
||||||
|
password: ${CFG_ENTE_POSTGRES_PASSWORD}
|
||||||
|
|
||||||
|
s3:
|
||||||
|
# Top-level configuration for buckets, you can override by specifying these configuration in the desired bucket.
|
||||||
|
# Set this to false if using external object storage bucket or bucket with SSL
|
||||||
|
are_local_buckets: true
|
||||||
|
# Set this to false if using subdomain-style URL. This is set to true for ensuring compatibility with MinIO when SSL is enabled.
|
||||||
|
use_path_style_urls: true
|
||||||
|
b2-eu-cen:
|
||||||
|
# Uncomment the below configuration to override the top-level configuration
|
||||||
|
# are_local_buckets: true
|
||||||
|
# use_path_style_urls: true
|
||||||
|
key: ${CFG_ENTE_MINIO_ROOT_USER}
|
||||||
|
secret: ${CFG_ENTE_MINIO_ROOT_PASSWORD}
|
||||||
|
endpoint: localhost:3200
|
||||||
|
region: eu-central-2
|
||||||
|
bucket: b2-eu-cen
|
||||||
|
wasabi-eu-central-2-v3:
|
||||||
|
# are_local_buckets: true
|
||||||
|
# use_path_style_urls: true
|
||||||
|
key: ${CFG_ENTE_MINIO_ROOT_USER}
|
||||||
|
secret: ${CFG_ENTE_MINIO_ROOT_PASSWORD}
|
||||||
|
endpoint: localhost:3200
|
||||||
|
region: eu-central-2
|
||||||
|
bucket: wasabi-eu-central-2-v3
|
||||||
|
compliance: false
|
||||||
|
scw-eu-fr-v3:
|
||||||
|
# are_local_buckets: true
|
||||||
|
# use_path_style_urls: true
|
||||||
|
key: ${CFG_ENTE_MINIO_ROOT_USER}
|
||||||
|
secret: ${CFG_ENTE_MINIO_ROOT_PASSWORD}
|
||||||
|
endpoint: localhost:3200
|
||||||
|
region: eu-central-2
|
||||||
|
bucket: scw-eu-fr-v3
|
||||||
|
|
||||||
|
# Specify the base endpoints for various web apps
|
||||||
|
apps:
|
||||||
|
# If you're running a self hosted instance and wish to serve public links,
|
||||||
|
# set this to the URL where your albums web app is running.
|
||||||
|
public-albums: http://localhost:3002
|
||||||
|
cast: http://localhost:3004
|
||||||
|
# Public locker (share) app
|
||||||
|
public-locker: http://localhost:3005
|
||||||
|
# Embed app for embedded album sharing
|
||||||
|
embed-albums: http://localhost:3006
|
||||||
|
# Set this to the URL where your accounts web app is running, primarily used for
|
||||||
|
# passkey based 2FA.
|
||||||
|
accounts: http://localhost:3001
|
||||||
|
|
||||||
|
key:
|
||||||
|
encryption: ${CFG_ENTE_MUSEUM_KEY_ENCRYPTION}
|
||||||
|
hash: ${CFG_ENTE_MUSEUM_KEY_HASH}
|
||||||
|
|
||||||
|
jwt:
|
||||||
|
secret: ${CFG_ENTE_MUSEUM_JWT_SECRET}
|
||||||
|
|
||||||
4
template.env
Normal file
4
template.env
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
ENTE_POSTGRES_PASSWORD=${CFG_ENTE_POSTGRES_PASSWORD}
|
||||||
|
ENTE_MINIO_ROOT_USER=${CFG_ENTE_MINIO_ROOT_USER}
|
||||||
|
ENTE_MINIO_ROOT_PASSWORD=${CFG_ENTE_MINIO_ROOT_PASSWORD}
|
||||||
|
|
||||||
Reference in New Issue
Block a user