https://github.com/aliasrobotics/aztarna

aztarna, a footprinting tool for robots.

https://github.com/aliasrobotics/aztarna

Science Score: 10.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
  • codemeta.json file
  • .zenodo.json file
  • DOI references
  • Academic publication links
    Links to: arxiv.org
  • Academic email domains
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (11.2%) to scientific vocabulary

Keywords

fingerprinting footprinting ics industrial-robots robotics robots ros ros2 security
Last synced: 5 months ago · JSON representation

Repository

aztarna, a footprinting tool for robots.

Basic Info
  • Host: GitHub
  • Owner: aliasrobotics
  • License: gpl-3.0
  • Language: Python
  • Default Branch: master
  • Homepage: https://aliasrobotics.com
  • Size: 6.86 MB
Statistics
  • Stars: 90
  • Watchers: 11
  • Forks: 27
  • Open Issues: 4
  • Releases: 0
Archived
Topics
fingerprinting footprinting ics industrial-robots robotics robots ros ros2 security
Created over 7 years ago · Last pushed over 5 years ago

https://github.com/aliasrobotics/aztarna/blob/master/

> This repository has been archived and is not maintained any further. Refer to [alurity](https://aliasrobotics.com/alurity.php) for future progress on robot footprinting and fingerprinting.

# aztarna


This repository contains Alias Robotics' aztarna, a footprinting tool for robots.

**Alias Robotics supports original robot manufacturers assessing their security and improving their quality of software. By no means we encourage or promote the unauthorized tampering with running robotic systems. This can cause serious human harm and material damages.**

[![PyPI version](https://badge.fury.io/py/aztarna.svg)](https://badge.fury.io/py/aztarna)   [![Documentation Status](https://readthedocs.org/projects/aztarna/badge/?version=latest)](https://aztarna.readthedocs.io/en/latest/?badge=latest)    [![Article](https://img.shields.io/badge/article-arxiv%3A1812.09490-red.svg)](https://arxiv.org/pdf/1812.09490.pdf)



### For ROS
* A list of the ROS nodes present in the system (Publishers and Subscribers)
* For each node, the published and subscribed topis including the topic type
* For each node, the ROS services each of the nodes offer
* A list of all ROS parameters present in the Parameter Server
* A list of the active communications running in the system. A single communication includes the involved publiser/subscriber nodes and the topics

### For SROS
* Determining if the system is a SROS master.
* Detecting if demo configuration is in use.
* A list of the nodes found in the system. (Extended mode)
* A list of allow/deny policies for each node.
  * Publishable topics.
  * Subscriptable topics.
  * Executable services.
  * Readable parameters.  
  
### For ROS2 **(Funded under the [ROSIN project](http://rosin-project.eu/))**
* A list of ROS2 nodes present in each communication domains.
* A list of discovered topics on each communication domain.
* A list of discovered services on each communication domain.
* For each node, the relationship of published and subscribed topics.
* For each node, the services provided by that node.

### For Industrial routers
*  Detecting eWON, Moxa, Sierra Wireless and Westermo industrial routers.
*  Default credential checking for found routers.

### For ROS Industrial packages **(Funded under the [ROSIN project](http://rosin-project.eu/))**
* Detection of ROS Industrial Hosts.
* Manufacturers:
    * ABB
    * Fanuc
    * Kuka
        

## Installing
### For production
Direcly from PyPi
```
pip3 install aztarna
```
or from the repository:
```
pip3 install .
```

### For development
```
pip3 install -e .
```
or
```
python3 setup.py develop
```
**Python 3.6** and the [setuptools](https://pypi.org/project/setuptools/) package is required for installation. 
Python 3.7 is recommended.


### ROS2 Module

For usage of the ROS2 footprinting module a ROS2 installation is required. Source the setup.bash script prior to launch.

### Install with docker
```bash
docker build -t aztarna_docker .
```

### Code usage:

```bash
usage: aztarna [-h] -t TYPE [-a ADDRESS] [-p PORTS] [-i INPUT_FILE]
               [-o OUT_FILE] [-e] [-r RATE] [-d DOMAIN] [--daemon] [--hidden]
               [--shodan] [--api-key API_KEY] [--passive PASSIVE]

Aztarna

optional arguments:
  -h, --help            show this help message and exit
  -t TYPE, --type TYPE   Scan
                        ROS, SROS, ROS2 hosts or Industrial routers
  -a ADDRESS, --address ADDRESS
                        Single address or network range to scan.
  -p PORTS, --ports PORTS
                        Ports to scan (format: 13311 or 11111-11155 or
                        1,2,3,4)
  -i INPUT_FILE, --input_file INPUT_FILE
                        Input file of addresses to use for scanning
  -o OUT_FILE, --out_file OUT_FILE
                        Output file for the results
  -e, --extended        Extended scan of the hosts
  -r RATE, --rate RATE  Maximum simultaneous network connections
  -d DOMAIN, --domain DOMAIN
                        ROS 2 DOMAIN ID (ROS_DOMAIN_ID environmental
                        variable). Only applies to ROS 2.
  --daemon              Use rclpy daemon (coming from ros2cli).
  --hidden              Show hidden ROS 2 nodes. By default filtering
                        _ros2cli*
  --shodan              Use shodan for the scan types that support it.
  --api-key API_KEY     Shodan API Key
  --passive PASSIVE     Passive search for ROS2
```

### Run the code (example input file):

```bash
aztarna -t ROS -p 11311 -i ros_scan_s20.csv
```

### Run the code with Docker (example input file):
```bash
docker run -v :/root -it aztarna_docker -t ROS -p 11311 -i 
```

### Run the code (example single ip address):

```bash
aztarna -t ROS -p 11311 -a 115.129.241.241
```

### Run the code (example subnet):

```bash
aztarna -t ROS -p 11311 -a 115.129.241.0/24
```

### Run the code (example single ip address, port range):

```bash
aztarna -t ROS -p 11311-11500 -a 115.129.241.241
```

### Run the code (example single ip address, port list):

```bash
aztarna -t ROS -p 11311,11312,11313 -a 115.129.241.241
```

### Run the code with ROS 2 (example exploring all ranges, 0-231)

```bash
aztarna -t ROS2
```

### Run the code with ROS 2 with `ROS_DOMAIN_ID=15`

```bash
aztarna -t ROS2 -d 15
```

### Run the code with ROS 2 using rclpy ros2cli daemon and with `ROS_DOMAIN_ID=0` while showing hidden nodes

```bash
aztarna -t ros2 -d 0 --daemon --hidden
```

### Run de code with ROS 2 using passive mode to search the hosts. if you set 'any' as argument, is going to search on all interfaces in your system:

```bash
aztarna -t ros2 --passive any
```

### Run the code (example piping directly from zmap):

```bash
zmap -p 11311 0.0.0.0/0 -q | aztarna -t SROS -p 11311
```

### Run the code (example search for industrial routers in shodan)
```bash
aztarna -t IROUTERS --shodan --api-key 
```

### Run the code (example search for industrial routers in shodan, piping to file)
```bash
aztarna -t IROUTERS --shodan --api-key  -o routers.csv
```
## Cite our work
If you're using our work for your research, please cite us as:
```
@ARTICLE{2018arXiv181209490V,
  author = {{Vilches}, V{\'\i}ctor Mayoral and {Mendia}, Gorka Olalde and
  {Baskaran}, Xabier Perez and {Cordero}, Alejandro Hern{\'a}ndez
  and {Juan}, Lander Usategui San and {Gil-Uriarte}, Endika and
  {de Urabain}, Odei Olalde Saez and {Kirschgens}, Laura Alzola},
  title = "{Aztarna, a footprinting tool for robots}",
  journal = {arXiv e-prints},
  keywords = {Computer Science - Cryptography and Security, Computer Science - Robotics},
  year = 2018,
  month = Dec,
  eid = {arXiv:1812.09490},
  pages = {arXiv:1812.09490},
  archivePrefix = {arXiv},
  eprint = {1812.09490},
  primaryClass = {cs.CR},
  adsurl = {https://ui.adsabs.harvard.edu/\#abs/2018arXiv181209490V},
  adsnote = {Provided by the SAO/NASA Astrophysics Data System}
}
```

***



  rosin_logo

Supported by ROSIN - ROS-Industrial Quality-Assured Robot Software Components. More information: rosin-project.eu eu_flag This repository was partly funded by ROSIN RedROS2-I FTP which received funding from the European Unions Horizon 2020 research and innovation programme under the project ROSIN with the grant agreement No 732287.

Owner

  • Name: Alias Robotics
  • Login: aliasrobotics
  • Kind: organization
  • Location: Vitoria, Spain

Robot cybersecurity.

GitHub Events

Total
  • Fork event: 1
Last Year
  • Fork event: 1

Dependencies

requirements.txt pypi
  • Babel ==2.6.0
  • Click ==7.0
  • Jinja2 ==2.10.1
  • MarkupSafe ==1.1.1
  • Pygments ==2.3.1
  • Sphinx ==2.0.1
  • XlsxWriter ==1.1.6
  • aiohttp ==3.5.4
  • aiohttp-xmlrpc ==0.7.4
  • alabaster ==0.7.12
  • argcomplete ==1.9.5
  • asn1crypto ==0.24.0
  • async-timeout ==3.0.1
  • attrs ==19.1.0
  • certifi ==2019.3.9
  • cffi ==1.12.2
  • chardet ==3.0.4
  • click-plugins ==1.1.1
  • colorama ==0.4.1
  • cryptography ==2.6.1
  • dnspython ==1.16.0
  • docutils ==0.14
  • idna ==2.8
  • idna-ssl ==1.1.0
  • imagesize ==1.1.0
  • ipwhois ==1.1.0
  • lxml ==4.3.3
  • multidict ==4.5.2
  • packaging ==19.0
  • property ==2.2
  • pycparser ==2.19
  • pyparsing ==2.4.0
  • pytz ==2019.1
  • requests ==2.22.0
  • scapy ==2.4.2
  • shodan ==1.12.1
  • six ==1.12.0
  • snowballstemmer ==1.2.1
  • sphinxcontrib-applehelp ==1.0.1
  • sphinxcontrib-devhelp ==1.0.1
  • sphinxcontrib-htmlhelp ==1.0.2
  • sphinxcontrib-jsmath ==1.0.1
  • sphinxcontrib-qthelp ==1.0.2
  • sphinxcontrib-serializinghtml ==1.1.3
  • sphinxcontrib-websupport ==1.1.0
  • urllib3 >=1.24.2
  • uvloop ==0.12.2
  • yarl ==1.3.0
setup.py pypi
  • Babel ==2.6.0
  • Click ==7.0
  • Jinja2 ==2.10.1
  • MarkupSafe ==1.1.1
  • Pygments ==2.3.1
  • Sphinx ==2.0.1
  • XlsxWriter ==1.1.6
  • aiohttp ==3.5.4
  • aiohttp-xmlrpc ==0.7.4
  • alabaster ==0.7.12
  • argcomplete ==1.9.5
  • asn1crypto ==0.24.0
  • async-timeout ==3.0.1
  • attrs ==19.1.0
  • certifi ==2019.3.9
  • cffi ==1.12.2
  • chardet ==3.0.4
  • click-plugins ==1.1.1
  • colorama ==0.4.1
  • cryptography ==2.6.1
  • dnspython ==1.16.0
  • docutils ==0.14
  • idna ==2.8
  • idna-ssl ==1.1.0
  • imagesize ==1.1.0
  • ipwhois ==1.1.0
  • lxml ==4.3.3
  • multidict ==4.5.2
  • packaging ==19.0
  • property ==2.2
  • pycparser ==2.19
  • pyparsing ==2.4.0
  • pyshark ==0.4.2.9
  • pytz ==2019.1
  • requests ==2.22.0
  • scapy ==2.4.2
  • shodan ==1.12.1
  • six ==1.12.0
  • snowballstemmer ==1.2.1
  • sphinxcontrib-applehelp ==1.0.1
  • sphinxcontrib-devhelp ==1.0.1
  • sphinxcontrib-htmlhelp ==1.0.2
  • sphinxcontrib-jsmath ==1.0.1
  • sphinxcontrib-qthelp ==1.0.2
  • sphinxcontrib-serializinghtml ==1.1.3
  • sphinxcontrib-websupport ==1.1.0
  • urllib3 >=1.24.2
  • uvloop ==0.12.2
  • yarl ==1.3.0