Skip to content

inguardians/zigbee_tools

Repository files navigation

zigbee_tools

A few ZigBee Tools to compliment KillerBee and learn the use of zbscapy. These tools leverage the KillerBee and Scapy-Com ZigBee Layer tools and functions. These tools are mainly examples of how to interact with different packet layers and fields while also, hopefully, providing some useful new functionality.

Check out the zigbee_tools Wiki Pages for tutorials on installing, setting up, and using zbscapy.

LAYER_identifier.py

The Layer Identifier tool is designed to determine the different layers in a ZigBee packet. It will print a summary of each ZigBee packet and then print the different layers found in that packet. If the packet has encrypted layers and a key is provided the encrypted layers will be decrypted and the internal layers parsed.

user> python LAYER_identifier.py -h
LAYER_identifier.py Usage
    -h: help
    -f <filename>: capture file with zigbee packets.
    -d <directory name>: directory containing capture files with zigbee packets.
    -k <network_key>: Network Key in ASCII format. Will be converted for use.
    -D: Turn on debugging.

APP_identifier.py

The Application Identifier tool is designed to review each ZigBee packet and determine if it has an Application Layer. If so, the layer is reviewed to determine the type of Application Layer present.

user> python APP_identifier.py -h
APP_identifier.py Usage
    -h: help
    -f <filename>: capture file with zigbee packets.
    -d <directory name>: directory containing capture files with zigbee packets.
    -k <network_key>: Network Key in ASCII format. Will be converted for use.
    -K: find Network Key from capture file.
    -D: Turn on debugging.

MOD_zb_pcap.py

The Modify ZigBee Pcap tool takes in a single ZigBee pcap file, identifies all extended and short addresses, and updates these with random values. This tool is used to obfuscate ZigBee capture files for sharing and analysis. Note: the addresses are NOT compliant with any manufacturer codes.

FIXME: Some Security Headers do have addresses in them. Updating these values, however, require decrypting the packet and then re-encrypting it with the new values.

user> python MOD_zb_pcap.py -h
MOD_zb_pcap.py Usage
    -h: help
    -f <filename>: capture file with zigbee packets.
    -o <filename>: file to write new zigbee packets.
    -D: Turn on debugging. This supresses writing to a file.

ADDRESS_identifier.py

The Address Identification tool is designed to locate all of the extended and short addresses of ZigBee devices from a Pcap file. Currently this tool just spits out the addresses (which was needed for the MOD_zb_pcap.py tool).

FIXME: Future versions of this tool should identify ZigBee devices with specific roles.

user> python ADDRESS_identifier.py -h
ADDRESS_identifier.py Usage
    -h: help
    -f <filename>: capture file with zigbee packets.
    -d <directory name>: directory containing capture files with zigbee packets.
    -D: Turn on debugging.

KEY_identifier.py

The Key Identifier tool searches a ZigBee Pcap file for a Network Key and prints it for the user. Future versions should include the identification of other keys and certs and whether or not additional encryption is being used by the devices on the ZigBee network.

NOTE: This provides similar functionality as zbdsniff, only implemented by calling the function that does the zbdsniff functionality. Key output is also the same as is used for input by these other tools.

user> python KEY_identifier.py -h
KEY_identifier.py Usage
    -h: help
    -f <filename>: capture file with zigbee packets.
    -d <directory name>: directory containing capture files with zigbee packets.
    -D: Turn on debugging.

SEP_confirm.py

The Smart Energy Profile Confirmation tools is designed to review a ZigBee packet capture and determine if it contains SEP data. Detection of SEP data will very likely require decrypting the Network Layer. This tool will decrypt the Network Layer by using a Network Key provided by the user or by searching the packet capture for the key.

user> python SEP_confirm.py -h
SEP_confirm.py Usage
    -h: help
    -f <filename>: capture file with zigbee packets.
    -d <directory name>: directory containing capture files with zigbee packets.
    -k <network_key>: Network Key in ASCII format. Will be converted for use.
    -c <cert_key>: Certificate Key in ASCII format to decrypt Application Layer Data. Will be converted for use.
    -K: find Network Key from capture file.
    -D: Turn on debugging.

zbdump_display2

The zbdump_display2 tool is an updated KillerBee zbdump. This tool provides all the same functionity as zbdump but also allows the user to display incoming packets as they are being written to the dump file. Packets are parsed using KillerBee functions to display the packet fields. If scapy-com is install then the packet is quickly parsed and output in scapy packet display format.

NOTE: The packet capture performance with parsing and writing to the screen has not been tested. Therefore, if you are experiencing dropped packets then disable packet display.

user> ./zbdump_display2 -h
usage: zbdump_display2 [-h] [-i DEVSTRING] [-w PCAPFILE] [-W DSNAFILE] [-p]
                       [-c CHANNEL] [-n COUNT] [-D] [-q] [-s]

zbdump - a tcpdump-like tool for ZigBee/IEEE 802.15.4 networks Compatible with
Wireshark 1.1.2 and later ([email protected]) The -p flag adds CACE
PPI headers to the PCAP ([email protected]) Contribution by Don C. Weber
(@cutaway), InGuardians, Inc. - packet display

optional arguments:
  -h, --help            show this help message and exit
  -i DEVSTRING, --iface DEVSTRING, --dev DEVSTRING
  -w PCAPFILE, --pcapfile PCAPFILE
  -W DSNAFILE, --dsnafile DSNAFILE
  -p, --ppi
  -c CHANNEL, -f CHANNEL, --channel CHANNEL
  -n COUNT, --count COUNT
  -D
  -q, --quiet           Disable showing packets.
  -s, --scapy_com       Use scapy-com package to display packet. Default:
                        killerbee parsing.

InGuardians, Inc.

About

A few ZigBee Tools to compliment KillerBee

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages