Skip to content

Commit

Permalink
[PD] pd daemon service: reconnect to dbus on otbr-agent reload
Browse files Browse the repository at this point in the history
  • Loading branch information
yangsong-cnyn committed Nov 20, 2024
1 parent e750ad7 commit 740fdb5
Showing 1 changed file with 24 additions and 22 deletions.
46 changes: 24 additions & 22 deletions script/reference-device/dhcp6_pd_daemon.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@
import gi.repository.GLib as GLib
import subprocess
import threading
import time
import os

from dbus.mainloop.glib import DBusGMainLoop
Expand All @@ -42,8 +41,8 @@
logging.basicConfig(level=logging.INFO,
format='%(asctime)s - %(levelname)s - %(message)s')

bus = dbus.SystemBus()
dbus_obj = None
dbus_owner = None
intended_dhcp6pd_state = None

DHCP_CONFIG_PATH = "/etc/dhcpcd.conf"
Expand Down Expand Up @@ -91,38 +90,40 @@ def properties_changed_handler(interface_name, changed_properties,
restart_dhcpcd_with_no_pd_config()


def connect_to_signal(bus):
global dbus_obj
def connect_to_signal():
global bus
try:
dbus_obj = bus.get_object('io.openthread.BorderRouter.wpan0',
'/io/openthread/BorderRouter/wpan0')
wpan0_dbus_object = bus.get_object('io.openthread.BorderRouter.wpan0',
'/io/openthread/BorderRouter/wpan0')
properties_dbus_iface = dbus.Interface(
dbus_obj, 'org.freedesktop.DBus.Properties')
dbus_obj.connect_to_signal(
wpan0_dbus_object, 'org.freedesktop.DBus.Properties')
wpan0_dbus_object.connect_to_signal(
"PropertiesChanged",
properties_changed_handler,
dbus_interface=properties_dbus_iface.dbus_interface)
logging.info("Connected to D-Bus signal.")
return dbus_obj
return wpan0_dbus_object
except dbus.DBusException as e:
logging.error(f"Error connecting to D-Bus: {e}")
return None


def check_and_reconnect(bus):
global dbus_obj, dbus_owner
current_owner = bus.get_name_owner('io.openthread.BorderRouter.wpan0')
if dbus_obj is None or current_owner != dbus_owner:
if dbus_obj is not None:
logging.warning("D-Bus owner changed, reconnecting...")

time.sleep(2) # Add a small delay to avoid aggressive reconnects
dbus_obj = connect_to_signal(bus)
dbus_owner = current_owner
def check_and_reconnect():
global dbus_obj
if dbus_obj is None:
dbus_obj = connect_to_signal()
return True


def handle_name_owner_changed(new_owner):
global dbus_obj
if new_owner:
logging.info(f"New D-Bus owner({new_owner}) assigned, connecting...")
dbus_obj = None


def main():
global bus
# Ensure dhcpcd is running in its last known state. This addresses a potential race condition
# during system startup due to the loop dependency in dhcpcd-radvd-network.target.
#
Expand All @@ -139,11 +140,12 @@ def main():
except subprocess.CalledProcessError as e:
logging.error(f"Error restarting dhcpcd service: {e}")

bus = dbus.SystemBus()

loop = GLib.MainLoop()

GLib.timeout_add_seconds(5, check_and_reconnect, bus)
GLib.timeout_add_seconds(2, check_and_reconnect)

bus.watch_name_owner(bus_name='io.openthread.BorderRouter.wpan0',
callback=handle_name_owner_changed)

loop.run()

Expand Down

0 comments on commit 740fdb5

Please sign in to comment.