summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Vinit Deshapnde <vinitd@google.com> 2013-09-12 17:53:39 +0000
committer Android (Google) Code Review <android-gerrit@google.com> 2013-09-12 17:53:39 +0000
commit074dc2eb2da23976bc2916cfe7c61dfcd9977e8f (patch)
treedd9c882c4f9f1f488a1d70b184eab5b923dd7fd6
parent204df6f06ad17f0e775fd32fd657cff7d4c4ab7d (diff)
parent1d1319e3e1c266399ca1805ef1453bca71fdf6ce (diff)
Merge "Don't restore EAP-TLS networks from backup" into klp-dev
-rw-r--r--packages/SettingsProvider/src/com/android/providers/settings/SettingsBackupAgent.java14
1 files changed, 14 insertions, 0 deletions
diff --git a/packages/SettingsProvider/src/com/android/providers/settings/SettingsBackupAgent.java b/packages/SettingsProvider/src/com/android/providers/settings/SettingsBackupAgent.java
index 344446f14bdd..7b09092508ad 100644
--- a/packages/SettingsProvider/src/com/android/providers/settings/SettingsBackupAgent.java
+++ b/packages/SettingsProvider/src/com/android/providers/settings/SettingsBackupAgent.java
@@ -137,6 +137,7 @@ public class SettingsBackupAgent extends BackupAgentHelper {
static class Network {
String ssid = ""; // equals() and hashCode() need these to be non-null
String key_mgmt = "";
+ boolean certUsed = false;
final ArrayList<String> rawLines = new ArrayList<String>();
public static Network readFromStream(BufferedReader in) {
@@ -167,6 +168,12 @@ public class SettingsBackupAgent extends BackupAgentHelper {
ssid = line;
} else if (line.startsWith("key_mgmt")) {
key_mgmt = line;
+ } else if (line.startsWith("client_cert=")) {
+ certUsed = true;
+ } else if (line.startsWith("ca_cert=")) {
+ certUsed = true;
+ } else if (line.startsWith("ca_path=")) {
+ certUsed = true;
}
}
@@ -246,6 +253,13 @@ public class SettingsBackupAgent extends BackupAgentHelper {
public void write(Writer w) throws IOException {
for (Network net : mNetworks) {
+ if (net.certUsed) {
+ // Networks that use certificates for authentication can't be restored
+ // because the certificates they need don't get restored (because they
+ // are stored in keystore, and can't be restored)
+ continue;
+ }
+
net.write(w);
}
}