-
Notifications
You must be signed in to change notification settings - Fork 3
176 lines (159 loc) · 6.64 KB
/
telegram-notify.yml
File metadata and controls
176 lines (159 loc) · 6.64 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
name: Telegram – Repo Notifications (Clean Text)
on:
push:
branches: ["**"]
tags: ["*"]
pull_request:
types: [opened, reopened, synchronize, closed]
release:
types: [published]
workflow_dispatch:
inputs:
title:
description: "Manual title (default: 📣 Manual)"
required: false
default: "📣 Manual"
text:
description: "Message to send"
required: true
chat_id:
description: "Override TG_CHAT_ID (e.g., @Channel or numeric ID)"
required: false
permissions:
contents: read
concurrency:
group: telegram-${{ github.ref }}-${{ github.event_name }}
cancel-in-progress: false
jobs:
notify:
if: >
github.repository == 'Someshdiwan/JavaEvolution-Learning-Growing-Mastering' &&
(github.event_name != 'pull_request' || github.event.pull_request.head.repo.fork == false)
runs-on: ubuntu-latest
environment: SANDBOX
permissions:
contents: read
steps:
- name: Checkout repository (for commit history)
if: github.event_name == 'push' # Only needed for push events
uses: actions/checkout@v4
with:
fetch-depth: 100
- name: Build notification message
id: build-message
shell: bash
env:
REPO: ${{ github.repository }}
ACTOR: ${{ github.actor }}
EVENT: ${{ github.event_name }}
REF_NAME: ${{ github.ref_name }}
REPO_URL: ${{ github.server_url }}/${{ github.repository }}
GIT_BEFORE: ${{ github.event.before }}
GIT_SHA: ${{ github.sha }}
PR_NUM: ${{ github.event.pull_request.number }}
PR_TITLE: ${{ github.event.pull_request.title }}
PR_URL: ${{ github.event.pull_request.html_url }}
PR_ACTION: ${{ github.event.action }}
PR_MERGED: ${{ github.event.pull_request.merged }}
PR_HEAD: ${{ github.event.pull_request.head.ref }}
PR_BASE: ${{ github.event.pull_request.base.ref }}
REL_TAG: ${{ github.event.release.tag_name }}
REL_NAME: ${{ github.event.release.name }}
REL_URL: ${{ github.event.release.html_url }}
WD_TITLE: ${{ github.event.inputs.title }}
WD_TEXT: ${{ github.event.inputs.text }}
run: |
set -euo pipefail
# Helper functions for headers
header_push() {
printf '📣 Repository Update\n🌐 Repo: %s\n🌳 Branch: %s\n👤 By: %s\n\n' \
"$REPO" "$REF_NAME" "https://github.com/$ACTOR"
}
header_pr() {
printf '📣 Pull Request Update\n🌐 Repo: %s\n👤 By: %s\n\n' \
"$REPO" "https://github.com/$ACTOR"
}
header_release() {
printf '📣 New Release\n🌐 Repo: %s\n👤 By: %s\n\n' \
"$REPO" "https://github.com/$ACTOR"
}
header_manual() {
printf '%s\n👤 By: %s\n\n' "${WD_TITLE:-📣 Manual}" "https://github.com/$ACTOR"
}
# Build message based on event type
message=""
case "$EVENT" in
workflow_dispatch)
message="$(header_manual)${WD_TEXT}"
;;
push)
# Fetch last 10 commits (subject, short hash, author)
before="${GIT_BEFORE:-}"
after="$GIT_SHA"
if [[ -z "$before" || "$before" =~ ^0+$ ]]; then
mapfile -t commits < <(git log -n 10 --pretty=format:'%s%x1f%h%x1f%an' "$after" 2>/dev/null || true)
else
mapfile -t commits < <(git log --pretty=format:'%s%x1f%h%x1f%an' "$before..$after" 2>/dev/null | head -n 10 || true)
fi
if [[ ${#commits[@]} -eq 0 ]]; then
commits_text="- No commit messages found"
else
commits_text=""
for row in "${commits[@]}"; do
IFS=$'\x1f' read -r subject hash author <<<"$row"
commits_text+="- ${subject} (${hash}) by ${author}\n"
done
commits_text="${commits_text%$'\n'}"
fi
message="$(header_push)Last 10 commits:\n${commits_text}\n\n🔗 Repo: ${REPO_URL}"
;;
pull_request)
# Determine PR status
case "$PR_ACTION" in
closed) [[ "$PR_MERGED" == "true" ]] && status="🔀 Merged PR #${PR_NUM}" || status="❌ Closed PR #${PR_NUM}";;
opened) status="🆕 Opened PR #${PR_NUM}";;
*) status="✏️ Updated PR #${PR_NUM}";;
esac
message="$(header_pr)${status}\n📝 Title: ${PR_TITLE}\n🔄 From: ${PR_HEAD} → ${PR_BASE}\n🔗 Link: ${PR_URL}\n\n🔗 Repo: ${REPO_URL}"
;;
release)
name="${REL_NAME:-$REL_TAG}"
message="$(header_release)🏷️ Tag: ${REL_TAG}\n📜 Name: ${name}\n🔗 Link: ${REL_URL}\n\n🔗 Repo: ${REPO_URL}"
;;
*)
message="📣 Event: ${EVENT}\n🌐 Repo: ${REPO}\n👤 By: https://github.com/${ACTOR}\n🌳 Ref: ${REF_NAME}\n\n🔗 Repo: ${REPO_URL}"
;;
esac
# Truncate message to avoid Telegram's ~4096 char limit
if (( $(printf %s "$message" | wc -c) > 3900 )); then
message="$(printf %s "$message" | head -c 3900) … (truncated)"
fi
# Escape and output message
message=$(printf '%s' "$message" | jq -R -s .)
echo "text=$message" >> "$GITHUB_OUTPUT"
- name: Send message to Telegram
shell: bash
env:
TG_BOT_TOKEN: ${{ secrets.TG_BOT_TOKEN }}
TG_CHAT_ID_DEFAULT: ${{ secrets.TG_CHAT_ID }}
OVERRIDE_CHAT_ID: ${{ github.event.inputs.chat_id }}
TEXT: ${{ steps.build-message.outputs.text }}
run: |
set -euo pipefail
# Validate secrets
chat_id="${OVERRIDE_CHAT_ID:-$TG_CHAT_ID_DEFAULT}"
if [[ -z "${TG_BOT_TOKEN}" || -z "${chat_id}" ]]; then
echo "Error: Missing TG_BOT_TOKEN or chat_id" >&2
exit 1
fi
# Send message to Telegram API
response=$(curl -sS -X POST "https://api.telegram.org/bot${TG_BOT_TOKEN}/sendMessage" \
-H 'Content-Type: application/json' \
-d "{\"chat_id\": \"${chat_id}\", \"text\": ${TEXT}, \"disable_web_page_preview\": true}")
# Check response
if ! echo "$response" | jq -e '.ok == true' >/dev/null; then
echo "Error: Failed to send message to Telegram" >&2
echo "Response: $response" >&2
exit 1
fi
echo "✅ Successfully sent message to Telegram"