logger(mesh, MESHLINK_ERROR, "Got bad %s from %s: %s", "REQ_PUBKEY", from->name, "invalid pubkey");
return true;
}
+
+ logger(mesh, MESHLINK_INFO, "Learned ECDSA public key from %s", from->name);
+ from->status.dirty = true;
+
+ if(!node_write_config(mesh, from, true)) {
+ // ignore
+ }
}
}
logger(mesh, MESHLINK_INFO, "Learned ECDSA public key from %s", from->name);
from->status.dirty = true;
+ if(!node_write_config(mesh, from, true)) {
+ // ignore
+ }
+
/* If we are trying to form an outgoing connection to this node, retry immediately */
for list_each(outgoing_t, outgoing, mesh->outgoings) {
if(outgoing->node == from && outgoing->ev.cb) {
return true;
}
- strncat(host, " ", MAX_STRING_SIZE - 1);
- strncat(host, port, MAX_STRING_SIZE - 1);
+ char *canonical_address;
+ xasprintf(&canonical_address, "%s %s", host, port);
- if(from->canonical_address && !strcmp(from->canonical_address, host)) {
- return true;
+ if(mesh->log_level <= MESHLINK_DEBUG && strcmp(from->canonical_address, canonical_address)) {
+ logger(mesh, MESHLINK_DEBUG, "Updating canonical address of %s to %s", from->name, canonical_address);
}
- logger(mesh, MESHLINK_DEBUG, "Updating canonical address of %s to %s", from->name, host);
free(from->canonical_address);
- from->canonical_address = xstrdup(host);
+ from->canonical_address = canonical_address;
return true;
}