wz_user.sh 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567
  1. #!/bin/sh
  2. LOG_NAME=/opt/wz_mini/log/wz_user
  3. if [[ -e $LOG_NAME.log || -L $LOG_NAME.log ]] ; then
  4. i=0
  5. while [[ -e $LOG_NAME.log.$i || -L $LOG_NAME.log.$i ]] ; do
  6. let i++
  7. done
  8. mv $LOG_NAME.log $LOG_NAME.log.$i
  9. LOG_NAME=$LOG_NAME
  10. fi
  11. touch -- "$LOG_NAME".log
  12. exec 1> $LOG_NAME.log 2>&1
  13. set -x
  14. echo "welcome to wz_user.sh"
  15. echo "PID $$"
  16. if [[ -e /tmp/dbgflag ]];then
  17. echo "debug mode, disabled"
  18. exit 0
  19. fi
  20. export WZMINI_CFG=/opt/wz_mini/wz_mini.conf
  21. [ -f $WZMINI_CFG ] && source $WZMINI_CFG
  22. hostname_set() {
  23. echo "set hostname"
  24. hostname $HOSTNAME
  25. }
  26. first_run_check() {
  27. if [[ -e /opt/wz_mini/tmp/.wz_user_firstrun ]]; then
  28. echo "wz_user.sh already run once, exit."
  29. exit 0
  30. fi
  31. }
  32. store_mac() {
  33. echo "store original mac"
  34. cat /sys/class/net/wlan0/address | tr '[:lower:]' '[:upper:]' > /opt/wz_mini/tmp/wlan0_mac
  35. }
  36. wait_wlan() {
  37. ##Check if the driver has been loaded for the onboard wlan0, store the MAC.
  38. while true
  39. do
  40. if ifconfig wlan0 | grep "inet addr";
  41. then
  42. store_mac
  43. break
  44. elif [[ "$ENABLE_USB_ETH" == "true" || "$ENABLE_USB_DIRECT" == "true" ]]; then
  45. store_mac
  46. break
  47. fi
  48. echo " wlan0 not ready yet..."
  49. sleep 5
  50. done
  51. }
  52. rename_interface() {
  53. ##Fool iCamera by renaming the hardline interface to wlan0
  54. echo "renaming interfaces"
  55. ifconfig $1 down
  56. ifconfig wlan0 down
  57. /opt/wz_mini/bin/busybox ip link set wlan0 name wlanold
  58. /opt/wz_mini/bin/busybox ip addr flush dev wlanold
  59. /opt/wz_mini/bin/busybox ip link set $1 name wlan0
  60. eth_wlan_up
  61. }
  62. eth_wlan_up() {
  63. ##Run DHCP client, and bind mount our fake wpa_cli.sh to fool iCamera
  64. ifconfig wlan0 up
  65. pkill udhcpc
  66. udhcpc -i wlan0 -x hostname:$HOSTNAME -p /var/run/udhcpc.pid -b
  67. if [[ "$V2" == "true" ]]; then
  68. mount -o bind /opt/wz_mini/bin/wpa_cli.sh /system/bin/wpa_cli
  69. else
  70. mount -o bind /opt/wz_mini/bin/wpa_cli.sh /bin/wpa_cli
  71. fi
  72. break
  73. }
  74. wpa_check() {
  75. #Check if wpa_supplicant has been created by iCamera
  76. if [[ -e /tmp/wpa_supplicant.conf ]]; then
  77. echo "wpa_supplicant.conf ready"
  78. wlanold_check $1
  79. else
  80. echo "wpa_supplicant.conf not ready, wait some time for creation."
  81. COUNT=0
  82. ATTEMPTS=15
  83. until [[ -e /tmp/wpa_supplicant.conf ]] || [[ $COUNT -eq $ATTEMPTS ]]; do
  84. echo -e "$(( COUNT++ ))... \c"
  85. sleep 5
  86. done
  87. [[ $COUNT -eq $ATTEMPTS ]] && echo "time exceeded waiting for iCamera, continue potentially broken condition without network." && wlanold_check $1
  88. fi
  89. }
  90. wlanold_check() {
  91. #Have we renamed interfaces yet?
  92. if [[ -d /sys/class/net/wlanold ]]; then
  93. echo "wlanold exist"
  94. eth_wlan_up
  95. else
  96. echo "wlanold doesn't exist"
  97. rename_interface $1
  98. fi
  99. }
  100. netloop() {
  101. ##While loop for check
  102. while true
  103. do
  104. wpa_check $1
  105. echo "wlan0 not ready yet..."
  106. sleep 5
  107. done
  108. }
  109. swap_enable() {
  110. if [[ -e /opt/wz_mini/swap ]]; then
  111. echo "Swap exists, enable"
  112. swapon /opt/wz_mini/swap
  113. else
  114. echo "Swap file missing!"
  115. fi
  116. }
  117. dmesg_log() {
  118. DMESG_LOG=/opt/wz_mini/log/dmesg
  119. if [[ -e $DMESG_LOG.log || -L $DMESG_LOG.log ]] ; then
  120. i=0
  121. while [[ -e $DMESG_LOG.log.$i || -L $DMESG_LOG.log.$i ]] ; do
  122. let i++
  123. done
  124. mv $DMESG_LOG.log $DMESG_LOG.log.$i
  125. DMESG_LOG=$DMESG_LOG
  126. fi
  127. touch -- "$DMESG_LOG".log
  128. dmesg > $DMESG_LOG.log 2>&1
  129. }
  130. trim_logs() {
  131. echo "Deleting logs older than 5 boots..."
  132. find /opt/wz_mini/log -name '*log*' | while read file; do
  133. [ "${file#/opt/wz_mini/log/*log.}" -gt 5 ] && rm -v "$file"
  134. done
  135. }
  136. first_run_check
  137. wait_wlan
  138. if cat /params/config/.product_config | grep WYZEC1-JZ; then
  139. V2="true"
  140. KMOD_PATH="/opt/wz_mini/lib/modules/3.10.14_v2"
  141. else
  142. V2="false"
  143. KMOD_PATH="/opt/wz_mini/lib/modules/3.10.14__isvp_swan_1.0__"
  144. fi
  145. if [[ "$ENABLE_SWAP" == "true" ]]; then
  146. if cat /proc/swaps | grep "mini" ; then
  147. echo "Swap is already enabled"
  148. else
  149. echo "Swap not enabled, enabling"
  150. swap_enable
  151. fi
  152. fi
  153. if [[ "$ENABLE_IPV6" == "true" ]]; then
  154. echo "ipv6 enabled"
  155. else
  156. echo "ipv6 disabled"
  157. sysctl -w net.ipv6.conf.all.disable_ipv6=1
  158. fi
  159. if [[ "$ENABLE_NFSv4" == "true" ]]; then
  160. insmod $KMOD_PATH/kernel/lib/oid_registry.ko
  161. insmod $KMOD_PATH/kernel/net/dns_resolver/dns_resolver.ko
  162. insmod $KMOD_PATH/kernel/fs/nfs/nfsv4.ko
  163. insmod $KMOD_PATH/kernel/net/sunrpc/auth_gss/auth_rpcgss.ko
  164. echo nfsv4 enabled
  165. else
  166. echo nfsv4 disabled
  167. fi
  168. if [[ "$ENABLE_IPTABLES" == "true" ]]; then
  169. if [[ "$V2" == "true" ]]; then
  170. echo "v2 has iptables built in"
  171. else
  172. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/netfilter/x_tables.ko
  173. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/ip_tables.ko
  174. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/ipt_REJECT.ko
  175. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/iptable_filter.ko
  176. insmod /lib/modules/3.10.14__isvp_swan_1.0__/kernel/net/ipv4/netfilter/iptable_mangle.ko
  177. echo "iptables ipv4 enabled"
  178. fi
  179. if [[ "$ENABLE_IPV6" == "true" ]]; then
  180. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6_tables.ko
  181. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6t_REJECT.ko
  182. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6table_filter.ko
  183. insmod $KMOD_PATH/kernel/net/ipv6/netfilter/ip6table_mangle.ko
  184. echo "iptables ipv6 enabled"
  185. fi
  186. else
  187. echo "iptables disabled"
  188. fi
  189. if [[ "$ENABLE_USB_ETH" == "true" ]]; then
  190. insmod $KMOD_PATH/kernel/drivers/net/usb/usbnet.ko
  191. for i in $(echo $ENABLE_USB_ETH_MODULES | tr "," "\n")
  192. do
  193. insmod $KMOD_PATH/kernel/drivers/net/usb/$i.ko
  194. done
  195. if [[ "$ENABLE_SWAP" == "true" ]]; then
  196. echo "swap already enabled"
  197. else
  198. swap_enable
  199. fi
  200. netloop eth0
  201. else
  202. echo "usb ethernet disabled"
  203. fi
  204. if [[ "$ENABLE_USB_DIRECT" == "true" ]]; then
  205. host_macaddr=$(echo $HOSTNAME|md5sum|sed 's/^\(..\)\(..\)\(..\)\(..\)\(..\).*$/02:\1:\2:\3:\4:\5/')
  206. if [[ "$V2" == "true" ]]; then
  207. echo connect > /sys/devices/platform/jz-dwc2/dwc2/udc/dwc2/soft_connect
  208. sleep 1
  209. devmem 0x10000040 32 0x0b800096
  210. sleep 1
  211. devmem 0x13500000 32 0x001100cc
  212. else
  213. #Set dwc2 ID_PIN driver memory
  214. devmem 0x13500000 32 0x001100cc
  215. devmem 0x10000040 32 0x0b000096
  216. #wipe the bits to set the ID_PIN, only for the V3.
  217. devmem 0x10000040 32 0x0b000FFF
  218. fi
  219. insmod $KMOD_PATH/kernel/drivers/usb/gadget/libcomposite.ko
  220. if [[ "$V2" == "false" ]]; then
  221. insmod /opt/wz_mini/lib/modules/3.10.14__isvp_swan_1.0__/kernel/drivers/usb/gadget/u_ether.ko
  222. insmod /opt/wz_mini/lib/modules/3.10.14__isvp_swan_1.0__/kernel/drivers/usb/gadget/usb_f_ncm.ko
  223. fi
  224. insmod $KMOD_PATH/kernel/drivers/usb/gadget/g_ncm.ko iManufacturer=wz_mini_ncm host_addr=$host_macaddr dev_addr=$USB_DIRECT_MAC_ADDR
  225. sleep 1
  226. if [[ "$ENABLE_SWAP" == "true" ]]; then
  227. echo "swap already enabled"
  228. else
  229. swap_enable
  230. fi
  231. #loop begin
  232. while true
  233. do
  234. wpa_check usb0
  235. echo "wlan0 not ready yet..."
  236. sleep 1
  237. done
  238. else
  239. echo "usb direct disabled"
  240. fi
  241. if [[ "$ENABLE_USB_RNDIS" == "true" ]]; then
  242. insmod $KMOD_PATH/kernel/drivers/net/usb/usbnet.ko
  243. insmod $KMOD_PATH/kernel/drivers/net/usb/cdc_ether.ko
  244. insmod $KMOD_PATH/kernel/drivers/net/usb/rndis_host.ko
  245. sleep 1
  246. if [[ "$ENABLE_SWAP" == "true" ]]; then
  247. echo "swap already enabled"
  248. else
  249. swap_enable
  250. fi
  251. #loop begin
  252. while true
  253. do
  254. wpa_check usb0
  255. echo "wlan0 not ready yet..."
  256. sleep 1
  257. done
  258. else
  259. echo "usb direct disabled"
  260. fi
  261. if [[ "$ENABLE_WIREGUARD" == "true" ]]; then
  262. insmod $KMOD_PATH/kernel/net/ipv4/tunnel4.ko
  263. insmod $KMOD_PATH/kernel/net/ipv4/ip_tunnel.ko
  264. insmod $KMOD_PATH/kernel/net/wireguard/wireguard.ko
  265. if [[ "$WIREGUARD_IPV4" != "" ]]; then
  266. if [ -d /opt/wz_mini/etc/wireguard ]; then
  267. echo "wireguard dir exists"
  268. else
  269. mkdir -p /opt/wz_mini/etc/wireguard
  270. fi
  271. if [ ! -f /opt/wz_mini/etc/wireguard/privatekey ]; then
  272. (umask 277 && /opt/wz_mini/bin/wg genkey | /opt/wz_mini/bin/busybox tee /opt/wz_mini/etc/wireguard/privatekey | /opt/wz_mini/bin/wg pubkey > /opt/wz_mini/etc/wireguard/publickey)
  273. fi
  274. /opt/wz_mini/bin/busybox ip link add dev wg0 type wireguard
  275. /opt/wz_mini/bin/busybox ip address add dev wg0 $WIREGUARD_IPV4
  276. /opt/wz_mini/bin/wg set wg0 private-key /opt/wz_mini/etc/wireguard/privatekey
  277. /opt/wz_mini/bin/busybox ip link set wg0 up
  278. fi
  279. if [[ "$WIREGUARD_PEER_PUBLIC_KEY" != "" ]] && [[ "$WIREGUARD_PEER_ALLOWED_IPS" != "" ]] && [[ "$WIREGUARD_PEER_ENDPOINT" != "" ]] && [[ "$WIREGUARD_PEER_KEEP_ALIVE" != "" ]]; then
  280. /opt/wz_mini/bin/wg set wg0 peer $WIREGUARD_PEER_PUBLIC_KEY allowed-ips $WIREGUARD_PEER_ALLOWED_IPS endpoint $WIREGUARD_PEER_ENDPOINT persistent-keepalive $WIREGUARD_PEER_KEEP_ALIVE
  281. /opt/wz_mini/bin/busybox ip route add $WIREGUARD_PEER_ALLOWED_IPS dev wg0
  282. fi
  283. else
  284. echo "wireguard disabled"
  285. fi
  286. if [[ "$ENABLE_CIFS" == "true" ]]; then
  287. insmod $KMOD_PATH/kernel/fs/cifs/cifs.ko
  288. else
  289. echo "cifs disabled"
  290. fi
  291. if [[ "$ENABLE_USB_STORAGE" == "true" ]]; then
  292. insmod $KMOD_PATH/kernel/drivers/scsi/scsi_mod.ko
  293. insmod $KMOD_PATH/kernel/drivers/scsi/sd_mod.ko
  294. insmod $KMOD_PATH/kernel/drivers/usb/storage/usb-storage.ko
  295. else
  296. echo "usb_storage disabled"
  297. fi
  298. if [[ "$ENABLE_EXT4" == "true" ]]; then
  299. if [[ "$V2" == "true" ]]; then
  300. insmod $KMOD_PATH/kernel/lib/crc16.ko
  301. fi
  302. insmod $KMOD_PATH/kernel/fs/jbd2/jbd2.ko
  303. insmod $KMOD_PATH/kernel/fs/mbcache.ko
  304. insmod $KMOD_PATH/kernel/fs/ext4/ext4.ko
  305. else
  306. echo "ext4 disabled"
  307. fi
  308. if [[ "$DISABLE_FW_UPGRADE" == "true" ]]; then
  309. mkdir /tmp/Upgrade
  310. mount -t tmpfs -o size=1,nr_inodes=1 none /tmp/Upgrade
  311. echo -e "127.0.0.1 localhost \n127.0.0.1 wyze-upgrade-service.wyzecam.com" > /opt/wz_mini/tmp/.storage/hosts
  312. mount --bind /opt/wz_mini/tmp/.storage/hosts /etc/hosts
  313. else
  314. mkdir /tmp/Upgrade
  315. /opt/wz_mini/bin/busybox inotifyd /opt/wz_mini/usr/bin/watch_up.sh /tmp:n &
  316. fi
  317. if [[ "$REMOTE_SPOTLIGHT" == "true" ]]; then
  318. /opt/wz_mini/bin/socat pty,link=/dev/ttyUSB0,raw tcp:$REMOTE_SPOTLIGHT_HOST:9000 &
  319. echo "remote accessory enabled"
  320. else
  321. echo "remote accessory disabled"
  322. fi
  323. if [[ "$ENABLE_MP4_WRITE" == "true" ]]; then
  324. if [[ "$V2" == "true" ]]; then
  325. echo "mp4_write not supported on v2"
  326. else
  327. /opt/wz_mini/bin/cmd mp4write on
  328. echo "mp4_write enabled"
  329. fi
  330. else
  331. echo "mp4 write disabled"
  332. fi
  333. if [[ "$RTSP_HI_RES_ENABLED" == "true" ]]; then
  334. if [[ "$V2" == "true" ]]; then
  335. HI_VIDEO_DEV="/dev/video6"
  336. else
  337. HI_VIDEO_DEV="/dev/video1"
  338. fi
  339. if [[ "$ENABLE_SWAP" == "true" ]]; then
  340. echo "swap already enabled"
  341. else
  342. swap_enable
  343. fi
  344. if [[ "$RTSP_PASSWORD" = "" ]]; then
  345. RTSP_PASSWORD=$(cat /opt/wz_mini/tmp/wlan0_mac)
  346. fi
  347. /opt/wz_mini/bin/cmd video on
  348. if [[ "$RTSP_HI_RES_ENABLE_AUDIO" == "true" ]]; then
  349. /opt/wz_mini/bin/cmd audio on
  350. AUDIO_CH="-C 1"
  351. AUDIO_FMT="-a S16_LE"
  352. DEVICE1="$HI_VIDEO_DEV,hw:Loopback,0"
  353. else
  354. DEVICE1="$HI_VIDEO_DEV"
  355. echo "rtsp audio disabled"
  356. fi
  357. if [[ "$RTSP_HI_RES_ENC_PARAMETER" != "" ]]; then
  358. if [[ "$V2" == "true" ]]; then
  359. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:0:4:$RTSP_HI_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  360. else
  361. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:44:4:$RTSP_HI_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  362. fi
  363. fi
  364. if [[ "$RTSP_HI_RES_MAX_BITRATE" != "" ]]; then
  365. if [[ "$V2" == "true" ]]; then
  366. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:28:4:$RTSP_HI_RES_MAX_BITRATE" > /dev/null 2>&1 &
  367. else
  368. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:52:4:$RTSP_HI_RES_MAX_BITRATE" > /dev/null 2>&1 &
  369. fi
  370. fi
  371. if [[ "$RTSP_HI_RES_TARGET_BITRATE" != "" ]]; then
  372. if [[ "$V2" == "true" ]]; then
  373. echo "not supported on v2"
  374. else
  375. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:48:4:$RTSP_HI_RES_TARGET_BITRATE" > /dev/null 2>&1 &
  376. fi
  377. fi
  378. if [[ "$RTSP_HI_RES_FPS" != "" ]]; then
  379. if [[ "$V2" == "true" ]]; then
  380. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:8:4:$RTSP_HI_RES_FPS" > /dev/null 2>&1 &
  381. else
  382. watch -n30 -t "/system/bin/impdbg --enc_rc_s 0:80:4:$RTSP_HI_RES_FPS" > /dev/null 2>&1 &
  383. fi
  384. fi
  385. else
  386. echo "rtsp disabled"
  387. fi
  388. if [[ "$RTSP_LOW_RES_ENABLED" == "true" ]]; then
  389. if [[ "$V2" == "true" ]]; then
  390. LOW_VIDEO_DEV="/dev/video7"
  391. else
  392. LOW_VIDEO_DEV="/dev/video2"
  393. fi
  394. if [[ "$ENABLE_SWAP" == "true" ]]; then
  395. echo "swap already enabled"
  396. else
  397. swap_enable
  398. fi
  399. /opt/wz_mini/bin/cmd video on1
  400. if [[ "$RTSP_PASSWORD" = "" ]]; then
  401. RTSP_PASSWORD=$(cat /opt/wz_mini/tmp/wlan0_mac)
  402. fi
  403. if [[ "$RTSP_LOW_RES_ENABLE_AUDIO" == "true" ]]; then
  404. /opt/wz_mini/bin/cmd audio on1
  405. AUDIO_CH="-C 1"
  406. AUDIO_FMT="-a S16_LE"
  407. DEVICE2="$LOW_VIDEO_DEV,hw:Loopback,1"
  408. else
  409. DEVICE2="$LOW_VIDEO_DEV"
  410. echo "rtsp audio disabled"
  411. fi
  412. if [[ "$RTSP_LOW_RES_ENC_PARAMETER" != "" ]]; then
  413. if [[ "$V2" == "true" ]]; then
  414. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:0:4:$RTSP_LOW_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  415. else
  416. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:44:4:$RTSP_LOW_RES_ENC_PARAMETER" > /dev/null 2>&1 &
  417. fi
  418. fi
  419. if [[ "$RTSP_LOW_RES_MAX_BITRATE" != "" ]]; then
  420. if [[ "$V2" == "true" ]]; then
  421. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:28:4:$RTSP_LOW_RES_MAX_BITRATE" > /dev/null 2>&1 &
  422. else
  423. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:52:4:$RTSP_LOW_RES_MAX_BITRATE" > /dev/null 2>&1 &
  424. fi
  425. fi
  426. if [[ "$RTSP_LOW_RES_TARGET_BITRATE" != "" ]]; then
  427. if [[ "$V2" == "true" ]]; then
  428. echo "not supported on v2"
  429. else
  430. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:48:4:$RTSP_LOW_RES_TARGET_BITRATE" > /dev/null 2>&1 &
  431. fi
  432. fi
  433. if [[ "$RTSP_LOW_RES_FPS" != "" ]]; then
  434. if [[ "$V2" == "true" ]]; then
  435. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:8:4:$RTSP_LOW_RES_FPS" > /dev/null 2>&1 &
  436. else
  437. watch -n30 -t "/system/bin/impdbg --enc_rc_s 1:80:4:$RTSP_LOW_RES_FPS" > /dev/null 2>&1 &
  438. fi
  439. fi
  440. else
  441. echo "rtsp disabled"
  442. fi
  443. if [[ "$RTSP_LOW_RES_ENABLED" == "true" ]] || [[ "$RTSP_HI_RES_ENABLED" == "true" ]]; then
  444. echo "delay RTSP for iCamera"
  445. #This delay is required. Sometimes, if you start the rtsp server too soon, live view will break on the app.
  446. sleep 5
  447. LD_LIBRARY_PATH=/opt/wz_mini/lib /opt/wz_mini/bin/v4l2rtspserver $AUDIO_CH $AUDIO_FMT -U $RTSP_LOGIN:$RTSP_PASSWORD -P $RTSP_PORT $DEVICE1 $DEVICE2 &
  448. fi
  449. if ([[ "$RTSP_LOW_RES_ENABLED" == "true" ]] || [[ "$RTSP_HI_RES_ENABLED" == "true" ]]) && [[ "$RTMP_STREAM_ENABLED" == "true" ]] && ([[ "$RTSP_LOW_RES_ENABLE_AUDIO" == "true" ]] || [[ "$RTSP_HI_RES_ENABLE_AUDIO" == "true" ]]); then
  450. if [[ "$RTMP_STREAM_DISABLE_AUDIO" == "true" ]]; then
  451. RMTP_AUDIO="no_audio"
  452. fi
  453. echo "delay RTMP server"
  454. #Follow the delay from the RTSP server
  455. sleep 5
  456. /opt/wz_mini/bin/rtmp-stream.sh $RMTP_STREAM_SERVICE $RTMP_AUDIO
  457. fi
  458. hostname_set
  459. touch /opt/wz_mini/tmp/.wz_user_firstrun
  460. pkill -f dumpload #Kill dumpload so it won't waste cpu or ram gathering cores when something crashes
  461. sysctl -w kernel.core_pattern='|/bin/false'
  462. dmesg_log
  463. trim_logs
  464. sync;echo 3 > /proc/sys/vm/drop_caches
  465. if [ -f "$CUSTOM_SCRIPT_PATH" ]; then
  466. echo "starting custom script"
  467. $CUSTOM_SCRIPT_PATH &
  468. else
  469. echo "custom script not found"
  470. fi
  471. echo "wz_user.sh done" > /dev/kmsg