A python3 module for the Open Glider Network.
Go to file
Konstantin Gründger 94286f984d add test cases for all message types 2025-05-06 13:38:39 +02:00
.github Add: gh action for sw testing and PyPI release 2025-04-19 11:27:52 +02:00
ogn Refactoring: use f-string instead of format function 2025-05-05 10:18:51 +02:00
ogn-aprs-protocol@bed93e0e84 check messages from ogn-aprs-protocol 2025-05-06 13:38:20 +02:00
tests add test cases for all message types 2025-05-06 13:38:39 +02:00
.gitignore Initial commit; Import from ogn-python 2016-02-28 12:11:16 +01:00
.gitmodules check messages from ogn-aprs-protocol 2025-05-06 13:38:20 +02:00
CHANGELOG.md Release v1.3.2 2025-04-23 10:45:16 +02:00
LICENSE Initial commit; Import from ogn-python 2016-02-28 12:11:16 +01:00
README.md Updated readme 2025-04-19 11:27:52 +02:00
poetry.lock Add: gh action for sw testing and PyPI release 2025-04-19 11:27:52 +02:00
pyproject.toml Release v1.3.2 2025-04-23 10:45:16 +02:00

README.md

python-ogn-client

build PyPi Version

A python3 module for the Open Glider Network. It can be used to connect to the OGN-APRS-Servers and to parse APRS-/OGN-Messages.

Installation

python-ogn-client is available at PyPI. So for installation simply use pip:

pip install ogn-client

Example Usage

Parse APRS/OGN packet.

from ogn.parser import parse
from datetime import datetime

beacon = parse("FLRDDDEAD>APRS,qAS,EDER:/114500h5029.86N/00956.98E'342/049/A=005524 id0ADDDEAD -454fpm -1.1rot 8.8dB 0e +51.2kHz gps4x5",
				reference_timestamp=datetime(2015, 7, 31, 12, 34, 56))

Connect to OGN and display all incoming beacons.

from ogn.client import AprsClient
from ogn.parser import parse, ParseError

def process_beacon(raw_message):
    try:
        beacon = parse(raw_message)
        print('Received {aprs_type}: {raw_message}'.format(**beacon))
    except ParseError as e:
        print('Error, {}'.format(e.message))
    except NotImplementedError as e:
        print('{}: {}'.format(e, raw_message))

client = AprsClient(aprs_user='N0CALL')
client.connect()

try:
    client.run(callback=process_beacon, autoreconnect=True)
except KeyboardInterrupt:
    print('\nStop ogn gateway')
    client.disconnect()

Connect to telnet console and display all decoded beacons.

from ogn.client import TelnetClient
from ogn.parser.telnet_parser import parse

def process_beacon(raw_message):
    beacon = parse(raw_message)
    if beacon:
        print(beacon)

client = TelnetClient()
client.connect()

try:
    client.run(callback=process_beacon)
except KeyboardInterrupt:
    print('\nStop ogn gateway')
    client.disconnect()

License

Licensed under the AGPLv3.