Skip to main content

Display Drones in Team Awareness Kit (TAK).

Project description

PyTAK Logo

DroneCOT - UAS Detection & Tracking for TAK

DroneCOT is a Python gateway that converts drone Remote ID, Open Drone ID (ODID), and DJI Drone ID signals into Cursor on Target (CoT) events for the Team Awareness Kit (TAK) ecosystem — enabling real-time C-UAS situational awareness in ATAK, WinTAK, iTAK, and TAK Server.

Use DroneCOT to detect, track, and display unmanned aircraft system (UAS) activity on your TAK common operating picture (COP) — from compliant Remote ID broadcasts to proprietary DJI Drone ID signals captured by AntSDR receivers.

Built on PyTAK.


C-UAS Capabilities

DroneCOT supports multiple drone detection sensor feeds, making it suitable for a range of counter-UAS (C-UAS) and UAS situational awareness missions:

Feed Protocol Source
serial:// MAVLink Open Drone ID Cube Orange, mRo X2.1, serial ODID receivers
mqtt:// Open Drone ID over MQTT Network-connected RID sensors
wifi:// Wi-Fi Beacon + NAN (802.11) Linux monitor-mode wireless adapter
ble:// Bluetooth Low Energy (BLE) Sniffle-compatible BLE sniffer dongle
wireless:// Wi-Fi + BLE combined Both Wi-Fi and BLE simultaneously
udp:// Pre-decoded Wi-Fi / BLE JSON (UDP 9999) Drone detection nodes broadcasting JSONL
tcp://…:41030 DJI AntSDR binary frames AntSDR E200 (DJI Drone ID, port 41030)
tcp://…:52002 DJI AntSDR text CSV AntSDR E200 text output (port 52002)
TCP listener Scanner-push mode Remote scanner connects to DroneCOT

Each feed produces CoT contact events (UAS position, operator location, home point) that appear as live tracks on your TAK map.


Features

  • Multi-protocol C-UAS sensor fusion — ingest Remote ID and DJI Drone ID from heterogeneous sensors simultaneously using side-by-side systemd instances
  • Open Drone ID (ODID) / Remote ID (RID) — decode FAA/EASA-compliant Remote ID broadcasts over MAVLink serial, MQTT, Wi-Fi 802.11, and BLE
  • DJI Drone ID (AntSDR) — decode proprietary DJI binary frame and text CSV output from AntSDR E200 receivers; supports both binary (port 41030) and text (port 52002) feeds
  • DJI TCP listener — accept scanner-push connections for deployment with centralized drone detection sensors
  • TAK integration — outputs CoT XML to ATAK, WinTAK, iTAK, TAK Server, and TAK multicast; supports TLS-authenticated TAK Server connections via PyTAK
  • Breadcrumb tracks — optional UAS trail history on the TAK map
  • Systemd-native — user-level systemd template for running multiple feeds side-by-side without root

Installation

pip install dronecot

For Wi-Fi and BLE wireless capture:

pip install 'dronecot[wireless]'

From source

git clone https://github.com/snstac/dronecot.git
cd dronecot
pip install .

Quick Start

Create a config.ini:

[dronecot]
COT_URL = udp+wo://239.2.3.1:6969

# Choose one FEED_URL for your sensor:

# MAVLink serial Remote ID (Cube Orange, mRo X2.1)
FEED_URL = serial:///dev/ttyACM0:115200

# MQTT Open Drone ID
# FEED_URL = mqtt://broker.example.net:1883

# Wi-Fi monitor mode Remote ID
# FEED_URL = wifi://wlan0

# BLE Remote ID (Sniffle dongle)
# FEED_URL = ble://

# Both Wi-Fi and BLE
# FEED_URL = wireless://wlan0

# Pre-decoded Remote ID JSON over UDP (port 9999)
# FEED_URL = udp://0.0.0.0:9999

# DJI AntSDR binary (port 41030)
# FEED_URL = tcp://192.168.1.10:41030

# DJI AntSDR text CSV (port 52002)
# FEED_URL = tcp://192.168.1.10:52002

Run:

dronecot -c config.ini

DJI Drone ID / AntSDR Configuration

