2011-03-21 12:27:51 +01:00
|
|
|
package hu.blint.ssldroid;
|
|
|
|
|
2011-04-12 17:06:00 +02:00
|
|
|
import java.io.IOException;
|
|
|
|
import java.net.ServerSocket;
|
2011-03-21 12:27:51 +01:00
|
|
|
|
|
|
|
import android.util.Log;
|
|
|
|
|
|
|
|
/**
|
2011-03-24 20:59:48 +01:00
|
|
|
* This is a modified version of the TcpTunnelGui utility borrowed from the
|
|
|
|
* xml.apache.org project.
|
2011-03-21 12:27:51 +01:00
|
|
|
*/
|
|
|
|
public class TcpProxy {
|
2011-03-24 20:59:48 +01:00
|
|
|
int listenPort;
|
|
|
|
String tunnelHost;
|
|
|
|
int tunnelPort;
|
|
|
|
String keyFile, keyPass;
|
|
|
|
Thread server = null;
|
2011-04-12 17:06:00 +02:00
|
|
|
ServerSocket ss = null;
|
2011-03-24 20:59:48 +01:00
|
|
|
|
|
|
|
public TcpProxy() {
|
|
|
|
}
|
|
|
|
|
2011-04-15 08:42:03 +02:00
|
|
|
public void serve(int listenPort, String tunnelHost, int tunnelPort, String keyFile, String keyPass) throws IOException {
|
2011-04-12 17:06:00 +02:00
|
|
|
try {
|
|
|
|
ss = new ServerSocket(listenPort);
|
|
|
|
Log.d("SSLDroid", "Listening for connections on port "
|
|
|
|
+ listenPort + " ...");
|
|
|
|
} catch (Exception e) {
|
2011-04-15 08:42:03 +02:00
|
|
|
Log.d("SSLDroid", "Error setting up listening socket: " + e.toString());
|
2011-04-12 17:06:00 +02:00
|
|
|
System.exit(1);
|
|
|
|
}
|
|
|
|
server = new TcpProxyServerThread(ss, listenPort, tunnelHost, tunnelPort, keyFile, keyPass);
|
2011-03-24 20:59:48 +01:00
|
|
|
server.start();
|
|
|
|
}
|
|
|
|
|
|
|
|
public void stop() {
|
2011-04-12 17:06:00 +02:00
|
|
|
if (server != null){
|
2011-03-24 20:59:48 +01:00
|
|
|
try {
|
2011-04-20 19:08:14 +02:00
|
|
|
//close the server socket and interrupt the server thread
|
2011-04-12 17:06:00 +02:00
|
|
|
ss.close();
|
|
|
|
server.interrupt();
|
|
|
|
} catch (Exception e) {
|
|
|
|
Log.d("SSLDroid", "Interrupt failure: " + e.toString());
|
2011-03-21 12:27:51 +01:00
|
|
|
}
|
2011-03-24 20:59:48 +01:00
|
|
|
}
|
2011-04-12 17:06:00 +02:00
|
|
|
Log.d("SSLDroid", "Stopping service");
|
2011-03-21 12:27:51 +01:00
|
|
|
}
|
2011-04-12 17:06:00 +02:00
|
|
|
|
2011-04-20 19:08:14 +02:00
|
|
|
//if the listening socket is still active, we're alive
|
2011-04-20 18:10:34 +02:00
|
|
|
public boolean isAlive(){
|
|
|
|
return ss.isBound();
|
|
|
|
}
|
2011-04-12 17:06:00 +02:00
|
|
|
|
|
|
|
}
|