+
+ switch(proxytype) {
+ case PROXY_NONE:
+ default:
+ break;
+
+ case PROXY_EXEC:
+ if(!space || !*space) {
+ logger(DEBUG_ALWAYS, LOG_ERR, "Argument expected for proxy type exec!");
+ return false;
+ }
+
+ proxyhost = xstrdup(space);
+ break;
+
+ case PROXY_SOCKS4:
+ case PROXY_SOCKS4A:
+ case PROXY_SOCKS5:
+ case PROXY_HTTP:
+ proxyhost = space;
+
+ if(space && (space = strchr(space, ' '))) {
+ *space++ = 0, proxyport = space;
+ }
+
+ if(space && (space = strchr(space, ' '))) {
+ *space++ = 0, proxyuser = space;
+ }
+
+ if(space && (space = strchr(space, ' '))) {
+ *space++ = 0, proxypass = space;
+ }
+
+ if(!proxyhost || !*proxyhost || !proxyport || !*proxyport) {
+ logger(DEBUG_ALWAYS, LOG_ERR, "Host and port argument expected for proxy!");
+ return false;
+ }
+
+ proxyhost = xstrdup(proxyhost);
+ proxyport = xstrdup(proxyport);
+
+ if(proxyuser && *proxyuser) {
+ proxyuser = xstrdup(proxyuser);
+ }
+
+ if(proxypass && *proxypass) {
+ proxypass = xstrdup(proxypass);
+ }
+
+ break;
+ }
+
+ free(proxy);
+ }
+
+ if(get_config_bool(lookup_config(config_tree, "IndirectData"), &choice) && choice) {
+ myself->options |= OPTION_INDIRECT;
+ }
+
+ if(get_config_bool(lookup_config(config_tree, "TCPOnly"), &choice) && choice) {
+ myself->options |= OPTION_TCPONLY;
+ }
+
+ if(myself->options & OPTION_TCPONLY) {
+ myself->options |= OPTION_INDIRECT;
+ }
+
+ get_config_bool(lookup_config(config_tree, "UDPDiscovery"), &udp_discovery);
+ get_config_int(lookup_config(config_tree, "UDPDiscoveryKeepaliveInterval"), &udp_discovery_keepalive_interval);
+ get_config_int(lookup_config(config_tree, "UDPDiscoveryInterval"), &udp_discovery_interval);
+ get_config_int(lookup_config(config_tree, "UDPDiscoveryTimeout"), &udp_discovery_timeout);
+
+ get_config_int(lookup_config(config_tree, "MTUInfoInterval"), &mtu_info_interval);
+ get_config_int(lookup_config(config_tree, "UDPInfoInterval"), &udp_info_interval);
+
+ get_config_bool(lookup_config(config_tree, "DirectOnly"), &directonly);
+ get_config_bool(lookup_config(config_tree, "LocalDiscovery"), &localdiscovery);
+
+ if(get_config_string(lookup_config(config_tree, "Mode"), &rmode)) {
+ if(!strcasecmp(rmode, "router")) {
+ routing_mode = RMODE_ROUTER;
+ } else if(!strcasecmp(rmode, "switch")) {
+ routing_mode = RMODE_SWITCH;
+ } else if(!strcasecmp(rmode, "hub")) {
+ routing_mode = RMODE_HUB;
+ } else {
+ logger(DEBUG_ALWAYS, LOG_ERR, "Invalid routing mode!");
+ return false;
+ }
+
+ free(rmode);
+ }
+
+ if(get_config_string(lookup_config(config_tree, "Forwarding"), &fmode)) {
+ if(!strcasecmp(fmode, "off")) {
+ forwarding_mode = FMODE_OFF;
+ } else if(!strcasecmp(fmode, "internal")) {
+ forwarding_mode = FMODE_INTERNAL;
+ } else if(!strcasecmp(fmode, "kernel")) {
+ forwarding_mode = FMODE_KERNEL;
+ } else {
+ logger(DEBUG_ALWAYS, LOG_ERR, "Invalid forwarding mode!");
+ return false;
+ }
+
+ free(fmode);
+ }
+
+ choice = !(myself->options & OPTION_TCPONLY);
+ get_config_bool(lookup_config(config_tree, "PMTUDiscovery"), &choice);
+
+ if(choice) {
+ myself->options |= OPTION_PMTU_DISCOVERY;
+ }
+
+ choice = true;
+ get_config_bool(lookup_config(config_tree, "ClampMSS"), &choice);
+
+ if(choice) {
+ myself->options |= OPTION_CLAMP_MSS;
+ }
+
+ get_config_bool(lookup_config(config_tree, "PriorityInheritance"), &priorityinheritance);
+ get_config_bool(lookup_config(config_tree, "DecrementTTL"), &decrement_ttl);
+
+ if(get_config_string(lookup_config(config_tree, "Broadcast"), &bmode)) {
+ if(!strcasecmp(bmode, "no")) {
+ broadcast_mode = BMODE_NONE;
+ } else if(!strcasecmp(bmode, "yes") || !strcasecmp(bmode, "mst")) {
+ broadcast_mode = BMODE_MST;
+ } else if(!strcasecmp(bmode, "direct")) {
+ broadcast_mode = BMODE_DIRECT;
+ } else {
+ logger(DEBUG_ALWAYS, LOG_ERR, "Invalid broadcast mode!");
+ return false;
+ }
+
+ free(bmode);