dns/.forgejo/workflows/ci.yaml

75 lines
2.8 KiB
YAML
Raw Permalink Normal View History

name: DNS automated deployment
2023-10-24 18:04:11 +02:00
on:
push:
branches:
2023-10-25 00:53:02 +02:00
- 'main'
2023-10-24 18:04:11 +02:00
jobs:
deploy:
2023-10-24 18:04:11 +02:00
runs-on: linux_amd64
steps:
2024-08-20 16:45:39 +02:00
- name: Apply zone changes
2023-10-24 18:04:11 +02:00
shell: bash
2024-08-20 16:51:32 +02:00
run: |
LAST_RUN=$(cat /home/runner/last_run)
2024-08-20 17:35:01 +02:00
CURRENT_ZONE=
2024-08-20 16:51:32 +02:00
echo "Preparing to update ${{ vars.DNS_SERVER }}..."
2024-08-20 17:27:39 +02:00
git clone ${{ gitea.server_url }}/${{ gitea.repository }} dns
cd dns
git diff $LAST_RUN ${{ env.GITHUB_SHA }} > zone_diff.txt
echo "${{ secrets.TSIG_KEY }}" | base64 -d > temp_keyfile
2024-08-20 17:29:06 +02:00
while IFS= read -r line; do
2024-08-20 19:56:54 +02:00
#echo "* line: $line"
2024-08-20 17:29:06 +02:00
case "$line" in
"--- "*".zone")
2024-08-20 17:40:11 +02:00
NAME=$(echo "$line" .zone | sed 's/--- //' | sed 's|a/||')
CURRENT_ZONE=$(basename $NAME)
2024-08-20 17:42:37 +02:00
echo "*** Updating $CURRENT_ZONE"
2024-08-20 17:29:06 +02:00
;;
2024-08-20 17:35:01 +02:00
"--- "*)
CURRENT_ZONE=
;;
2024-08-20 17:29:06 +02:00
"+++"*)
;;
2024-08-20 19:51:09 +02:00
"-"*IN* | "+"*IN*)
2024-08-20 17:36:31 +02:00
if [ ! -z $CURRENT_ZONE ]; then
2024-08-20 17:35:01 +02:00
if [[ $line == -* ]]; then # Enregistrement supprimé
2024-09-28 12:42:23 +02:00
RECORD=$(echo "$line" | sed 's/^-//' | sed "s/^\([^ ]\+\)\(\s\+\)\(IN\s\+\)\([^ ]\+\)\(\s\+\)/\1.${CURRENT_ZONE}.\2\3\4\5/" | sed 's/@.//')
2024-08-20 17:49:34 +02:00
echo "update delete $RECORD"
2024-09-28 12:32:28 +02:00
echo -e "server ${{vars.DNS_SERVER}}\nttl 3600\nupdate delete $RECORD\nsend" > temp_delete
nsupdate -k temp_keyfile temp_delete
2024-08-20 17:57:43 +02:00
rm temp_delete
2024-09-28 12:28:44 +02:00
fi
2024-09-28 12:21:28 +02:00
fi
;;
esac
done < zone_diff.txt
while IFS= read -r line; do
#echo "* line: $line"
case "$line" in
"--- "*".zone")
NAME=$(echo "$line" .zone | sed 's/--- //' | sed 's|a/||')
CURRENT_ZONE=$(basename $NAME)
echo "*** Updating $CURRENT_ZONE"
;;
"--- "*)
CURRENT_ZONE=
;;
"+++"*)
;;
"-"*IN* | "+"*IN*)
if [ ! -z $CURRENT_ZONE ]; then
if [[ $line == +* ]]; then # Enregistrement ajouté
RECORD=$(echo "$line" | sed 's/^+//' | sed "s/^\([^ ]\+\)\(\s\+\)\(IN\s\+\)\([^ ]\+\)\(\s\+\)/\1.${CURRENT_ZONE}.\2\3\4\5/" | sed 's/@.//')
echo "update add $RECORD"
echo -e "server ${{vars.DNS_SERVER}}\nttl 3600\nupdate add $RECORD\nsend" > temp_add
nsupdate -k temp_keyfile temp_add
2024-08-20 17:57:43 +02:00
rm temp_add
2024-08-20 17:35:01 +02:00
fi
2024-08-20 17:29:06 +02:00
fi
;;
esac
done < zone_diff.txt
rm temp_keyfile
2024-09-28 12:21:28 +02:00
echo ${{ env.GITHUB_SHA }} > /home/runner/last_run