mirror of
https://github.com/systemd/systemd.git
synced 2025-01-11 09:18:07 +03:00
networkd: expose a global list of DNS and NTP servers in the state file
This commit is contained in:
parent
87f5a19343
commit
c0c743cb3d
@ -415,7 +415,42 @@ int manager_bus_listen(Manager *m) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int set_put_in_addr(Set *s, const struct in_addr *address) {
|
||||||
|
char *p;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(s);
|
||||||
|
|
||||||
|
r = in_addr_to_string(AF_INET, (const union in_addr_union*) address, &p);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
r = set_consume(s, p);
|
||||||
|
if (r == -EEXIST)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int set_put_in_addrv(Set *s, const struct in_addr *addresses, int n) {
|
||||||
|
int r, i, c = 0;
|
||||||
|
|
||||||
|
assert(s);
|
||||||
|
assert(n <= 0 || addresses);
|
||||||
|
|
||||||
|
for (i = 0; i < n; i++) {
|
||||||
|
r = set_put_in_addr(s, addresses+i);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
c += r;
|
||||||
|
}
|
||||||
|
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
int manager_save(Manager *m) {
|
int manager_save(Manager *m) {
|
||||||
|
_cleanup_set_free_free_ Set *dns = NULL, *ntp = NULL;
|
||||||
Link *link;
|
Link *link;
|
||||||
Iterator i;
|
Iterator i;
|
||||||
_cleanup_free_ char *temp_path = NULL;
|
_cleanup_free_ char *temp_path = NULL;
|
||||||
@ -427,12 +462,61 @@ int manager_save(Manager *m) {
|
|||||||
assert(m);
|
assert(m);
|
||||||
assert(m->state_file);
|
assert(m->state_file);
|
||||||
|
|
||||||
|
/* We add all NTP and DNS server to a set, to filter out duplicates */
|
||||||
|
dns = set_new(string_hash_func, string_compare_func);
|
||||||
|
if (!dns)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
ntp = set_new(string_hash_func, string_compare_func);
|
||||||
|
if (!ntp)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
HASHMAP_FOREACH(link, m->links, i) {
|
HASHMAP_FOREACH(link, m->links, i) {
|
||||||
if (link->flags & IFF_LOOPBACK)
|
if (link->flags & IFF_LOOPBACK)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (link->operstate > operstate)
|
if (link->operstate > operstate)
|
||||||
operstate = link->operstate;
|
operstate = link->operstate;
|
||||||
|
|
||||||
|
if (!link->network)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* First add the static configured entries */
|
||||||
|
r = set_put_strdupv(dns, link->network->dns);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
r = set_put_strdupv(ntp, link->network->ntp);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
if (!link->dhcp_lease)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* Secondly, add the entries acquired via DHCP */
|
||||||
|
if (link->network->dhcp_dns) {
|
||||||
|
const struct in_addr *addresses;
|
||||||
|
|
||||||
|
r = sd_dhcp_lease_get_dns(link->dhcp_lease, &addresses);
|
||||||
|
if (r > 0) {
|
||||||
|
r = set_put_in_addrv(dns, addresses, r);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
} else if (r != -ENOENT)
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (link->network->dhcp_ntp) {
|
||||||
|
const struct in_addr *addresses;
|
||||||
|
|
||||||
|
r = sd_dhcp_lease_get_ntp(link->dhcp_lease, &addresses);
|
||||||
|
if (r > 0) {
|
||||||
|
r = set_put_in_addrv(ntp, addresses, r);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
} else if (r != -ENOENT)
|
||||||
|
return r;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
operstate_str = link_operstate_to_string(operstate);
|
operstate_str = link_operstate_to_string(operstate);
|
||||||
@ -448,6 +532,34 @@ int manager_save(Manager *m) {
|
|||||||
"# This is private data. Do not parse.\n"
|
"# This is private data. Do not parse.\n"
|
||||||
"OPER_STATE=%s\n", operstate_str);
|
"OPER_STATE=%s\n", operstate_str);
|
||||||
|
|
||||||
|
if (!set_isempty(dns)) {
|
||||||
|
bool space = false;
|
||||||
|
char *p;
|
||||||
|
|
||||||
|
fputs("DNS=", f);
|
||||||
|
SET_FOREACH(p, dns, i) {
|
||||||
|
if (space)
|
||||||
|
fputc(' ', f);
|
||||||
|
fputs(p, f);
|
||||||
|
space = true;
|
||||||
|
}
|
||||||
|
fputc('\n', f);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!set_isempty(ntp)) {
|
||||||
|
bool space = false;
|
||||||
|
char *p;
|
||||||
|
|
||||||
|
fputs("NTP=", f);
|
||||||
|
SET_FOREACH(p, ntp, i) {
|
||||||
|
if (space)
|
||||||
|
fputc(' ', f);
|
||||||
|
fputs(p, f);
|
||||||
|
space = true;
|
||||||
|
}
|
||||||
|
fputc('\n', f);
|
||||||
|
}
|
||||||
|
|
||||||
r = fflush_and_check(f);
|
r = fflush_and_check(f);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
#include "set.h"
|
#include "set.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
|
#include "strv.h"
|
||||||
|
|
||||||
#define MAKE_SET(h) ((Set*) (h))
|
#define MAKE_SET(h) ((Set*) (h))
|
||||||
#define MAKE_HASHMAP(s) ((Hashmap*) (s))
|
#define MAKE_HASHMAP(s) ((Hashmap*) (s))
|
||||||
@ -59,6 +60,39 @@ int set_consume(Set *s, void *value) {
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int set_put_strdup(Set *s, const char *p) {
|
||||||
|
char *c;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(s);
|
||||||
|
assert(p);
|
||||||
|
|
||||||
|
c = strdup(p);
|
||||||
|
if (!c)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
r = set_consume(s, c);
|
||||||
|
if (r == -EEXIST)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
int set_put_strdupv(Set *s, char **l) {
|
||||||
|
int n = 0, r;
|
||||||
|
char **i;
|
||||||
|
|
||||||
|
STRV_FOREACH(i, l) {
|
||||||
|
r = set_put_strdup(s, *i);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
n += r;
|
||||||
|
}
|
||||||
|
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
int set_replace(Set *s, void *value) {
|
int set_replace(Set *s, void *value) {
|
||||||
return hashmap_replace(MAKE_HASHMAP(s), value, value);
|
return hashmap_replace(MAKE_HASHMAP(s), value, value);
|
||||||
}
|
}
|
||||||
|
@ -41,6 +41,8 @@ int set_ensure_allocated(Set **s, hash_func_t hash_func, compare_func_t compare_
|
|||||||
|
|
||||||
int set_put(Set *s, void *value);
|
int set_put(Set *s, void *value);
|
||||||
int set_consume(Set *s, void *value);
|
int set_consume(Set *s, void *value);
|
||||||
|
int set_put_strdup(Set *s, const char *p);
|
||||||
|
int set_put_strdupv(Set *s, char **l);
|
||||||
int set_replace(Set *s, void *value);
|
int set_replace(Set *s, void *value);
|
||||||
void *set_get(Set *s, void *value);
|
void *set_get(Set *s, void *value);
|
||||||
bool set_contains(Set *s, void *value);
|
bool set_contains(Set *s, void *value);
|
||||||
|
Loading…
Reference in New Issue
Block a user