X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fubus.git;a=blobdiff_plain;f=ubusd_proto.c;h=d2feed9aa3ae027b648586ade4d5803d23b51960;hp=b591384283ed0669e3b2f0234ec11c31a2c3f74f;hb=5ca6bae3a27ca02e304339ed0d94a8baa461b609;hpb=d009a084735c7e0bca28ca05919fa9c60007f314 diff --git a/ubusd_proto.c b/ubusd_proto.c index b591384..d2feed9 100644 --- a/ubusd_proto.c +++ b/ubusd_proto.c @@ -156,7 +156,7 @@ static int ubusd_handle_add_object(struct ubus_client *cl, struct ubus_msg_buf * static void ubusd_send_obj(struct ubus_client *cl, struct ubus_msg_buf *ub, struct ubus_object *obj) { struct ubus_method *m; - int cnt = 0; + int all_cnt = 0, cnt = 0; void *s; if (!obj->type) @@ -170,6 +170,7 @@ static void ubusd_send_obj(struct ubus_client *cl, struct ubus_msg_buf *ub, stru s = blob_nest_start(&b, UBUS_ATTR_SIGNATURE); list_for_each_entry(m, &obj->type->methods, list) { + all_cnt++; if (!ubusd_acl_check(cl, obj->path.key, blobmsg_name(m->data), UBUS_ACL_ACCESS)) { blobmsg_add_blob(&b, m->data); cnt++; @@ -177,7 +178,7 @@ static void ubusd_send_obj(struct ubus_client *cl, struct ubus_msg_buf *ub, stru } blob_nest_end(&b, s); - if (cnt) + if (cnt || !all_cnt) ubus_proto_send_msg_from_blob(cl, ub, UBUS_MSG_DATA); }