6 Commits

Author SHA1 Message Date
73badf986b chore(changelog): update changelog for v0.2.2
All checks were successful
Create Major Version Tag / update-major-tag (release) Successful in 4s
2025-06-14 17:53:17 +00:00
2ab0da2e14 chore(version): bump version to 0.2.2
All checks were successful
Auto Changelog & Release / release (push) Successful in 7s
2025-06-14 19:53:07 +02:00
35eff4400f chore(changelog): update unreleased changelog 2025-06-14 17:50:38 +00:00
041d7e9a8a refactor(scripts): standardize scripts and improve readability
All checks were successful
Auto Changelog & Release / release (push) Successful in 6s
- Removed unnecessary comments and adjusted formatting for clarity
- Translated German comments, logs, and error messages to English
- Improved consistency in variable naming and messages across scripts
- Enhanced error handling and output for better user feedback
2025-06-14 19:50:28 +02:00
bb27eccc86 chore(changelog): update unreleased changelog 2025-06-14 17:39:28 +00:00
212e8c6a49 feat(scripts): validate git configuration during setup
All checks were successful
Auto Changelog & Release / release (push) Successful in 6s
- Updates default email domain to prevent misuse
- Adds checks to ensure git author name and email are set correctly
- Improves reliability of git configuration setup
2025-06-14 19:39:22 +02:00
6 changed files with 51 additions and 25 deletions

View File

@@ -2,6 +2,16 @@
All notable changes to this project will be documented in this file.
## [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
### 🚀 Features

View File

@@ -1 +1 @@
0.2.1
0.2.2

View File

@@ -1,7 +1,7 @@
#!/usr/bin/env bash
set -euo pipefail
# === Inputs from GitHub/Gitea Action environment ===
# Inputs from GitHub/Gitea Action environment
GIT_REF="${GITHUB_REF:-}"
COMMIT_BEFORE="${GITHUB_EVENT_BEFORE:-}"
COMMIT_AFTER="${GITHUB_SHA:-}"
@@ -11,7 +11,7 @@ echo "🔍 Comparing commits:"
echo "Before: $COMMIT_BEFORE"
echo "After: $COMMIT_AFTER"
# === Check branch condition ===
# Check branch condition
if [[ "$GIT_REF" != "refs/heads/main" ]]; then
echo "Not on 'main' branch – skipping version check."
echo "version_changed=false" >> "$GITHUB_OUTPUT"

View File

@@ -1,7 +1,7 @@
#!/usr/bin/env bash
# install-git-cliff.sh – holt neueste oder gewünschte git-cliff-Binary (x86_64)
# Usage: sudo ./install-git-cliff.sh # neueste Version
# sudo ./install-git-cliff.sh 2.9.0 # bestimmte Version
# install-git-cliff.sh – fetches the latest or specified git-cliff binary (x86_64)
# Usage: sudo ./install-git-cliff.sh # latest version
# sudo ./install-git-cliff.sh 2.9.0 # specific version
set -euo pipefail
REPO="orhun/git-cliff"
@@ -9,42 +9,42 @@ ARCH_OS="x86_64-unknown-linux-gnu"
INSTALL_DIR="/usr/local/bin"
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
# 1 Version ermitteln → Release-JSON abrufen
# 1 Determine version → Fetch release JSON
if [[ "$VERSION" == "latest" ]]; then
API_URL="https://api.github.com/repos/${REPO}/releases/latest"
else
API_URL="https://api.github.com/repos/${REPO}/releases/tags/v${VERSION}"
fi
echo "🔍 Hole Release-Info ($API_URL)…"
echo "🔍 Fetching release info ($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" |
grep -Eo '"browser_download_url": *"[^"]+' |
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")
echo "📦 Lade git-cliff v${VERSION} (${ASSET_FILE}) …"
echo "📦 Downloading git-cliff v${VERSION} (${ASSET_FILE}) …"
TMP=$(mktemp -d)
curl -#L -o "${TMP}/${ASSET_FILE}" "$ASSET_URL"
# 2 Entpacken je nach Endung
# 2 Extract based on file extension
case "$ASSET_FILE" in
*.tar.gz|*.tgz) tar -C "$TMP" -xzf "${TMP}/${ASSET_FILE}" ;;
*.tar.xz) tar -C "$TMP" -xJf "${TMP}/${ASSET_FILE}" ;;
*.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
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"
echo "✅ git-cliff $(git-cliff --version) installiert unter ${INSTALL_DIR}"
echo "✅ git-cliff $(git-cliff --version) installed in ${INSTALL_DIR}"

View File

@@ -6,7 +6,7 @@ create_release() {
local -i max_attempts=3 delay=5 attempt
local http status
# Release-Body für die JSON-Payload einlesen
# Read release body for JSON payload
local body_json
body_json=$(tail -n +2 "$body_file" | jq -Rs .)
@@ -53,7 +53,7 @@ CHANGELOG_FILE="CHANGELOG.md"
CLIFF_CONFIG="cliff.toml"
RELEASE_BODY_TMP="$(mktemp)"
# === Schritt 1: Version lesen ===
# === Step 1: Read version ===
if [[ ! -f "$VERSION_FILE" ]]; then
echo "❌ VERSION file not found"
exit 1
@@ -61,7 +61,7 @@ fi
VERSION="$(<"$VERSION_FILE")"
echo "📦 Version: $VERSION"
# === Schritt 2: Changelog für Release erzeugen ===
# === Step 2: Generate changelog for release ===
echo "📄 Generating changelog for tag v$VERSION"
git-cliff -c "$CLIFF_CONFIG" -t "v$VERSION" -o "$CHANGELOG_FILE"
@@ -80,7 +80,7 @@ awk -v ver="$ESCAPED_VERSION" '
print_flag
' "$CHANGELOG_FILE" > "$RELEASE_BODY_TMP"
# === Schritt 3: Changelog committen ===
# === Step 3: Commit changelog ===
git add "$CHANGELOG_FILE"
if git diff --cached --quiet; then
echo "✅ No changes to commit"
@@ -90,7 +90,7 @@ else
git push origin main
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
echo "🔁 Tag v$VERSION already exists, skipping."
else
@@ -101,7 +101,7 @@ else
git push origin "v$VERSION"
fi
# === Schritt 5: Release anlegen (mit Retry) ===
# === Step 5: Create release (with retry) ===
OWNER="${GITHUB_REPOSITORY%/*}"
REPO="${GITHUB_REPOSITORY#*/}"
TOKEN="${RELEASE_PUBLISH_TOKEN:-$ACTIONS_RUNTIME_TOKEN}"

View File

@@ -1,9 +1,9 @@
#!/usr/bin/env bash
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_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 " Name : $AUTHOR_NAME"
@@ -11,3 +11,19 @@ echo " Email: $AUTHOR_EMAIL"
git config --global user.name "$AUTHOR_NAME"
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."