.. _interfaces-main: ******************** Supported Interfaces ******************** Reticulum supports using many kinds of devices as networking interfaces, and allows you to mix and match them in any way you choose. The number of distinct network topologies you can create with Reticulum is more or less endless, but common to them all is that you will need to define one or more *interfaces* for Reticulum to use. The following sections describe the interfaces currently available in Reticulum, and gives example configurations for the respective interface types. For a high-level overview of how networks can be formed over different interface types, have a look at the :ref:`Building Networks` chapter of this manual. .. _interfaces-options: Common Interface Options ======================== A number of general configuration options are available on most interfaces. These can be used to control various aspects of interface behaviour. * | The ``enabled`` option tells Reticulum whether or not to bring up the interface. Defaults to ``False``. For any interface to be brought up, the ``enabled`` option must be set to ``True`` or ``Yes``. * | The ``mode`` option allows selecting the high-level behaviour of the interface from a number of options. - The default value is ``full``. In this mode, all discovery, meshing and transport functionality is available. - In the ``access_point`` (or shorthand ``ap``) mode, the interface will operate as a network access point. In this mode, announces will not be automatically broadcasted on the interface, and paths to destinations on the interface will have a much shorter expiry time. This mode is useful for creating interfaces that are mostly quiet, unless when someone is actually using them. An example of this could be a radio interface serving a wide area, where users are expected to connect momentarily, use the network, and then disappear again. * | The ``outgoing`` option sets whether an interface is allowed to transmit. Defaults to ``True``. If set to ``False`` or ``No`` the interface will only receive data, and never transmit. * | The ``network_name`` option sets the virtual network name for the interface. This allows multiple separate network segments to exist on the same physical channel or medium. * | The ``passphrase`` option sets an authentication passphrase on the interface. This option can be used in conjunction with the ``network_name`` option, or be used alone. * | The ``ifac_size`` option allows customising the length of the Interface Authentication Codes carried by each packet on named and/or authenticated network segments. It is set by default to a size suitable for the interface in question, but can be set to a custom size between 8 and 512 bits by using this option. In normal usage, this option should not be changed from the default. * | The ``announce_cap`` option lets you configure the maximum bandwidth to allocate, at any given time, to propagating announces and other network upkeep traffic. It is configured at 2% by default, and should normally not need to be changed. Can be set to any value between ``1`` and ``100``. * | The ``bitrate`` option configures the interface bitrate. Reticulum will use interface speeds reported by hardware, or try to guess a suitable rate when the hardware doesn't report any. In most cases, the automatically found rate should be sufficient, but it can be configured by using the ``bitrate`` option, to set the interface speed in *bits per second*. .. _interfaces-auto: Auto Interface ============== The Auto Interface enables communication with other discoverable Reticulum nodes over autoconfigured IPv6 and UDP. It does not need any functional IP infrastructure like routers or DHCP servers, but will require at least some sort of switching medium between peers (a wired switch, a hub, a WiFi access point or similar), and that link-local IPv6 is enabled in your operating system, which should be enabled by default in almost all OSes. .. code:: # This example demonstrates a TCP server interface. # It will listen for incoming connections on the # specified IP address and port number. [[Default Interface]] type = AutoInterface interface_enabled = True # You can create multiple isolated Reticulum # networks on the same physical LAN by # specifying different Group IDs. group_id = reticulum # You can also select specifically which # kernel networking devices to use. devices = wlan0,eth1 # Or let AutoInterface use all suitable # devices except for a list of ignored ones. ignored_devices = tun0,eth0 If you are connected to the Internet with IPv6, and your provider will route IPv6 multicast, you can potentially configure the Auto Interface to globally autodiscover other Reticulum nodes within your selected Group ID. You can specify the discovery scope by setting it to one of ``link``, ``admin``, ``site``, ``organisation`` or ``global``. .. code:: [[Default Interface]] type = AutoInterface interface_enabled = True # Configure global discovery group_id = custom_network_name discovery_scope = global # Other configuration options discovery_port = 48555 data_port = 49555 .. _interfaces-i2p: I2P Interface ============= The I2P interface lets you connect Reticulum instances over the `Invisible Internet Protocol `_. This can be especially useful in cases where you want to host a globally reachable Reticulum instance, but do not have access to any public IP addresses, have a frequently changing IP address, or have firewalls blocking inbound traffic. Using the I2P interface, you will get a globally reachable, portable and persistent I2P address that your Reticulum instance can be reached at. To use the I2P interface, you must have an I2P router running on your system. The easiest way to acheive this is to download and install the `latest release `_ of the ``ì2pd`` package. For more details about I2P, see the `geti2p.net website `_.` When an I2P router is running on your system, you can simply add an I2P interface to reticulum: .. code:: [[I2P]] type = I2PInterface interface_enabled = yes connectable = yes On the first start, Reticulum will generate a new I2P address for the interface and start listening for inbound traffic on it. This can take a while the first time, especially if your I2P router was also just started, and is not yet well-connected to the I2P network. When ready, you should see I2P base32 address printed to your log file. You can also inspect the status of the interface using the ``rnstatus`` utility. To connect to other Reticulum instances over I2P, just add a comma-separated list of I2P base32 addresses to the ``peers`` option of the interface: .. code:: [[I2P]] type = I2PInterface interface_enabled = yes connectable = yes peers = 5urvjicpzi7q3ybztsef4i5ow2aq4soktfj7zedz53s47r54jnqq.b32.i2p It can take anywhere from a few seconds to a few minutes to establish I2P connections to the desired peers, so Reticulum handles the process in the background, and will output relevant events to the log. **Please Note!** While the I2P interface is the simplest way to use Reticulum over I2P, it is also possible to tunnel the TCP server and client interfaces over I2P manually. This can be useful in situations where more control is needed, but requires manual tunnel setup through the I2P daemon configuration. It is important to note that the two methods are *interchangably compatible*. You can use the I2PInterface to connect to a TCPServerInterface that was manually tunneled over I2P, for example. This offers a high degree of flexibility in network setup, while retaining ease of use in simpler use-cases. .. _interfaces-tcps: TCP Server Interface ==================== The TCP Server interface is suitable for allowing other peers to connect over the Internet or private IP networks. When a TCP server interface has been configured, other Reticulum peers can connect to it with a TCP Client interface. .. code:: # This example demonstrates a TCP server interface. # It will listen for incoming connections on the # specified IP address and port number. [[TCP Server Interface]] type = TCPServerInterface interface_enabled = True # This configuration will listen on all IP # interfaces on port 4242 listen_ip = 0.0.0.0 listen_port = 4242 # Alternatively you can bind to a specific IP # listen_ip = 10.0.0.88 # listen_port = 4242 # Or a specific network device # device = eth0 # port = 4242 **Please Note!** The TCP interfaces support tunneling over I2P, but to do so reliably, you must use the i2p_tunneled option: .. code:: [[TCP Server on I2P]] type = TCPServerInterface interface_enabled = yes listen_ip = 127.0.0.1 listen_port = 5001 i2p_tunneled = yes .. _interfaces-tcpc: TCP Client Interface ==================== To connect to a TCP server interface, you would naturally use the TCP client interface. Many TCP Client interfaces from different peers can connect to the same TCP Server interface at the same time. .. code:: # Here's an example of a TCP Client interface. The # target_host can either be an IP address or a hostname. [[TCP Client Interface]] type = TCPClientInterface interface_enabled = True target_host = 127.0.0.1 target_port = 4242 It is also possible to use this interface type to connect via other programs or hardware devices that expose a KISS interface on a TCP port, for example software-based soundmodems. To do this, use the ``kiss_framing`` option: .. code:: # Here's an example of a TCP Client interface that connects # to a software TNC soundmodem on a KISS over TCP port. [[TCP KISS Interface]] type = TCPClientInterface interface_enabled = True kiss_framing = True target_host = 127.0.0.1 target_port = 8001 **Caution!** Only use the KISS framing option when connecting to external devices and programs like soundmodems and similar over TCP. When using the ``TCPClientInterface`` in conjunction with the ``TCPServerInterface`` you should never enable ``kiss_framing``, since this will disable internal reliability and recovery mechanisms that greatly improves performance over unreliable and intermittent TCP links. **Please Note!** The TCP interfaces support tunneling over I2P, but to do so reliably, you must use the i2p_tunneled option: .. code:: [[TCP Client over I2P]] type = TCPClientInterface interface_enabled = yes target_host = 127.0.0.1 target_port = 5001 i2p_tunneled = yes .. _interfaces-udp: UDP Interface ============= A UDP interface can be useful for communicating over IP networks, both private and the internet. It can also allow broadcast communication over IP networks, so it can provide an easy way to enable connectivity with all other peers on a local area network. *Please Note!* Using broadcast UDP traffic has performance implications, especially on WiFi. If your goal is simply to enable easy communication with all peers in your local ethernet broadcast domain, the :ref:`Auto Interface` performs better, and is just as easy to use. The below example is enabled by default on new Reticulum installations, as it provides an easy way to get started and to test Reticulum on a pre-existing LAN. .. code:: # This example enables communication with other # local Reticulum peers over UDP. [[Default UDP Interface]] type = UDPInterface interface_enabled = True listen_ip = 0.0.0.0 listen_port = 4242 forward_ip = 255.255.255.255 forward_port = 4242 # The above configuration will allow communication # within the local broadcast domains of all local # IP interfaces. # Instead of specifying listen_ip, listen_port, # forward_ip and forward_port, you can also bind # to a specific network device like below. # device = eth0 # port = 4242 # Assuming the eth0 device has the address # 10.55.0.72/24, the above configuration would # be equivalent to the following manual setup. # Note that we are both listening and forwarding to # the broadcast address of the network segments. # listen_ip = 10.55.0.255 # listen_port = 4242 # forward_ip = 10.55.0.255 # forward_port = 4242 # You can of course also communicate only with # a single IP address # listen_ip = 10.55.0.15 # listen_port = 4242 # forward_ip = 10.55.0.16 # forward_port = 4242 .. _interfaces-rnode: RNode LoRa Interface ==================== To use Reticulum over LoRa, the `RNode `_ interface can be used, and offers full control over LoRa parameters. .. code:: # Here's an example of how to add a LoRa interface # using the RNode LoRa transceiver. [[RNode LoRa Interface]] type = RNodeInterface # Enable interface if you want use it! interface_enabled = True # Serial port for the device port = /dev/ttyUSB0 # Set frequency to 867.2 MHz frequency = 867200000 # Set LoRa bandwidth to 125 KHz bandwidth = 125000 # Set TX power to 7 dBm (5 mW) txpower = 7 # Select spreading factor 8. Valid # range is 7 through 12, with 7 # being the fastest and 12 having # the longest range. spreadingfactor = 8 # Select coding rate 5. Valid range # is 5 throough 8, with 5 being the # fastest, and 8 the longest range. codingrate = 5 # You can configure the RNode to send # out identification on the channel with # a set interval by configuring the # following two parameters. # id_callsign = MYCALL-0 # id_interval = 600 # For certain homebrew RNode interfaces # with low amounts of RAM, using packet # flow control can be useful. By default # it is disabled. flow_control = False .. _interfaces-serial: Serial Interface ================ Reticulum can be used over serial ports directly, or over any device with a serial port, that will transparently pass data. Useful for communicating directly over a wire-pair, or for using devices such as data radios and lasers. .. code:: [[Serial Interface]] type = SerialInterface interface_enabled = True # Serial port for the device port = /dev/ttyUSB0 # Set the serial baud-rate and other # configuration parameters. speed = 115200 databits = 8 parity = none stopbits = 1 .. _interfaces-kiss: KISS Interface ============== With the KISS interface, you can use Reticulum over a variety of packet radio modems and TNCs, including `OpenModem `_. KISS interfaces can also be configured to periodically send out beacons for station identification purposes. .. code:: [[Packet Radio KISS Interface]] type = KISSInterface interface_enabled = True # Serial port for the device port = /dev/ttyUSB1 # Set the serial baud-rate and other # configuration parameters. speed = 115200 databits = 8 parity = none stopbits = 1 # Set the modem preamble. preamble = 150 # Set the modem TX tail. txtail = 10 # Configure CDMA parameters. These # settings are reasonable defaults. persistence = 200 slottime = 20 # You can configure the interface to send # out identification on the channel with # a set interval by configuring the # following two parameters. The KISS # interface will only ID if the set # interval has elapsed since it's last # actual transmission. The interval is # configured in seconds. # This option is commented out and not # used by default. # id_callsign = MYCALL-0 # id_interval = 600 # Whether to use KISS flow-control. # This is useful for modems that have # a small internal packet buffer, but # support packet flow control instead. flow_control = false .. _interfaces-ax25: AX.25 KISS Interface ==================== If you're using Reticulum on amateur radio spectrum, you might want to use the AX.25 KISS interface. This way, Reticulum will automatically encapsulate it's traffic in AX.25 and also identify your stations transmissions with your callsign and SSID. Only do this if you really need to! Reticulum doesn't need the AX.25 layer for anything, and it incurs extra overhead on every packet to encapsulate in AX.25. A more efficient way is to use the plain KISS interface with the beaconing functionality described above. .. code:: [[Packet Radio AX.25 KISS Interface]] type = AX25KISSInterface # Set the station callsign and SSID callsign = NO1CLL ssid = 0 # Enable interface if you want use it! interface_enabled = True # Serial port for the device port = /dev/ttyUSB2 # Set the serial baud-rate and other # configuration parameters. speed = 115200 databits = 8 parity = none stopbits = 1 # Set the modem preamble. A 150ms # preamble should be a reasonable # default, but may need to be # increased for radios with slow- # opening squelch and long TX/RX # turnaround preamble = 150 # Set the modem TX tail. In most # cases this should be kept as low # as possible to not waste airtime. txtail = 10 # Configure CDMA parameters. These # settings are reasonable defaults. persistence = 200 slottime = 20 # Whether to use KISS flow-control. # This is useful for modems with a # small internal packet buffer. flow_control = false