+static int netifd_handle_status(struct ubus_context *ctx, struct ubus_object *obj,
+ struct ubus_request_data *req, const char *method,
+ struct blob_attr *msg)
+{
+ struct interface *iface;
+
+ iface = container_of(obj, struct interface, ubus);
+
+ blob_buf_init(&b, 0);
+ blobmsg_add_u8(&b, "up", iface->up);
+ blobmsg_add_u8(&b, "active", iface->active);
+ blobmsg_add_u8(&b, "autostart", iface->autostart);
+ if (iface->main_dev.dev) {
+ struct device *dev = iface->main_dev.dev;
+
+ if (dev->avl.key)
+ blobmsg_add_string(&b, "device", dev->ifname);
+ else
+ /* use a different field for virtual devices */
+ blobmsg_add_string(&b, "link", dev->ifname);
+ }
+
+ ubus_send_reply(ctx, req, b.head);
+
+ return 0;
+}
+