瀏覽代碼

control->Send: Also set the src port

With the source port also set, we only need to enable inbound
firewall rules on the 'server' side of the connection, as
the conntrack will allow replies.
Dave Russell 5 年之前
父節點
當前提交
e9657d571e
共有 1 個文件被更改,包括 5 次插入0 次删除
  1. 5 0
      control.go

+ 5 - 0
control.go

@@ -204,7 +204,12 @@ func (c *Control) Send(ip uint32, port uint16, t NebulaMessageSubType, payload [
 	binary.BigEndian.PutUint16(packet[2:4], uint16(length))
 	binary.BigEndian.PutUint32(packet[12:16], ip2int(c.f.inside.CidrNet().IP.To4()))
 	binary.BigEndian.PutUint32(packet[16:20], ip)
+
+	// Set identical values for src and dst port as they're only
+	// used for nebula firewall rule mataching.
+	binary.BigEndian.PutUint16(packet[20:22], port)
 	binary.BigEndian.PutUint16(packet[22:24], port)
+
 	copy(packet[headerLen:], payload)
 
 	nb := make([]byte, 12)