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 | CFLAGS += -Wall -Werror-implicit-function-declaration | ||||||
| 
 | 
 | ||||||
| respondd.so: respondd.c | 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 <respondd.h> | ||||||
| 
 | 
 | ||||||
|  | #include <stdbool.h> | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
|  | #include <unistd.h> | ||||||
| 
 | 
 | ||||||
| #include <json-c/json.h> | #include <json-c/json.h> | ||||||
| #include <libgluonutil.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) { | char * read_stdout(const char *command) { | ||||||
| 	FILE *f = popen(command, "r"); | 	FILE *f = popen(command, "r"); | ||||||
| 	if (!f) | 	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 *network = json_object_new_object(); | ||||||
| 	struct json_object *mesh_vpn = 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, "provider", get_active_vpn_provider()); | ||||||
| 	json_object_object_add(mesh_vpn, "enabled", get_mesh_vpn_enabled()); | 	json_object_object_add(mesh_vpn, "enabled", get_mesh_vpn_enabled()); | ||||||
| 	json_object_object_add(network, "mesh_vpn", mesh_vpn); | 	json_object_object_add(network, "mesh_vpn", mesh_vpn); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user