#!/usr/bin/env bash # Usage: run option -h to get help # BT auto detection: only working under Linux at the moment # Shall we look for white HC-06-USB dongle ? FINDBTDONGLE=true # Shall we look for rfcomm interface ? FINDBTDIRECT=true PM3PATH=$(dirname "$0") FULLIMAGE="fullimage.elf" BOOTIMAGE="bootrom.elf" # try pm3 dirs in current repo workdir if [ -d "$PM3PATH/client/" ]; then CLIENT="$PM3PATH/client/proxmark3" # try install dir elif [ -x "$PM3PATH/proxmark3" ]; then CLIENT="$PM3PATH/proxmark3" else # hope it's installed somehow, still not sure where fw images are... CLIENT="proxmark3" fi PM3LIST=() SHOWLIST=false function get_pm3_list_Linux { PM3LIST=() for DEV in $(find /dev/ttyACM* 2>/dev/null); do if udevadm info -q property -n "$DEV" |grep -q "ID_VENDOR=proxmark.org"; then PM3LIST+=("$DEV") fi done if $FINDBTDONGLE; then for DEV in $(find /dev/ttyUSB* 2>/dev/null); do if udevadm info -q property -n "$DEV" |grep -q "ID_MODEL=CP2104_USB_to_UART_Bridge_Controller"; then PM3LIST+=("$DEV") fi done fi if $FINDBTDIRECT; then for DEV in $(rfcomm -a|grep " 20:19:0[45]"|sed 's/:.*//'); do PM3LIST+=("/dev/$DEV") done fi } function get_pm3_list_macOS { PM3LIST=() for DEV in $(ioreg -r -c "IOUSBHostDevice" -l|awk -F '"' ' $2=="USB Vendor Name"{b=($4=="proxmark.org")} b==1 && $2=="IODialinDevice"{print $4}'); do PM3LIST+=("$DEV") done } function get_pm3_list_Windows { PM3LIST=() for DEV in $(wmic path Win32_SerialPort where "PNPDeviceID like '%VID_9AC4&PID_4B8F%'" get DeviceID,PNPDeviceID 2>/dev/null|awk '/^COM/{print $1}'); do DEV=${DEV/ */} PM3LIST+=("$DEV") done } function get_pm3_list_WSL { PM3LIST=() for DEV in $(wmic.exe path Win32_SerialPort where "PNPDeviceID like '%VID_9AC4&PID_4B8F%'" get DeviceID,PNPDeviceID 2>/dev/null|awk '/^COM/{print $1}'); do DEV=${DEV/ */} DEV="/dev/ttyS${DEV#COM}" # ttyS counterpart takes some more time to appear if [ -e "$DEV" ]; then PM3LIST+=("$DEV") if [ ! -w "$DEV" ]; then echo "[!!] Let's give users read/write access to $DEV" sudo chmod 666 "$DEV" fi fi done } SCRIPT=$(basename -- "$0") if [ "$SCRIPT" = "pm3" ]; then CMD() { $CLIENT "$@"; } HELP() { cat << EOF Quick helper script for proxmark3 client when working with a Proxmark3 device connected via USB Description: The usage is the same as for the proxmark3 client, with the following differences: * the correct port name will be automatically guessed; * the script will wait for a Proxmark to be connected (same as option -w of the client). You can also specify a first option -n N to access the Nth Proxmark3 connected on USB. Don't use this script if you want to work offline or with the BT addon. To see a list of available ports, use --list. Usage: $SCRIPT [-n ] [-f] [-c ]|[-l ]|[-s ] [-i] $SCRIPT --list See "$CLIENT -h" for more details on options. EOF } elif [ "$SCRIPT" = "pm3-flash" ]; then FINDBTDONGLE=false FINDBTDIRECT=false CMD() { ARGS=("--port" "$1" "--flash") shift; while [ "$1" != "" ]; do if [ "$1" == "-b" ]; then ARGS+=("--unlock-bootloader") else ARGS+=("--image" "$1") fi shift; done $CLIENT ${ARGS[@]}; } HELP() { cat << EOF Quick helper script for flashing a Proxmark device via USB Description: The usage is similar to the old proxmark3-flasher binary, except that the correct port name will be automatically guessed. You can also specify a first option -n N to access the Nth Proxmark3 connected on USB. If this doesn't work, you'll have to use manually the proxmark3 client, see "$CLIENT -h". To see a list of available ports, use --list. Usage: $SCRIPT [-n ] [-b] image.elf [image.elf...] $SCRIPT --list Options: -b Enable flashing of bootloader area (DANGEROUS) Example: $SCRIPT -b bootrom.elf fullimage.elf EOF } elif [ "$SCRIPT" = "pm3-flash-all" ]; then FINDBTDONGLE=false FINDBTDIRECT=false CMD() { $CLIENT "--port" "$1" "--flash" "--unlock-bootloader" "--image" "$BOOTIMAGE" "--image" "$FULLIMAGE"; } HELP() { cat << EOF Quick helper script for flashing a Proxmark device via USB Description: The correct port name will be automatically guessed and the stock bootloader and firmware image will be flashed. You can also specify a first option -n N to access the Nth Proxmark3 connected on USB. If this doesn't work, you'll have to use manually the proxmark3 client, see "$CLIENT -h". To see a list of available ports, use --list. Usage: $SCRIPT [-n ] $SCRIPT --list EOF } elif [ "$SCRIPT" = "pm3-flash-fullimage" ]; then FINDBTDONGLE=false FINDBTDIRECT=false CMD() { $CLIENT "--port" "$1" "--flash" "--image" "$FULLIMAGE"; } HELP() { cat << EOF Quick helper script for flashing a Proxmark device via USB Description: The correct port name will be automatically guessed and the stock firmware image will be flashed. You can also specify a first option -n N to access the Nth Proxmark3 connected on USB. If this doesn't work, you'll have to use manually the proxmark3 client, see "$CLIENT -h". To see a list of available ports, use --list. Usage: $SCRIPT [-n ] $SCRIPT --list EOF } elif [ "$SCRIPT" = "pm3-flash-bootrom" ]; then FINDBTDONGLE=false FINDBTDIRECT=false CMD() { $CLIENT "--port" "$1" "--flash" "--unlock-bootloader" "--image" "$BOOTIMAGE"; } HELP() { cat << EOF Quick helper script for flashing a Proxmark device via USB Description: The correct port name will be automatically guessed and the stock bootloader will be flashed. You can also specify a first option -n N to access the Nth Proxmark3 connected on USB. If this doesn't work, you'll have to use manually the proxmark3 client, see "$CLIENT -h". To see a list of available ports, use --list. Usage: $SCRIPT [-n ] $SCRIPT --list EOF } else echo "[!!] Script ran under unknown name, abort: $SCRIPT" exit 1 fi if [ "$1" == "-h" ] || [ "$1" == "--help" ]; then HELP exit 0 fi # if a port is already provided, let's just run the command as such for ARG in "$@"; do if [ "$ARG" == "-p" ]; then CMD "$@" exit $? fi done if [ "$1" == "--list" ]; then shift if [ "$1" != "" ]; then echo "Option --list must be used alone" exit 1 fi SHOWLIST=true fi # Number of the proxmark3 we're interested in N=1 if [ "$1" == "-n" ]; then shift if [ "$1" -ge 1 ] && [ "$1" -lt 10 ]; then N=$1 shift else echo "Option -n requires a number between 1 and 9, got \"$1\"" exit 1 fi fi HOSTOS=$(uname | awk '{print toupper($0)}') if [ "$HOSTOS" = "LINUX" ]; then if uname -a|grep -q Microsoft; then # Test presence of wmic wmic.exe computersystem get name >/dev/null 2>&1 if [ $? -ne 0 ]; then echo "[!] Cannot run wmic.exe, are you sure your WSL is authorized to run Windows processes? (cf WSL interop flag)" exit 1 fi GETPM3LIST=get_pm3_list_WSL else GETPM3LIST=get_pm3_list_Linux fi elif [ "$HOSTOS" = "DARWIN" ]; then GETPM3LIST=get_pm3_list_macOS elif [[ "$HOSTOS" =~ MINGW(32|64)_NT* ]]; then GETPM3LIST=get_pm3_list_Windows else echo "[!!] Host OS not recognized, abort: $HOSTOS" exit 1 fi if $SHOWLIST; then $GETPM3LIST if [ ${#PM3LIST} -lt 1 ]; then echo "[!!] No port found" exit 0 fi n=1 for DEV in ${PM3LIST[@]} do echo "$n: $DEV" n=$((n+1)) done exit 0 fi # Wait till we get at least N proxmark3 devices $GETPM3LIST if [ ${#PM3LIST} -lt $N ]; then echo >&2 "[=] Waiting for Proxmark3 to appear..." fi while true; do if [ ${#PM3LIST[*]} -ge $N ]; then break fi sleep .1 $GETPM3LIST done if [ ${#PM3LIST} -lt $N ]; then echo "[!!] No port found, abort" exit 1 fi CMD "${PM3LIST[$((N-1))]}" "$@" exit $?