From 8e6775102cae857726601cc4f32dcb774cd4e50b Mon Sep 17 00:00:00 2001 From: Arne Schwabe Date: Thu, 7 Mar 2013 22:22:42 +0100 Subject: Add x509-verify-name support to ics-openvpn GUI --HG-- extra : rebase_source : 58613dd0fdf7a9ea75d59b1ea16c68fb6524138b --- src/de/blinkt/openvpn/RemoteCNPreference.java | 109 ++++++++++++++++++++++++++ 1 file changed, 109 insertions(+) create mode 100644 src/de/blinkt/openvpn/RemoteCNPreference.java (limited to 'src/de/blinkt/openvpn/RemoteCNPreference.java') diff --git a/src/de/blinkt/openvpn/RemoteCNPreference.java b/src/de/blinkt/openvpn/RemoteCNPreference.java new file mode 100644 index 00000000..4daf54c2 --- /dev/null +++ b/src/de/blinkt/openvpn/RemoteCNPreference.java @@ -0,0 +1,109 @@ +package de.blinkt.openvpn; + +import android.content.Context; +import android.preference.DialogPreference; +import android.preference.EditTextPreference; +import android.preference.ListPreference; +import android.util.AttributeSet; +import android.util.Pair; +import android.view.View; +import android.view.ViewGroup; +import android.widget.ArrayAdapter; +import android.widget.EditText; +import android.widget.Spinner; + +public class RemoteCNPreference extends DialogPreference { + + + private Spinner mSpinner; + private EditText mEditText; + private int mDNType; + private ArrayAdapter mAuthtypes; + private String mDn; + + public RemoteCNPreference(Context context, AttributeSet attrs) { + super(context, attrs); + setDialogLayoutResource(R.layout.tlsremote); + + } + + @Override + protected void onBindDialogView(View view) { + + super.onBindDialogView(view); + + mEditText = (EditText) view.findViewById(R.id.tlsremotecn); + mSpinner = (Spinner) view.findViewById(R.id.x509verifytype); + if(mDn!=null) + mEditText.setText(mDn); + + populateSpinner(); + + } + + private void populateSpinner() { + mAuthtypes = new ArrayAdapter(getContext(), android.R.layout.simple_spinner_item); + mAuthtypes.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); + + mAuthtypes.add(getContext().getString(R.string.complete_dn)); + mAuthtypes.add("RDN (common name)"); + mAuthtypes.add("RDN prefix"); + if (mDNType == VpnProfile.X509_VERIFY_TLSREMOTE || mDNType == VpnProfile.X509_VERIFY_TLSREMOTE_COMPAT_NOREMAPPING ) + mAuthtypes.add("tls-remote (DEPRECATED)"); + + mSpinner.setAdapter(mAuthtypes); + } + + public String getCNText() { + return mDn; + } + + public int getAuthtype() { + return mDNType; + } + + public void setDN(String dn) { + mDn = dn; + if(mEditText!=null) + mEditText.setText(dn); + } + + void setAuthType(int x509authtype) { + mDNType = x509authtype; + if (mSpinner!=null) + populateSpinner(); + } + + @Override + protected void onDialogClosed(boolean positiveResult) { + super.onDialogClosed(positiveResult); + + if (positiveResult) { + String dn = mEditText.getText().toString(); + int authtype = getAuthTypeFromSpinner(); + if (callChangeListener(new Pair(authtype, dn))) { + mDn = dn; + mDNType = authtype; + } + } + } + + private int getAuthTypeFromSpinner() { + int pos = mSpinner.getSelectedItemPosition(); + switch (pos) { + case 0: + return VpnProfile.X509_VERIFY_TLSREMOTE_DN; + case 1: + return VpnProfile.X509_VERIFY_TLSREMOTE_RDN; + case 2: + return VpnProfile.X509_VERIFY_TLSREMOTE_RDN_PREFIX; + case 3: + // This is the tls-remote entry, only visible if mDntype is a + // tls-remote type + return mDNType; + default: + return VpnProfile.X509_VERIFY_TLSREMOTE; + } + } + +} -- cgit v1.2.3