tazpanel annotate network.cgi @ rev 495

network.cgi: add iptables status
author Pascal Bellard <pascal.bellard@slitaz.org>
date Wed May 13 15:36:42 2015 +0200 (2015-05-13)
parents 0d743f0c129e
children 470ab4241de5
rev   line source
pankso@38 1 #!/bin/sh
pankso@38 2 #
pankso@38 3 # Network configuration CGI interface
pankso@38 4 #
al@419 5 # Copyright (C) 2012-2015 SliTaz GNU/Linux - BSD License
pankso@112 6 #
pankso@38 7
al@419 8
pankso@38 9 # Common functions from libtazpanel
al@419 10
pankso@38 11 . lib/libtazpanel
pankso@38 12 get_config
pascal@81 13 header
pankso@38 14
al@443 15 TITLE=$(_ 'TazPanel - Network')
pankso@42 16
pascal@493 17 ip_forward=/proc/sys/net/ipv4/ip_forward
pankso@106 18
al@419 19 # Start a Wi-Fi connection
al@419 20
pankso@247 21 start_wifi() {
pankso@247 22 sed -i \
al@419 23 -e 's|^WIFI=.*|WIFI="yes"|' \
al@419 24 -e 's|^DHCP=.*|DHCP="yes"|' \
al@419 25 -e 's|^STATIC=.*|STATIC="no"|' /etc/network.conf
pankso@247 26 ifconfig $WIFI_INTERFACE up
pankso@247 27 iwconfig $WIFI_INTERFACE txpower auto
Christian@273 28 /etc/init.d/network.sh restart | log
al@463 29
al@463 30 # Sleep until connection established (max 5 seconds)
al@463 31 for i in $(seq 5); do
al@419 32 [ -n "$(iwconfig 2>/dev/null | fgrep Link)" ] && break
al@419 33 sleep 1
al@419 34 done
al@419 35 }
al@419 36
al@419 37
al@420 38 # Start an Ethernet connection
al@420 39
al@420 40 start_eth() {
al@420 41 case "$(GET staticip)" in
al@420 42 on) DHCP='no'; STATIC='yes';;
al@420 43 *) DHCP='yes'; STATIC='no';;
al@420 44 esac
al@420 45
al@420 46 /etc/init.d/network.sh stop | log
al@420 47 sleep 2
al@420 48 sed -i \
al@420 49 -e "s|^INTERFACE=.*|INTERFACE=\"$(GET iface)\"|" \
al@420 50 -e 's|^WIFI=.*|WIFI="no"|' \
al@420 51 -e "s|^DHCP=.*|DHCP=\"$DHCP\"|" \
al@420 52 -e "s|^STATIC=.*|STATIC=\"$STATIC\"|" \
al@420 53 -e "s|^IP=.*|IP=\"$(GET ip)\"|" \
al@420 54 -e "s|^NETMASK=.*|NETMASK=\"$(GET netmask)\"|" \
al@420 55 -e "s|^GATEWAY=.*|GATEWAY=\"$(GET gateway)\"|" \
al@420 56 -e "s|^DNS_SERVER=.*|DNS_SERVER=\"$(GET dns)\"|" \
al@420 57 /etc/network.conf
al@420 58 /etc/init.d/network.sh start | log
al@420 59 . /etc/network.conf
al@420 60 }
al@420 61
al@420 62
al@419 63 # Use /etc/wpa/wpa.conf as single database for known networks, passwords, etc.
al@419 64 # Translate this data to use in javascript.
al@419 65
al@419 66 parse_wpa_conf() {
al@419 67 awk '
al@419 68 BEGIN { print "networks = ["; begin_list = 1; network = 0; }
al@419 69 {
al@419 70 if ($0 == "network={") {
al@419 71 if (begin_list == 0) print ",";
al@419 72 begin_list = 0;
al@419 73 printf "{"; begin_obj = 1;
al@419 74 network = 1; next;
al@419 75 }
al@419 76 if (network == 1) {
al@419 77 if ($0 ~ "=") {
al@419 78 if (begin_obj == 0) printf ", ";
al@419 79 begin_obj = 0;
al@463 80
al@463 81 # split line into variable and value (note "=" can appear in the value)
al@463 82 split($0, a, "="); variable = a[1];
al@463 83 value = gensub(variable "=", "", "");
al@463 84
al@463 85 # escape html entities
al@463 86 value = gensub("\\\\", "\\\\", "g", value);
al@463 87 value = gensub("&", "\\&amp;", "g", value);
al@463 88 value = gensub("<", "\\&lt;", "g", value);
al@463 89 value = gensub(">", "\\&gt;", "g", value);
al@463 90 value = gensub("\"", "\\\"", "g", value);
al@463 91
al@463 92 # if value was already quoted - remove \" from begin and end
al@463 93 if (substr(value, 1, 2) == "\\\"")
al@463 94 value = substr(value, 3, length(value) - 4);
al@463 95
al@463 96 # output in form: variable:"escaped value"
al@463 97 printf "%s:\"%s\"", variable, value;
al@419 98 }
al@419 99 }
al@419 100 if (network == 1 && $0 ~ "}") { printf "}"; network = 0; next; }
al@419 101 }
al@419 102 END {print "\n];"}
al@419 103 ' /etc/wpa/wpa.conf | sed 's|\t||g;'
al@419 104 }
al@419 105
al@419 106
al@419 107 # Waiting for network link up
al@419 108
al@419 109 wait_up() {
al@463 110 for i in $(seq 5); do
al@419 111 [ -z "$(cat /sys/class/net/*/operstate | fgrep up)"] && sleep 1
al@419 112 done
pankso@247 113 }
pankso@247 114
pascal@485 115 select_if() {
pascal@485 116 echo '<select name="interface">'
pascal@485 117 for i in $(ls /sys/class/net); do
pascal@485 118 echo "<option>$i"
pascal@485 119 done
pascal@485 120 echo '</select>'
pascal@485 121 }
al@463 122
pankso@41 123 # Actions commands before page is displayed
al@419 124
pascal@81 125 case " $(GET) " in
pascal@81 126 *\ start\ *)
al@419 127 /etc/init.d/network.sh start | log
pankso@41 128 # Here we sleep a bit to let udhcp get the lease before reloading
paul@205 129 # the page with status
al@419 130 wait_up ;;
pascal@81 131 *\ stop\ *)
pankso@76 132 /etc/init.d/network.sh stop | log ;;
naitsirhc@269 133 *\ restart\ *)
al@419 134 /etc/init.d/network.sh restart | log
al@419 135 wait_up ;;
al@420 136 *\ start_wifi\ *)
al@419 137 start_wifi ;;
al@420 138 *\ start_eth\ *)
al@420 139 start_eth ;;
pascal@475 140 *\ dowakeup\ *)
pascal@475 141 mac="$(GET macwakup)"
pascal@475 142 unset pass
pascal@477 143 [ "$(GET macpass)" ] && pass="-p $(GET macpass)"
pascal@475 144 if [ "$mac" ]; then
pascal@475 145 ether-wake $(GET iface) $mac $pass
pascal@475 146 else
pascal@475 147 ether-wake -b $(GET iface) $pass
pascal@475 148 fi
pascal@475 149 ;;
al@419 150 *\ host\ *)
al@419 151 get_hostname="$(GET host)"
al@443 152 echo $(_ 'Changed hostname: %s' $get_hostname) | log
al@303 153 echo "$get_hostname" > /etc/hostname ;;
pascal@485 154 *\ rmarp\ *)
pascal@485 155 arp -d $(urldecode "$(GET entry)") ;;
pascal@485 156 *\ addarp\ *)
pascal@485 157 arp -i $(GET interface) -s $(GET ip) $(GET mac) ;;
pascal@485 158 *\ proxyarp\ *)
pascal@493 159 arp -i $(GET interface) -Ds $(GET ip) $(GET interface) pub ;;
pascal@493 160 *\ toggleipforward\ *)
pascal@493 161 echo $((1 - $(cat $ip_forward))) > $ip_forward ;;
pankso@41 162 esac
pankso@41 163
al@463 164 case " $(POST) " in
al@463 165 *\ connect_wifi\ *)
al@463 166 # Connect to a Wi-Fi network
al@463 167 /etc/init.d/network.sh stop | log
al@463 168 password="$(POST password)"
al@463 169
al@463 170 # Escape special characters to use with sed substitutions
al@463 171 password="$(echo -n "$password" | sed 's|\\|\\\\|g; s|&|\\\&|g' | sed "s|'|'\"'\"'|g")"
al@463 172
al@463 173 sed -i \
al@463 174 -e "s|^WIFI_ESSID=.*|WIFI_ESSID=\"$(POST essid)\"|" \
al@463 175 -e "s|^WIFI_BSSID=.*|WIFI_BSSID=\"$(POST bssid)\"|" \
al@463 176 -e "s|^WIFI_KEY_TYPE=.*|WIFI_KEY_TYPE=\"$(POST keyType)\"|" \
al@463 177 -e "s|^WIFI_KEY=.*|WIFI_KEY='$password'|" \
al@463 178 -e "s|^WIFI_EAP_METHOD=.*|WIFI_EAP_METHOD=\"$(POST eap)\"|" \
al@463 179 -e "s|^WIFI_CA_CERT=.*|WIFI_CA_CERT=\"$(POST caCert)\"|" \
al@463 180 -e "s|^WIFI_CLIENT_CERT=.*|WIFI_CLIENT_CERT=\"$(POST clientCert)\"|" \
al@463 181 -e "s|^WIFI_IDENTITY=.*|WIFI_IDENTITY=\"$(POST identity)\"|" \
al@463 182 -e "s|^WIFI_ANONYMOUS_IDENTITY=.*|WIFI_ANONYMOUS_IDENTITY=\"$(POST anonymousIdentity)\"|" \
al@463 183 -e "s|^WIFI_PHASE2=.*|WIFI_PHASE2=\"$(POST phase2)\"|" \
al@463 184 /etc/network.conf
al@463 185 . /etc/network.conf
al@463 186 start_wifi
al@463 187 ;;
al@463 188 esac
al@463 189
al@419 190
paul@127 191 # Get values only now since they could have been modified by actions.
al@419 192
pankso@108 193 . /etc/network.conf
pankso@108 194
al@419 195
al@419 196
al@419 197
al@419 198
pankso@38 199 #
pankso@41 200 # Main Commands for pages
pankso@38 201 #
pankso@38 202
pascal@81 203 case " $(GET) " in
al@419 204
pascal@136 205 *\ scan\ *)
pascal@136 206 # Scan open ports
al@419 207 scan=$(GET scan); back=$(GET back)
pascal@136 208 xhtml_header
al@443 209 LOADING_MSG=$(_ 'Scanning open ports...'); loading_msg
al@303 210
al@419 211 cat <<EOT
al@419 212 <section>
al@419 213 <header>
al@443 214 $(_ 'Port scanning for %s' $scan)
al@443 215 $(back_button "$back" "$(_ 'Network')" "")
al@419 216 </header>
al@419 217 <pre>$(pscan -b $scan)</pre>
al@419 218 </section>
pascal@136 219 EOT
pascal@136 220 ;;
al@303 221
al@419 222
pascal@81 223 *\ eth\ *)
pankso@41 224 # Wired connections settings
pankso@38 225 xhtml_header
al@419 226
al@420 227 PAR1="size=\"20\" required"; PAR="$PAR1 pattern=\"\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\""
al@420 228
al@420 229 case "$STATIC" in
al@420 230 yes) use_static='checked';;
al@420 231 *) use_static='';;
al@420 232 esac
al@420 233
al@420 234 stop_disabled=''; start_disabled=''
al@420 235 if cat /sys/class/net/eth*/operstate | fgrep -q up; then
al@420 236 start_disabled='disabled'
al@420 237 else
al@420 238 stop_disabled='disabled'
pankso@107 239 fi
al@419 240
pascal@477 241 [ -s /etc/ethers ] || echo "#01:02:03:04:05:06 mystation" > /etc/ethers
al@419 242 cat <<EOT
al@443 243 <h2>$(_ 'Ethernet connection')</h2>
pascal@435 244 EOT
pascal@435 245 [ -w /etc/network.conf ] && cat <<EOT
al@443 246 <p>$(_ "Here you can configure a wired connection using DHCP to \
al@303 247 automatically get a random IP or configure a static/fixed IP")</p>
al@303 248
al@312 249 <section>
al@443 250 <header>$(_ 'Configuration')</header>
pascal@477 251 <form action="index.cgi" id="indexform"></form>
al@419 252 <form id="conf">
al@419 253 <input type="hidden" name="eth"/>
al@419 254 <div>
al@419 255 <table>
al@443 256 <tr><td>$(_ 'Interface')</td>
al@420 257 <td><select name="iface" value="$INTERFACE" style="width:100%">
al@419 258 $(cd /sys/class/net; ls -1 | awk -viface="$INTERFACE" '{
al@419 259 sel = ($0 == iface) ? " selected":""
al@419 260 printf "<option value=\"%s\"%s>%s", $0, sel, $0
al@419 261 }')
al@419 262 </select></td>
al@419 263 </tr>
al@443 264 <tr><td>$(_ 'Static IP')</td>
al@420 265 <td><label><input type="checkbox" name="staticip" id="staticip" $use_static/>
al@443 266 $(_ 'Use static IP')</td>
al@419 267 </tr>
al@443 268 <tr id="st1"><td>$(_ 'IP address')</td>
al@420 269 <td><input type="text" name="ip" value="$IP" $PAR/></td>
al@419 270 </tr>
al@443 271 <tr id="st2"><td>$(_ 'Netmask')</td>
al@420 272 <td><input type="text" name="netmask" value="$NETMASK" $PAR/></td>
al@419 273 </tr>
al@443 274 <tr id="st3"><td>$(_ 'Gateway')</td>
al@420 275 <td><input type="text" name="gateway" value="$GATEWAY" $PAR/></td>
al@420 276 </tr>
al@443 277 <tr id="st4"><td>$(_ 'DNS server')</td>
al@420 278 <td><input type="text" name="dns" value="$DNS_SERVER" $PAR/></td>
al@419 279 </tr>
pascal@475 280 <tr><td>$(_ 'Wake up')</td>
pascal@475 281 <td><label><input type="checkbox" name="wakeup" id="wakeup" />
pascal@475 282 $(_ 'Wake up machines by network')</td>
pascal@475 283 </tr>
pascal@475 284 <tr id="wk1"><td>$(_ 'MAC address to wake up')</td>
pascal@475 285 <td><input type="text" name="macwakup" title="$(_ 'Leave empty for a general wakeup')" $PAR/><!--
pascal@477 286 --><button form="indexform" name="file" value="/etc/ethers" data-icon="view">$(_ 'List')</button>
pascal@477 287 </td>
pascal@477 288 </tr>
pascal@477 289 <tr id="wk2"><td>$(_ 'MAC/IP address password')</td>
pascal@477 290 <td><input type="text" name="macpass" title="$(_ 'Leave empty for a general wakeup')" $PAR/><!--
pascal@477 291 --><button form="indexform" name="exec" value="ether-wake --help" data-icon="help">$(_ 'Help')</button>
pascal@475 292 </td>
pascal@475 293 </tr>
al@419 294 </table>
al@419 295 </div>
al@419 296 </form>
al@419 297 <footer><!--
al@443 298 --><button form="conf" type="submit" name="start_eth" data-icon="start" $start_disabled>$(_ 'Start' )</button><!--
al@443 299 --><button form="conf" type="submit" name="stop" data-icon="stop" $stop_disabled >$(_ 'Stop' )</button><!--
pascal@475 300 --><button form="conf" type="submit" name="dowakeup" data-icon="clock" $stop_disabled >$(_ 'Wake up')</button><!--
al@419 301 --></footer>
al@419 302 </section>
al@419 303
al@419 304 <script type="text/javascript">
pascal@475 305 function check_change() {
pascal@475 306 enabled = document.getElementById('staticip').checked;
al@420 307 for (i = 1; i < 5; i++) {
pascal@475 308 document.getElementById('st' + i).style.display = enabled ? '' : 'none';
pascal@475 309 }
pascal@475 310 enabled = document.getElementById('wakeup').checked;
pascal@477 311 for (i = 1; i < 3; i++) {
pascal@475 312 document.getElementById('wk' + i).style.display = enabled ? '' : 'none';
al@420 313 }
al@420 314 }
al@419 315
pascal@475 316 document.getElementById('staticip').onchange = check_change;
pascal@475 317 document.getElementById('wakeup').onchange = check_change;
pascal@475 318 check_change();
al@419 319 </script>
pascal@435 320 EOT
pascal@435 321 cat <<EOT
al@419 322 <section>
al@419 323 <header>
al@443 324 $(_ 'Configuration file')
pascal@435 325 EOT
pascal@435 326 [ -w /etc/network.conf ] && cat <<EOT
al@419 327 <form action="index.cgi">
al@419 328 <input type="hidden" name="file" value="/etc/network.conf"/>
al@443 329 <button name="action" value="edit" data-icon="edit">$(_ 'Edit')</button>
al@419 330 </form>
pascal@435 331 EOT
pascal@435 332 cat <<EOT
al@419 333 </header>
al@443 334 <div>$(_ "These values are the ethernet settings in the main /etc/network.conf configuration file")</div>
al@419 335 <pre>$(awk '{if($1 !~ "WIFI" && $1 !~ "#" && $1 != ""){print $0}}' /etc/network.conf | syntax_highlighter conf)</pre>
al@419 336 </section>
al@419 337 EOT
al@419 338 ;;
al@419 339
al@419 340
al@419 341
al@419 342 *\ wifi_list\ *)
al@419 343 # Catch ESSIDs and format output.
al@419 344 # We get the list of networks by Cell and without spaces.
al@419 345
al@443 346 HIDDEN="$(_ '(hidden)')"
al@419 347
al@419 348 cat <<EOT
al@419 349 <table class="wide center zebra">
pankso@107 350 <thead>
pankso@107 351 <tr>
al@443 352 <td>$(_ 'Name')</td>
al@443 353 <td>$(_ 'Signal level')</td>
al@443 354 <td>$(_ 'Channel')</td>
al@443 355 <td>$(_ 'Encryption')</td>
al@443 356 <td>$(_ 'Status')</td>
pankso@107 357 </tr>
pankso@107 358 </thead>
al@303 359 <tbody>
al@419 360 EOT
al@419 361 if [ -d /sys/class/net/$WIFI_INTERFACE/wireless ]; then
al@419 362 ifconfig $WIFI_INTERFACE up
al@419 363 for i in $(iwlist $WIFI_INTERFACE scan | sed '/Cell /!d;s/.*Cell \([^ ]*\).*/Cell.\1/')
al@419 364 do
al@419 365 SCAN=$(iwlist $WIFI_INTERFACE scan last | sed "/$i/,/Cell/!d" | sed '$d')
al@419 366
al@419 367 BSSID=$(echo "$SCAN" | sed -n 's|.*Address: \([^ ]*\).*|\1|p')
al@419 368
al@419 369 CHANNEL=$(echo "$SCAN" | sed -n 's|.*Channel[:=]\([^ ]*\).*|\1|p')
al@419 370
al@419 371 QUALITY=$(echo "$SCAN" | sed -n 's|.*Quality[:=]\([^ ]*\).*|\1|p')
al@419 372 QUALITY_ICON="lvl$(( 5*${QUALITY:-0} ))" # lvl0 .. lvl4, lvl5
al@419 373 LEVEL=$(echo "$SCAN" | sed -n 's|.*Signal level[:=]\([^ ]*\).*|\1|p; s|-|−|')
al@419 374
al@419 375 ENCRYPTION=$(echo "$SCAN" | sed -n 's|.*Encryption key[:=]\([^ ]*\).*|\1|p') # on/off
al@419 376
al@419 377 ESSID=$(echo "$SCAN" | sed -n 's|.*ESSID:"\([^"]*\).*|\1|p')
al@419 378
al@419 379 # WPA Type - Group Cipher - Pairwise Ciphers - Authentication Suites
al@419 380 # {WPA|WPA2}-{TKIP|CCMP}-{TKIP|CCMP|TKIP CCMP}-{PSK|802.1x}
al@419 381 #CAPABILITIES="$(echo "$SCAN" | grep -e 'IE: .*WPA*' -A3 | cut -d: -f2 | sed -e 's|^ ||' -e '/WPA2/s|.*|=WPA2|' -e '/WPA /s|.*|=WPA|' -e '/--/d' | tr '\n' '-' | tr '=' '\n' | sed -e '/^$/d' -e 's|-$||')"
al@419 382
al@419 383 # Authentication type
al@419 384 AUTH="$(echo "$SCAN" | sed -n 's|.*Authentication Suites[^:]*: *\(.*\)|\1|p')"
al@419 385 if [ -n "$(echo -n $AUTH | fgrep PSK)" ]; then
al@419 386 # WPA-Personal. Authentication using password (PSK = pre-shared key)
al@419 387 WIFI_KEY_TYPE='WPA'
al@419 388 elif [ -n "$(echo -n $AUTH | fgrep 802.1x)" ]; then
al@419 389 # WPA-Enterprise. Authentication using username, password, certificates...
al@419 390 WIFI_KEY_TYPE='EAP'
al@419 391 else
al@419 392 WIFI_KEY_TYPE='NONE'
al@419 393 fi
al@419 394
al@419 395 # Check encryption type
al@419 396 if [ "$ENCRYPTION" == 'on' ]; then
al@419 397 # "WPA" or "WPA2" or "WPA/WPA2" (maybe also "WPA2/WPA")
al@419 398 ENC_SIMPLE=$(echo "$SCAN" | sed -n '/.*WPA.*/ s|.*\(WPA[^ ]*\).*|\1|p')
al@419 399 ENC_SIMPLE=$(echo $ENC_SIMPLE | sed 's| |/|')
al@419 400 ENC_ICON='sechi' # high
al@419 401 if [ -z "$ENC_SIMPLE" ]; then
al@419 402 WIFI_KEY_TYPE='WEP'
al@419 403 ENC_SIMPLE='WEP'; ENC_ICON='secmi' # middle
al@419 404 fi
al@419 405 else
al@419 406 WIFI_KEY_TYPE='NONE'
al@443 407 ENC_SIMPLE="$(_ 'None')"; ENC_ICON='seclo' # low
al@419 408 fi
al@419 409
al@419 410 # Connected or not connected...
al@419 411 if ifconfig $WIFI_INTERFACE | fgrep -q inet && \
al@419 412 iwconfig $WIFI_INTERFACE | fgrep -q "ESSID:\"$ESSID\""; then
al@443 413 status="$(_ 'Connected')"
al@419 414 else
al@419 415 status='---'
al@419 416 fi
al@419 417
al@419 418 cat <<EOT
al@419 419 <tr>
al@419 420 <td><a data-icon="wifi" onclick="loadcfg('$ESSID', '$BSSID', '$WIFI_KEY_TYPE')">${ESSID:-$HIDDEN}</a></td>
al@419 421 <td><span data-icon="$QUALITY_ICON" title="Quality: $QUALITY"> $LEVEL dBm</span></td>
al@419 422 <td>$CHANNEL</td>
al@419 423 <td><span data-icon="$ENC_ICON">$ENC_SIMPLE</span></td>
al@419 424 <td>$status</td>
al@419 425 </tr>
al@419 426 EOT
al@419 427 done
al@419 428 fi
al@419 429 cat <<EOT
al@303 430 </tbody>
al@419 431 </table>
al@419 432 EOT
al@419 433 exit 0
al@419 434 ;;
al@419 435
al@419 436
al@419 437 *\ wifi\ *)
al@419 438 # Wireless connections settings
al@419 439 xhtml_header
al@419 440
al@419 441 . /etc/network.conf
al@419 442 cat <<EOT
al@443 443 <h2>$(_ 'Wireless connection')</h2>
al@419 444 EOT
al@419 445
al@419 446 start_disabled=''; stop_disabled=''
al@419 447 if iwconfig 2>/dev/null | grep -q 'Tx-Power=off'; then
al@419 448 stop_disabled='disabled'
al@419 449 else
al@419 450 start_disabled='disabled'
al@419 451 fi
al@419 452
pascal@435 453 [ -w /etc/network.conf ] && cat <<EOT
pascal@435 454 <form>
pascal@435 455 <input type="hidden" name="wifi"/>
al@443 456 <button name="start_wifi" data-icon="start" $start_disabled>$(_ 'Start')</button><!--
al@443 457 --><button name="stop" data-icon="stop" $stop_disabled >$(_ 'Stop' )</button><!--
al@443 458 --><button type="submit" data-icon="refresh" $stop_disabled >$(_ 'Scan' )</button>
pankso@107 459 </form>
al@419 460 EOT
al@419 461
pascal@435 462 [ -w /etc/network.conf ] &&
al@419 463 if [ -n "$start_disabled" ]; then
al@419 464 cat <<EOT
al@419 465 <section id="wifiList">
al@443 466 <div style="text-align: center;"><span id="ajaxStatus"></span>$(_ 'Scanning wireless interface...')</div>
al@312 467 </section>
pankso@107 468
al@419 469 <script type="text/javascript">
pascal@441 470 ajax('network.cgi?wifi_list', '1', 'wifiList');
al@419 471 $(parse_wpa_conf)
al@419 472 </script>
al@419 473 EOT
al@419 474
al@463 475 # Escape html characters in the WIFI_KEY
al@463 476 WIFI_KEY_ESCAPED="$(echo -n "$WIFI_KEY" | sed 's|&|\&amp;|g; s|<|\&lt;|g; s|>|\&gt;|g; s|"|\&quot;|g')"
al@419 477
al@419 478 cat <<EOT
al@312 479 <section>
al@443 480 <header>$(_ 'Connection')</header>
al@419 481 <div>
al@463 482 <form method="post" action="?wifi" id="connection">
al@420 483 <input type="hidden" name="connect_wifi"/>
al@420 484 <input type="hidden" name="bssid" id="bssid"/>
al@419 485 <table>
al@443 486 <tr><td>$(_ 'Network SSID')</td>
al@419 487 <td><input type="text" name="essid" value="$WIFI_ESSID" id="essid"/></td>
al@419 488 </tr>
al@303 489
al@443 490 <tr><td>$(_ 'Security')</td>
al@419 491 <td><select name="keyType" id="keyType">
al@443 492 <option value="NONE">$(_ 'None')</option>
al@419 493 <option value="WEP" >WEP</option>
al@419 494 <option value="WPA" >WPA/WPA2 PSK</option>
al@419 495 <option value="EAP" >802.1x EAP</option>
al@419 496 </select>
al@419 497 </td>
al@419 498 </tr>
al@419 499
al@419 500 <tr class="eap">
al@443 501 <td><div>$(_ 'EAP method')</div></td>
al@419 502 <td><div><select name="eap" id="eap">
al@419 503 <option value="PEAP">PEAP</option>
al@419 504 <option value="TLS" >TLS</option>
al@419 505 <option value="TTLS">TTLS</option>
al@419 506 <option value="PWD" >PWD</option>
al@419 507 </select>
al@419 508 </div></td>
al@419 509 </tr>
al@419 510
al@419 511 <tr class="eap1">
al@443 512 <td><div>$(_ 'Phase 2 authentication')</div></td>
al@419 513 <td><div><select name="phase2" id="phase2">
al@443 514 <option value="none" >$(_ 'None')</option>
al@419 515 <option value="pap" >PAP</option>
al@419 516 <option value="mschap" >MSCHAP</option>
al@419 517 <option value="mschapv2">MSCHAPV2</option>
al@419 518 <option value="gtc" >GTC</option>
al@419 519 </select>
al@419 520 </div></td>
al@419 521 </tr>
al@419 522
al@419 523 <tr class="eap1">
al@443 524 <td><div>$(_ 'CA certificate')</div></td>
al@419 525 <td><div><input type="text" name="caCert" id="caCert"></div></td>
al@419 526 </tr>
al@419 527
al@419 528 <tr class="eap1">
al@443 529 <td><div>$(_ 'User certificate')</div></td>
al@419 530 <td><div><input type="text" name="clientCert" id="clientCert"></div></td>
al@419 531 </tr>
al@419 532
al@419 533 <tr class="eap">
al@443 534 <td><div>$(_ 'Identity')</div></td>
al@419 535 <td><div><input type="text" name="identity" id="identity"></div></td>
al@419 536 </tr>
al@419 537
al@419 538 <tr class="eap1">
al@443 539 <td><div>$(_ 'Anonymous identity')</div></td>
al@419 540 <td><div><input type="text" name="anonymousIdentity" id="anonymousIdentity"></div></td>
al@419 541 </tr>
al@419 542
al@419 543 <tr class="wep wpa eap">
al@443 544 <td><div>$(_ 'Password')</div></td>
al@419 545 <td><div>
al@463 546 <input type="password" name="password" value="$WIFI_KEY_ESCAPED" id="password"/>
al@443 547 <span data-img="view" title="$(_ 'Show password')"
al@419 548 onmousedown="document.getElementById('password').type='text'; return false"
al@419 549 onmouseup="document.getElementById('password').type='password'"
al@419 550 onmouseout="document.getElementById('password').type='password'"
al@419 551 ></span>
al@419 552 </div></td>
al@419 553 </tr>
al@419 554
al@419 555 <script type="text/javascript">
al@419 556 function wifiSettingsChange() {
al@419 557 document.getElementById('connection').className =
al@419 558 document.getElementById('keyType').value.toLowerCase() + ' ' +
al@419 559 document.getElementById('eap').value.toLowerCase();
al@419 560 }
al@419 561 document.getElementById('keyType').onchange = wifiSettingsChange;
al@419 562 document.getElementById('eap').onchange = wifiSettingsChange;
al@419 563
al@419 564 document.getElementById('keyType').value = "$WIFI_KEY_TYPE"; wifiSettingsChange();
al@419 565 </script>
al@419 566
al@419 567 <style type="text/css">
al@419 568 #connection input[type="text"], #connection input[type="password"] { width: 14rem; }
al@419 569 #connection select { width: 14.4rem; }
al@419 570
al@419 571 #connection td { padding: 0; margin: 0; }
al@419 572 #connection [class] div {
al@419 573 max-height: 0; overflow: hidden; padding: 0; margin: 0;
al@419 574 -webkit-transition: all 0.5s ease-in-out;
al@419 575 -moz-transition: all 0.5s ease-in-out;
al@419 576 transition: all 0.5s ease-in-out;
al@419 577 }
al@419 578 .wep .wep div, .wpa .wpa div, .eap .eap div,
al@419 579 .eap.peap .eap1 div, .eap.tls .eap1 div, .eap.ttls .eap1 div {
al@419 580 max-height: 2em !important;
al@419 581 }
al@419 582 </style>
al@419 583
al@419 584 </table>
al@419 585 </form>
al@419 586 </div>
al@419 587 <footer>
al@443 588 <button form="connection" type="submit" name="wifi" data-icon="ok">$(_ 'Configure')</button>
al@419 589 </footer>
al@419 590 </section>
al@419 591 EOT
al@419 592 fi
al@419 593
al@419 594 cat <<EOT
al@419 595 <section>
al@419 596 <header>
al@443 597 $(_ 'Configuration file')
pascal@435 598 EOT
pascal@435 599 [ -w /etc/network.conf ] && cat <<EOT
al@419 600 <form action="index.cgi">
al@419 601 <input type="hidden" name="file" value="/etc/network.conf"/>
al@443 602 <button name="action" value="edit" data-icon="edit">$(_ 'Edit')</button>
al@419 603 </form>
pascal@435 604 EOT
pascal@435 605 cat <<EOT
al@419 606 </header>
al@443 607 <div>$(_ "These values are the wifi settings in the main /etc/network.conf configuration file")</div>
al@463 608 <pre>$(grep ^WIFI /etc/network.conf | sed 's|WIFI_KEY=.*|WIFI_KEY="********"|' | syntax_highlighter conf)</pre>
al@419 609 </section>
al@419 610
al@419 611
al@419 612 <section>
al@443 613 <header>$(_ 'Output of iwconfig')</header>
al@419 614 <pre>$(iwconfig)</pre>
al@312 615 </section>
pankso@41 616 EOT
pankso@41 617 ;;
pankso@238 618
al@303 619
pankso@41 620 *)
pankso@41 621 # Main Network page starting with a summary
pankso@41 622 xhtml_header
al@419 623
al@419 624 stop_disabled=''; start_disabled=''
al@419 625 if cat /sys/class/net/*/operstate | fgrep -q up; then
al@419 626 start_disabled='disabled'
al@419 627 else
al@419 628 stop_disabled='disabled'
al@419 629 fi
al@419 630
al@439 631 if [ ! -w /etc/network.conf ]; then
al@439 632 start_disabled='disabled'; stop_disabled='disabled'
al@439 633 fi
al@439 634
al@419 635 cat <<EOT
al@443 636 <h2>$(_ 'Networking')</h2>
al@303 637
al@443 638 <p>$(_ 'Manage network connections and services')</p>
al@303 639
al@419 640 <form action="index.cgi" id="indexform"></form>
al@439 641
al@419 642 <form id="mainform"><!--
al@443 643 --><button name="start" data-icon="start" $start_disabled>$(_ 'Start' )</button><!--
al@443 644 --><button name="stop" data-icon="stop" $stop_disabled >$(_ 'Stop' )</button><!--
al@443 645 --><button name="restart" data-icon="restart" $stop_disabled >$(_ 'Restart')</button>
al@419 646 </form>
al@439 647
al@419 648 <div class="float-right"><!--
al@443 649 -->$(_ 'Configuration:')<!--
al@419 650 --><button form="indexform" name="file" value="/etc/network.conf" data-icon="conf">network.conf</button><!--
al@419 651 --><button form="mainform" name="eth" data-icon="eth">Ethernet</button><!--
al@419 652 --><button form="mainform" name="wifi" data-icon="wifi">Wireless</button>
pankso@38 653 </div>
pankso@38 654
al@419 655
al@419 656 <section>
al@443 657 <header>$(_ 'Network interfaces')</header>
al@419 658 $(list_network_interfaces)
pascal@493 659 <footer>
pascal@493 660 <input form="mainform" type="checkbox" name="opt" value="ipforward" $(
pascal@493 661 [ "$REMOTE_USER" == "root" ] || echo " disabled" ;
pascal@493 662 [ $(cat $ip_forward) -eq 1 ] && echo checked)/>
pascal@493 663 EOT
pascal@493 664 _ 'forward packets between interfaces'
pascal@493 665 [ "$REMOTE_USER" == "root" ] && cat <<EOT
pascal@494 666 <button form="mainform" name="toggleipforward" data-icon="ok">$(_ 'Change')</button>
pascal@493 667 EOT
pascal@493 668 cat <<EOT
pascal@493 669 </footer>
al@312 670 </section>
pankso@38 671
al@419 672
al@312 673 <section>
pascal@485 674 <header id="hosts">
pascal@485 675 $(_ 'Hosts')
pascal@435 676 EOT
pascal@435 677 [ -w /etc/hosts ] && cat <<EOT
al@419 678 <form action="index.cgi">
al@419 679 <input type="hidden" name="file" value="/etc/hosts"/>
al@443 680 <button name="action" value="edit" data-icon="edit">$(_ 'Edit')</button>
al@419 681 </form>
pascal@435 682 EOT
pascal@435 683 cat <<EOT
pascal@485 684 </header>
pascal@485 685 <footer>
pascal@485 686 <pre>$(cat /etc/hosts)</pre>
pascal@485 687 </footer>
al@312 688 </section>
pankso@108 689
al@419 690
al@312 691 <section>
al@443 692 <header>$(_ 'Hostname')</header>
al@419 693 <footer>
pascal@435 694 EOT
pascal@435 695 if [ -w /etc/hostname ]; then
pascal@435 696 cat <<EOT
al@419 697 <form>
al@419 698 <!-- was: name="hostname"; please don't use 'name' in name: unwanted webkit styling -->
al@419 699 <input type="text" name="host" value="$(cat /etc/hostname)"/><!--
al@443 700 --><button type="submit" data-icon="ok">$(_ 'Change')</button>
al@419 701 </form>
pascal@435 702 EOT
pascal@435 703 else
pascal@435 704 cat /etc/hostname
pascal@435 705 fi
pascal@435 706 cat <<EOT
al@419 707 </footer>
al@312 708 </section>
pankso@108 709
al@419 710
al@312 711 <section>
al@443 712 <header id="ifconfig">$(_ 'Output of ifconfig')</header>
pascal@485 713 <footer><pre>$(ifconfig)</pre></footer>
al@312 714 </section>
pascal@68 715
al@419 716
al@312 717 <section>
al@443 718 <header id="routing">$(_ 'Routing table')</header>
pascal@485 719 <footer><pre>$(route -n)</pre></footer>
al@312 720 </section>
pascal@131 721
al@419 722
al@312 723 <section>
pascal@485 724 <header id="dns">
pascal@485 725 $(_ 'Domain name resolution')
pascal@485 726 EOT
pascal@485 727 [ -w /etc/resolv.conf ] && cat <<EOT
pascal@485 728 <form action="index.cgi">
pascal@485 729 <input type="hidden" name="file" value="/etc/resolv.conf"/>
pascal@485 730 <button name="action" value="edit" data-icon="edit">$(_ 'Edit')</button>
pascal@485 731 </form>
pascal@485 732 EOT
pascal@485 733 cat <<EOT
pascal@485 734 </header>
pascal@485 735 <footer><pre>$(cat /etc/resolv.conf)</pre></footer>
al@312 736 </section>
al@303 737
al@419 738
al@312 739 <section>
al@443 740 <header id="arp">$(_ 'ARP table')</header>
pascal@485 741 <footer>
pascal@485 742 EOT
pascal@485 743 if [ "$REMOTE_USER" == "root" ]; then
pascal@485 744 echo "<table>"
pascal@485 745 arp -n | while read line ; do
pascal@485 746 cat <<EOT
pascal@485 747 <form>
pascal@485 748 <tr><td>
pascal@485 749 <input type="hidden" name="entry" value="$(urlencode "$(echo $line | \
pascal@485 750 sed 's/) .* on/ -i/;s/.*(//')")">
pascal@485 751 <button type="submit" data-icon="remove" name="rmarp"></button>
pascal@485 752 </td><td><pre>$line</pre></td></tr>
pascal@485 753 </form>
pascal@485 754 EOT
pascal@485 755 done
pascal@485 756 cat <<EOT
pascal@485 757 </table>
pascal@485 758 <form>
pascal@485 759 IP <input type="text" name="ip" value="10.20.30.40" size="12" /> on $(select_if)<!--
pascal@485 760 --><button type="submit" data-icon="upgrade" name="proxyarp">$(_ 'Proxy')</button>
pascal@485 761 or <button type="submit" data-icon="add" name="addarp">$(_ 'Add')</button>
pascal@485 762 MAC <input type="text" name="mac" value="11:22:33:44:55:66" size="16" />
pascal@485 763 </form>
pascal@485 764 EOT
pascal@485 765 else
pascal@485 766 echo "<pre>$(arp -n)</pre>"
pascal@485 767 fi
pascal@485 768 cat <<EOT
pascal@485 769 </footer>
al@312 770 </section>
al@303 771
al@419 772
al@312 773 <section>
al@443 774 <header id="connections">$(_ 'IP Connections')</header>
pascal@485 775 <footer>
al@419 776 <pre>$(netstat -anp 2>/dev/null | sed -e '/UNIX domain sockets/,$d' \
al@419 777 -e 's#\([0-9]*\)/#<a href="boot.cgi?daemons=pid=\1">\1</a>/#')</pre>
pascal@485 778 </footer>
al@312 779 </section>
pascal@495 780
pankso@38 781 EOT
pascal@495 782 [ "$REMOTE_USER" == "root" -a "$(which iptables-save)" ] && cat <<EOT
pascal@495 783 <section>
pascal@495 784 <header id="iptables">$(_ 'Firewall')</header>
pascal@495 785 <footer>
pascal@495 786 <pre>$(iptables-save)</pre>
pascal@495 787 </footer>
pascal@495 788 </section>
pascal@495 789 EOT
pascal@495 790
pankso@38 791 ;;
pankso@38 792 esac
pankso@38 793
pankso@38 794 xhtml_footer
pankso@38 795 exit 0