Бот Telegram: различия между версиями
Дым (обсуждение | вклад) Нет описания правки |
Дым (обсуждение | вклад) Нет описания правки |
||
Строка 49: | Строка 49: | ||
Notify "$TESTDB распакована за $TIME, можно проверять целостность." | Notify "$TESTDB распакована за $TIME, можно проверять целостность." | ||
</source> | </source> | ||
Статья только начата и пока в стадии создания, так что лакуны типа '''гуглится''' будут | Статья только начата и пока в стадии создания, так что лакуны типа '''(гуглится)''' будут заполняться по мере того, как вспомню, как делал это сам. |
Версия от 03:56, 26 января 2023
Многие ищут способы отправлять оповещения о событиях на инфраструктуре в свои группы телеграм.
Изучают перл, питон (дело хорошее, но необязательное), роются на гитхабе в поисках телегоботов, написанных другими.
А меж тем всё довольно просто:
- Генерим нового телегобота в... генераторе телегоботов (гуглится).
- Получаем ИД группы (гуглится), в которую боту нужно слать мессаги.
- Добавляем в баш-скрипт команду, которая по наступлению ключевого события будет слать соответствующий текст по жетону бота и ИДу канала вида (на куски разбито для удобочитаемости):
curl -s -X POST -H 'Content-Type: application/json' -d \ "{\"chat_id\": \"ИД_чатика\", \"text\": \"текст сообщения\", \"disable_notification\": true}" \ https://api.telegram.org/bot<токен бота>/sendMessage
Пример такого скрипта (у меня распаковывается дамп базы для проверки его на целостность — dumpcheck):
#!/bin/bash
WD=/mnt/dumps.psql/daily # Ежедневные дампы на СХД.
DUMP=`ls -1 $WD/$1*| tail -2 | head -1 | sed 's|.*/||'` # Проверять предпоследнюю ежедневку.
DATE=`echo $DUMP | cut -d, -f2`
ChatID="-13_цифр" # ИД чатика, куда слать оповещения.
BoTokn="10_цифр:???-31_цифробуква" # Токен/жетон созданного для этого бота.
Notify(){ # Функция отправки оповещений, предварительно формирующая текст.
curl -s -X POST -H 'Content-Type: application/json' \
-d "{\"chat_id\": \"$ChatID\", \"text\": \"$1\", \"disable_notification\": true}" \
https://api.telegram.org/bot$BoTokn/sendMessage 2>&1 >/dev/null
}
case ${DUMP##*.} in
zst) UNPAK=zstdcat ;;
lzo) UNPAK="lzop -dcf" ;;
esac
TESTDB=check_${DUMP%%,*}
Notify "Распаковывается база $TESTDB от $DATE."
# [пере]создадим проверочную базу:
[ `psql -U postgres -c "\l+" | grep -c $TESTDB` -lt 1 ] ||
for DO in drop create; do
${DO}db -U postgres $TESTDB
done
# и распакуем в неё дамп:
$UNPAK $WD/$DUMP | psql -U postgres -d $TESTDB >/dev/null 2>&1
#date +"Elapsed %T" -ud @$[`date +%s`-START] # Сколько длился весь процесс.
TIME=$(date +%T -ud @$[`date +%s`-START])
Notify "$TESTDB распакована за $TIME, можно проверять целостность."
Статья только начата и пока в стадии создания, так что лакуны типа (гуглится) будут заполняться по мере того, как вспомню, как делал это сам.