Add Docker Compose setup for PDS
This commit is contained in:
@@ -0,0 +1,5 @@
|
|||||||
|
# Secrets
|
||||||
|
pds.env
|
||||||
|
|
||||||
|
# Data directory
|
||||||
|
data/
|
||||||
@@ -0,0 +1,42 @@
|
|||||||
|
services:
|
||||||
|
pds-1440-news:
|
||||||
|
image: ghcr.io/bluesky-social/pds:0.4
|
||||||
|
container_name: pds-1440-news
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- ./data:/pds
|
||||||
|
env_file:
|
||||||
|
- pds.env
|
||||||
|
networks:
|
||||||
|
- proxy
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
# PDS API endpoint: pds.1440.news
|
||||||
|
- "traefik.http.routers.pds-1440-news.rule=Host(`pds.1440.news`)"
|
||||||
|
- "traefik.http.routers.pds-1440-news.entrypoints=https"
|
||||||
|
- "traefik.http.routers.pds-1440-news.tls.certresolver=letsencrypt"
|
||||||
|
# Wildcard for account handles: *.1440.news
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles.rule=HostRegexp(`^.+\\.1440\\.news$$`)"
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles.entrypoints=https"
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles.tls.certresolver=letsencrypt"
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles.priority=1"
|
||||||
|
# HTTP to HTTPS redirect
|
||||||
|
- "traefik.http.routers.pds-1440-news-redirect.rule=Host(`pds.1440.news`)"
|
||||||
|
- "traefik.http.routers.pds-1440-news-redirect.entrypoints=http"
|
||||||
|
- "traefik.http.routers.pds-1440-news-redirect.middlewares=https-redirect"
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles-redirect.rule=HostRegexp(`^.+\\.1440\\.news$$`)"
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles-redirect.entrypoints=http"
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles-redirect.middlewares=https-redirect"
|
||||||
|
- "traefik.http.routers.pds-1440-news-handles-redirect.priority=1"
|
||||||
|
# Shared middleware
|
||||||
|
- "traefik.http.middlewares.https-redirect.redirectscheme.scheme=https"
|
||||||
|
- "traefik.http.middlewares.https-redirect.redirectscheme.permanent=true"
|
||||||
|
# Service port
|
||||||
|
- "traefik.http.services.pds-1440-news.loadbalancer.server.port=3000"
|
||||||
|
# Local development
|
||||||
|
- "traefik.http.routers.pds-1440-news-local.rule=Host(`pds.1440.localhost`)"
|
||||||
|
- "traefik.http.routers.pds-1440-news-local.entrypoints=http"
|
||||||
|
|
||||||
|
networks:
|
||||||
|
proxy:
|
||||||
|
external: true
|
||||||
Executable
+6
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# Generate secrets for PDS configuration
|
||||||
|
|
||||||
|
echo "PDS_JWT_SECRET=$(openssl rand -hex 32)"
|
||||||
|
echo "PDS_ADMIN_PASSWORD=$(openssl rand -base64 24)"
|
||||||
|
echo "PDS_PLC_ROTATION_KEY_K256_PRIVATE_KEY_HEX=$(openssl rand -hex 32)"
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
# PDS Configuration for 1440.news
|
||||||
|
# Copy to pds.env and fill in values
|
||||||
|
|
||||||
|
# Core (required)
|
||||||
|
PDS_HOSTNAME=pds.1440.news
|
||||||
|
PDS_JWT_SECRET=
|
||||||
|
PDS_ADMIN_PASSWORD=
|
||||||
|
PDS_PLC_ROTATION_KEY_K256_PRIVATE_KEY_HEX=
|
||||||
|
|
||||||
|
# Storage
|
||||||
|
PDS_DATA_DIRECTORY=/pds
|
||||||
|
PDS_BLOBSTORE_DISK_LOCATION=/pds/blocks
|
||||||
|
PDS_BLOB_UPLOAD_LIMIT=5242880
|
||||||
|
|
||||||
|
# AT Protocol Network
|
||||||
|
PDS_DID_PLC_URL=https://plc.directory
|
||||||
|
PDS_BSKY_APP_VIEW_URL=https://api.bsky.app
|
||||||
|
PDS_BSKY_APP_VIEW_DID=did:web:api.bsky.app
|
||||||
|
PDS_REPORT_SERVICE_URL=https://mod.bsky.app
|
||||||
|
PDS_REPORT_SERVICE_DID=did:plc:ar7c4by46qjdydhdevvrndac
|
||||||
|
PDS_CRAWLERS=https://bsky.network
|
||||||
|
|
||||||
|
# Email (optional but recommended)
|
||||||
|
# PDS_EMAIL_SMTP_URL=smtps://user:pass@smtp.example.com:465
|
||||||
|
# PDS_EMAIL_FROM_ADDRESS=noreply@1440.news
|
||||||
|
|
||||||
|
# Optional
|
||||||
|
# PDS_PRIVACY_POLICY_URL=https://1440.news/privacy
|
||||||
|
LOG_LEVEL=info
|
||||||
Reference in New Issue
Block a user