gluon-mesh-vpn-core: add simple-tc respondd-provider
omit unlimited bandwidth limit A value of '-' marks a streamdirection as unlimited.
This commit is contained in:
		
							parent
							
								
									16c5c64141
								
							
						
					
					
						commit
						c71959df68
					
				| @ -3,4 +3,4 @@ all: respondd.so | ||||
| CFLAGS += -Wall -Werror-implicit-function-declaration | ||||
| 
 | ||||
| respondd.so: respondd.c | ||||
| 	$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) -shared -fPIC -D_GNU_SOURCE -o $@ $^ $(LDLIBS) -lgluonutil | ||||
| 	$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) -shared -fPIC -D_GNU_SOURCE -o $@ $^ $(LDLIBS) -lgluonutil -luci | ||||
|  | ||||
| @ -23,13 +23,63 @@ | ||||
| 
 | ||||
| #include <respondd.h> | ||||
| 
 | ||||
| #include <stdbool.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <unistd.h> | ||||
| 
 | ||||
| #include <json-c/json.h> | ||||
| #include <libgluonutil.h> | ||||
| #include <uci.h> | ||||
| 
 | ||||
| 
 | ||||
| static struct json_object * get_bandwidth_limit(void) { | ||||
| 	bool enabled = false; | ||||
| 	int egress = -1; | ||||
| 	int ingress = -1; | ||||
| 
 | ||||
| 	struct json_object *ret = json_object_new_object(); | ||||
| 
 | ||||
| 	struct uci_context *ctx = uci_alloc_context(); | ||||
| 	if (!ctx) | ||||
| 		goto disabled; | ||||
| 	ctx->flags &= ~UCI_FLAG_STRICT; | ||||
| 
 | ||||
| 	struct uci_package *p; | ||||
| 	if (uci_load(ctx, "gluon", &p)) | ||||
| 		goto disabled; | ||||
| 
 | ||||
| 	struct uci_section *s = uci_lookup_section(ctx, p, "mesh_vpn"); | ||||
| 	if (!s) | ||||
| 		goto disabled; | ||||
| 
 | ||||
| 	const char *enabled_str = uci_lookup_option_string(ctx, s, "limit_enabled"); | ||||
| 	if (enabled_str && strcmp(enabled_str, "1")) | ||||
| 		goto disabled; | ||||
| 
 | ||||
| 	enabled = true; | ||||
| 
 | ||||
| 	const char *egress_str = uci_lookup_option_string(ctx, s, "limit_egress"); | ||||
| 	if (strcmp(egress_str, "-")) | ||||
| 		egress = atoi(egress_str); | ||||
| 
 | ||||
| 	const char *ingress_str = uci_lookup_option_string(ctx, s, "limit_ingress"); | ||||
| 	if (strcmp(ingress_str, "-")) | ||||
| 		ingress = atoi(ingress_str); | ||||
| 
 | ||||
| 	if (egress >= 0) | ||||
| 		json_object_object_add(ret, "egress", json_object_new_int(egress)); | ||||
| 	if (ingress >= 0) | ||||
| 		json_object_object_add(ret, "ingress", json_object_new_int(ingress)); | ||||
| 
 | ||||
| disabled: | ||||
| 	if (ctx) | ||||
| 		uci_free_context(ctx); | ||||
| 
 | ||||
| 	json_object_object_add(ret, "enabled", json_object_new_boolean(enabled)); | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| char * read_stdout(const char *command) { | ||||
| 	FILE *f = popen(command, "r"); | ||||
| 	if (!f) | ||||
| @ -89,6 +139,7 @@ static struct json_object * respondd_provider_nodeinfo(void) { | ||||
| 	struct json_object *network = json_object_new_object(); | ||||
| 	struct json_object *mesh_vpn = json_object_new_object(); | ||||
| 
 | ||||
| 	json_object_object_add(mesh_vpn, "bandwidth_limit", get_bandwidth_limit()); | ||||
| 	json_object_object_add(mesh_vpn, "provider", get_active_vpn_provider()); | ||||
| 	json_object_object_add(mesh_vpn, "enabled", get_mesh_vpn_enabled()); | ||||
| 	json_object_object_add(network, "mesh_vpn", mesh_vpn); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user