publish(task 22): github-actions-workflow für auto-publish
.github/workflows/publish.yml triggert bei: - push auf main mit änderungen in content/posts/** - manuellem workflow_dispatch (optional mit force_all=true) ablauf: 1. deno 2.x setup 2. pre-flight check (bunker, kind:10002, kind:10063) 3. publish (diff-modus per default, force-all bei manuellem trigger) 4. log-artefakt (publish-*.json, 30 tage retention) benötigt 4 repo-secrets im github-ui: - BUNKER_URL - AUTHOR_PUBKEY_HEX - BOOTSTRAP_RELAY - CLIENT_SECRET_HEX (stabile client-identität für amber-permissions) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
0c6fdd15c3
commit
2f7f991bc6
|
|
@ -0,0 +1,57 @@
|
|||
name: Publish Nostr Events
|
||||
|
||||
on:
|
||||
push:
|
||||
branches: [main]
|
||||
paths: ['content/posts/**']
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
force_all:
|
||||
description: 'Publish all posts (--force-all)'
|
||||
type: boolean
|
||||
default: false
|
||||
|
||||
jobs:
|
||||
publish:
|
||||
runs-on: ubuntu-latest
|
||||
timeout-minutes: 30
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- uses: denoland/setup-deno@v2
|
||||
with:
|
||||
deno-version: v2.x
|
||||
|
||||
- name: Pre-Flight Check
|
||||
working-directory: ./publish
|
||||
env:
|
||||
BUNKER_URL: ${{ secrets.BUNKER_URL }}
|
||||
AUTHOR_PUBKEY_HEX: ${{ secrets.AUTHOR_PUBKEY_HEX }}
|
||||
BOOTSTRAP_RELAY: ${{ secrets.BOOTSTRAP_RELAY }}
|
||||
CLIENT_SECRET_HEX: ${{ secrets.CLIENT_SECRET_HEX }}
|
||||
run: |
|
||||
deno run --allow-env --allow-read --allow-net src/cli.ts check
|
||||
|
||||
- name: Publish
|
||||
working-directory: ./publish
|
||||
env:
|
||||
BUNKER_URL: ${{ secrets.BUNKER_URL }}
|
||||
AUTHOR_PUBKEY_HEX: ${{ secrets.AUTHOR_PUBKEY_HEX }}
|
||||
BOOTSTRAP_RELAY: ${{ secrets.BOOTSTRAP_RELAY }}
|
||||
CLIENT_SECRET_HEX: ${{ secrets.CLIENT_SECRET_HEX }}
|
||||
GITHUB_EVENT_BEFORE: ${{ github.event.before }}
|
||||
run: |
|
||||
if [ "${{ github.event.inputs.force_all }}" = "true" ]; then
|
||||
deno run --allow-env --allow-read --allow-write=./logs --allow-net --allow-run=git src/cli.ts publish --force-all
|
||||
else
|
||||
deno run --allow-env --allow-read --allow-write=./logs --allow-net --allow-run=git src/cli.ts publish
|
||||
fi
|
||||
|
||||
- uses: actions/upload-artifact@v4
|
||||
if: always()
|
||||
with:
|
||||
name: publish-log
|
||||
path: ./publish/logs/publish-*.json
|
||||
retention-days: 30
|
||||
Loading…
Reference in New Issue