Skip to content

Commit

Permalink
Fix interface values not being set on RNodeSubInterface instances
Browse files Browse the repository at this point in the history
  • Loading branch information
jacobeva committed Sep 20, 2024
1 parent c71ece6 commit 8e71a1d
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 10 deletions.
14 changes: 9 additions & 5 deletions RNS/Interfaces/RNodeMultiInterface.py
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,7 @@ def __init__(self, owner, name, port, subint_config, id_interval = None, id_call
if (not self.validcfg):
raise ValueError("The configuration for "+str(self)+" contains errors, interface is offline")

def start(self):
try:
self.open_port()

Expand Down Expand Up @@ -323,11 +324,8 @@ def configure_device(self):
lt_alock=subint[9]
)

interface.OUT = self.OUT
interface.IN = self.IN

interface.announce_rate_target = self.announce_rate_target
interface.mode = self.mode
interface.OUT = subint[10]
interface.IN = True
interface.HW_MTU = self.HW_MTU
interface.detected = True
RNS.Transport.interfaces.append(interface)
Expand Down Expand Up @@ -1006,9 +1004,15 @@ def __init__(self, owner, name, parent_interface, index, interface_type, frequen
self.parent_interface = parent_interface
self.announce_rate_target = None

self.mode = None
self.announce_cap = None
self.bitrate = None
self.ifac_size = None

# add this interface to the subinterfaces array
self.parent_interface.subinterfaces[index] = self


self.validcfg = True
if (self.interface_type == "SX126X" or self.interface_type == "SX127X"):
if (self.frequency < RNodeSubInterface.LOW_FREQ_MIN or self.frequency > RNodeSubInterface.LOW_FREQ_MAX):
Expand Down
19 changes: 14 additions & 5 deletions RNS/Reticulum.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@
import os
import RNS


class Reticulum:
"""
This class is used to initialise access to Reticulum within a
Expand Down Expand Up @@ -971,7 +972,7 @@ def __apply_config(self):
enabled_count += 1

# Create an array with a row for each subinterface
subint_config = [[0 for x in range(10)] for y in range(enabled_count)]
subint_config = [[0 for x in range(11)] for y in range(enabled_count)]
subint_index = 0

for subinterface in c:
Expand Down Expand Up @@ -1000,6 +1001,11 @@ def __apply_config(self):
subint_config[subint_index][8] = st_alock
lt_alock = float(subinterface_config["airtime_limit_long"]) if "airtime_limit_long" in subinterface_config else None
subint_config[subint_index][9] = lt_alock

if "outgoing" in subinterface_config and subinterface_config.as_bool("outgoing") == False:
subint_config[subint_index][10] = False
else:
subint_config[subint_index][10] = True
subint_index += 1

# if no subinterfaces are defined
Expand All @@ -1016,6 +1022,7 @@ def __apply_config(self):
if port == None:
raise ValueError("No port specified for "+name)


interface = RNodeMultiInterface.RNodeMultiInterface(
RNS.Transport,
name,
Expand All @@ -1025,10 +1032,8 @@ def __apply_config(self):
id_callsign = id_callsign
)

if "outgoing" in c and c.as_bool("outgoing") == False:
interface.OUT = False
else:
interface.OUT = True
interface.IN = False
interface.OUT = False

interface.mode = interface_mode

Expand Down Expand Up @@ -1077,6 +1082,10 @@ def __apply_config(self):
interface.ifac_identity = RNS.Identity.from_bytes(interface.ifac_key)
interface.ifac_signature = interface.ifac_identity.sign(RNS.Identity.full_hash(interface.ifac_key))

if isinstance(interface, RNS.Interfaces.RNodeMultiInterface.RNodeMultiInterface):
interface.start()


RNS.Transport.interfaces.append(interface)

else:
Expand Down

0 comments on commit 8e71a1d

Please sign in to comment.