wz_user.sh 16 KB

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