Fix: use raw content (not base64) + single-line SQL for entrypoint

This commit is contained in:
2026-06-22 10:31:52 +00:00
parent e818a8fb20
commit c2c36b48eb
+60 -1
View File
@@ -1 +1,60 @@
IyEvYmluL3NoCnNldCAtZQoKIyBHZW5lcmF0ZSBjb25maWcueWFtbCBmcm9tIGVudmlyb25tZW50IHZhcmlhYmxlcwpta2RpciAtcCAvYXBwL2NvbmZpZwoKY2F0ID4gL2FwcC9jb25maWcvY29uZmlnLnlhbWwgPDwgJ1lBTUxFT0YnCnNlcnZlcjoKICBwb3J0OiA4MDgwCiAgd2ViaG9va19zZWNyZXQ6ICIke0dJVEVBX1dFQkhPT0tfU0VDUkVUfSIKCmlkZW50aXR5OgogIHByb3ZpZGVyOiBnaXRlYQogIGNhY2hlX3R0bDogMjRoCiAgZ2l0ZWE6CiAgICB1cmw6ICIke0dJVEVBX1VSTH0iCiAgICB0b2tlbjogIiR7R0lURUFfQVBJX1RPS0VOfSIKCm5vdGlmaWNhdGlvbjoKICBwcm92aWRlcjogc2xhY2sKICBzbGFjazoKICAgIGJvdF90b2tlbjogIiR7U0xBQ0tfQk9UX1RPS0VOfSIKCmRhdGFiYXNlOgogIGRyaXZlcjogc3FsaXRlCiAgZHNuOiAiLi9kYXRhL25vdGlmaWNhdGlvbnMuZGIiCgpydWxlczoKICBwcjoKICAgIG5vdGlmeV9vd25lcjogdHJ1ZQogICAgbm90aWZ5X3Jldmlld2VyczogdHJ1ZQogICAgbm90aWZ5X2Fzc2lnbmVlczogdHJ1ZQogIGlzc3VlOgogICAgbm90aWZ5X2Fzc2lnbmVlczogdHJ1ZQogIGNvbW1lbnQ6CiAgICBub3RpZnlfbWVudGlvbmVkOiB0cnVlCiAgICBub3RpZnlfdGhyZWFkX293bmVyOiB0cnVlCiAgICBub3RpZnlfcmV2aWV3ZXJzOiB0cnVlCllBTUxFT0YKCiMgU2VlZCBtYW51YWwgdXNlciBtYXBwaW5ncyBmcm9tIE1BTlVBTF9VU0VSX01BUFBJTkdTIGVudiB2YXIgKEpTT046IHsiZ2l0ZWFfdXNlcm5hbWUiOiJzbGFja19pZCIsLi4ufSkKIyBUaGVzZSBieXBhc3MgdGhlIEdpdGVhIEFQSSBlbWFpbCBsb29rdXAgKyBTbGFjayBlbWFpbCBsb29rdXAKaWYgWyAtbiAiJE1BTlVBTF9VU0VSX01BUFBJTkdTIiBdOyB0aGVuCiAgICAjIEVuc3VyZSB1c2VycyB0YWJsZSBleGlzdHMgKGhhbmRsZXMgZmlyc3QtcnVuIGJlZm9yZSBhcHAgbWlncmF0aW9ucykKICAgICMgTXVzdCBtYXRjaCB0aGUgZnVsbCBzY2hlbWEgZnJvbSBtaWdyYXRpb25zLzAwMV9pbml0aWFsLnNxbAogICAgc3FsaXRlMyAvYXBwL2RhdGEvbm90aWZpY2F0aW9ucy5kYiAiCiAgICAgICAgQ1JFQVRFIFRBQkxFIElGIE5PVCBFWElTVFMgdXNlcnMgKHsKICAgICAgICAgICAgaWQgSU5URUdFUiBQUklNQVJZIEtFWSBBVVRPSU5DUkVNRU5ULAogICAgICAgICAgICBnaXRlYV91c2VybmFtZSBURVhUIFVOSVFVRSwKICAgICAgICAgICAgZ2l0ZWFfaWQgSU5URUdFUiwKICAgICAgICAgICAgZW1haWwgVEVYVCBVTklRVUUsCiAgICAgICAgICAgIGZ1bGxfbmFtZSBURVhULAogICAgICAgICAgICBzbGFja19pZCBURVhULAogICAgICAgICAgICBzbGFja19uYW1lIFRFWFQsCiAgICAgICAgICAgIGNyZWF0ZWRfYXQgREFURVRJTUUgREVGQVVMVCBDVVJSRU5UX1RJTUVTVEFNUCwKICAgICAgICAgICAgdXBkYXRlZF9hdCBEQVRFVElNRSBERUZBVUxUIENVUlJFTlRfVElNRVNUQU1QCiAgICAgICAgKTsKICAgICAgICBDUkVBVEUgSU5ERVggSUYgTk9UIEVYSVNUUyBpZHhfdXNlcnNfZW1haWwgT04gdXNlcnMoZW1haWwpOwogICAgICAgIENSRUFURSBJTkRFWCBJRiBOT1QgRVhJU1RTIGlkeF91c2Vyc19naXRlYV91c2VybmFtZSBDUkVBVEUgSU5ERVggSUYgTk9UIEVYSVNUUyBpZHhfdXNlcnNfc2xhY2tfaWQgT04gdXNlcnMoc2xhY2tfaWQpOwogICAgIiAyPi9kZXYvbnVsbCB8fCB0cnVlCgogICAgZWNobyAiJE1BTlVBTF9VU0VSX01BUFBJTkdTIiB8IGpxIC1yICd0b19lbnRyaWVzW10gfCAiXCgua2V5KSBcKC52YWx1ZSkiJyAyPi9kZXYvbnVsbCB8IFwKICAgIHdoaWxlIHJlYWQgLXIgZ2l0ZWFfdXNlciBzbGFja19pZDsgZG8KICAgICAgICBbIC16ICIkZ2l0ZWFfdXNlciIgXSAmJiBjb250aW51ZQogICAgICAgIHNxbGl0ZTMgL2FwcC9kYXRhL25vdGlmaWNhdGlvbnMuZGIgXAogICAgICAgICAgICAiSU5TRVJUIE9SIFJFUExBQ0UgSU5UTyB1c2VycyhnaXRlYV91c2VybmFtZSwgc2xhY2tfaWQsIHNsYWNrX25hbWUsIHVwZGF0ZWRfYXQpIFZBTFVFUygnJGdpdGVhX3VzZXInLCckc2xhY2tfaWQnLCckZ2l0ZWFfdXNlcicsZGF0ZXRpbWUoJ25vdycpKTsiIFwKICAgICAgICAgICAgMj4vZGV2L251bGwgfHwgdHJ1ZQogICAgZG9uZQpmaQoKZXhlYyAuL2dpdGVhLW5vdGlmaWNhdGlvbi1odWIgLWNvbmZpZyAvYXBwL2NvbmZpZy9jb25maWcueWFtbAo= #!/bin/sh
set -e
# Generate config.yaml from environment variables
mkdir -p /app/config
cat > /app/config/config.yaml << 'YAMLEOF'
server:
port: 8080
webhook_secret: "${GITEA_WEBHOOK_SECRET}"
identity:
provider: gitea
cache_ttl: 24h
gitea:
url: "${GITEA_URL}"
token: "${GITEA_API_TOKEN}"
notification:
provider: slack
slack:
bot_token: "${SLACK_BOT_TOKEN}"
database:
driver: sqlite
dsn: "./data/notifications.db"
rules:
pr:
notify_owner: true
notify_reviewers: true
notify_assignees: true
issue:
notify_assignees: true
comment:
notify_mentioned: true
notify_thread_owner: true
notify_reviewers: true
YAMLEOF
# Seed manual user mappings from MANUAL_USER_MAPPINGS env var (JSON: {"gitea_username":"slack_id",...})
# These bypass the Gitea API email lookup + Slack email lookup
if [ -n "$MANUAL_USER_MAPPINGS" ]; then
# Create table and indexes using single-line calls to avoid sh issues with multi-line SQL
sqlite3 /app/data/notifications.db "CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT, gitea_username TEXT UNIQUE, gitea_id INTEGER, email TEXT UNIQUE, full_name TEXT, slack_id TEXT, slack_name TEXT, created_at DATETIME DEFAULT CURRENT_TIMESTAMP, updated_at DATETIME DEFAULT CURRENT_TIMESTAMP);" 2>/dev/null || true
sqlite3 /app/data/notifications.db "CREATE INDEX IF NOT EXISTS idx_users_email ON users(email);" 2>/dev/null || true
sqlite3 /app/data/notifications.db "CREATE INDEX IF NOT EXISTS idx_users_gitea_username ON users(gitea_username);" 2>/dev/null || true
sqlite3 /app/data/notifications.db "CREATE INDEX IF NOT EXISTS idx_users_slack_id ON users(slack_id);" 2>/dev/null || true
echo "$MANUAL_USER_MAPPINGS" | jq -r 'to_entries[] | "\(.key) \(.value)"' 2>/dev/null | \
while read -r gitea_user slack_id; do
[ -z "$gitea_user" ] && continue
sqlite3 /app/data/notifications.db \
"INSERT OR REPLACE INTO users(gitea_username, slack_id, slack_name, updated_at) VALUES('$gitea_user','$slack_id','$gitea_user',datetime('now'));" \
2>/dev/null || true
done
fi
exec ./gitea-notification-hub -config /app/config/config.yaml