X-Git-Url: https://tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fprotocol_edge.c;h=af0b2e7243d31d5b65ebe48f5e90d4cd9887cf10;hp=5949a38e7bea336fdbdcb1ca1dd994a29abb6d61;hb=0e59fb022c6c015a5be7ed70e0378cb011be98b5;hpb=a8f415e67fd316d929f9b9e6661e0d3d66fc197b diff --git a/src/protocol_edge.c b/src/protocol_edge.c index 5949a38e..af0b2e72 100644 --- a/src/protocol_edge.c +++ b/src/protocol_edge.c @@ -17,7 +17,7 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id: protocol_edge.c,v 1.1.4.21 2003/08/28 15:27:12 guus Exp $ + $Id: protocol_edge.c,v 1.1.4.22 2003/11/10 22:31:53 guus Exp $ */ #include "system.h" @@ -110,6 +110,9 @@ bool add_edge_h(connection_t *c) node_add(to); } + if(c->status.opaque && from != myself && from != c->node && to != myself && to != c->node) + return false; + /* Convert addresses */ address = str2sockaddr(to_address, to_port); @@ -154,7 +157,8 @@ bool add_edge_h(connection_t *c) /* Tell the rest about the new edge */ - forward_request(c); + if(!c->status.opaque) + forward_request(c); /* Run MST before or after we tell the rest? */ @@ -221,6 +225,9 @@ bool del_edge_h(connection_t *c) return true; } + if(c->status.opaque && from != myself && from != c->node && to != myself && to != c->node) + return false; + /* Check if edge exists */ e = lookup_edge(from, to); @@ -240,7 +247,8 @@ bool del_edge_h(connection_t *c) /* Tell the rest about the deleted edge */ - forward_request(c); + if(!c->status.opaque) + forward_request(c); /* Delete the edge */