Compare commits
No commits in common. "8cd20ec9acc852925de5042507920526f9c371e0" and "8c46f9c7755fe47273b0f93476222e84e009723b" have entirely different histories.
8cd20ec9ac
...
8c46f9c775
2 changed files with 9 additions and 65 deletions
|
@ -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 + 1));
|
((counter++));
|
||||||
# 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:
|
||||||
needs: release_tag
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
needs: release_tag
|
||||||
env:
|
env:
|
||||||
RELEASE: ${{ needs.release_tag.outputs.release }}
|
release_tag: ${{needs.release_tag.outputs.release}}
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
@ -72,64 +72,5 @@ jobs:
|
||||||
push: true
|
push: true
|
||||||
cleanup: true
|
cleanup: true
|
||||||
tags: |
|
tags: |
|
||||||
${{ secrets.DOCKER_USER }}/docker-owndyndns-netcup:$RELEASE
|
${{ secrets.DOCKER_USER }}/docker-owndyndns-netcup:${{needs.release_tag.outputs.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"
|
|
||||||
|
|
3
.vscode/settings.json
vendored
Executable file
3
.vscode/settings.json
vendored
Executable file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"ansible.python.interpreterPath": "/usr/bin/python3"
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue