dev #5

Merged
sujiba merged 3 commits from dev into main 2024-07-08 22:47:41 +02:00
2 changed files with 65 additions and 9 deletions

View file

@ -9,7 +9,7 @@ jobs:
release_tag: release_tag:
runs-on: ubuntu-latest runs-on: ubuntu-latest
outputs: outputs:
release: steps.create_release.outputs.release release: steps.create_release.outputs.RELEASE
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
@ -28,7 +28,7 @@ jobs:
# increase the counter, if the release is from the same year and month # increase the counter, if the release is from the same year and month
if [[ $(date +'%Y') == $year ]] && [[ $(date +'%m') == $month ]]; then if [[ $(date +'%Y') == $year ]] && [[ $(date +'%m') == $month ]]; then
((counter++)); counter=$(($counter + 1));
# else reset counter # else reset counter
else else
counter=1; counter=1;
@ -36,14 +36,14 @@ jobs:
# Create # Create
new_release=$(date +'%Y').$(date +'%m').$counter new_release=$(date +'%Y').$(date +'%m').$counter
echo "release=$new_release">> $GITHUB_OUTPUT echo "RELEASE=$new_release">> $GITHUB_OUTPUT
echo "Release $new_release successfully set" echo "Release $new_release successfully set"
build: build:
runs-on: ubuntu-latest
needs: release_tag needs: release_tag
runs-on: ubuntu-latest
env: env:
release_tag: ${{needs.release_tag.outputs.release}} RELEASE: ${{ needs.release_tag.outputs.release }}
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
@ -72,5 +72,64 @@ jobs:
push: true push: true
cleanup: true cleanup: true
tags: | tags: |
${{ secrets.DOCKER_USER }}/docker-owndyndns-netcup:${{needs.release_tag.outputs.release}} ${{ secrets.DOCKER_USER }}/docker-owndyndns-netcup:$RELEASE
${{ secrets.DOCKER_USER }}/docker-owndyndns-netcup:latest ${{ secrets.DOCKER_USER }}/docker-owndyndns-netcup:latest
publish_release:
needs: [release_tag, build]
runs-on: ubuntu-latest
env:
RELEASE: ${{ needs.release_tag.outputs.release }}
GH_TOKEN: "${{ secrets.GH_TOKEN }}"
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Create new release
shell: bash
run: |
echo $RELEASE
# Get latest release "created at" timestemp
latest_release=$(curl -s https://git.smail.koeln/api/v1/repos/homelab/docker-ownDynDNS-netcup/releases\?limit\=1 | jq -r '.[] | .tag_name')
latest_release_time=$(date -d $(curl -s https://git.smail.koeln/api/v1/repos/homelab/docker-ownDynDNS-netcup/releases\?limit\=1 | jq -r '.[] | .created_at')))
echo "Last release from $latest_release_time"
# Get last 50 commits
curl -s "https://git.smail.koeln/api/v1/repos/homelab/docker-ownDynDNS-netcup/commits?limit=50" > /tmp/last_50_commits.json
# Count commits (max. 50) between now and the latest release
i=0
fin=0
while [[ $fin == 0 ]]; do
commit_time=$(date --date=$(cat /tmp/last_50_commits.json | jq -r --arg -i "$i" '.[$i|tonumber] | .created' ));
if [[ $(date -d "$latest_release_time" +%s) -le $(date -d "$commit_time" +%s) ]]; then
echo "$i $commit_time"
i=$(($i + 1));
else
fin=1;
fi
done
# Generate list of commit messages since latest release for release message
j=0
release_list=""
while [[ "$j" != "$i" ]]; do
message=$(cat /tmp/last_50_commits.json | jq -r --args j "$j" '.[$j|tonumber] | .commit.message')
echo "$j $message"
message_newline="${message}\n\""
message_list="$message_list* $message_newline"
j=$(($j + 1))
done
# Generate release message
datetime=$(env TZ=Europe/Berlin date "+%A, %d.%m.%Y at %R")
body="Create automatically on $datetime by forgejo action \\n\\n $i commit(s) since relase $latest_release:\\n\\n$(echo $message_list | sed 's/"//g')"
echo $body
# Create release
curl -d "{\"body\": \"$body\", \"tag_name\": \"$RELEASE\", \"target_commitish\": \"main\" }" https://git.smail.koeln/api/v1/repos/homelab/docker-ownDynDNS-netcup/release -H "Authorization: token $GH_TOKEN" -H "Content-Type: application/json"

View file

@ -1,3 +0,0 @@
{
"ansible.python.interpreterPath": "/usr/bin/python3"
}