Skip to main content
This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (pypi.python.org).
Help us improve Python packaging - Donate today!

Universal Radio Hacker: investigate wireless protocols like a boss

Project Description

Universal Radio Hacker

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!

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.

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!

Release History

Release History

This version
History Node

1.7.1

History Node

1.7.0

History Node

1.6.6

History Node

1.6.5.3

History Node

1.6.5.1

History Node

1.6.5

History Node

1.6.4.2

History Node

1.6.4.1

History Node

1.6.4

History Node

1.6.3

History Node

1.6.2.6

History Node

1.6.2.5

History Node

1.6.2.4

History Node

1.6.2.3

History Node

1.6.2.2

History Node

1.6.2.1

History Node

1.6.2.0

History Node

1.6.1.9

History Node

1.6.1.8

History Node

1.6.1.7

History Node

1.6.1.6

History Node

1.6.1.5

History Node

1.6.1.4

History Node

1.6.1.3

History Node

1.6.1.2

History Node

1.6.1.1

History Node

1.6.1

History Node

1.6.0

History Node

1.5.7

History Node

1.5.6

History Node

1.5.5

History Node

1.5.4

History Node

1.5.3

History Node

1.5.2

History Node

1.5.1

History Node

1.5.0

History Node

1.4.10

History Node

1.4.9

History Node

1.4.8

History Node

1.4.7

History Node

1.4.6

History Node

1.4.5

History Node

1.4.4

History Node

1.4.2

History Node

1.4.1

History Node

1.4.0

History Node

1.3.10

History Node

1.3.9

History Node

1.3.8

History Node

1.3.7

History Node

1.3.5

History Node

1.3.4

History Node

1.3.3

History Node

1.3.2

History Node

1.3.1

History Node

1.3.0

Download Files

Download Files

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

File Name & Checksum SHA256 Checksum Help Version File Type Upload Date
urh-1.7.1-cp35-cp35m-win32.whl (8.0 MB) Copy SHA256 Checksum SHA256 cp35 Wheel Jul 19, 2017
urh-1.7.1-cp35-cp35m-win_amd64.whl (8.2 MB) Copy SHA256 Checksum SHA256 cp35 Wheel Jul 19, 2017
urh-1.7.1-cp36-cp36m-win32.whl (8.0 MB) Copy SHA256 Checksum SHA256 cp36 Wheel Jul 19, 2017
urh-1.7.1-cp36-cp36m-win_amd64.whl (8.2 MB) Copy SHA256 Checksum SHA256 cp36 Wheel Jul 19, 2017
urh-1.7.1.tar.gz (7.6 MB) Copy SHA256 Checksum SHA256 Source Jul 19, 2017

Supported By

WebFaction WebFaction Technical Writing Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Rackspace Rackspace Cloud Servers DreamHost DreamHost Log Hosting