2021-02-27 16:57:07 +01:00
|
|
|
#!/bin/bash
|
|
|
|
# shellcheck disable=SC1090,SC2034,SC2059
|
|
|
|
#===============================================================================
|
|
|
|
#
|
|
|
|
# FILE: bin/process_batch.sh
|
|
|
|
#
|
2021-06-03 12:03:10 +02:00
|
|
|
USAGE='process_batch.sh [-h|--help] [-s|--startbot] [-w|--watch] [-n|--lines n] [file] [debug]'
|
2021-02-27 16:57:07 +01:00
|
|
|
#
|
|
|
|
# DESCRIPTION: processes last 10 telegram updates in file, one update per line
|
|
|
|
#
|
2021-02-28 16:51:28 +01:00
|
|
|
# -s --startbot load addons, start TIMER, trigger startup actions
|
2021-02-27 16:57:07 +01:00
|
|
|
# -w --watch watch for new updates added to file
|
|
|
|
# -n --lines read only last "n" lines
|
|
|
|
# file to read updates from
|
|
|
|
# empty means read from webhook pipe
|
|
|
|
#
|
|
|
|
# -h - display short help
|
|
|
|
# --help - this help
|
|
|
|
#
|
|
|
|
# LICENSE: WTFPLv2 http://www.wtfpl.net/txt/copying/
|
|
|
|
# AUTHOR: KayM (gnadelwartz), kay@rrr.de
|
|
|
|
# CREATED: 27.02.2021 13:14
|
|
|
|
#
|
2021-06-03 14:21:40 +02:00
|
|
|
#### $$VERSION$$ v1.51-0-g6e66a28
|
2021-02-27 16:57:07 +01:00
|
|
|
#===============================================================================
|
|
|
|
|
|
|
|
####
|
|
|
|
# parse args
|
|
|
|
COMMAND="process_multi_updates"
|
|
|
|
lines="-n 10"
|
2021-03-18 10:48:43 +01:00
|
|
|
mode="batch"
|
2021-02-27 16:57:07 +01:00
|
|
|
|
2021-03-02 18:05:14 +01:00
|
|
|
opt=0
|
2021-03-02 18:26:41 +01:00
|
|
|
while [[ "${opt}" -lt 5 && "$1" == "-"* ]]
|
2021-03-02 18:05:14 +01:00
|
|
|
do
|
|
|
|
(( opt++ ))
|
|
|
|
case "$1" in
|
2021-02-28 16:51:28 +01:00
|
|
|
"-s"|"--startbot")
|
|
|
|
startbot="yes"
|
|
|
|
shift
|
|
|
|
;;
|
2021-03-02 18:05:14 +01:00
|
|
|
"-w"|"--watch")
|
2021-02-27 16:57:07 +01:00
|
|
|
follow="-f"
|
2021-03-18 10:48:43 +01:00
|
|
|
mode="webhook"
|
2021-02-27 16:57:07 +01:00
|
|
|
shift
|
|
|
|
;;
|
|
|
|
"-n"|"--lines")
|
|
|
|
lines="-n $2"
|
|
|
|
shift 2
|
|
|
|
;;
|
2021-03-02 18:05:14 +01:00
|
|
|
esac
|
|
|
|
done
|
2021-02-27 16:57:07 +01:00
|
|
|
|
|
|
|
# set bashbot environment
|
|
|
|
source "${0%/*}/bashbot_env.inc.sh" "debug" # debug
|
|
|
|
print_help "${1:-nix}"
|
|
|
|
|
|
|
|
# empty file is webhook
|
|
|
|
file="${WEBHOOK}"
|
|
|
|
[ -n "$1" ] && file="$1"
|
|
|
|
|
2021-02-28 16:51:28 +01:00
|
|
|
# start bot
|
|
|
|
if [ -n "${startbot}" ]; then
|
|
|
|
# warn when starting bot without pipe
|
2021-03-05 12:33:15 +01:00
|
|
|
[ -p "${file}" ] || printf "%(%c)T: %b\n" -1 "${ORANGE}Warning${NC}: File is not a pipe:${GREY} ${file##*/}${NC}"
|
2021-03-18 10:48:43 +01:00
|
|
|
start_bot "$2" "${mode}"
|
2021-03-18 14:58:18 +01:00
|
|
|
printf "%(%c)T: %b\n" -1 "${GREEN}Bot startup actions done, start ${mode} updates ...${NC}"
|
2021-02-28 16:51:28 +01:00
|
|
|
fi
|
|
|
|
# check file exist
|
2021-02-27 16:57:07 +01:00
|
|
|
if [[ ! -r "${file}" || -d "${file}" ]]; then
|
2021-03-05 12:33:15 +01:00
|
|
|
printf "%(%c)T: %b\n" -1 "${RED}Error${NC}: File not readable:${GREY} ${file}${NC}."
|
2021-02-27 16:57:07 +01:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
####
|
|
|
|
# ready, do stuff here -----
|
2021-02-28 16:51:28 +01:00
|
|
|
|
|
|
|
# kill all sub processes on exit
|
2021-06-03 12:03:10 +02:00
|
|
|
trap 'printf "%(%c)T: %s\n" -1 "Bot in '"${mode}"' mode stopped"; kill $(jobs -p) 2>/dev/null; wait $(jobs -p) 2>/dev/null; send_normal_message "'"${BOTADMIN}"'" "Bot '"${BOTNAME} ${mode}"' stopped ..."' EXIT HUP QUIT
|
2021-02-27 16:57:07 +01:00
|
|
|
|
2021-03-05 12:03:04 +01:00
|
|
|
# wait after (first) update to avoid processing to many in parallel
|
|
|
|
UPDWAIT="0.5"
|
2021-02-28 16:51:28 +01:00
|
|
|
# use tail to read appended updates
|
2021-02-27 16:57:07 +01:00
|
|
|
# shellcheck disable=SC2086,SC2248
|
2021-06-03 12:03:10 +02:00
|
|
|
tail ${follow} ${lines} "${file}" 2>/dev/null |\
|
|
|
|
while IFS="" read -r input 2>/dev/null
|
2021-02-27 16:57:07 +01:00
|
|
|
do
|
|
|
|
# read json from stdin and convert update format
|
2021-02-28 14:15:26 +01:00
|
|
|
# replace any ID named BOTADMIN with ID of bot admin
|
2021-03-03 13:40:51 +01:00
|
|
|
: "${input//\"id\":BOTADMIN,/\"id\":${BOTADMIN},}"
|
2021-02-28 14:15:26 +01:00
|
|
|
json='{"result": ['"${_}"']}'
|
2021-02-27 16:57:07 +01:00
|
|
|
UPDATE="$(${JSONSHFILE} -b -n <<<"${json}" 2>/dev/null)"
|
|
|
|
|
|
|
|
# process telegram update
|
2021-02-28 14:15:26 +01:00
|
|
|
"${COMMAND}" "$2"
|
2021-03-05 12:03:04 +01:00
|
|
|
sleep "${UPDWAIT}"
|
|
|
|
UPDWAIT="0.05"
|
2021-02-27 16:57:07 +01:00
|
|
|
done
|