X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fnet_setup.c;h=70291bffe97111f5f4a30691e63c56172a669351;hp=cad84ccb26d2865157d0289e1de359eda5284ecc;hb=8ae54dc7c782bcc4b771ec0766fcf9eee115756e;hpb=9fed0ec34b9208611a7e96a595f23fa04e60a5c0 diff --git a/src/net_setup.c b/src/net_setup.c index cad84ccb..70291bff 100644 --- a/src/net_setup.c +++ b/src/net_setup.c @@ -339,7 +339,10 @@ bool setup_myself(void) { if(myself->options & OPTION_TCPONLY) myself->options |= OPTION_INDIRECT; + get_config_bool(lookup_config(config_tree, "DirectOnly"), &directonly); + get_config_bool(lookup_config(config_tree, "StrictSubnets"), &strictsubnets); get_config_bool(lookup_config(config_tree, "TunnelServer"), &tunnelserver); + strictsubnets |= tunnelserver; if(get_config_string(lookup_config(config_tree, "Mode"), &mode)) { if(!strcasecmp(mode, "router")) @@ -353,8 +356,21 @@ bool setup_myself(void) { return false; } free(mode); - } else - routing_mode = RMODE_ROUTER; + } + + if(get_config_string(lookup_config(config_tree, "Forwarding"), &mode)) { + if(!strcasecmp(mode, "off")) + forwarding_mode = FMODE_OFF; + else if(!strcasecmp(mode, "internal")) + forwarding_mode = FMODE_INTERNAL; + else if(!strcasecmp(mode, "kernel")) + forwarding_mode = FMODE_KERNEL; + else { + logger(LOG_ERR, "Invalid forwarding mode!"); + return false; + } + free(mode); + } choice = true; get_config_bool(lookup_config(myself->connection->config_tree, "PMTUDiscovery"), &choice); @@ -485,7 +501,7 @@ bool setup_myself(void) { graph(); - if(tunnelserver) + if(strictsubnets) load_all_subnets(); /* Open device */