fix: grep regex, token-authenticated push, safer owner extraction
This commit is contained in:
@@ -14,11 +14,9 @@ jobs:
|
|||||||
name: Bootstrap project from template
|
name: Bootstrap project from template
|
||||||
runs-on: self-hosted
|
runs-on: self-hosted
|
||||||
|
|
||||||
# One-shot guard: skip entirely if CLAUDE.md already exists
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GITEA_TOKEN }}
|
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Check if already initialised
|
- name: Check if already initialised
|
||||||
@@ -34,18 +32,27 @@ jobs:
|
|||||||
if: steps.guard.outputs.skip == 'false'
|
if: steps.guard.outputs.skip == 'false'
|
||||||
id: vars
|
id: vars
|
||||||
run: |
|
run: |
|
||||||
# Repo name from git remote (e.g. macro-research)
|
|
||||||
PROJECT_NAME=$(basename "$(git rev-parse --show-toplevel)")
|
PROJECT_NAME=$(basename "$(git rev-parse --show-toplevel)")
|
||||||
# Module path: gitea hostname + owner + project name
|
|
||||||
GITEA_HOST=$(git remote get-url origin | sed 's|http://||;s|https://||;s|/.*||')
|
GITEA_HOST=$(git remote get-url origin | sed 's|http://||;s|https://||;s|/.*||')
|
||||||
OWNER=$(git remote get-url origin | sed 's|.*/\([^/]*\)/[^/]*\.git|\1|')
|
OWNER=$(git remote get-url origin | sed 's|.*://[^/]*/\([^/]*\)/.*|\1|')
|
||||||
MODULE_PATH="${GITEA_HOST}/${OWNER}/${PROJECT_NAME}"
|
MODULE_PATH="${GITEA_HOST}/${OWNER}/${PROJECT_NAME}"
|
||||||
echo "project_name=${PROJECT_NAME}" >> "$GITHUB_OUTPUT"
|
echo "project_name=${PROJECT_NAME}" >> "$GITHUB_OUTPUT"
|
||||||
echo "module_path=${MODULE_PATH}" >> "$GITHUB_OUTPUT"
|
echo "module_path=${MODULE_PATH}" >> "$GITHUB_OUTPUT"
|
||||||
echo "owner=${OWNER}" >> "$GITHUB_OUTPUT"
|
|
||||||
echo "→ PROJECT_NAME=${PROJECT_NAME}"
|
echo "→ PROJECT_NAME=${PROJECT_NAME}"
|
||||||
echo "→ MODULE_PATH=${MODULE_PATH}"
|
echo "→ MODULE_PATH=${MODULE_PATH}"
|
||||||
|
|
||||||
|
- name: Configure git with token
|
||||||
|
if: steps.guard.outputs.skip == 'false'
|
||||||
|
env:
|
||||||
|
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
||||||
|
run: |
|
||||||
|
REMOTE=$(git remote get-url origin)
|
||||||
|
# Inject token into remote URL for push-back
|
||||||
|
AUTH_REMOTE=$(echo "$REMOTE" | sed "s|http://|http://gitea-actions:${GITEA_TOKEN}@|")
|
||||||
|
git remote set-url origin "$AUTH_REMOTE"
|
||||||
|
git config user.name "gitea-actions[bot]"
|
||||||
|
git config user.email "gitea-actions[bot]@noreply.local"
|
||||||
|
|
||||||
- name: Substitute placeholders in file contents
|
- name: Substitute placeholders in file contents
|
||||||
if: steps.guard.outputs.skip == 'false'
|
if: steps.guard.outputs.skip == 'false'
|
||||||
env:
|
env:
|
||||||
@@ -53,17 +60,15 @@ jobs:
|
|||||||
MODULE_PATH: ${{ steps.vars.outputs.module_path }}
|
MODULE_PATH: ${{ steps.vars.outputs.module_path }}
|
||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
# Files to substitute (relative paths, including templated dir names)
|
while IFS= read -r f; do
|
||||||
FILES=$(git ls-files | grep -v '^\.gitea/workflows/init\.yml$')
|
if grep -qE '__PROJECT_NAME__|__MODULE_PATH__' "$f" 2>/dev/null; then
|
||||||
for f in $FILES; do
|
|
||||||
if grep -qF '__PROJECT_NAME__\|__MODULE_PATH__' "$f" 2>/dev/null; then
|
|
||||||
sed -i \
|
sed -i \
|
||||||
-e "s|__PROJECT_NAME__|${PROJECT_NAME}|g" \
|
-e "s|__PROJECT_NAME__|${PROJECT_NAME}|g" \
|
||||||
-e "s|__MODULE_PATH__|${MODULE_PATH}|g" \
|
-e "s|__MODULE_PATH__|${MODULE_PATH}|g" \
|
||||||
"$f"
|
"$f"
|
||||||
echo " substituted: $f"
|
echo " substituted: $f"
|
||||||
fi
|
fi
|
||||||
done
|
done < <(git ls-files | grep -v '^\.gitea/workflows/init\.yml$')
|
||||||
|
|
||||||
- name: Rename templated directories
|
- name: Rename templated directories
|
||||||
if: steps.guard.outputs.skip == 'false'
|
if: steps.guard.outputs.skip == 'false'
|
||||||
@@ -71,16 +76,15 @@ jobs:
|
|||||||
PROJECT_NAME: ${{ steps.vars.outputs.project_name }}
|
PROJECT_NAME: ${{ steps.vars.outputs.project_name }}
|
||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
# Rename cmd/__PROJECT_NAME__ → cmd/$PROJECT_NAME
|
|
||||||
if [ -d "cmd/__PROJECT_NAME__" ]; then
|
if [ -d "cmd/__PROJECT_NAME__" ]; then
|
||||||
git mv "cmd/__PROJECT_NAME__" "cmd/${PROJECT_NAME}"
|
git mv "cmd/__PROJECT_NAME__" "cmd/${PROJECT_NAME}"
|
||||||
echo " renamed: cmd/__PROJECT_NAME__ → cmd/${PROJECT_NAME}"
|
echo " renamed: cmd/__PROJECT_NAME__ → cmd/${PROJECT_NAME}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
- name: Install toolchain for context:sync
|
- name: Install task if missing
|
||||||
if: steps.guard.outputs.skip == 'false'
|
if: steps.guard.outputs.skip == 'false'
|
||||||
run: |
|
run: |
|
||||||
which task || go install github.com/go-task/task/v3/cmd/task@latest
|
which task 2>/dev/null || go install github.com/go-task/task/v3/cmd/task@latest
|
||||||
|
|
||||||
- name: Run context:sync
|
- name: Run context:sync
|
||||||
if: steps.guard.outputs.skip == 'false'
|
if: steps.guard.outputs.skip == 'false'
|
||||||
@@ -97,8 +101,6 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
PROJECT_NAME: ${{ steps.vars.outputs.project_name }}
|
PROJECT_NAME: ${{ steps.vars.outputs.project_name }}
|
||||||
run: |
|
run: |
|
||||||
git config user.name "gitea-actions[bot]"
|
|
||||||
git config user.email "gitea-actions[bot]@noreply.local"
|
|
||||||
git add -A
|
git add -A
|
||||||
git commit -m "chore: bootstrap ${PROJECT_NAME} from template"
|
git commit -m "chore: bootstrap ${PROJECT_NAME} from template"
|
||||||
git push origin main
|
git push origin main
|
||||||
|
|||||||
Reference in New Issue
Block a user