Coder Social home page Coder Social logo

ax25irc's Introduction

ax25irc

ax25irc is a Java project attempting to create an IRC-like messaging system over HAM radio. This software can be used by both licensed HAMs and general public, though only licensed HAMs would be legally allowed to transmit.

ax25irc is not implemented from scratch. It combines following projects and libraries:

Those codebases have been merged into the project for ease of development. Currently RTL-SDR (receive only), Mobilinkd and TNC-X have been tested on Ubuntu, OSX and Windows.

Build

You will need Java 8 (JDK) and Apache Ant to build this project. Simply run build.sh if you're on Linux or OSX, or run ant manually.

The project depends on jSerialComm library for serial communication to KISS TNC. http://fazecast.github.io/jSerialComm/

Run

Multiple application modes are available :

  1. stdin

    AX25 packets are decoded from audio stream via standard input. This mode can be used with RTL-SDR via rtl_fm as demonstrated in provided run.sh script.

  2. rtlfm

    Application will directly invoke rtl_fm via shell. This mode will not work on Windows.
    Invoke as java -jar Ax25Irc.jar rtlfm

  3. kiss

    Application will attempt to open a serial port for communication with a KISS compatible TNC.
    Invoke as java -jar Ax25Irc.jar kiss <path to serial port>

  4. sound

    Application will process input/output on the sound card device. Theoretically this can be used with any radio in VOX mode, but I have only tested this mode for encoding/decoding via microphone and speakers. Sound card naming is OS-specific, this works on OSX with "Default Audio Device" and on Ubuntu with "default [default]". Still need to verify on Windows. Note that due to spaces sound device name needs to be quoted. Also the application will print all detected sound devices, which should help in determining the correct name.
    Invoke as java -jar Ax25Irc.jar sound "sound device name"

Use

Once the application is running, it will listen on standard IRC TCP port 6667. Users can connect with any IRC compatible client with no password. Licensed HAM operators intending to transmit should utilize their callsign as username, with or without SSID.

Once connected, users can join one or several of the pre-populated channels :

  • #APRS - displays all received APRS packets in decoded form. Posting to channel transmits APRS Position with entered message being the comment.
  • #APRS-RAW - displays received APRS packets in raw form. Posting to channel has no effect.
  • #APRS-CHAT - channel will display APRS Message packets when target call sign is 1 character long. Posting to channel will transmit APRS Message to target call sign "A".
  • #AX25-CHAT - channel displays non-APRS AX25 payloads.
  • #CONTROL - channel for manipulating runtime configuration.

In addition, direct messages sent to any call sign will be sent as APRS Messages, unless global mode is set to AX25. Note that call sign "A" for "round table" communication was chosen arbitrarily and can be replaced with any other string that is not a real call sign.

Screenshots

#APRS screenshot #APRS-RAW screenshot

ax25irc's People

Contributors

xba1k avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.