Skip to content

Commit

Permalink
fix(ns-api): enhance interface filtering and ensure uniqueness in net…
Browse files Browse the repository at this point in the history
…ifyd configuration
  • Loading branch information
stephdl committed Dec 3, 2024
1 parent ea02f6f commit ae92e98
Showing 1 changed file with 17 additions and 3 deletions.
20 changes: 17 additions & 3 deletions packages/ns-api/files/post-commit/configure-netifyd.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,16 +23,30 @@
if config[cname].get('autoconfig', '1') == "1":
uci.set("netifyd", cname, "autoconfig", "0")
commit = True


# Fetch excluded interfaces (one-liner)
excluded_interfaces = set(uci.get_all("netifyd").get(cname, {}).get("exclude", []))

# Collect interfaces
internal_if = set()
external_if = set()
zones = firewall.list_zones(uci)
for z in zones:
zone = zones[z]
devices = utils.get_all_devices_by_zone(uci, zone['name'], exclude_aliases=True)
# Filter interfaces based on exclusion patterns
filtered_devices = set()
for iface in devices:
if any(iface.startswith(pattern) for pattern in excluded_interfaces):
continue
filtered_devices.add(iface.split('.')[0]) # Strip VLAN part for base interface
filtered_devices = sorted(filtered_devices) # Return sorted list

# Assign devices to internal or external interfaces
if zone['name'] == "wan":
external_if.update(utils.get_all_devices_by_zone(uci, zone['name'], exclude_aliases=True))
external_if.update(filtered_devices)
else:
internal_if.update(utils.get_all_devices_by_zone(uci, zone['name'], exclude_aliases=True))
internal_if.update(filtered_devices)

if tuple(internal_if) != uci.get("netifyd", cname, "internal_if", default=()):
uci.set("netifyd", cname, "internal_if", list(internal_if))
Expand Down

0 comments on commit ae92e98

Please sign in to comment.