int _manager_send_changed(Manager *manager, const char *property, ...) {
assert(manager);
+ if (sd_bus_is_ready(manager->bus) <= 0)
+ return 0;
+
char **l = strv_from_stdarg_alloca(property);
int r = sd_bus_emit_properties_changed_strv(
/* Withdraw the conflict item */
i->state = DNS_ZONE_ITEM_WITHDRAWN;
- dnssd_signal_conflict(i->scope->manager, dns_resource_key_name(i->rr->key));
+ (void) dnssd_signal_conflict(i->scope->manager, dns_resource_key_name(i->rr->key));
/* Maybe change the hostname */
if (manager_is_own_hostname(i->scope->manager, dns_resource_key_name(i->rr->key)) > 0)
return 0;
}
-void dnssd_signal_conflict(Manager *manager, const char *name) {
+int dnssd_signal_conflict(Manager *manager, const char *name) {
DnssdService *s;
int r;
+ if (sd_bus_is_ready(manager->bus) <= 0)
+ return 0;
+
HASHMAP_FOREACH(s, manager->dnssd_services) {
if (s->withdrawn)
continue;
s->withdrawn = true;
r = sd_bus_path_encode("/org/freedesktop/resolve1/dnssd", s->name, &path);
- if (r < 0) {
- log_error_errno(r, "Can't get D-BUS object path: %m");
- return;
- }
+ if (r < 0)
+ return log_error_errno(r, "Can't get D-BUS object path: %m");
r = sd_bus_emit_signal(manager->bus,
path,
"org.freedesktop.resolve1.DnssdService",
"Conflicted",
NULL);
- if (r < 0) {
- log_error_errno(r, "Cannot emit signal: %m");
- return;
- }
+ if (r < 0)
+ return log_error_errno(r, "Cannot emit signal: %m");
break;
}
}
+
+ return 0;
}
int dnssd_txt_item_new_from_string(const char *key, const char *value, DnsTxtItem **ret_item);
int dnssd_txt_item_new_from_data(const char *key, const void *value, const size_t size, DnsTxtItem **ret_item);
int dnssd_update_rrs(DnssdService *s);
-void dnssd_signal_conflict(Manager *manager, const char *name);
+int dnssd_signal_conflict(Manager *manager, const char *name);