mirror of
https://github.com/gtxaspec/wz_mini_hacks.git
synced 2025-01-10 14:47:01 +00:00
Merge pull request #188 from virmaior/master
Rudimentary webserver over httpd
This commit is contained in:
commit
63f2442d6c
@ -593,6 +593,10 @@ if [[ "$NIGHT_DROP_DISABLE" == "true" ]]; then
|
|||||||
touch /opt/wz_mini/tmp/.nd
|
touch /opt/wz_mini/tmp/.nd
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [[ "$WEB_SERVER_ENABLED" == "true" ]]; then
|
||||||
|
httpd -p 80 -h /opt/wz_mini/www
|
||||||
|
fi
|
||||||
|
|
||||||
hostname_set
|
hostname_set
|
||||||
touch /opt/wz_mini/tmp/.wz_user_firstrun
|
touch /opt/wz_mini/tmp/.wz_user_firstrun
|
||||||
pkill -f dumpload #Kill dumpload so it won't waste cpu or ram gathering cores and uploading them when something crashes
|
pkill -f dumpload #Kill dumpload so it won't waste cpu or ram gathering cores and uploading them when something crashes
|
||||||
|
@ -93,11 +93,15 @@ DISABLE_MOTOR="false"
|
|||||||
ENABLE_FSCK_ON_BOOT="false"
|
ENABLE_FSCK_ON_BOOT="false"
|
||||||
ENABLE_CAR_DRIVER="false"
|
ENABLE_CAR_DRIVER="false"
|
||||||
|
|
||||||
|
#####WEB#####
|
||||||
|
WEB_SERVER_ENABLED="false"
|
||||||
|
|
||||||
#####DEBUG#####
|
#####DEBUG#####
|
||||||
#drops you to a shell via serial, doesn't load app_init.sh
|
#drops you to a shell via serial, doesn't load app_init.sh
|
||||||
DEBUG_ENABLED="false"
|
DEBUG_ENABLED="false"
|
||||||
DEBUG_INITRAMFS_ENABLED="false"
|
DEBUG_INITRAMFS_ENABLED="false"
|
||||||
DEBUG_PASSWORD="false"
|
DEBUG_PASSWORD="false"
|
||||||
|
|
||||||
|
|
||||||
#####SCRIPTING#####
|
#####SCRIPTING#####
|
||||||
CUSTOM_SCRIPT_PATH=""
|
CUSTOM_SCRIPT_PATH=""
|
||||||
|
4
SD_ROOT/wz_mini/www/cgi-bin/DISABLE_FW_UPGRADE.md
Normal file
4
SD_ROOT/wz_mini/www/cgi-bin/DISABLE_FW_UPGRADE.md
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
If a remote or app update is initiated, the camera will reboot due to the failure of the update. The firmware update should not proceed again for some time, or at all.
|
||||||
|
|
||||||
|
When a firmware update is initiated, due to a bootloader issue (bug?), we intercept the update process and flash it manually. This should now result in a successful update, if it doesn't, please restore the unit's firmware manually using demo_wcv3.bin on the micro sd card.
|
||||||
|
|
13
SD_ROOT/wz_mini/www/cgi-bin/ENABLE_USB_ETH.md
Normal file
13
SD_ROOT/wz_mini/www/cgi-bin/ENABLE_USB_ETH.md
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
USB Ethernet Adapter support:
|
||||||
|
|
||||||
|
ENABLE_USB_ETH="true"
|
||||||
|
ENABLE_USB_ETH_MODULE_AUTODETECT="true"
|
||||||
|
ENABLE_USB_ETH_MODULE_MANUAL=""
|
||||||
|
To have the Ethernet NIC be auto-detected and loaded automatically, set the ENABLE_USB_ETH_MODULE_AUTODETECT value to true.
|
||||||
|
|
||||||
|
To load a specific USB Ethernet NIC driver, set ENABLE_USB_ETH_MODULE_MANUAL to one of the following: asix, ax88179_178a, cdc_ether, r8152
|
||||||
|
|
||||||
|
NOTE: There is a possibility of a conflict between Ethernet NIC adapters that report themselves as PCI ID '0bda:8152'. (Realtek 8152 and CDC Ethernet) Since the 8152 is Realtek's product, that driver will be the one used for products that report that PCI ID. If you happen to have a CDC Ethernet product that uses that specific PCI ID, please set the ENABLE_USB_ETH_MODULE_AUTODETECT option to false, and set ENABLE_USB_ETH_MODULE_MANUAL to "cdc_ether"
|
||||||
|
|
||||||
|
The next time you boot your camera, make sure your USB Ethernet Adapter is connected to the camera and ethernet. The camera has to be setup initially with Wi-Fi for this to work. After setup, Wi-Fi is no longer needed, as long as you are using the USB Ethernet Adapter. Note that using USB Ethernet disables the onboard Wi-Fi.
|
||||||
|
|
19
SD_ROOT/wz_mini/www/cgi-bin/ENABLE_WIREGUARD.md
Normal file
19
SD_ROOT/wz_mini/www/cgi-bin/ENABLE_WIREGUARD.md
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
Wireguard support is available as a kernel module:
|
||||||
|
|
||||||
|
ENABLE_WIREGUARD="true"
|
||||||
|
Use the command wg to setup. See https://www.wireguard.com/quickstart/ for more info.
|
||||||
|
|
||||||
|
Some users have asked about tailscale support, I have tested and it works. See the issue #30 for further information.
|
||||||
|
|
||||||
|
Example setup:
|
||||||
|
|
||||||
|
ENABLE_WIREGUARD="true"
|
||||||
|
WIREGUARD_IPV4="192.168.2.101/32"
|
||||||
|
WIREGUARD_PEER_ENDPOINT="x.x.x.x:51820"
|
||||||
|
WIREGUARD_PEER_PUBLIC_KEY="INSERT_PEER_PUBLIC_KEY_HERE"
|
||||||
|
WIREGUARD_PEER_ALLOWED_IPS="192.168.2.0/24"
|
||||||
|
WIREGUARD_PEER_KEEP_ALIVE="25"
|
||||||
|
To retrieve the public key that you'll need to add the peer to your wireguard endpoint:
|
||||||
|
|
||||||
|
Use SSH to log in
|
||||||
|
wg
|
157
SD_ROOT/wz_mini/www/cgi-bin/index.cgi
Normal file
157
SD_ROOT/wz_mini/www/cgi-bin/index.cgi
Normal file
@ -0,0 +1,157 @@
|
|||||||
|
#we!/bin/sh
|
||||||
|
# This serves a rudimentary webpage based on wz_mini.conf
|
||||||
|
base_dir=/opt/wz_mini/
|
||||||
|
hack_ini=/opt/wz_mini/wz_mini.conf
|
||||||
|
www_dir=/opt/wz_mini/www/cgi-bin/
|
||||||
|
camver=V3
|
||||||
|
camfirmware=$(tail -n1 /configs/app.ver | cut -f2 -d= )
|
||||||
|
hackver=$(cat /opt/wz_mini/usr/bin/app.ver)
|
||||||
|
hostname=$(uname -n)
|
||||||
|
title="Wyze $camver on $camfirmware running wz_mini $hackver as $hostname"
|
||||||
|
|
||||||
|
echo "HTTP/1.1 200"
|
||||||
|
echo -e "Content-type: text/html\n\n"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
|
||||||
|
shft() {
|
||||||
|
cd $base_dir
|
||||||
|
# https://stackoverflow.com/questions/3690936/change-file-name-suffixes-using-sed/3691279#3691279
|
||||||
|
# Change this '8' to one less than your desired maximum rollover file.
|
||||||
|
# Must be in reverse order for renames to work (n..1, not 1..n).
|
||||||
|
for suff in {8..1} ; do
|
||||||
|
if [[ -f "$1.${suff}" ]] ; then
|
||||||
|
((nxt = suff + 1))
|
||||||
|
mv -f "$1.${suff}" "$1.${nxt}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
mv -f "$1" "$1.1"
|
||||||
|
}
|
||||||
|
|
||||||
|
#test for post
|
||||||
|
if [[ $REQUEST_METHOD = 'POST' ]]; then
|
||||||
|
if [ "$CONTENT_LENGTH" -gt 0 ]; then
|
||||||
|
read -n $CONTENT_LENGTH POST_DATA <&0
|
||||||
|
while read line
|
||||||
|
do eval "echo ${line}"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
#since ash does not handle arrays we create variables using eval
|
||||||
|
IFS='&'
|
||||||
|
for PAIR in $POST_DATA
|
||||||
|
do
|
||||||
|
K=$(echo $PAIR | cut -f1 -d=)
|
||||||
|
VA=$(echo $PAIR | cut -f2 -d=)
|
||||||
|
VB=\"${VA//%3A/:}\"
|
||||||
|
#echo "<div>$K=$VB</div>"
|
||||||
|
eval POST_$K=\"$VB\"
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
#switch back to going through the config file
|
||||||
|
IFS=$'\n'
|
||||||
|
output="$hack_ini.new"
|
||||||
|
|
||||||
|
#name our output file
|
||||||
|
for ARGUMENT in $(cat $hack_ini)
|
||||||
|
do
|
||||||
|
#cycle through each line of the current config
|
||||||
|
|
||||||
|
#copy through all comments
|
||||||
|
if [[ ${ARGUMENT:0:1} == "#" ]] ; then
|
||||||
|
#echo $ARGUMENT $'\n'
|
||||||
|
echo -ne $ARGUMENT"\n" >> $output
|
||||||
|
else
|
||||||
|
#for non-comments check to see if we have an entry in the POST data by deciphering the key from the ini file and using eval for our fake array
|
||||||
|
KEY=$(echo $ARGUMENT | cut -f1 -d=)
|
||||||
|
test=$(eval echo \$POST_$KEY)
|
||||||
|
#echo "key was $KEY test was ... $test <br /> "
|
||||||
|
if [[ "$test" ]]; then
|
||||||
|
#if in the fake array then we use the new value
|
||||||
|
#echo "<div style=\"color:#c00\">matched </div>"
|
||||||
|
echo -ne $KEY=\"$test\""\n" >> $output
|
||||||
|
else
|
||||||
|
#if not in the fake array we use the current value
|
||||||
|
#echo "<div>key not found</div>"
|
||||||
|
echo -ne $ARGUMENT"\n" >> $output
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
shft $hack_ini
|
||||||
|
mv $output $hack_ini
|
||||||
|
echo "rebooting! wait a bit -- and go the same url"
|
||||||
|
reboot
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function documentation_to_html
|
||||||
|
{
|
||||||
|
if [[ -f "$www_dir$1.md" ]]; then
|
||||||
|
printf '<div class="ii_explain"><pre>'
|
||||||
|
cat $web_dir$1.md
|
||||||
|
printf '</pre></div>'
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function ini_to_html_free
|
||||||
|
{
|
||||||
|
printf '<div class="ii"><div class="ii_key_DIV">%s</div><div class="ii_value_DIV"><input class="ii_value" type="text" name="%s" value="%s" /></div>' $1 $1 $2
|
||||||
|
documentation_to_html $1
|
||||||
|
printf '</div>'
|
||||||
|
}
|
||||||
|
|
||||||
|
function ini_to_html_tf
|
||||||
|
{
|
||||||
|
printf '<div class="ii"><div class="ii_key_DIV">%s</div>' $1
|
||||||
|
printf '<div class="ii_value_DIV">'
|
||||||
|
if [[ "$2" == "true" ]]; then
|
||||||
|
printf '<input class="ii_radio" type="radio" name="%s" value="true" checked="checked" /> True ' $1
|
||||||
|
printf '<input class="ii_radio" type="radio" name="%s" value="false" /> False ' $1
|
||||||
|
else
|
||||||
|
printf '<input class="ii_radio" type="radio" name="%s" value="true" /> True ' $1
|
||||||
|
printf '<input class="ii_radio" type="radio" name="%s" value="false" checked="checked" /> False ' $1
|
||||||
|
|
||||||
|
fi
|
||||||
|
printf '</div>'
|
||||||
|
documentation_to_html $1
|
||||||
|
printf '</div>'
|
||||||
|
}
|
||||||
|
echo -ne "<html><head><title>$title</title>"
|
||||||
|
echo -ne "<style type=\"text/css\">"
|
||||||
|
cat wz_mini_web.css
|
||||||
|
echo -ne '</style>';
|
||||||
|
echo -ne "</head>"
|
||||||
|
|
||||||
|
|
||||||
|
echo -ne '<body>'
|
||||||
|
echo -ne "<h1>$title</h1>";
|
||||||
|
echo -ne '<form name="wz_mini_hack_FORM" method="POST" enctype="application/x-www-form-urlencoded" >'
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
for ARGUMENT in $(cat $hack_ini)
|
||||||
|
do
|
||||||
|
if [[ ${ARGUMENT:0:1} == "#" ]] ; then
|
||||||
|
echo -ne '<div class="ii_info">'$ARGUMENT'</div>'
|
||||||
|
else
|
||||||
|
KEY=$(echo $ARGUMENT | cut -f1 -d=)
|
||||||
|
VAL=$(echo $ARGUMENT | cut -f2 -d=)
|
||||||
|
VALUE=${VAL//\"/}
|
||||||
|
case "$VALUE" in
|
||||||
|
"true") ini_to_html_tf $KEY $VALUE ;;
|
||||||
|
"false") ini_to_html_tf $KEY $VALUE ;;
|
||||||
|
*) ini_to_html_free $KEY $VALUE
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo -ne '<input type="submit" name="update" value="Update" />'
|
||||||
|
echo -ne '</form>'
|
||||||
|
|
||||||
|
|
||||||
|
echo -ne '</body></html>'
|
26
SD_ROOT/wz_mini/www/cgi-bin/wz_mini_web.css
Normal file
26
SD_ROOT/wz_mini/www/cgi-bin/wz_mini_web.css
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
.ii_info {
|
||||||
|
font-weight:bold;
|
||||||
|
background-color:#ccc;
|
||||||
|
}
|
||||||
|
.ii {
|
||||||
|
width:100%;
|
||||||
|
position:relative;
|
||||||
|
display:flex;
|
||||||
|
}
|
||||||
|
.ii_key_DIV {
|
||||||
|
|
||||||
|
flex:0 0 30vw;
|
||||||
|
font-weight:bold;
|
||||||
|
}
|
||||||
|
.ii_value_DIV {
|
||||||
|
flex: 0 0 40vw;
|
||||||
|
text-align:right;
|
||||||
|
}
|
||||||
|
.ii_value {
|
||||||
|
width:75%;
|
||||||
|
}
|
||||||
|
.ii_explain {
|
||||||
|
width:29vw;
|
||||||
|
overflow:scroll;
|
||||||
|
max-height:140px;
|
||||||
|
}
|
@ -99,5 +99,8 @@ DEBUG_ENABLED="false"
|
|||||||
DEBUG_INITRAMFS_ENABLED="false"
|
DEBUG_INITRAMFS_ENABLED="false"
|
||||||
DEBUG_PASSWORD="false"
|
DEBUG_PASSWORD="false"
|
||||||
|
|
||||||
|
####WEB####
|
||||||
|
WEB_SERVER_ENABLED="true"
|
||||||
|
|
||||||
#####SCRIPTING#####
|
#####SCRIPTING#####
|
||||||
CUSTOM_SCRIPT_PATH=""
|
CUSTOM_SCRIPT_PATH=""
|
||||||
|
Loading…
Reference in New Issue
Block a user