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 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+ - openSUSE - Windows - Mac OS X

Dependencies

Required

Optional

Python 3.4+

librtlsdr (for native RTL-SDR support)

python-numpy

libhackrf (for native HackRF support)

python-psutil

libairspy (for native AirSPy support)

python-zmq

liblimesdr (for native LimeSDR support)

PyQt5

libuhd (for native USRP suppport)

C++ Compiler

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

openSUSE

If you use Tumbleweed (Rolling Release), you can install URH directly with

sudo zypper install urh

If you use Leap 42.2+ you need to add the hardware:sdr repo before:

sudo zypper addrepo -f https://download.opensuse.org/repositories/hardware:/sdr/openSUSE_Leap_42.3/hardware:sdr.repo
sudo zypper install urh

Windows

MSI Installer

The easiest way to install URH on Windows is to use the .msi installer available here.

It is recommended to use the 64 bit version of URH because native device support is not available on 32 bit windows. If you get an error about missing api-ms-win-crt-runtime-l1-1-0.dll, run Windows Update or directly install KB2999226.

Pip

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.17.tar.gz (7.8 MB view details)

Uploaded Source

Built Distributions

urh-1.8.17-cp36-cp36m-win_amd64.whl (8.5 MB view details)

Uploaded CPython 3.6m Windows x86-64

urh-1.8.17-cp36-cp36m-win32.whl (8.2 MB view details)

Uploaded CPython 3.6m Windows x86

urh-1.8.17-cp35-cp35m-win_amd64.whl (8.5 MB view details)

Uploaded CPython 3.5m Windows x86-64

urh-1.8.17-cp35-cp35m-win32.whl (8.2 MB view details)

Uploaded CPython 3.5m Windows x86

File details

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

File metadata

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

File hashes

Hashes for urh-1.8.17.tar.gz
Algorithm Hash digest
SHA256 bba27515ae00bbc349fc1926c8bbcc55f3f6f572a075ac09933b3d7ae8ffff9a
MD5 92d6cd87096b846eaca301dce2a04125
BLAKE2b-256 0abdde6cbf2ee609b0873fab4b32b265d4f02f413f82ef26aa73eef7e153d92c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.8.17-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 5f7b391c55a67cca27690c2ca23026c188001e9178ec289bf445eede9e3a5f84
MD5 795a62b720d7ada52df6d43e58dbc75a
BLAKE2b-256 a3014eacae528f631b0647b806f75b3ab810b43963e11ed6e8b1abf7f22f63e1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.8.17-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 ab9d584b12be02d1ab60f2c65d6b927ffcfc9b6ee72ef0a026d88221d932112a
MD5 22410ae30c441f7441c2e860f9c70542
BLAKE2b-256 74b90c130a37d9a2fb49a78cc9c374cf7429909c8b15a0d3f20e27118352a32b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.8.17-cp35-cp35m-win_amd64.whl
Algorithm Hash digest
SHA256 4871e21a03a99a45e7a51d00a5f8a4b0b5d581d4f5fb24d474e0bc6aadf950db
MD5 307e48dcdbbcbc26b537da8e3d0c1df7
BLAKE2b-256 def5133e36cd3e979a19fb6301c15e704961929331bdd859e08e29d7d8737d72

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.8.17-cp35-cp35m-win32.whl
Algorithm Hash digest
SHA256 1982c6260e0a0d91f69e2d070b1818df5ee453a47c1c27ecb090b685b19c3aae
MD5 895400fd21a674c35ab05e2dc87481e2
BLAKE2b-256 d87d5b3a13773972923225ebde939d4a94f07c35dd226030f1b3d987d04ca939

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