Browse Source

Trojan: Do not panic when UDP dispatcher failed to write response (#153)

maskedeken 4 years ago
parent
commit
96adf3fbca
1 changed files with 4 additions and 1 deletions
  1. 4 1
      proxy/trojan/server.go

+ 4 - 1
proxy/trojan/server.go

@@ -256,7 +256,10 @@ func (s *Server) handleUDPPayload(ctx context.Context, clientReader *PacketReade
 		if udpPayload.UDP == nil {
 			udpPayload.UDP = &packet.Source
 		}
-		common.Must(clientWriter.WriteMultiBuffer(buf.MultiBuffer{udpPayload}))
+
+		if err := clientWriter.WriteMultiBuffer(buf.MultiBuffer{udpPayload}); err != nil {
+			newError("failed to write response").Base(err).AtWarning().WriteToLog(session.ExportIDToError(ctx))
+		}
 	})
 
 	inbound := session.InboundFromContext(ctx)