DroneCOT decodes DJI's proprietary Drone ID protocol as captured by AntSDR E200 receivers running DJI firmware.

[dronecot]
COT_URL = tcp://tak-server.example.net:8089

# Binary frame feed (default DJI AntSDR port)
FEED_URL = tcp://192.168.1.10:41030

# Or text CSV feed
# FEED_URL = tcp://192.168.1.10:52002

# TCP listener (scanner connects to us)
# DJI_TCP_PORT = 52002

# Optional: sensor position for relative geometry
DJI_SENSOR_LAT = 37.7749
DJI_SENSOR_LON = -122.4194
DJI_SENSOR_HAE = 10.0
DJI_SENSOR_NAME = AntSDR-Alpha

Running as a Service

See docs/usage.md for full systemd setup. Quick reference:

# /etc/systemd/system/dronecot.service
[Unit]
Description=DroneCOT - UAS Detection for TAK
Documentation=https://dronecot.rtfd.io
After=network.target

[Service]
ExecStart=/usr/local/bin/dronecot -c /etc/dronecot.ini
EnvironmentFile=-/etc/default/dronecot
Restart=always
RestartSec=30

[Install]
WantedBy=multi-user.target

Multiple sensors side-by-side

Use the bundled user systemd template to run a serial MAVLink feed and an AntSDR DJI feed simultaneously:

make install_user_systemd
# ~/.config/dronecot/serial.env
FEED_URL=serial:///dev/ttyACM0:115200
COT_URL=udp+wo://239.2.3.1:6969

# ~/.config/dronecot/antsdr.env
FEED_URL=tcp://192.168.1.10:41030
COT_URL=udp+wo://239.2.3.1:6969
DJI_SENSOR_NAME=AntSDR-Alpha

systemctl --user enable --now dronecot@serial dronecot@antsdr

Documentation

Full documentation at dronecot.rtfd.io — includes configuration reference, feed-specific setup, TAK Server TLS, and troubleshooting.


About

DroneCOT is developed by Sensors & Signals LLC — builders of open-source TAK gateway tools for public safety, defense, and critical infrastructure protection.

Related projects:

  • PyTAK — Python TAK framework
  • ADSBCOT — ADS-B aircraft tracking for TAK
  • APRS2TAK — APRS position reporting for TAK

Contact: info@snstac.com · snstac.com


License

DroneCOT

Copyright Sensors & Signals LLC https://www.snstac.com/

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

open_drone_id.py

Copyright (c) 2022 BlueMark Innovations BV

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Project details


Download files

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

Source Distribution

dronecot-2.1.4.tar.gz (43.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dronecot-2.1.4-py3-none-any.whl (49.9 kB view details)

Uploaded Python 3

File details

Details for the file dronecot-2.1.4.tar.gz.

File metadata

  • Download URL: dronecot-2.1.4.tar.gz
  • Upload date:
  • Size: 43.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dronecot-2.1.4.tar.gz
Algorithm Hash digest
SHA256 84ca2f02854cca31e1483e37e3abc683ac99b5cf7fc8a0087a361eeeea73f92e
MD5 b2ad4a5b6796cfe156da4a9db6f898ab
BLAKE2b-256 b95538686a2a2a32f84448358fccede2aaf45099341dccdf04b82d6994a9fbea

See more details on using hashes here.

Provenance

The following attestation bundles were made for dronecot-2.1.4.tar.gz:

Publisher: python-publish_to_pypi.yml on snstac/dronecot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file dronecot-2.1.4-py3-none-any.whl.

File metadata

  • Download URL: dronecot-2.1.4-py3-none-any.whl
  • Upload date:
  • Size: 49.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dronecot-2.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 1d6d1dc9b34c25962ff8a1c6c840f4ed98a7b43a3c8dd8bc1458be0db1f08c29
MD5 acabb08a5ec01db30659a6979710bb90
BLAKE2b-256 fb5fd8858e19b10a220f119013b1aad1cb047f66eda7c881ad74e8374f877a05

See more details on using hashes here.

Provenance

The following attestation bundles were made for dronecot-2.1.4-py3-none-any.whl:

Publisher: python-publish_to_pypi.yml on snstac/dronecot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page