3 for QUERY in `echo $QUERY_STRING | tr '&' ' '`; do
4 for VALUE in `echo $QUERY | tr '=' ' '`; do
5 if [ "$VALUE" = "id" ]; then
7 elif [ "$ID" = "?" ]; then
9 elif [ "$VALUE" = "power" ]; then
11 elif [ "$POWER" = "?" ]; then
13 elif [ "$VALUE" = "mobile" ]; then
16 elif [ "$VALUE" = "nofloat" ]; then
24 GPIOPATH=/sys/class/gpio/gpio
25 VALID_ONOFF_IDS="4 17 18 21 22 23"
29 GPIOVALUE=$(cat "${GPIOPATH}${1}/value")
30 if [ "$GPIOVALUE" = "0" ]; then
38 GPIOVALUE=$(cat "${GPIOPATH}${1}/value")
39 [ "$GPIOVALUE" = "0" ]
42 if [ "$POWER" = "1" -o "$POWER" = "0" ]; then
43 for CHECKID in $VALID_ONOFF_IDS ; do
44 if [ "$CHECKID" = "$ID" ]; then
45 [ $POWER = 1 ] && POWER=0 || POWER=1
46 echo "$POWER" > "${GPIOPATH}${ID}/value"
47 echo "Content-type: text/html"
51 echo "<title>Realraum Relay Switch</title>"
52 echo '<script type="text/javascript">window.location="/cgi-bin/switch.cgi";</script>'
59 DESC_23="Decke Links Leinwand"
60 DESC_4="Decke Rechts Leinwand"
61 DESC_18="Decke Eingang Mitte"
62 DESC_17="Decke Durchgang Mitte"
63 DESC_22="Decke Links Couch"
64 DESC_21="Decke Rechts Couch"
66 echo "Content-type: text/html"
70 echo "<title>Realraum Relay Power</title>"
71 echo '<script type="text/javascript">'
73 echo 'function callbackUpdateButtons(req) {
74 if (req.status != 200) {
77 var data = JSON.parse(req.responseText);
78 for (var keyid in data) {
79 on_btn = document.getElementById("onbtn_"+keyid);
80 off_btn = document.getElementById("offbtn_"+keyid);
81 if (on_btn && off_btn)
83 on_btn.className = "onbutton";
84 off_btn.className = "offbutton";
86 { on_btn.className += " enableborder"; }
88 { off_btn.className += " enableborder"; }
93 echo 'function updateButtons(uri) {
94 var req = new XMLHttpRequest;
95 req.overrideMimeType("application/json");
96 req.open("GET", uri, true);
97 req.onload = function() {callbackUpdateButtons(req)};
98 req.setRequestHeader("googlechromefix","");
102 echo 'function sendMultiButton( str ) {
103 url = "/cgi-bin/mswitch.cgi?"+str;
107 echo 'setInterval("updateButtons(\"/cgi-bin/mswitch.cgi\");", 30*1000);'
109 echo 'function sendButton( onoff, btn )'
111 echo ' var req = new XMLHttpRequest();'
112 echo ' url = "/cgi-bin/switch.cgi?power="+onoff+"&id="+btn;'
113 echo ' req.open("GET", url ,false);'
114 echo ' //google chrome workaround'
115 echo ' req.setRequestHeader("googlechromefix","");'
116 echo ' req.send(null);'
120 echo 'div.switchbox {'
123 #echo ' max-width:236px;'
124 echo ' max-width:300px;'
125 echo ' font-size:10pt;'
126 echo ' border:1px solid black;'
127 #echo ' height: 32px;'
131 echo 'div.switchnameleft {'
132 echo ' width:12em; display:inline-block; vertical-align:middle; margin-left:3px;'
135 echo 'span.alignbuttonsright {'
136 echo ' top:0px; float:right; display:inline-block; text-align:right; padding:0;'
139 echo 'div.switchnameright {'
140 echo ' width:12em; display:inline-block; vertical-align:middle; float:right; display:inline-block; margin-left:1ex; margin-right:3px; margin-top:3px; margin-bottom:3px;'
143 echo 'span.alignbuttonsleft {'
144 echo ' float:left; text-align:left; padding:0;'
148 echo ' font-size:11pt;'
150 echo ' height: 32px;'
151 echo ' background-color: lime;'
156 echo ' font-size:11pt;'
158 echo ' height: 32px;'
159 echo ' background-color: red;'
164 echo ' font-size:11pt;'
166 echo ' height: 32px;'
167 #echo ' background-color: grey;'
171 echo '.enableborder {
173 font-variant: small-caps;
174 border-style: inset;'
179 #echo "<h1>Realraum rf433ctl</h1>"
180 #echo "<div style=\"float:left; border:1px solid black;\">"
181 echo "<div style=\"float:left;\">"
182 echo "<div style=\"float:left; border:1px solid black; margin-right:2ex; margin-bottom:2ex;\">"
183 for DISPID in $VALID_ONOFF_IDS; do
184 NAME="$(eval echo -n \$DESC_$DISPID)"
185 [ -z "$NAME" ] && NAME=$DISPID
187 echo "<div class=\"switchbox\">"
188 echo "<span class=\"alignbuttonsleft\">"
189 if gpio_is_on $DISPID; then
190 echo " <button id=\"onbtn_$DISPID\" class=\"onbutton enableborder\" onClick='sendMultiButton(\"$DISPID=1\");'>On</button>"
191 echo " <button id=\"offbtn_$DISPID\" class=\"offbutton\" onClick='sendMultiButton(\"$DISPID=0\");'>Off</button>"
193 echo " <button id=\"onbtn_$DISPID\" class=\"onbutton\" onClick='sendMultiButton(\"$DISPID=1\");'>On</button>"
194 echo " <button id=\"offbtn_$DISPID\" class=\"offbutton enableborder\" onClick='sendMultiButton(\"$DISPID=0\");'>Off</button>"
197 echo -n "<div class=\"switchnameright\">$NAME</div>"
198 # echo -n "<div class=\"switchnameright\">$NAME ("
199 # print_gpio_state $DISPID
203 if [ "$NOFLOAT" = "1" ]; then
208 echo "<div class=\"switchbox\">"
209 echo "<span class=\"alignbuttonsleft\">"
210 echo -n " <button class=\"onbutton\" onClick='sendMultiButton(\""
211 for DISPID in $VALID_ONOFF_IDS; do echo -n "$DISPID=1&"; done
212 echo "\");'>On</button>"
213 echo -n " <button class=\"offbutton\" onClick='sendMultiButton(\""
214 for DISPID in $VALID_ONOFF_IDS; do echo -n "$DISPID=0&"; done
215 echo "\");'>Off</button>"
217 echo -n "<div class=\"switchnameright\">Alle</div>"
219 if [ "$NOFLOAT" = "1" ]; then
224 if [ "$MOBILE" != "1" -a -n "$VALID_SEND_IDS" ]; then
226 echo "<div style=\"float:left; border:1px solid black; margin-right:2ex; margin-bottom:2ex;\">"
230 for DISPID in $VALID_SEND_IDS; do
231 ITEMCOUNT=$((ITEMCOUNT+1))
232 NAME="$(eval echo \$DESC_$DISPID)"
233 [ -z "$NAME" ] && NAME=$DISPID
235 echo "<div class=\"switchbox\">"
236 echo "<span class=\"alignbuttonsleft\">"
237 echo " <button class=\"sendbutton\" onClick='sendButton(\"on\",\"$DISPID\");'> </button>"
239 echo "<div class=\"switchnameright\">$NAME</div>"
241 if [ "$NOFLOAT" = "1" -a $((ITEMCOUNT % 2 )) -ne 1 ]; then