forked from pducharme/UniFi-Video-Controller
-
Notifications
You must be signed in to change notification settings - Fork 0
/
run.sh
163 lines (137 loc) · 5.62 KB
/
run.sh
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
#!/bin/bash
# Start up w/ the right umask
echo "[info] UMASK defined as '${UMASK}'." | ts '%Y-%m-%d %H:%M:%.S'
umask "${UMASK}"
# Options fed into unifi-video script
unifi_video_opts=""
# Graceful shutdown, used by trapping SIGTERM
function graceful_shutdown {
echo -n "Stopping unifi-video... " | ts '%Y-%m-%d %H:%M:%.S'
if /usr/sbin/unifi-video --nodetach stop; then
echo "done."
exit 0
else
echo "failed."
exit 1
fi
}
# Trap SIGTERM for graceful exit
trap graceful_shutdown SIGTERM
# Change user nobody's UID to custom or match unRAID.
echo "[info] PUID defined as '${PUID}'" | ts '%Y-%m-%d %H:%M:%.S'
# Set user unify-video to specified user id (non unique)
usermod -o -u "${PUID}" unifi-video &>/dev/null
# Change group users to GID to custom or match unRAID.
echo "[info] PGID defined as '${PGID}'" | ts '%Y-%m-%d %H:%M:%.S'
# Set group users to specified group id (non unique)
groupmod -o -g "${PGID}" unifi-video &>/dev/null
# Create logs directory
mkdir -p /var/lib/unifi-video/logs
# check for presence of perms file, if it exists then skip setting
# permissions, otherwise recursively set on volume mappings for host
if [[ ! -f "/var/lib/unifi-video/perms.txt" ]]; then
echo "[info] No perms.txt found, setting ownership and permissions recursively on videos." | ts '%Y-%m-%d %H:%M:%.S'
volumes=( "/var/lib/unifi-video" )
# Set user and group ownership of volumes.
if ! chown -R "${PUID}":"${PGID}" "${volumes[@]}"; then
echo "[warn] Unable to chown ${volumes[*]}." | ts '%Y-%m-%d %H:%M:%.S'
fi
# Check for umask 002, set permissions to 775 folders and 664 files.
if [[ "${UMASK}" -eq 002 ]]; then
if ! chmod -R a=,a+rX,u+w,g+w "${volumes[@]}"; then
echo "[warn] Unable to chmod ${volumes[*]}." | ts '%Y-%m-%d %H:%M:%.S'
fi
fi
# Check for umask 022, set permissions to 755 folders and 644 files.
if [[ "${UMASK}" -eq 022 ]]; then
if ! chmod -R a=,a+rX,u+w "${volumes[@]}"; then
echo "[warn] Unable to chmod ${volumes[*]}." | ts '%Y-%m-%d %H:%M:%.S'
fi
fi
# Warn when neither umask 002 or 022 is set.
if [[ "${UMASK}" -ne 002 ]] && [[ "${UMASK}" -ne 022 ]]; then
echo "[warn] Umask not set to 002 or 022, skipping chmod." | ts '%Y-%m-%d %H:%M:%.S'
fi
echo "This file prevents permissions from being applied/re-applied to /config, if you want to reset permissions then please delete this file and restart the container." > /var/lib/unifi-video/perms.txt
else
echo "[info] File perms.txt blocks chown/chmod of videos." | ts '%Y-%m-%d %H:%M:%.S'
fi
# No debug mode set via env, default to off
if [[ -z ${DEBUG} ]]; then
DEBUG=0
fi
# Run with --debug if DEBUG=1
if [[ ${DEBUG} -eq 1 ]]; then
echo "[debug] Running unifi-video service with --debug." | ts '%Y-%m-%d %H:%M:%.S'
unifi_video_opts="--debug --verbose"
fi
# Run the unifi-video daemon the unifi-video way
echo -n "Starting unifi-video... " | ts '%Y-%m-%d %H:%M:%.S'
if /usr/sbin/unifi-video "${unifi_video_opts}" start; then
echo "done."
else
echo "failed."
exit 1
fi
# Wait for mongodb to come online.
echo -n "Waiting for mongodb to come online..." | ts '%Y-%m-%d %H:%M:%.S'
while ! mongo --quiet localhost:7441 --eval "{ ping: 1}" > /dev/null 2>&1; do
sleep 2
echo -n "."
done
echo " done."
# Get the current featureCompatibilityVersion
MONGO_FEATURE_COMPATIBILITY_VERSION=$( mongo --quiet --eval "db.adminCommand( { getParameter: 1, featureCompatibilityVersion: 1 } )" localhost:7441 | jq -r .featureCompatibilityVersion.version )
# Update db to 3.4 features
if mongo --version 2>&1 | grep -q "v3.4"; then
if [[ "${MONGO_FEATURE_COMPATIBILITY_VERSION}" != "3.4" ]]; then
echo -n "Found FeatureCompatibilityVersion ${MONGO_FEATURE_COMPATIBILITY_VERSION}, setting to 3.4..." | ts '%Y-%m-%d %H:%M:%.S'
if mongo --quiet --eval 'db.adminCommand( { setFeatureCompatibilityVersion: "3.4" } )' localhost:7441 > /dev/null 2>&1; then
echo " done."
else
echo " failed."
fi
fi
fi
# Update db to 3.6 features
if mongo --version 2>&1 | grep -q "v3.6"; then
if [[ "${MONGO_FEATURE_COMPATIBILITY_VERSION}" != "3.6" ]]; then
echo -n "Found FeatureCompatibilityVersion ${MONGO_FEATURE_COMPATIBILITY_VERSION}, setting to 3.6..." | ts '%Y-%m-%d %H:%M:%.S'
if mongo --quiet --eval 'db.adminCommand( { setFeatureCompatibilityVersion: "3.6" } )' localhost:7441 > /dev/null 2>&1; then
echo " done."
else
echo " failed."
fi
fi
fi
# Update db to 4.0 features
if mongo --version 2>&1 | grep -q "v4.0"; then
if [[ "${MONGO_FEATURE_COMPATIBILITY_VERSION}" != "4.0" ]]; then
echo -n "Found FeatureCompatibilityVersion ${MONGO_FEATURE_COMPATIBILITY_VERSION}, setting to 4.0..." | ts '%Y-%m-%d %H:%M:%.S'
if mongo --quiet --eval 'db.adminCommand( { setFeatureCompatibilityVersion: "4.0" } )' localhost:7441 > /dev/null 2>&1; then
echo " done."
else
echo " failed."
fi
fi
fi
# Loop while we wait for shutdown trap
while true; do
# When --tmpfs is used, container restarts cause these folders to go missing.
# See issue #178 for details.
if [[ ! -d /var/cache/unifi-video/exports ]]; then
echo -n "Re-creating and setting ownership/permissions on /var/cache/unifi-video/exports... "
mkdir -p /var/cache/unifi-video/exports
chown unifi-video:unifi-video /var/cache/unifi-video/exports
chmod 700 /var/cache/unifi-video/exports
echo "done."
fi
if [[ ! -d /var/cache/unifi-video/hls ]]; then
echo -n "Re-creating and setting ownership/permissions on /var/cache/unifi-video/hls... "
mkdir -p /var/cache/unifi-video/hls
chown unifi-video:unifi-video /var/cache/unifi-video/hls
chmod 775 /var/cache/unifi-video/hls
echo "done."
fi
sleep 5
done