Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/BastilleResearch/mousejack
MouseJack device discovery and research tools
https://github.com/BastilleResearch/mousejack
Last synced: 22 days ago
JSON representation
MouseJack device discovery and research tools
- Host: GitHub
- URL: https://github.com/BastilleResearch/mousejack
- Owner: BastilleResearch
- License: gpl-3.0
- Created: 2016-02-23T14:19:38.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2017-12-19T10:16:25.000Z (almost 7 years ago)
- Last Synced: 2024-08-05T17:32:08.078Z (4 months ago)
- Homepage:
- Size: 8.44 MB
- Stars: 1,276
- Watchers: 110
- Forks: 256
- Open Issues: 31
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hacking-lists - BastilleResearch/mousejack - MouseJack device discovery and research tools (Others)
README
# MouseJack device discovery and research tools
For information on the MouseJack vulnerabilities, please visit [mousejack.com](https://www.mousejack.com).
## Requirements
- SDCC (minimum version 3.1.0)
- GNU Binutils
- Python
- PyUSB
- platformioInstall dependencies on Ubuntu:
```
sudo apt-get install sdcc binutils python python-pip
sudo pip install -U pip
sudo pip install -U -I pyusb
sudo pip install -U platformio
```## Supported Hardware
The following hardware has been tested and is known to work.
- CrazyRadio PA USB dongle
- SparkFun nRF24LU1+ breakout board
- Logitech Unifying dongle (model C-U0007, Nordic Semiconductor based)## Initialize the submodule
```
git submodule init
git submodule update
```## Build the firmware
```
cd nrf-research-firmware
make
```## Flash over USB
nRF24LU1+ chips come with a factory programmed bootloader occupying the topmost 2KB of flash memory. The CrazyRadio firmware and RFStorm research firmware support USB commands to enter the Nordic bootloader.
Dongles and breakout boards can be programmed over USB if they are running one of the following firmwares:
- Nordic Semiconductor Bootloader
- CrazyRadio Firmware
- RFStorm Research FirmwareTo flash the firmware over USB:
```
cd nrf-research-firmware
sudo make install
```## Flash a Logitech Unifying dongle
*The most common Unifying dongles are based on the nRF24LU1+, but some use chips from Texas Instruments.
This firmware is only supported on the nRF24LU1+ variants, which have a model number of C-U0007. The flashing
script will automatically detect which type of dongle is plugged in, and will only attempt to flash the nRF24LU1+ variants.*To flash the firmware over USB onto a Logitech Unifying dongle:
```
cd nrf-research-firmware
sudo make logitech_install
```## Flash a Logitech Unifying dongle back to the original firmware
Download and extract the Logitech firmware image, which will be named `RQR_012_005_00028.hex` or similar. Then, run the following command to flash the Logitech firmware onto the dongle:
```
cd nrf-research-firmware
sudo ./prog/usb-flasher/logitech-usb-restore.py [path-to-firmware.hex]
```## Flash over SPI using a Teensy
If your dongle or breakout board is bricked, you can alternatively program it over SPI using a Teensy.
This has only been tested with a Teensy 3.1/3.2, but is likely to work with other Arduino variants as well.
### Build and Upload the Teensy Flasher
```
cd nrf-research-firmware/prog
platformio run --project-dir teensy-flasher --target upload
```### Connect the Teensy to the nRF24LU1+
| Teensy | CrazyRadio PA | Sparkfun nRF24LU1+ Breakout |
| ------ | ---------- | -------- |
| GND | 9 | GND |
| 8 | 3 | RESET |
| 9 | 2 | PROG |
| 10 | 10 | P0.3 |
| 11 | 6 | P0.1 |
| 12 | 8 | P0.2 |
| 13 | 4 | P0.0 |
| 3.3V | 5 | VIN |### Flash the nRF24LU1+
```
cd nrf-research-firmware
sudo make spi_install
```# Python Scripts
## scanner
Pseudo-promiscuous mode device discovery tool, which sweeps a list of channels and prints out decoded Enhanced Shockburst packets.
```
usage: ./nrf24-scanner.py [-h] [-c N [N ...]] [-v] [-l] [-p PREFIX] [-d DWELL]optional arguments:
-h, --help show this help message and exit
-c N [N ...], --channels N [N ...] RF channels
-v, --verbose Enable verbose output
-l, --lna Enable the LNA (for CrazyRadio PA dongles)
-p PREFIX, --prefix PREFIX Promiscuous mode address prefix
-d DWELL, --dwell DWELL Dwell time per channel, in milliseconds
```Scan for devices on channels 1-5
```
./nrf24-scanner.py -c {1..5}
```Scan for devices with an address starting in 0xA9 on all channels
```
cd nrf-research-firmware
./nrf24-scanner.py -p A9
```## sniffer
Device following sniffer, which follows a specific nRF24 device as it hops, and prints out decoded Enhanced Shockburst packets from the device.
```
usage: ./nrf24-sniffer.py [-h] [-c N [N ...]] [-v] [-l] -a ADDRESS [-t TIMEOUT] [-k ACK_TIMEOUT] [-r RETRIES]optional arguments:
-h, --help show this help message and exit
-c N [N ...], --channels N [N ...] RF channels
-v, --verbose Enable verbose output
-l, --lna Enable the LNA (for CrazyRadio PA dongles)
-a ADDRESS, --address ADDRESS Address to sniff, following as it changes channels
-t TIMEOUT, --timeout TIMEOUT Channel timeout, in milliseconds
-k ACK_TIMEOUT, --ack_timeout ACK_TIMEOUT ACK timeout in microseconds, accepts [250,4000], step 250
-r RETRIES, --retries RETRIES Auto retry limit, accepts [0,15]
```Sniff packets from address 61:49:66:82:03 on all channels
```
cd nrf-research-firmware
./nrf24-sniffer.py -a 61:49:66:82:03
```## network mapper
Star network mapper, which attempts to discover the active addresses in a star network by changing the last byte in the given address, and pinging each of 256 possible addresses on each channel in the channel list.
```
usage: ./nrf24-network-mapper.py [-h] [-c N [N ...]] [-v] [-l] -a ADDRESS [-p PASSES] [-k ACK_TIMEOUT] [-r RETRIES]optional arguments:
-h, --help show this help message and exit
-c N [N ...], --channels N [N ...] RF channels
-v, --verbose Enable verbose output
-l, --lna Enable the LNA (for CrazyRadio PA dongles)
-a ADDRESS, --address ADDRESS Known address
-p PASSES, --passes PASSES Number of passes (default 2)
-k ACK_TIMEOUT, --ack_timeout ACK_TIMEOUT ACK timeout in microseconds, accepts [250,4000], step 250
-r RETRIES, --retries RETRIES Auto retry limit, accepts [0,15]
```Map the star network that address 61:49:66:82:03 belongs to
```
cd nrf-research-firmware
./nrf24-network-mapper.py -a 61:49:66:82:03
```## continuous tone test
The nRF24LU1+ chips include a test mechanism to transmit a continuous tone, the frequency of which can be verified if you have access to an SDR. There is the potential for frequency offsets between devices to cause unexpected behavior. For instance, one of the SparkFun breakout boards that was tested had a frequency offset of ~300kHz, which caused it to receive packets on two adjacent channels.
This script will cause the transceiver to transmit a tone on the first channel that is passed in.
```
usage: ./nrf24-continuous-tone-test.py [-h] [-c N [N ...]] [-v] [-l]optional arguments:
-h, --help show this help message and exit
-c N [N ...], --channels N [N ...] RF channels
-v, --verbose Enable verbose output
-l, --lna Enable the LNA (for CrazyRadio PA dongles)```
Transmit a continuous tone at 2405MHz
```
cd nrf-research-firmware
./nrf24-continuous-tone-test.py -c 5
```