aboutsummaryrefslogtreecommitdiff
blob: 1fd2768fd2bbf4d559a6fc49ae38f182f45576b6 (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
#!/bin/bash
set -x
set -e
set -o pipefail

# sleep interval (seconds)
sleep_interval=1
# extend_timeout_interval second(s)
extend_timeout_interval=1
# number of sleep_intervals before READY=1
start_intervals=10
# number of sleep_intervals before exiting
stop_intervals=10
# run intervals, number of sleep_intervals to run
run_intervals=7
# service name
SERVICE=unknown

while [ $# -gt 0 ];
do
    eval ${1%=*}=${1#*=}
    shift
done

# We convert to usec
extend_timeout_interval=$(( $extend_timeout_interval * 1000000 ))

trap "{ touch /${SERVICE}.terminated; exit 1; }"  SIGTERM SIGABRT

rm -f /${SERVICE}.*
touch /${SERVICE}.startfail

systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
while [ $start_intervals -gt 0 ]
do
    sleep $sleep_interval
    start_intervals=$(( $start_intervals - 1 ))
    systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
done

systemd-notify --ready --status="Waiting for your request"

touch /${SERVICE}.runtimefail
rm /${SERVICE}.startfail

systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
while [ $run_intervals -gt 0 ]
do
    sleep $sleep_interval
    run_intervals=$(( $run_intervals - 1 ))
    systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
done

systemd-notify STOPPING=1

touch /${SERVICE}.stopfail
rm /${SERVICE}.runtimefail

systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
while [ $stop_intervals -gt 0 ]
do
    sleep $sleep_interval
    stop_intervals=$(( $stop_intervals - 1 ))
    systemd-notify EXTEND_TIMEOUT_USEC=$extend_timeout_interval
done

touch /${SERVICE}.success
rm /${SERVICE}.stopfail

exit 0