From 9b435398e4d2ba515dc7a30ec7d269370023e92c Mon Sep 17 00:00:00 2001 From: Damon To Date: Sun, 28 Jul 2024 17:47:32 +0800 Subject: [PATCH] chore: update modem manager to handle modem additions and removals --- internal/pkg/modem/manager.go | 36 +++++++++++++++++++------------- internal/pkg/modem/modem.go | 4 ++++ internal/pkg/modem/subscriber.go | 2 +- 3 files changed, 26 insertions(+), 16 deletions(-) diff --git a/internal/pkg/modem/manager.go b/internal/pkg/modem/manager.go index cf06794..ff0e9eb 100644 --- a/internal/pkg/modem/manager.go +++ b/internal/pkg/modem/manager.go @@ -6,6 +6,7 @@ import ( "sync" "time" + "github.com/godbus/dbus/v5" "github.com/maltegrosse/go-modemmanager" ) @@ -21,9 +22,9 @@ type Modem struct { } type Manager struct { - mmgr modemmanager.ModemManager - modems map[string]*Modem - reboot chan struct{} + mmgr modemmanager.ModemManager + modems map[string]*Modem + rebootSignal chan struct{} } var instance *Manager @@ -34,9 +35,9 @@ func NewManager() (*Manager, error) { return nil, err } instance = &Manager{ - mmgr: mmgr, - modems: make(map[string]*Modem), - reboot: make(chan struct{}, 1), + mmgr: mmgr, + modems: make(map[string]*Modem), + rebootSignal: make(chan struct{}, 1), } go instance.watch() return instance, nil @@ -61,8 +62,8 @@ func (m *Manager) watchModems() error { if err != nil { return err } - - modemAdded := false + shouldReboot := false + currentModems := make(map[string]dbus.ObjectPath) for _, mm := range modems { state, err := mm.GetState() if err != nil { @@ -77,22 +78,27 @@ func (m *Manager) watchModems() error { if err != nil { return err } + currentModems[modemId] = mm.GetObjectPath() if exist, ok := m.modems[modemId]; ok { if exist.modem.GetObjectPath() == mm.GetObjectPath() { continue } } slog.Info("new modem added", "modemId", modemId, "objectPath", mm.GetObjectPath()) - modemAdded = true - nm := &Modem{ - modem: mm, - } + shouldReboot = true + nm := &Modem{modem: mm} nm.IsEuicc, nm.Eid = nm.detectEuicc() m.modems[modemId] = nm } - // If the modem is not in the list, add it, and send a signal to reboot the subscriber - if modemAdded { - m.reboot <- struct{}{} + for modemId, modem := range m.modems { + if _, ok := currentModems[modemId]; !ok { + slog.Info("modem removed", "modemId", modemId, "objectPath", modem.modem.GetObjectPath()) + delete(m.modems, modemId) + shouldReboot = true + } + } + if shouldReboot { + m.rebootSignal <- struct{}{} } return nil } diff --git a/internal/pkg/modem/modem.go b/internal/pkg/modem/modem.go index 1c30a53..fececef 100644 --- a/internal/pkg/modem/modem.go +++ b/internal/pkg/modem/modem.go @@ -78,6 +78,10 @@ func (m *Modem) Restart() error { slog.Error("failed to power on sim", "error", err, "result", string(result)) return err } + // Some older modems require disabling and enabling the modem to take effect. + if err := m.modem.Disable(); err != nil { + slog.Error("failed to disable modem", "error", err) + } return nil } diff --git a/internal/pkg/modem/subscriber.go b/internal/pkg/modem/subscriber.go index 843c303..75c7419 100644 --- a/internal/pkg/modem/subscriber.go +++ b/internal/pkg/modem/subscriber.go @@ -20,7 +20,7 @@ Subscriber: go m.messagingSubscriber(modem, stopChan, subscriber) } - <-m.reboot + <-m.rebootSignal slog.Info("got reboot signal, restarting messaging subscriber") for _, stopChan := range stopChans { stopChan <- struct{}{}