mirror of
https://github.com/jopohl/urh.git
synced 2026-03-09 09:46:48 +01:00
132 lines
6.6 KiB
Markdown
132 lines
6.6 KiB
Markdown
# Universal Radio Hacker [](http://www.toolswatch.org/2017/06/the-black-hat-arsenal-usa-2017-phenomenal-line-up-announced/)
|
|
|
|
|
|
| Tests Linux/OSX | Tests Windows | Test Coverage | Latest Release |
|
|
| ------------- | ------------- | ------------- | -------- |
|
|
|[](https://travis-ci.org/jopohl/urh) | [](https://ci.appveyor.com/project/jopohl/urh/branch/master) | [](https://coveralls.io/github/jopohl/urh?branch=master) | [](https://badge.fury.io/py/urh) |
|
|
|
|
|
|
The Universal Radio Hacker (URH) 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
|
|
* __simulation environment__ to perform stateful attacks
|
|
|
|
To get started, download the [official userguide (PDF)](https://github.com/jopohl/urh/releases/download/v2.0.0/userguide.pdf), watch the [demonstration videos (YouTube)](https://www.youtube.com/watch?v=kuubkTDAxwA)
|
|
or check out the [wiki](https://github.com/jopohl/urh/wiki) for more information and supported devices. Scroll down this page to learn how to install URH on your system.
|
|
|
|
Want to stay in touch? [](https://join.slack.com/t/stralsundsecurity/shared_invite/enQtMjEwOTIxNzMzODc3LWU4ZWIzMTQ3NDAyNjkzODBhZTJiZDNmN2U0MTA4ZTM1MjhhNTNiYTc4YzQ5MDk2NjU5YzMxOWJmMDQyZDczYjg)
|
|
|
|
If you find URH useful, please consider giving this repository a :star: or even [donate via PayPal](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=6WDFF59DL56Z2). We appreciate your support!
|
|
|
|
# Installation
|
|
Universal Radio Hacker can be installed via __pip__ or using the __package manager__ of your distribution (if included).
|
|
Below you find more specific installation instructions for:
|
|
- [Windows](#windows)
|
|
- [Linux](#linux)
|
|
- [Via Package Manager](#via-package-manager)
|
|
- [Generic way with pip (Ubuntu/Debian)](#generic-way-with-pip-ubuntudebian)
|
|
- [Docker Image](#docker-image)
|
|
- [Mac OS X](#mac-os-x)
|
|
- [Updating your installation](#update-your-installation)
|
|
- [Updating with Pip](#updating-with-pip)
|
|
- [Updating with MSI](#updating-with-msi)
|
|
- [Running from source](#running-from-source)
|
|
|
|
|
|
## Windows
|
|
On Windows, URH can be installed with it's [MSI Installer](https://github.com/jopohl/urh/releases). No further dependencies are required.
|
|
|
|
If you get an error about missing ``` api-ms-win-crt-runtime-l1-1-0.dll ```, run Windows Update or directly install [KB2999226](https://support.microsoft.com/en-us/help/2999226/update-for-universal-c-runtime-in-windows).
|
|
|
|
## Linux
|
|
### Via Package Manager
|
|
For the following linux distributions you can install URH using your package manager.
|
|
|
|
| Distribution | Install with |
|
|
| ------------- | ------------- |
|
|
| Arch Linux | ``` yaourt -S urh ``` |
|
|
| Gentoo / Pentoo | ``` emerge -av urh ``` |
|
|
| Fedora 25+ | ``` dnf install urh ``` |
|
|
| openSUSE | ``` zypper install urh ``` |
|
|
|
|
|
|
### Generic way with pip (Ubuntu/Debian)
|
|
URH you can also be installed with __pip__ using ```pip3 install urh```.
|
|
In case you are running Ubuntu or Debian read on for more specific instructions.
|
|
|
|
In order to use native device backends, make sure you install the __-dev__ package for your desired SDRs, that is ``` libairspy-dev ```, ``` libhackrf-dev ```, ``` librtlsdr-dev ```, ``` 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:
|
|
```bash
|
|
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:
|
|
|
|
```bash
|
|
sudo apt-get update
|
|
sudo apt-get install python3-numpy python3-psutil python3-zmq python3-pyqt5 g++ libpython3-dev python3-pip cython3
|
|
sudo pip3 install urh
|
|
```
|
|
|
|
### Docker Image
|
|
If you use docker you can also run the official URH docker image available [here](https://hub.docker.com/r/jopohl/urh/).
|
|
|
|
## Mac OS X
|
|
1. Install [Python 3 for Mac OS X](https://www.python.org/downloads/mac-osx/).
|
|
_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
|
|
### Updating with Pip
|
|
If you installed URH via pip you can keep it up to date with ``` pip3 install --upgrade urh ```, or, if this should not work ``` python3 -m pip install --upgrade urh ```.
|
|
|
|
### Updating with MSI
|
|
If you experience issues after updating URH using the ``` .msi ``` installer on Windows, please perform a __full uninstallation__. That is, uninstall URH via Windows and after that remove the installation folder (something like ``` C:\Program Files\Universal Radio Hacker ```). Now, install the new version using the recent ```.msi ```.
|
|
|
|
## 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:
|
|
```bash
|
|
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:
|
|
```bash
|
|
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](https://github.com/jopohl/urh/wiki/External-decodings) for a list of external decodings provided by our community! Thanks for that!
|
|
|
|
## Screenshots
|
|
### Get the data out of raw signals
|
|

|
|
|
|
### Keep an overview even on complex protocols
|
|

|
|
|
|
### Record and send signals
|
|

|