Zbigniew Jędrzejewski-Szmek 62fe94
From adc5b2e2ebcb91ee18b6a32681b8ec1e52793473 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: Tom Gundersen <teg@jklm.no>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Mon, 8 Sep 2014 13:50:52 +0200
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] sd-network: add _get_network_file api
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 src/libsystemd/sd-network/sd-network.c | 24 ++++++++++++++++++++++++
Zbigniew Jędrzejewski-Szmek 62fe94
 src/network/networkd-link.c            |  2 ++
Zbigniew Jędrzejewski-Szmek 62fe94
 src/systemd/sd-network.h               |  3 +++
Zbigniew Jędrzejewski-Szmek 62fe94
 3 files changed, 29 insertions(+)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/libsystemd/sd-network/sd-network.c b/src/libsystemd/sd-network/sd-network.c
Zbigniew Jędrzejewski-Szmek 62fe94
index 3a3f53576f..d63e6f9dfa 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/libsystemd/sd-network/sd-network.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/libsystemd/sd-network/sd-network.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -120,6 +120,30 @@ _public_ int sd_network_link_get_setup_state(int ifindex, char **state) {
Zbigniew Jędrzejewski-Szmek 62fe94
         return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
 }
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
+_public_ int sd_network_link_get_network_file(int ifindex, char **filename) {
Zbigniew Jędrzejewski-Szmek 62fe94
+        _cleanup_free_ char *s = NULL, *p = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
+        int r;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        assert_return(ifindex > 0, -EINVAL);
Zbigniew Jędrzejewski-Szmek 62fe94
+        assert_return(filename, -EINVAL);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (asprintf(&p, "/run/systemd/netif/links/%d", ifindex) < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return -ENOMEM;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        r = parse_env_file(p, NEWLINE, "NETWORK_FILE", &s, NULL);
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (r == -ENOENT)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return -ENODATA;
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (r < 0)
Zbigniew Jędrzejewski-Szmek 62fe94
+                return r;
Zbigniew Jędrzejewski-Szmek 62fe94
+        if (isempty(s))
Zbigniew Jędrzejewski-Szmek 62fe94
+                return -ENODATA;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        *filename = s;
Zbigniew Jędrzejewski-Szmek 62fe94
+        s = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
+        return 0;
Zbigniew Jędrzejewski-Szmek 62fe94
+}
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
 _public_ int sd_network_link_get_operational_state(int ifindex, char **state) {
Zbigniew Jędrzejewski-Szmek 62fe94
         _cleanup_free_ char *s = NULL, *p = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
         int r;
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/network/networkd-link.c b/src/network/networkd-link.c
Zbigniew Jędrzejewski-Szmek 62fe94
index a88cf48d9d..11ac1307d8 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/network/networkd-link.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/network/networkd-link.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -1785,6 +1785,8 @@ int link_save(Link *link) {
Zbigniew Jędrzejewski-Szmek 62fe94
                 char **address, **domain;
Zbigniew Jędrzejewski-Szmek 62fe94
                 bool space;
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
+                fprintf(f, "NETWORK_FILE=%s\n", link->network->filename);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
                 fputs("DNS=", f);
Zbigniew Jędrzejewski-Szmek 62fe94
                 space = false;
Zbigniew Jędrzejewski-Szmek 62fe94
                 STRV_FOREACH(address, link->network->dns) {
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/systemd/sd-network.h b/src/systemd/sd-network.h
Zbigniew Jędrzejewski-Szmek 62fe94
index b2086c7836..203a2a6a47 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/systemd/sd-network.h
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/systemd/sd-network.h
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -93,6 +93,9 @@ int sd_network_link_get_setup_state(int ifindex, char **state);
Zbigniew Jędrzejewski-Szmek 62fe94
  */
Zbigniew Jędrzejewski-Szmek 62fe94
 int sd_network_link_get_operational_state(int ifindex, char **state);
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
+/* Get path to .network file applied to link */
Zbigniew Jędrzejewski-Szmek 62fe94
+int sd_network_link_get_network_file(int ifindex, char **filename);
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
 /* Get DNS entries for a given link. These are string representations of
Zbigniew Jędrzejewski-Szmek 62fe94
  * IP addresses */
Zbigniew Jędrzejewski-Szmek 62fe94
 int sd_network_link_get_dns(int ifindex, char ***addr);