From: Bernhard Tittelbach Date: Wed, 4 Dec 2013 07:45:16 +0000 (+0000) Subject: zsh_mswitch X-Git-Url: https://git.realraum.at/?a=commitdiff_plain;h=da5a79fd167a2123c0e4b3d97f72539d4da9e76c;p=svn42.git zsh_mswitch --- diff --git a/raspberrypi_gpio_relay_licht/mswitch.cgi b/raspberrypi_gpio_relay_licht/mswitch.cgi index dbfc79a..adf1d19 100755 --- a/raspberrypi_gpio_relay_licht/mswitch.cgi +++ b/raspberrypi_gpio_relay_licht/mswitch.cgi @@ -1,16 +1,14 @@ -#!/bin/sh +#!/bin/zsh -VALID_ONOFF_IDS="4 17 18 21 22 23" +VALID_ONOFF_IDS=(4 17 18 21 22 23) GPIOPATH=/sys/class/gpio/gpio - +local -A GPIOS for QUERY in `echo $QUERY_STRING | tr '&' ' '`; do for VALIDID in $VALID_ONOFF_IDS; do if [ "$QUERY" = "$VALIDID=1" ]; then - eval "GPIO_$VALIDID"=1 + GPIOS[$VALIDID]=1 elif [ "$QUERY" = "$VALIDID=0" ]; then - eval "GPIO_$VALIDID=0" - elif [ "$QUERY" = "$VALIDID=q" ]; then - eval "GPIO_$VALIDID=q" + GPIOS[$VALIDID]=0 fi done if [ "$QUERY" = "mobile=1" ]; then @@ -24,7 +22,7 @@ done print_gpio_state() { GPIOVALUE=$(cat "${GPIOPATH}${1}/value") - if [ "$GPIOVALUE" = "0" ]; then + if [[ $GPIOVALUE == "0" ]]; then echo -n "true" else echo -n "false" @@ -39,24 +37,17 @@ gpio_is_on() { echo "Content-type: text/html" echo "" -echo "{" +local -a GPIOSTATES for CHECKID in $VALID_ONOFF_IDS; do - VAL="" - VAL="$(eval echo \$GPIO_$CHECKID)" - [ -z $VAL ] && continue - if [ $VAL = 1 -o $VAL = 0 ]; then - [ $VAL = 1 ] && VAL=0 || VAL=1 + VAL=$GPIOS[$CHECKID] + if [[ $VAL == 1 || $VAL == 0 ]]; then + [[ $VAL == 1 ]] && VAL=0 || VAL=1 echo "$VAL" > "${GPIOPATH}${CHECKID}/value" fi - echo -n "\"$CHECKID\":" - print_gpio_state $CHECKID - echo "," + GPIOSTATES+=(\"${CHECKID}\":"$(print_gpio_state $CHECKID)") done -echo "\"-1\":false}" -# echo "" -# echo "" -# echo "Realraum Relay Switch" -# echo '' -# echo "" -# exit 0 - +JSON_STATE="{${(j:,:)GPIOSTATES}}" +print ${(q)JSON_STATE} +if ((#GPIOS > 0)); then + print "[$(date +%s),\"$REMOTE_ADDR\",${(q)JSON_STATE}]," >> /var/log/licht/mswitch.log +fi