diff options
author | Arne Schwabe <arne@rfc2549.org> | 2021-01-21 12:24:06 +0100 |
---|---|---|
committer | Arne Schwabe <arne@rfc2549.org> | 2021-02-16 16:40:04 +0100 |
commit | 96db8d0bf1110f029cf5ad90bc939cd444100600 (patch) | |
tree | b2d7915f465bdeee6847e171e72a5c28e7bd9b72 /main/src/ui | |
parent | a965f961b5dc5cba44d9a81a538c11c4394de24e (diff) |
Implement UI support for --peer-fingerprint
Diffstat (limited to 'main/src/ui')
-rw-r--r-- | main/src/ui/java/de/blinkt/openvpn/fragments/Settings_Basic.java | 19 | ||||
-rw-r--r-- | main/src/ui/res/layout/basic_settings.xml | 14 |
2 files changed, 32 insertions, 1 deletions
diff --git a/main/src/ui/java/de/blinkt/openvpn/fragments/Settings_Basic.java b/main/src/ui/java/de/blinkt/openvpn/fragments/Settings_Basic.java index 294b33fb..0afb754d 100644 --- a/main/src/ui/java/de/blinkt/openvpn/fragments/Settings_Basic.java +++ b/main/src/ui/java/de/blinkt/openvpn/fragments/Settings_Basic.java @@ -20,7 +20,7 @@ import de.blinkt.openvpn.VpnProfile; import de.blinkt.openvpn.core.ProfileManager; import de.blinkt.openvpn.views.FileSelectLayout; -public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSelectedListener, FileSelectLayout.FileSelectCallback { +public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSelectedListener, FileSelectLayout.FileSelectCallback, CompoundButton.OnCheckedChangeListener { private static final int CHOOSE_FILE_OFFSET = 1000; private FileSelectLayout mClientCert; @@ -36,6 +36,8 @@ public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSe private View mView; private EditText mProfileName; private EditText mKeyPassword; + private CheckBox mEnablePeerFingerprint; + private EditText mPeerFingerprints; private SparseArray<FileSelectLayout> fileselects = new SparseArray<>(); private Spinner mAuthRetry; @@ -68,6 +70,8 @@ public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSe mUseLzo = mView.findViewById(id.lzo); mType = mView.findViewById(id.type); mPKCS12Password = mView.findViewById(id.pkcs12password); + mEnablePeerFingerprint = mView.findViewById(id.enable_peer_fingerprint); + mPeerFingerprints = mView.findViewById(id.peer_fingerprint); mUserName = mView.findViewById(id.auth_username); mPassword = mView.findViewById(id.auth_password); @@ -84,6 +88,7 @@ public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSe mType.setOnItemSelectedListener(this); mAuthRetry.setOnItemSelectedListener(this); + mEnablePeerFingerprint.setOnCheckedChangeListener(this); initKeychainViews(mView); @@ -192,6 +197,8 @@ public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSe mPassword.setText(mProfile.mPassword); mKeyPassword.setText(mProfile.mKeyPassword); mAuthRetry.setSelection(mProfile.mAuthRetry); + mEnablePeerFingerprint.setChecked(mProfile.mCheckPeerFingerprint); + mPeerFingerprints.setText(mProfile.mPeerFingerPrints); } protected void savePreferences() { @@ -211,6 +218,8 @@ public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSe mProfile.mUsername = mUserName.getText().toString(); mProfile.mKeyPassword = mKeyPassword.getText().toString(); mProfile.mAuthRetry = mAuthRetry.getSelectedItemPosition(); + mProfile.mCheckPeerFingerprint = mEnablePeerFingerprint.isChecked(); + mProfile.mPeerFingerPrints = mPeerFingerprints.getText().toString(); } @@ -228,4 +237,12 @@ public class Settings_Basic extends KeyChainSettingsFragment implements OnItemSe } + @Override + public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { + if (buttonView == mEnablePeerFingerprint) + { + mPeerFingerprints.setVisibility(isChecked ? View.VISIBLE : View.GONE); + + } + } } diff --git a/main/src/ui/res/layout/basic_settings.xml b/main/src/ui/res/layout/basic_settings.xml index 66f8b1fa..6763e52f 100644 --- a/main/src/ui/res/layout/basic_settings.xml +++ b/main/src/ui/res/layout/basic_settings.xml @@ -88,6 +88,20 @@ blinkt:showClear="true" blinkt:fileTitle="@string/ca_title" /> + <CheckBox + android:id="@+id/enable_peer_fingerprint" + style="@style/item" + android:text="@string/check_peer_fingerprint" + /> + + <EditText + android:id="@+id/peer_fingerprint" + style="@style/item" + android:inputType="textMultiLine" + android:layout_marginLeft="8dip" + android:layout_marginRight="8dip" + android:hint="@string/fingerprint" + android:visibility="gone" /> </LinearLayout> <LinearLayout |