summaryrefslogtreecommitdiff
path: root/main/src
diff options
context:
space:
mode:
Diffstat (limited to 'main/src')
-rw-r--r--main/src/main/java/de/blinkt/openvpn/activities/ConfigConverter.java65
1 files changed, 40 insertions, 25 deletions
diff --git a/main/src/main/java/de/blinkt/openvpn/activities/ConfigConverter.java b/main/src/main/java/de/blinkt/openvpn/activities/ConfigConverter.java
index 1ad9d9e3..9dee3557 100644
--- a/main/src/main/java/de/blinkt/openvpn/activities/ConfigConverter.java
+++ b/main/src/main/java/de/blinkt/openvpn/activities/ConfigConverter.java
@@ -4,9 +4,7 @@ package de.blinkt.openvpn.activities;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
-import android.app.ListActivity;
import android.content.ActivityNotFoundException;
-import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.os.Bundle;
@@ -16,13 +14,31 @@ import android.security.KeyChain;
import android.security.KeyChainAliasCallback;
import android.text.TextUtils;
import android.util.Base64;
-import android.util.Log;
-import android.view.*;
-import android.widget.ArrayAdapter;
+import android.view.Menu;
+import android.view.MenuInflater;
+import android.view.MenuItem;
+import android.view.View;
+import android.view.ViewGroup;
import android.widget.CheckBox;
import android.widget.LinearLayout;
import android.widget.TextView;
+import junit.framework.Assert;
+
+import org.jetbrains.annotations.NotNull;
+
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Vector;
+
import de.blinkt.openvpn.R;
import de.blinkt.openvpn.VpnProfile;
import de.blinkt.openvpn.core.ConfigParser;
@@ -30,12 +46,6 @@ import de.blinkt.openvpn.core.ConfigParser.ConfigParseError;
import de.blinkt.openvpn.core.ProfileManager;
import de.blinkt.openvpn.fragments.Utils;
import de.blinkt.openvpn.views.FileSelectLayout;
-import junit.framework.Assert;
-
-import org.jetbrains.annotations.Nullable;
-
-import java.io.*;
-import java.util.*;
import static de.blinkt.openvpn.views.FileSelectLayout.FileSelectCallback;
@@ -83,7 +93,7 @@ public class ConfigConverter extends Activity implements FileSelectCallback {
}
@Override
- protected void onSaveInstanceState(Bundle outState) {
+ protected void onSaveInstanceState(@NotNull Bundle outState) {
super.onSaveInstanceState(outState);
if (mResult != null)
outState.putSerializable(VPNPROFILE, mResult);
@@ -366,7 +376,7 @@ public class ConfigConverter extends Activity implements FileSelectCallback {
// /document/primary:ovpn/openvpn-imt.conf
- if (path.indexOf(':') != -1) {
+ if (path.indexOf(':') != -1 && path.indexOf('/') != -1) {
String possibleDir = path.substring(path.indexOf(':') + 1, path.length());
possibleDir = possibleDir.substring(0, possibleDir.lastIndexOf('/'));
@@ -437,7 +447,7 @@ public class ConfigConverter extends Activity implements FileSelectCallback {
// Read in the bytes
int offset = 0;
- int bytesRead = 0;
+ int bytesRead;
while (offset < bytes.length
&& (bytesRead = input.read(bytes, offset, bytes.length - offset)) >= 0) {
offset += bytesRead;
@@ -480,13 +490,17 @@ public class ConfigConverter extends Activity implements FileSelectCallback {
mAliasName = savedInstanceState.getString("mAliasName");
mEmbeddedPwFile = savedInstanceState.getString("pwfile");
- for(String logItem : savedInstanceState.getStringArray("logentries"))
- log (logItem);
-
- for (int k : savedInstanceState.getIntArray("fileselects")) {
- addFileSelectDialog(Utils.FileType.getFileTypeByValue(k));
+ if (savedInstanceState.containsKey("logentries")) {
+ //noinspection ConstantConditions
+ for (String logItem : savedInstanceState.getStringArray("logentries"))
+ log(logItem);
+ }
+ if (savedInstanceState.containsKey("fileselects")) {
+ //noinspection ConstantConditions
+ for (int k : savedInstanceState.getIntArray("fileselects")) {
+ addFileSelectDialog(Utils.FileType.getFileTypeByValue(k));
+ }
}
-
return;
}
@@ -500,9 +514,11 @@ public class ConfigConverter extends Activity implements FileSelectCallback {
log(R.string.importing_config, data.toString());
try {
String possibleName = null;
- if (data.getScheme().equals("file") ||
- data.getLastPathSegment().endsWith(".ovpn") ||
- data.getLastPathSegment().endsWith(".conf")) {
+ if ((data.getScheme() != null && data.getScheme().equals("file")) ||
+ (data.getLastPathSegment() != null &&
+ (data.getLastPathSegment().endsWith(".ovpn") ||
+ data.getLastPathSegment().endsWith(".conf")))
+ ) {
possibleName = data.getLastPathSegment();
if (possibleName.lastIndexOf('/') != -1)
possibleName = possibleName.substring(possibleName.lastIndexOf('/') + 1);
@@ -574,8 +590,7 @@ public class ConfigConverter extends Activity implements FileSelectCallback {
InputStreamReader isr = new InputStreamReader(is);
cp.parseConfig(isr);
- VpnProfile vp = cp.convertProfile();
- mResult = vp;
+ mResult = cp.convertProfile();
embedFiles();
displayWarnings();
mResult.mName = getUniqueProfileName(newName);