Commit 82bccaca authored by Thiago Camargo's avatar Thiago Camargo Committed by thiago

Improved Security

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk@6686 b35dd754-fafc-0310-a699-88a17e54d16e
parent e5803eeb
...@@ -104,8 +104,8 @@ public class SmartSession extends MediaProxySession { ...@@ -104,8 +104,8 @@ public class SmartSession extends MediaProxySession {
* Default Channel Constructor * Default Channel Constructor
* *
* @param dataSocket datasocket to used to send and receive packets * @param dataSocket datasocket to used to send and receive packets
* @param host default destination host for received packets * @param host default destination host for received packets
* @param port default destination port for received packets * @param port default destination port for received packets
*/ */
public SmartChannel(DatagramSocket dataSocket, InetAddress host, int port) { public SmartChannel(DatagramSocket dataSocket, InetAddress host, int port) {
super(dataSocket, host, port); super(dataSocket, host, port);
...@@ -117,23 +117,22 @@ public class SmartSession extends MediaProxySession { ...@@ -117,23 +117,22 @@ public class SmartSession extends MediaProxySession {
public void run() { public void run() {
try { try {
long c = 0; long c = 0;
long band = System.currentTimeMillis();
while (true) { while (true) {
// Block until a datagram appears: // Block until a datagram appears:
packet = new DatagramPacket(buf, buf.length); packet = new DatagramPacket(buf, buf.length);
dataSocket.receive(packet); dataSocket.receive(packet);
if (this.getPort() != packet.getPort()) // Relay Destination
System.out.println(dataSocket.getLocalAddress().getHostAddress() + ":" + dataSocket.getLocalPort() + " relay to: " + packet.getAddress().getHostAddress() + ":" + packet.getPort()); if (c++ < 100) { // 100 packets are enough to discover relay address
this.setHost(packet.getAddress());
if (c++ < 5) { this.setPort(packet.getPort());
System.out.println("Received:" + dataSocket.getLocalAddress().getHostAddress() + ":" + dataSocket.getLocalPort()); } else {
c = 1000; // Prevents long overflow
System.out.println("Addr: " + packet.getAddress().getHostName()); // Check Source Address. If its different, discard packet.
if (!this.getHost().equals(packet.getAddress())) continue;
} }
this.setHost(packet.getAddress());
this.setPort(packet.getPort());
boolean resend = true; boolean resend = true;
for (DatagramListener dl : listeners) { for (DatagramListener dl : listeners) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment