Portál AbcLinuxu, 29. dubna 2024 14:14
Jak jednoduše vypínat, zapínat a přepínat stav bezdrátových zařízení?
No přeci používáním RF Kill Switch! Protože se mi s posledním jádrem začly chovat rozumě, po softwarové blokaci se samovolně neodblokují - například wifi to s oblibou dělala, jsem si napsal malý skript na obsluhu této vymoženosti. Ano existuje utilita rfkill, ale tam jaksi není ono jednoduché překlopení stavu, proto vlastní řešení, podobnost ostatního je čistě náhodná.
#!/bin/bash SYS_DIR="/sys/class/rfkill" SYS_FILE="index" Usage() { echo "usage:" >&2 echo "${0##*/} list" >&2 echo "${0##*/} block [index|type]" >&2 echo "${0##*/} unblock [index|type]" >&2 echo "${0##*/} toggle [index|type]" >&2 echo "type:" >&2 echo "all" >&2 cat "$SYS_DIR"/*/type | sort -u >&2 exit 1 } GetStatusText() { case "$1" in 0) echo "soft blocked" ;; 1) echo "unblocked" ;; 2) echo "hard blocked" ;; esac } List() { for DIR in "$SYS_DIR"/*; do INDEX=$(cat "$DIR"/index) NAME=$(cat "$DIR"/name) TYPE=$(cat "$DIR"/type) STATE=$(GetStatusText $(cat "$DIR"/state)) echo "$INDEX: $NAME: $TYPE: $STATE" done } SetState() { for DIR in "$SYS_DIR"/*; do if [ "$3" = "all" ] || [ "$3" = $(cat "$DIR"/"$2") ]; then echo "$1" > $DIR/state || exit 1 fi done } Toggle() { for DIR in "$SYS_DIR/"*; do if [ "$2" = "all" ] || [ "$2" = $(cat "$DIR"/"$1") ]; then echo "$((! $(cat "$DIR"/state)))" > "$DIR"/state || exit 1 fi done } if ! [ -d "$SYS_DIR" ]; then echo "${0##*/}: no RF Kill Switch found!" exit 1 fi if [ "$1" = "list" ]; then List exit 0 fi if [ -z "$2" ]; then Usage exit 1 fi if cat "$SYS_DIR"/*/type | grep -q ^"$2"$; then SYS_FILE="type" elif cat "$SYS_DIR"/*/index | grep -q ^"$2"; then SYS_FILE="index" elif [ "$2" != "all" ]; then echo "${0##*/}: no such index or type" >&2 exit 1 fi case "$1" in unblock) SetState 1 "$SYS_FILE" $2 ;; block) SetState 0 "$SYS_FILE" $2 ;; toggle) Toggle "$SYS_FILE" $2 ;; *) Usage ;; esac
Tiskni Sdílej:
Err " ${0/*\/} toggle [index|type]" Err "type:" Err " all" for TYPE in `cat "$SYS_DIR"/*/type | sort | uniq`; do
${0##*/}
je lepší než ${0/*\/}
, když ti jde o oříznutí řetězce od začátku.
for x in `cat ...`
je hrůza. Tohle nejde?
cat "$SYS_DIR"/*/type | sort -u | while read TYPEDál jsem to neřešil. Neber to jako buzeraci, jen se snažím pomoct... Jo a ještě přesměrování do stderr je obecnější pomocí tohoto chvatu:
>&2
.
for i in ` comman`;do
je bohuzel nekdy nutnosti. Min. ve dvou pripadech.
Prvni pripad je, kdyz kod v cykly neco cte ze stdin, potom totiz command | while read a;do command2 "$a" ; done
probehne pouze jednou, protoze z nejakyho duvodu sezere ten command2 ze stdin zbytek toho vystupu z command. Uz se mi to parkrat stalo, pokud si vzpominam, tak to bylo se ssh. generate-host-list | while read host; do ssh "$host" remote-cmd ; done
bezelo jenom jednou pro prvniho hosta.
Druhy pripad je, kdyz chces v cyklu nastavit nejakou hodnotu, kterou pak pouzijes dal. Pipe totiz vyvola dalsi bash, takze veskere upravy jsou pouze lokalni, cili generate-list | while read item;do if [ $item -gt $max ] ; then max=$item;fi;done ; pracuj-dale-s-max
nebude to same jako for item in `generate-list` ; do if [ $item -gt $max ];then max=$item;fi;done;pracuj-dale-s-max
"-n"
pre ssh, potom ssh necita standardny vstup.
dave@amd64 ~ $ for x in $(echo a b c); do max=$item; done dave@amd64 ~ $ echo $max
$ for x in a b c; do max=$x; done $ echo $max c
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.