Skip to content

Commit

Permalink
A notification is successful as long as we can send to at least one u…
Browse files Browse the repository at this point in the history
…ser (kolide#2000)
  • Loading branch information
RebeccaMahany authored Dec 13, 2024
1 parent 2717386 commit 0c60d4c
Showing 1 changed file with 14 additions and 5 deletions.
19 changes: 14 additions & 5 deletions ee/desktop/runner/runner.go
Original file line number Diff line number Diff line change
Expand Up @@ -435,19 +435,28 @@ func (r *DesktopUsersProcessesRunner) SendNotification(n notify.Notification) er
return errors.New("cannot send notification, no child desktop processes")
}

atLeastOneSuccess := false
errs := make([]error, 0)
for _, proc := range r.uidProcs {
for uid, proc := range r.uidProcs {
client := client.New(r.userServerAuthToken, proc.socketPath)
if err := client.Notify(n); err != nil {
errs = append(errs, err)
continue
}

r.slogger.Log(context.TODO(), slog.LevelDebug,
"sent notification",
"uid", uid,
)
atLeastOneSuccess = true
}

if len(errs) > 0 {
return fmt.Errorf("errors sending notifications: %+v", errs)
// We just need to be able to notify one user successfully.
if atLeastOneSuccess {
return nil
}

return nil
return fmt.Errorf("errors sending notifications: %+v", errs)
}

// Update handles control server updates for the desktop-menu subsystem
Expand Down Expand Up @@ -501,7 +510,7 @@ func (r *DesktopUsersProcessesRunner) FlagsChanged(flagKeys ...keys.FlagKey) {
"sending refresh command to user desktop process",
"uid", uid,
"pid", proc.Process.Pid,
"path", proc.path,
"path", proc.socketPath,
"err", err,
)
}
Expand Down

0 comments on commit 0c60d4c

Please sign in to comment.