wz_user.sh 13 KB

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