aboutsummaryrefslogtreecommitdiff
path: root/usb-disable
diff options
context:
space:
mode:
authorSilvio Rhatto <rhatto@riseup.net>2015-07-16 12:34:08 -0300
committerSilvio Rhatto <rhatto@riseup.net>2015-07-16 12:34:08 -0300
commit9cc4ae694bab02694511c588bd4e68743accf0ed (patch)
treecbdd04cac1c46328b475e59e31c638d9b5cbcee4 /usb-disable
parent245914ce083785cc72b1c0b63309e743cf1ddd52 (diff)
downloadbadusb-switcher-9cc4ae694bab02694511c588bd4e68743accf0ed.tar.gz
badusb-switcher-9cc4ae694bab02694511c588bd4e68743accf0ed.tar.bz2
Fixes BadUSB mitigation
Diffstat (limited to 'usb-disable')
-rwxr-xr-xusb-disable24
1 files changed, 21 insertions, 3 deletions
diff --git a/usb-disable b/usb-disable
index cc4525e..5268256 100755
--- a/usb-disable
+++ b/usb-disable
@@ -2,16 +2,34 @@
#
# USB hotplug switcher.
# See https://links.sarava.org/tags/badusb
+# https://www.kernel.org/doc/Documentation/usb/authorization.txt
#
# Parameters
BASENAME="`basename $0`"
+# Set hotplug state
+function usb_set_state {
+ echo "Applying at /sys/module/usbcore/parameters/authorized_default..."
+ sudo su -c "echo $1 > /sys/module/usbcore/parameters/authorized_default"
+
+ for bus in /sys/bus/usb/devices/usb*; do
+ echo "Applying at ${bus}/authorized_default..."
+ sudo su -c "echo $1 > ${bus}/authorized_default"
+ done
+}
+
# Dispatch
if [ "$BASENAME" == 'usb-enable' ]; then
- sudo su -c "echo '-1' > /sys/module/usbcore/parameters/authorized_default"
+ usb_set_state 1
elif [ "$BASENAME" == 'usb-disable' ]; then
- sudo su -c "echo '0' > /sys/module/usbcore/parameters/authorized_default"
+ usb_set_state 0
elif [ "$BASENAME" == 'usb-status' ]; then
- cat /sys/module/usbcore/parameters/authorized_default
+ status="`cat /sys/module/usbcore/parameters/authorized_default`"
+
+ if [ "$status" == "0" ]; then
+ echo "Hotplug disabled."
+ elif [ "$status" == "1" ]; then
+ echo "Hotplug enabled."
+ fi
fi