diff options
| author | Arne Schwabe <arne@rfc2549.org> | 2012-05-05 17:55:46 +0200 | 
|---|---|---|
| committer | Arne Schwabe <arne@rfc2549.org> | 2012-05-05 17:55:46 +0200 | 
| commit | 4a7488e0b5dc2a0069d2a4c9b461631016a95d45 (patch) | |
| tree | 4b3ea85dc5d6ef8c2f583238533b4ce20def5936 /src | |
| parent | 93a5fd15a90fe88308003547d55e32123b6999e4 (diff) | |
First time a fd was successfully transfered over a socket :)
Diffstat (limited to 'src')
| -rw-r--r-- | src/de/blinkt/openvpn/AboutFragment.java | 13 | ||||
| -rw-r--r-- | src/de/blinkt/openvpn/LaunchVPN.java | 1 | ||||
| -rw-r--r-- | src/de/blinkt/openvpn/MainActivity.java | 4 | ||||
| -rw-r--r-- | src/de/blinkt/openvpn/OpenVpnManagementThread.java | 76 | ||||
| -rw-r--r-- | src/de/blinkt/openvpn/OpenVpnService.java | 3 | 
5 files changed, 69 insertions, 28 deletions
| diff --git a/src/de/blinkt/openvpn/AboutFragment.java b/src/de/blinkt/openvpn/AboutFragment.java index c96c5833..065e53bc 100644 --- a/src/de/blinkt/openvpn/AboutFragment.java +++ b/src/de/blinkt/openvpn/AboutFragment.java @@ -1,10 +1,12 @@  package de.blinkt.openvpn;  import android.app.Fragment; +import android.content.pm.PackageManager.NameNotFoundException;  import android.os.Bundle;  import android.view.LayoutInflater;  import android.view.View;  import android.view.ViewGroup; +import android.widget.TextView;  public class AboutFragment extends Fragment  { @@ -18,6 +20,17 @@ public class AboutFragment extends Fragment  {      public View onCreateView(LayoutInflater inflater, ViewGroup container,      		Bundle savedInstanceState) {      	View v= inflater.inflate(R.layout.about, container, false); +    	TextView ver = (TextView) v.findViewById(R.id.version); +    	 +    	String version; +		try { +			version = getActivity().getPackageManager().getPackageInfo(getActivity().getPackageName(), 0).versionName; +		} catch (NameNotFoundException e) { +			version = "error fetching version"; +		} + +    	 +    	ver.setText(getString(R.string.version_info,version));      	return v;      } diff --git a/src/de/blinkt/openvpn/LaunchVPN.java b/src/de/blinkt/openvpn/LaunchVPN.java index 2e25f7a2..28abaf3d 100644 --- a/src/de/blinkt/openvpn/LaunchVPN.java +++ b/src/de/blinkt/openvpn/LaunchVPN.java @@ -32,7 +32,6 @@ import android.os.Parcelable;  import android.text.InputType;  import android.text.method.PasswordTransformationMethod;  import android.view.View; -import android.view.inputmethod.EditorInfo;  import android.widget.AdapterView;  import android.widget.AdapterView.OnItemClickListener;  import android.widget.ArrayAdapter; diff --git a/src/de/blinkt/openvpn/MainActivity.java b/src/de/blinkt/openvpn/MainActivity.java index 5eaf146c..86c1d73f 100644 --- a/src/de/blinkt/openvpn/MainActivity.java +++ b/src/de/blinkt/openvpn/MainActivity.java @@ -9,7 +9,9 @@ public class MainActivity extends PreferenceActivity {  	@Override  	public void onBuildHeaders(List<Header> target) { -		loadHeadersFromResource(R.xml.main_headers, target);    +		loadHeadersFromResource(R.xml.main_headers, target); +		//debug +		OpenVPN.foo();  	}  	@Override diff --git a/src/de/blinkt/openvpn/OpenVpnManagementThread.java b/src/de/blinkt/openvpn/OpenVpnManagementThread.java index 2421b28c..093e4d6d 100644 --- a/src/de/blinkt/openvpn/OpenVpnManagementThread.java +++ b/src/de/blinkt/openvpn/OpenVpnManagementThread.java @@ -3,6 +3,8 @@ package de.blinkt.openvpn;  import java.io.FileDescriptor;
  import java.io.IOException;
  import java.io.InputStream;
 +import java.lang.reflect.InvocationTargetException;
 +import java.lang.reflect.Method;
  import java.util.Vector;
  import android.net.LocalSocket;
 @@ -14,9 +16,10 @@ public class OpenVpnManagementThread implements Runnable {  	private LocalSocket mSocket;
  	private VpnProfile mProfile;
  	private OpenVpnService mOpenVPNService;
 -	
 -private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManagementThread>();
 -	
 +	private Vector<Integer> mFDList=new Vector<Integer>();
 +
 +	private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManagementThread>();
 +
  	public OpenVpnManagementThread(VpnProfile profile, LocalSocket mgmtsocket, OpenVpnService openVpnService) {
  		mProfile = profile;
  		mSocket = mgmtsocket;
 @@ -46,7 +49,7 @@ private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManageme  	public void run() {
  		Log.i(TAG, "Managment Socket Thread started");
  		byte [] buffer  =new byte[2048];
 -	//	mSocket.setSoTimeout(5); // Setting a timeout cannot be that bad
 +		//	mSocket.setSoTimeout(5); // Setting a timeout cannot be that bad
  		InputStream instream = null;
  		try {
  			instream = mSocket.getInputStream();
 @@ -55,23 +58,48 @@ private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManageme  		}
  		String pendingInput="";
  		active.add(this);
 -		
 +
  		try {
  			while(true) {
 -			int numbytesread = instream.read(buffer);
 -			if(numbytesread==-1)
 -				return;
 -			
 -			String input = new String(buffer,0,numbytesread,"UTF-8");
 -			
 -			pendingInput += input;
 -			
 -			pendingInput=processInput(pendingInput);
 -			
 -			
 -			
 -		}
 +				int numbytesread = instream.read(buffer);
 +				if(numbytesread==-1)
 +					return;
 +				
 +				FileDescriptor[] fds = null;
 +				try {
 +					fds = mSocket.getAncillaryFileDescriptors();
 +				} catch (IOException e) {
 +					e.printStackTrace();
 +				}
 +				if(fds!=null){
 +					Log.i(TAG, "fds:" + fds);
 +					for (FileDescriptor fd : fds) {
 +						try {
 +							Method getInt = FileDescriptor.class.getDeclaredMethod("getInt$");
 +							int fdint = (Integer) getInt.invoke(fd);
 +							mFDList.add(fdint);
 +						} catch (NoSuchMethodException e) {
 +							e.printStackTrace();
 +						} catch (IllegalArgumentException e) {
 +							e.printStackTrace();
 +						} catch (IllegalAccessException e) {
 +							e.printStackTrace();
 +						} catch (InvocationTargetException e) {
 +							e.printStackTrace();
 +						}
 +					}
 +				}
 +
 +				String input = new String(buffer,0,numbytesread,"UTF-8");
 +
 +				pendingInput += input;
 +
 +				pendingInput=processInput(pendingInput);
 +
 +
 +
 +			}
  		} catch (IOException e) {
  			e.printStackTrace();
  		}
 @@ -80,6 +108,8 @@ private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManageme  	private String processInput(String pendingInput) {
 +
 +
  		while(pendingInput.contains("\n")) {
  			String[] tokens = pendingInput.split("\\r?\\n", 2);
  			processCommand(tokens[0]);
 @@ -105,7 +135,7 @@ private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManageme  			else if (cmd.equals("PASSWORD")) {
  				processPWCommand(argument);
  			} else if (cmd.equals("HOLD")) {
 -				managmentCommand("hold release\nlog on\n");
 +				managmentCommand("hold release\n");
  			} else if (cmd.equals("PROTECT-FD")) {
  				protectFD(argument);
  			}
 @@ -119,7 +149,7 @@ private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManageme  	private void protectFD(String argument) {
  		try {
  			FileDescriptor[] fds = mSocket.getAncillaryFileDescriptors();
 -			
 +
  		} catch (IOException e) {
  			e.printStackTrace();
  		}
 @@ -133,9 +163,9 @@ private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManageme  		int p2 = argument.indexOf('\'',p1+1);
  		//String needed = argument.replace("Need '", "").replace("' password", "");
  		String needed = argument.substring(p1+1, p2);
 -		
 +
  		String pw=null;
 -		
 +
  		if(needed.equals("Private Key")) {
  			pw = mProfile.getPasswordPrivateKey();
  		} else if (needed.equals("Auth")) {
 @@ -148,7 +178,7 @@ private static Vector<OpenVpnManagementThread> active=new Vector<OpenVpnManageme  			String cmd = String.format("password '%s' %s\n", needed, managmentEscape(pw));
  			managmentCommand(cmd);
  		}
 -		
 +
  	}
 diff --git a/src/de/blinkt/openvpn/OpenVpnService.java b/src/de/blinkt/openvpn/OpenVpnService.java index b4ae411a..e6e69ab6 100644 --- a/src/de/blinkt/openvpn/OpenVpnService.java +++ b/src/de/blinkt/openvpn/OpenVpnService.java @@ -17,11 +17,8 @@  package de.blinkt.openvpn;  import java.io.IOException; -import java.lang.reflect.Array;  import java.util.Vector; -import de.blinkt.openvpn.OpenVpnService.CIDRIP; -  import android.app.PendingIntent;  import android.content.Intent;  import android.net.LocalSocket; | 
