aboutsummaryrefslogtreecommitdiff
path: root/tools/sync-recordings-to-remote.sh
blob: cf979d1bca7ac289900de6befd513e7162fcf2db (plain)
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
#!/bin/bash

PROGNAME="$0"
NODE_CONFIG="/etc/sound_node.toml"
REMOTE_USER=user
REMOTE_SERVER=solarmon.ru
REMOTE_DIRECTORY=/var/recordings

set -e

echoerr() {
	>&2 echo "error: $@"
}

echowarn() {
	>&2 echo "warning: $@"
}

telegram_alert() {
	if [ -z "$TG_TOKEN" ] || [ -z "$TG_CHAT_ID" ]; then return; fi
	curl -X POST \
		-F "chat_id=${TG_CHAT_ID}" \
		-F "text=$1" \
		"https://api.telegram.org/bot${TG_TOKEN}/sendMessage"
}

fatal() {
	echoerr "$@"
	telegram_alert "$PROGNAME: $@"
	exit 1
}

get_config_var() {
	local varname="$1"
	cat "$NODE_CONFIG"  | grep "^$varname = \"" | awk '{print $3}' | tr -d '"'
}

get_mp3_count() {
	find "$LOCAL_DIR" -mindepth 1 -type f -name "*.mp3" -printf x | wc -c
}

[ -z "$TG_TOKEN" ] && echowarn "TG_TOKEN is not set"
[ -z "$TG_CHAT_ID" ] && echowarn "TG_CHAT_ID is not set"

NODE_NAME=$(get_config_var name)
LOCAL_DIR=$(get_config_var storage)

[ -z "$NODE_NAME" ] && fatal "failed to parse NODE_NAME"
[ -z "$LOCAL_DIR" ] && fatal "failed to parse LOCAL_DIR"

[ -d "$LOCAL_DIR" ] || fatal "$LOCAL_DIR is not a directory"

COUNT=$(get_mp3_count)
(( $COUNT < 1 )) && {
	echo "seems there's nothing to sync"
	exit
}

cd "$LOCAL_DIR" || fatal "failed to change to $LOCAL_DIR"

rsync -azPv -e "ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -o LogLevel=ERROR" \
	*.mp3 \
	${REMOTE_USER}@${REMOTE_SERVER}:"${REMOTE_DIRECTORY}/${NODE_NAME}/" \
	--exclude temp.mp3

RC=$?

if [ $RC -eq 0 ]; then
	find "$LOCAL_DIR" -name "*.mp3" -type f -mmin +1440 -delete || fatal "find failed to delete old files"
else
	fatal "failed to rsync: code $RC"
fi