From b686acb27ea4de042320fa196cfb14e08f30165b Mon Sep 17 00:00:00 2001 From: Tom Gundersen Date: Mon, 2 Jun 2014 15:13:30 +0200 Subject: [PATCH] resolved: move resolv.conf to resolved's runtime dir --- man/systemd-resolved.service.xml | 4 ++-- src/resolve/resolved-manager.c | 8 ++++---- src/resolve/resolved.c | 2 +- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/man/systemd-resolved.service.xml b/man/systemd-resolved.service.xml index cd73cb73c7e..ed1f5a23658 100644 --- a/man/systemd-resolved.service.xml +++ b/man/systemd-resolved.service.xml @@ -58,7 +58,7 @@ systemd-networkd is a system service that manages network name resolution. It does so by - generating /run/systemd/network/resolv.conf, + generating /run/systemd/resolve/resolv.conf, which may be symlinked from /etc/resolv.conf. The contents is generated from the global settings in resolved.conf5, @@ -67,7 +67,7 @@ systemd.network5 for more details. - Note that /run/systemd/network/resolv.conf + Note that /run/systemd/resolve/resolv.conf should not be used directly, but only through a symlink from /etc/resolv.conf. diff --git a/src/resolve/resolved-manager.c b/src/resolve/resolved-manager.c index ae173991da2..3ed0603f9b2 100644 --- a/src/resolve/resolved-manager.c +++ b/src/resolve/resolved-manager.c @@ -30,7 +30,6 @@ #include "dhcp-lease-internal.h" #include "network-internal.h" #include "conf-parser.h" -#include "mkdir.h" static int set_fallback_dns(Manager *m, const char *string) { char *word, *state; @@ -192,6 +191,7 @@ static void append_dns(FILE *f, void *dns, unsigned char family, unsigned *count } int manager_update_resolv_conf(Manager *m) { + const char *path = "/run/systemd/resolve/resolv.conf"; _cleanup_free_ char *temp_path = NULL; _cleanup_fclose_ FILE *f = NULL; _cleanup_free_ unsigned *indices = NULL; @@ -201,7 +201,7 @@ int manager_update_resolv_conf(Manager *m) { assert(m); - r = fopen_temporary("/run/systemd/network/resolv.conf", &f, &temp_path); + r = fopen_temporary(path, &f, &temp_path); if (r < 0) return r; @@ -263,9 +263,9 @@ int manager_update_resolv_conf(Manager *m) { fflush(f); - if (ferror(f) || rename(temp_path, "/run/systemd/network/resolv.conf") < 0) { + if (ferror(f) || rename(temp_path, path) < 0) { r = -errno; - unlink("/run/systemd/network/resolv.conf"); + unlink(path); unlink(temp_path); return r; } diff --git a/src/resolve/resolved.c b/src/resolve/resolved.c index 82f43d68031..2eaff60fce8 100644 --- a/src/resolve/resolved.c +++ b/src/resolve/resolved.c @@ -43,7 +43,7 @@ int main(int argc, char *argv[]) { } /* Always create the directory where resolv.conf will live */ - r = mkdir_label("/run/systemd/network", 0755); + r = mkdir_label("/run/systemd/resolve", 0755); if (r < 0) log_error("Could not create runtime directory: %s", strerror(-r)); -- 2.39.2