Skip to main content

Universal Radio Hacker: investigate wireless protocols like a boss

Project description

Universal Radio Hacker

Linux Build Status Windows Build status OSX Build Status Code Climate PyPI version

Blackhat Arsenal 2017 Slack Donate

The Universal Radio Hacker is a software for investigating unknown wireless protocols. Features include

  • hardware interfaces for common Software Defined Radios

  • easy demodulation of signals

  • assigning participants to keep overview of your data

  • customizable decodings to crack even sophisticated encodings like CC1101 data whitening

  • assign labels to reveal the logic of the protocol

  • fuzzing component to find security leaks

  • modulation support to inject the data back into the system

Check out the wiki for more information and supported devices.

Like to see things in action? Watch URH on YouTube!

Youtube Image

Want to stay in touch? Join our Slack Channel!

Installation

Universal Radio Hacker can be installed via pip or using the package manager of your distribution (if included). Furthermore, you can install urh from source or run it without installation directly from source. Below you find more specific installation instructions for: - Linux Distributions: - Arch Linux - Ubuntu/Debian - Gentoo/Pentoo - Fedora 25+ - Windows - Mac OS X

Dependencies - Python 3.4+ - numpy / psutil / zmq - PyQt5 - C++ Compiler

Optional - librtlsdr (for native RTL-SDR device backend) - libhackrf (for native HackRF device backend) - libairspy (for native AirSPy device backend) - liblimesdr (for native LimeSDR device backend) - libuhd (for native USRP device backend) - rfcat (for RfCat plugin to send e.g. with YardStick One) - gnuradio / gnuradio-osmosdr (for GNU Radio device backends)

Installation examples

Arch Linux

yaourt -S urh

Ubuntu/Debian

If you want to use native device backends, make sure you install the -dev package for your desired SDRs, that is: - AirSpy: libairspy-dev - HackRF: libhackrf-dev - RTL-SDR: librtlsdr-dev - USRP: libuhd-dev

If your device does not have a -dev package, e.g. LimeSDR, you need to manually create a symlink to the .so, like this:

sudo ln -s /usr/lib/x86_64-linux-gnu/libLimeSuite.so.17.02.2 /usr/lib/x86_64-linux-gnu/libLimeSuite.so

before installing URH, using:

sudo apt-get update
sudo apt-get install python3-numpy python3-psutil python3-zmq python3-pyqt5 g++ libpython3-dev python3-pip
sudo pip3 install urh

Gentoo/Pentoo

emerge -av urh

Fedora 25+

dnf install urh

Windows

If you run Python 3.4 on Windows you need to install Visual C++ Build Tools 2015 first.

It is recommended to use Python 3.5 or later on Windows, so no C++ compiler needs to be installed.

  1. Install Python 3 for Windows.

  • Make sure you tick the Add Python to PATH checkbox on first page in Python installer.

  • Choose a 64 Bit Python version for native device support.

  1. In a terminal, type: pip install urh.

  2. Type urh in a terminal or search for urh in search bar to start the application.

Mac OS X

  1. Install Python 3 for Mac OS X. If you experience issues with preinstalled Python, make sure you update to a recent version using the given link.

  2. (Optional) Install desired native libs e.g. brew install librtlsdr for corresponding native device support.

  3. In a terminal, type: pip3 install urh.

  4. Type urh in a terminal to get it started.

Update your installation

If you installed URH via pip you can keep it up to date with

pip3 install --upgrade urh

If this shouldn’t work you can try:

python3 -m pip install --upgrade urh

Running from source

If you like to live on bleeding edge, you can run URH from source.

Without installation

To execute the Universal Radio Hacker without installation, just run:

git clone https://github.com/jopohl/urh/
cd urh/src/urh
./main.py

Note, before first usage the C++ extensions will be built.

Installing from source

To install from source you need to have python-setuptools installed. You can get it e.g. with pip install setuptools. Once the setuptools are installed use:

git clone https://github.com/jopohl/urh/
cd urh
python setup.py install

And start the application by typing urh in a terminal.

External decodings

See wiki for a list of external decodings provided by our community! Thanks for that!

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

urh-1.8.1.tar.gz (7.7 MB view details)

Uploaded Source

Built Distributions

urh-1.8.1-cp36-cp36m-win_amd64.whl (8.3 MB view details)

Uploaded CPython 3.6m Windows x86-64

urh-1.8.1-cp36-cp36m-win32.whl (8.1 MB view details)

Uploaded CPython 3.6m Windows x86

urh-1.8.1-cp35-cp35m-win_amd64.whl (8.3 MB view details)

Uploaded CPython 3.5m Windows x86-64

urh-1.8.1-cp35-cp35m-win32.whl (8.1 MB view details)

Uploaded CPython 3.5m Windows x86

File details

Details for the file urh-1.8.1.tar.gz.

File metadata

  • Download URL: urh-1.8.1.tar.gz
  • Upload date:
  • Size: 7.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for urh-1.8.1.tar.gz
Algorithm Hash digest
SHA256 cd5135c92bcc65957a2180980cc316fc2fa2adc093ad77097a41647fe76dfc47
MD5 8a7d72a5dba3155f017b4ee5517f6e22
BLAKE2b-256 87e3cb93afbae3501f2dc5c6b21d25c7199069da5a1cf0580b563b0df6645637

See more details on using hashes here.

File details

Details for the file urh-1.8.1-cp36-cp36m-win_amd64.whl.

File metadata

File hashes

Hashes for urh-1.8.1-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 55b716362a1b3b6a1d30a121f9fb8a06298052ab4086f85a86fc0eceb2e7c8b5
MD5 2eb75e3540c9e8ffd19692f6a9e7089a
BLAKE2b-256 5e463d55da46795f707435dc4db57b71872bf47f213f125c06a3d189894c5e1c

See more details on using hashes here.

File details

Details for the file urh-1.8.1-cp36-cp36m-win32.whl.

File metadata

File hashes

Hashes for urh-1.8.1-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 73c047dfc4b89350771d2b86dab658c97bf3ab894599f9d94bd9b5474e3d26f4
MD5 e010bb5d5a8b8998a4bf0e626867acfe
BLAKE2b-256 d387bc58b836dbec472aee182c0382cbd377676b3c3ee575bec35a5e581dab6c

See more details on using hashes here.

File details

Details for the file urh-1.8.1-cp35-cp35m-win_amd64.whl.

File metadata

File hashes

Hashes for urh-1.8.1-cp35-cp35m-win_amd64.whl
Algorithm Hash digest
SHA256 66b143c82abf9b2e73ad0bb0a70ccfb29b9e9771f449146e8f57b7655dade6b8
MD5 09f78c3ac7ed97137a342eec0f941eb2
BLAKE2b-256 70b955255d72be6b57cbbc3b18266735877c94c11f7b01810ca7c1097df35244

See more details on using hashes here.

File details

Details for the file urh-1.8.1-cp35-cp35m-win32.whl.

File metadata

File hashes

Hashes for urh-1.8.1-cp35-cp35m-win32.whl
Algorithm Hash digest
SHA256 1322bc440affdc86bfaf38b6fe66008349bc12ea4a8e096d8bb9213a42a8f898
MD5 912d10aac6d9bde294cafaac26730525
BLAKE2b-256 6f7490931b1ab5ae53c7712167e56d4afdcd623d08d1224ef0afa7709a9d564c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page