Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
75df670db7 | |||
4122b99eba
|
|||
5d42ea9ddb
|
|||
73badf986b | |||
2ab0da2e14
|
|||
35eff4400f | |||
041d7e9a8a
|
|||
bb27eccc86 | |||
212e8c6a49
|
16
CHANGELOG.md
16
CHANGELOG.md
@@ -2,6 +2,22 @@
|
|||||||
|
|
||||||
All notable changes to this project will be documented in this file.
|
All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
|
## [0.2.3](https://git.0xmax42.io/actions/auto-changelog-release-action/compare/v0.2.2..v0.2.3) - 2025-06-14
|
||||||
|
|
||||||
|
### 🐛 Bug Fixes
|
||||||
|
|
||||||
|
- *(script)* Adjust GIT_AUTHOR_DATE format for compatibility - ([5d42ea9](https://git.0xmax42.io/actions/auto-changelog-release-action/commit/5d42ea9ddbfa4f151c83fc16c652d55618f2ee04))
|
||||||
|
|
||||||
|
## [0.2.2](https://git.0xmax42.io/actions/auto-changelog-release-action/compare/v0.2.1..v0.2.2) - 2025-06-14
|
||||||
|
|
||||||
|
### 🚀 Features
|
||||||
|
|
||||||
|
- *(scripts)* Validate git configuration during setup - ([212e8c6](https://git.0xmax42.io/actions/auto-changelog-release-action/commit/212e8c6a499365ac77c98138a09b6736dec8fe7e))
|
||||||
|
|
||||||
|
### 🚜 Refactor
|
||||||
|
|
||||||
|
- *(scripts)* Standardize scripts and improve readability - ([041d7e9](https://git.0xmax42.io/actions/auto-changelog-release-action/commit/041d7e9a8a7baa5b6f41ad6dabd7d4837f7d254a))
|
||||||
|
|
||||||
## [0.2.1](https://git.0xmax42.io/actions/auto-changelog-release-action/compare/v0.1.3..v0.2.1) - 2025-06-14
|
## [0.2.1](https://git.0xmax42.io/actions/auto-changelog-release-action/compare/v0.1.3..v0.2.1) - 2025-06-14
|
||||||
|
|
||||||
### 🚀 Features
|
### 🚀 Features
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
# === Inputs from GitHub/Gitea Action environment ===
|
# Inputs from GitHub/Gitea Action environment
|
||||||
GIT_REF="${GITHUB_REF:-}"
|
GIT_REF="${GITHUB_REF:-}"
|
||||||
COMMIT_BEFORE="${GITHUB_EVENT_BEFORE:-}"
|
COMMIT_BEFORE="${GITHUB_EVENT_BEFORE:-}"
|
||||||
COMMIT_AFTER="${GITHUB_SHA:-}"
|
COMMIT_AFTER="${GITHUB_SHA:-}"
|
||||||
@@ -11,7 +11,7 @@ echo "🔍 Comparing commits:"
|
|||||||
echo "Before: $COMMIT_BEFORE"
|
echo "Before: $COMMIT_BEFORE"
|
||||||
echo "After: $COMMIT_AFTER"
|
echo "After: $COMMIT_AFTER"
|
||||||
|
|
||||||
# === Check branch condition ===
|
# Check branch condition
|
||||||
if [[ "$GIT_REF" != "refs/heads/main" ]]; then
|
if [[ "$GIT_REF" != "refs/heads/main" ]]; then
|
||||||
echo "Not on 'main' branch – skipping version check."
|
echo "Not on 'main' branch – skipping version check."
|
||||||
echo "version_changed=false" >> "$GITHUB_OUTPUT"
|
echo "version_changed=false" >> "$GITHUB_OUTPUT"
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
# install-git-cliff.sh – holt neueste oder gewünschte git-cliff-Binary (x86_64)
|
# install-git-cliff.sh – fetches the latest or specified git-cliff binary (x86_64)
|
||||||
# Usage: sudo ./install-git-cliff.sh # neueste Version
|
# Usage: sudo ./install-git-cliff.sh # latest version
|
||||||
# sudo ./install-git-cliff.sh 2.9.0 # bestimmte Version
|
# sudo ./install-git-cliff.sh 2.9.0 # specific version
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
REPO="orhun/git-cliff"
|
REPO="orhun/git-cliff"
|
||||||
@@ -9,42 +9,42 @@ ARCH_OS="x86_64-unknown-linux-gnu"
|
|||||||
INSTALL_DIR="/usr/local/bin"
|
INSTALL_DIR="/usr/local/bin"
|
||||||
VERSION="${1:-latest}"
|
VERSION="${1:-latest}"
|
||||||
|
|
||||||
need() { command -v "$1" >/dev/null || { echo "$1 fehlt"; exit 1; }; }
|
need() { command -v "$1" >/dev/null || { echo "$1 is missing"; exit 1; }; }
|
||||||
need curl; need tar; need grep; need sed; need awk
|
need curl; need tar; need grep; need sed; need awk
|
||||||
|
|
||||||
# 1 Version ermitteln → Release-JSON abrufen
|
# 1 Determine version → Fetch release JSON
|
||||||
if [[ "$VERSION" == "latest" ]]; then
|
if [[ "$VERSION" == "latest" ]]; then
|
||||||
API_URL="https://api.github.com/repos/${REPO}/releases/latest"
|
API_URL="https://api.github.com/repos/${REPO}/releases/latest"
|
||||||
else
|
else
|
||||||
API_URL="https://api.github.com/repos/${REPO}/releases/tags/v${VERSION}"
|
API_URL="https://api.github.com/repos/${REPO}/releases/tags/v${VERSION}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "🔍 Hole Release-Info ($API_URL)…"
|
echo "🔍 Fetching release info ($API_URL)…"
|
||||||
JSON=$(curl -sL "$API_URL")
|
JSON=$(curl -sL "$API_URL")
|
||||||
|
|
||||||
VERSION=$(echo "$JSON" | grep -m1 '"tag_name":' | sed -E 's/.*"v?([^"]+)".*/\1/')
|
VERSION=$(echo "$JSON" | grep -m1 '"tag_name":' | sed -E 's/.*"v?([^\"]+)".*/\1/')
|
||||||
ASSET_URL=$(echo "$JSON" |
|
ASSET_URL=$(echo "$JSON" |
|
||||||
grep -Eo '"browser_download_url": *"[^"]+' |
|
grep -Eo '"browser_download_url": *"[^"]+' |
|
||||||
cut -d'"' -f4 |
|
cut -d'"' -f4 |
|
||||||
grep "${ARCH_OS}\\.tar" | head -n1)
|
grep "${ARCH_OS}\.tar" | head -n1)
|
||||||
|
|
||||||
[[ -z "$ASSET_URL" ]] && { echo "❌ passender Asset nicht gefunden"; exit 1; }
|
[[ -z "$ASSET_URL" ]] && { echo "❌ Matching asset not found"; exit 1; }
|
||||||
|
|
||||||
ASSET_FILE=$(basename "$ASSET_URL")
|
ASSET_FILE=$(basename "$ASSET_URL")
|
||||||
echo "📦 Lade git-cliff v${VERSION} (${ASSET_FILE}) …"
|
echo "📦 Downloading git-cliff v${VERSION} (${ASSET_FILE}) …"
|
||||||
TMP=$(mktemp -d)
|
TMP=$(mktemp -d)
|
||||||
curl -#L -o "${TMP}/${ASSET_FILE}" "$ASSET_URL"
|
curl -#L -o "${TMP}/${ASSET_FILE}" "$ASSET_URL"
|
||||||
|
|
||||||
# 2 Entpacken je nach Endung
|
# 2 Extract based on file extension
|
||||||
case "$ASSET_FILE" in
|
case "$ASSET_FILE" in
|
||||||
*.tar.gz|*.tgz) tar -C "$TMP" -xzf "${TMP}/${ASSET_FILE}" ;;
|
*.tar.gz|*.tgz) tar -C "$TMP" -xzf "${TMP}/${ASSET_FILE}" ;;
|
||||||
*.tar.xz) tar -C "$TMP" -xJf "${TMP}/${ASSET_FILE}" ;;
|
*.tar.xz) tar -C "$TMP" -xJf "${TMP}/${ASSET_FILE}" ;;
|
||||||
*.zip) need unzip; unzip -q "${TMP}/${ASSET_FILE}" -d "$TMP" ;;
|
*.zip) need unzip; unzip -q "${TMP}/${ASSET_FILE}" -d "$TMP" ;;
|
||||||
*) echo "❌ Unbekanntes Archivformat: $ASSET_FILE"; exit 1 ;;
|
*) echo "❌ Unknown archive format: $ASSET_FILE"; exit 1 ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
BIN_PATH=$(find "$TMP" -type f -name git-cliff -perm -u+x | head -n1)
|
BIN_PATH=$(find "$TMP" -type f -name git-cliff -perm -u+x | head -n1)
|
||||||
[[ -z "$BIN_PATH" ]] && { echo "❌ Binary nicht gefunden"; exit 1; }
|
[[ -z "$BIN_PATH" ]] && { echo "❌ Binary not found"; exit 1; }
|
||||||
|
|
||||||
sudo install -m755 "$BIN_PATH" "${INSTALL_DIR}/git-cliff"
|
sudo install -m755 "$BIN_PATH" "${INSTALL_DIR}/git-cliff"
|
||||||
echo "✅ git-cliff $(git-cliff --version) installiert unter ${INSTALL_DIR}"
|
echo "✅ git-cliff $(git-cliff --version) installed in ${INSTALL_DIR}"
|
||||||
|
@@ -6,7 +6,7 @@ create_release() {
|
|||||||
local -i max_attempts=3 delay=5 attempt
|
local -i max_attempts=3 delay=5 attempt
|
||||||
local http status
|
local http status
|
||||||
|
|
||||||
# Release-Body für die JSON-Payload einlesen
|
# Read release body for JSON payload
|
||||||
local body_json
|
local body_json
|
||||||
body_json=$(tail -n +2 "$body_file" | jq -Rs .)
|
body_json=$(tail -n +2 "$body_file" | jq -Rs .)
|
||||||
|
|
||||||
@@ -53,7 +53,7 @@ CHANGELOG_FILE="CHANGELOG.md"
|
|||||||
CLIFF_CONFIG="cliff.toml"
|
CLIFF_CONFIG="cliff.toml"
|
||||||
RELEASE_BODY_TMP="$(mktemp)"
|
RELEASE_BODY_TMP="$(mktemp)"
|
||||||
|
|
||||||
# === Schritt 1: Version lesen ===
|
# === Step 1: Read version ===
|
||||||
if [[ ! -f "$VERSION_FILE" ]]; then
|
if [[ ! -f "$VERSION_FILE" ]]; then
|
||||||
echo "❌ VERSION file not found"
|
echo "❌ VERSION file not found"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -61,7 +61,7 @@ fi
|
|||||||
VERSION="$(<"$VERSION_FILE")"
|
VERSION="$(<"$VERSION_FILE")"
|
||||||
echo "📦 Version: $VERSION"
|
echo "📦 Version: $VERSION"
|
||||||
|
|
||||||
# === Schritt 2: Changelog für Release erzeugen ===
|
# === Step 2: Generate changelog for release ===
|
||||||
echo "📄 Generating changelog for tag v$VERSION"
|
echo "📄 Generating changelog for tag v$VERSION"
|
||||||
git-cliff -c "$CLIFF_CONFIG" -t "v$VERSION" -o "$CHANGELOG_FILE"
|
git-cliff -c "$CLIFF_CONFIG" -t "v$VERSION" -o "$CHANGELOG_FILE"
|
||||||
|
|
||||||
@@ -80,7 +80,7 @@ awk -v ver="$ESCAPED_VERSION" '
|
|||||||
print_flag
|
print_flag
|
||||||
' "$CHANGELOG_FILE" > "$RELEASE_BODY_TMP"
|
' "$CHANGELOG_FILE" > "$RELEASE_BODY_TMP"
|
||||||
|
|
||||||
# === Schritt 3: Changelog committen ===
|
# === Step 3: Commit changelog ===
|
||||||
git add "$CHANGELOG_FILE"
|
git add "$CHANGELOG_FILE"
|
||||||
if git diff --cached --quiet; then
|
if git diff --cached --quiet; then
|
||||||
echo "✅ No changes to commit"
|
echo "✅ No changes to commit"
|
||||||
@@ -90,18 +90,18 @@ else
|
|||||||
git push origin main
|
git push origin main
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# === Schritt 4: Tag anlegen, falls nötig ===
|
# === Step 4: Create tag if necessary ===
|
||||||
if git rev-parse "v$VERSION" >/dev/null 2>&1; then
|
if git rev-parse "v$VERSION" >/dev/null 2>&1; then
|
||||||
echo "🔁 Tag v$VERSION already exists, skipping."
|
echo "🔁 Tag v$VERSION already exists, skipping."
|
||||||
else
|
else
|
||||||
echo "🏷️ Creating annotated tag v$VERSION"
|
echo "🏷️ Creating annotated tag v$VERSION"
|
||||||
export GIT_AUTHOR_DATE="$(date --iso-8601=seconds)"
|
export GIT_AUTHOR_DATE="@$(date +%s)"
|
||||||
export GIT_COMMITTER_DATE="$GIT_AUTHOR_DATE"
|
export GIT_COMMITTER_DATE="$GIT_AUTHOR_DATE"
|
||||||
git tag -a "v$VERSION" -F "$RELEASE_BODY_TMP" --cleanup=verbatim
|
git tag -a "v$VERSION" -F "$RELEASE_BODY_TMP" --cleanup=verbatim
|
||||||
git push origin "v$VERSION"
|
git push origin "v$VERSION"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# === Schritt 5: Release anlegen (mit Retry) ===
|
# === Step 5: Create release (with retry) ===
|
||||||
OWNER="${GITHUB_REPOSITORY%/*}"
|
OWNER="${GITHUB_REPOSITORY%/*}"
|
||||||
REPO="${GITHUB_REPOSITORY#*/}"
|
REPO="${GITHUB_REPOSITORY#*/}"
|
||||||
TOKEN="${RELEASE_PUBLISH_TOKEN:-$ACTIONS_RUNTIME_TOKEN}"
|
TOKEN="${RELEASE_PUBLISH_TOKEN:-$ACTIONS_RUNTIME_TOKEN}"
|
||||||
|
@@ -1,9 +1,9 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
# Optional inputs (positionals) oder Fallback auf Umgebungsvariablen
|
# Optional inputs (positionals) or fallback to environment variables
|
||||||
AUTHOR_NAME="${1:-${CI_COMMIT_AUTHOR_NAME:-CI Bot}}"
|
AUTHOR_NAME="${1:-${CI_COMMIT_AUTHOR_NAME:-CI Bot}}"
|
||||||
AUTHOR_EMAIL="${2:-${CI_COMMIT_AUTHOR_EMAIL:-ci@example.com}}"
|
AUTHOR_EMAIL="${2:-${CI_COMMIT_AUTHOR_EMAIL:-ci@bot.none}}"
|
||||||
|
|
||||||
echo "🔧 Setting up git author:"
|
echo "🔧 Setting up git author:"
|
||||||
echo " Name : $AUTHOR_NAME"
|
echo " Name : $AUTHOR_NAME"
|
||||||
@@ -11,3 +11,19 @@ echo " Email: $AUTHOR_EMAIL"
|
|||||||
|
|
||||||
git config --global user.name "$AUTHOR_NAME"
|
git config --global user.name "$AUTHOR_NAME"
|
||||||
git config --global user.email "$AUTHOR_EMAIL"
|
git config --global user.email "$AUTHOR_EMAIL"
|
||||||
|
|
||||||
|
# Check if the values were set correctly
|
||||||
|
CONFIGURED_NAME=$(git config --global user.name)
|
||||||
|
CONFIGURED_EMAIL=$(git config --global user.email)
|
||||||
|
|
||||||
|
if [[ "$CONFIGURED_NAME" != "$AUTHOR_NAME" ]]; then
|
||||||
|
echo "❌ Error: Git username was not set correctly!" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$CONFIGURED_EMAIL" != "$AUTHOR_EMAIL" ]]; then
|
||||||
|
echo "❌ Error: Git email was not set correctly!" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "✅ Git configuration completed successfully."
|
||||||
|
Reference in New Issue
Block a user