summaryrefslogtreecommitdiff
path: root/ubus.c
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2013-02-01 13:17:41 +0100
committerSteven Barth <steven@midlink.org>2013-02-01 13:17:41 +0100
commitf73f11865e8601a0cb3983a6f2b2beb5ebabd14d (patch)
treece6165fabeba21f4e0905ecda3ee08e99b8c2d10 /ubus.c
parent4bb99d4eb462776336928392010b372236ac3c93 (diff)
downloadnetifd-f73f11865e8601a0cb3983a6f2b2beb5ebabd14d.tar.gz
Improved IPv6 featureset
* Fix reloading of ula-prefixes * Added support for temporary addresses and routes * Added support for offlink addresses * Improved status-output for assigned prefixes
Diffstat (limited to 'ubus.c')
-rw-r--r--ubus.c67
1 files changed, 60 insertions, 7 deletions
diff --git a/ubus.c b/ubus.c
index 2fd9e92..f2421cc 100644
--- a/ubus.c
+++ b/ubus.c
@@ -347,6 +347,7 @@ interface_ip_dump_address_list(struct interface_ip_settings *ip, bool v6,
int buflen = 128;
int af;
+ time_t now = system_get_rtime();
vlist_for_each_element(&ip->addr, addr, node) {
if (addr->enabled != enabled)
continue;
@@ -367,6 +368,16 @@ interface_ip_dump_address_list(struct interface_ip_settings *ip, bool v6,
blobmsg_add_u32(&b, "mask", addr->mask);
+ if (addr->preferred_until) {
+ int preferred = addr->preferred_until - now;
+ if (preferred < 0)
+ preferred = 0;
+ blobmsg_add_u32(&b, "preferred", preferred);
+ }
+
+ if (addr->valid_until)
+ blobmsg_add_u32(&b, "valid", addr->valid_until - now);
+
blobmsg_close_table(&b, a);
}
}
@@ -380,6 +391,7 @@ interface_ip_dump_route_list(struct interface_ip_settings *ip, bool enabled)
void *r;
int af;
+ time_t now = system_get_rtime();
vlist_for_each_element(&ip->route, route, node) {
if (route->enabled != enabled)
continue;
@@ -407,6 +419,9 @@ interface_ip_dump_route_list(struct interface_ip_settings *ip, bool enabled)
if (route->flags & DEVROUTE_METRIC)
blobmsg_add_u32(&b, "metric", route->metric);
+ if (route->valid_until)
+ blobmsg_add_u32(&b, "valid", route->valid_until - now);
+
blobmsg_close_table(&b, r);
}
}
@@ -420,6 +435,7 @@ interface_ip_dump_prefix_list(struct interface_ip_settings *ip)
void *a, *c;
const int buflen = INET6_ADDRSTRLEN;
+ time_t now = system_get_rtime();
vlist_for_each_element(&ip->prefix, prefix, node) {
a = blobmsg_open_table(&b, NULL);
@@ -429,7 +445,6 @@ interface_ip_dump_prefix_list(struct interface_ip_settings *ip)
blobmsg_add_u32(&b, "mask", prefix->length);
- time_t now = system_get_rtime();
if (prefix->preferred_until) {
int preferred = prefix->preferred_until - now;
if (preferred < 0)
@@ -437,12 +452,8 @@ interface_ip_dump_prefix_list(struct interface_ip_settings *ip)
blobmsg_add_u32(&b, "preferred", preferred);
}
- if (prefix->valid_until) {
- int valid = prefix->valid_until - now;
- if (valid < 0)
- valid = 0;
- blobmsg_add_u32(&b, "valid", valid);
- }
+ if (prefix->valid_until)
+ blobmsg_add_u32(&b, "valid", prefix->valid_until - now);
c = blobmsg_open_table(&b, "assigned");
struct device_prefix_assignment *assign;
@@ -465,6 +476,45 @@ interface_ip_dump_prefix_list(struct interface_ip_settings *ip)
static void
+interface_ip_dump_prefix_assignment_list(struct interface *iface)
+{
+ void *a;
+ char *buf;
+ const int buflen = INET6_ADDRSTRLEN;
+ time_t now = system_get_rtime();
+
+ struct device_prefix *prefix;
+ list_for_each_entry(prefix, &prefixes, head) {
+ struct device_prefix_assignment *assign;
+ vlist_for_each_element(prefix->assignments, assign, node) {
+ if (strcmp(assign->name, iface->name))
+ continue;
+
+ a = blobmsg_open_table(&b, NULL);
+
+ buf = blobmsg_alloc_string_buffer(&b, "address", buflen);
+ inet_ntop(AF_INET6, &assign->addr, buf, buflen);
+ blobmsg_add_string_buffer(&b);
+
+ blobmsg_add_u32(&b, "mask", assign->length);
+
+ if (prefix->preferred_until) {
+ int preferred = prefix->preferred_until - now;
+ if (preferred < 0)
+ preferred = 0;
+ blobmsg_add_u32(&b, "preferred", preferred);
+ }
+
+ if (prefix->valid_until)
+ blobmsg_add_u32(&b, "valid", prefix->valid_until - now);
+
+ blobmsg_close_table(&b, a);
+ }
+ }
+}
+
+
+static void
interface_ip_dump_dns_server_list(struct interface_ip_settings *ip,
bool enabled)
{
@@ -542,6 +592,9 @@ netifd_handle_status(struct ubus_context *ctx, struct ubus_object *obj,
interface_ip_dump_prefix_list(&iface->config_ip);
interface_ip_dump_prefix_list(&iface->proto_ip);
blobmsg_close_array(&b, a);
+ a = blobmsg_open_array(&b, "ipv6-prefix-assignment");
+ interface_ip_dump_prefix_assignment_list(iface);
+ blobmsg_close_array(&b, a);
a = blobmsg_open_array(&b, "route");
interface_ip_dump_route_list(&iface->config_ip, true);
interface_ip_dump_route_list(&iface->proto_ip, true);