1
0
mirror of https://github.com/moparisthebest/k-9 synced 2024-11-23 18:02:15 -05:00

More structure for the XML export (identity)

This commit is contained in:
cketti 2011-03-30 03:55:14 +02:00
parent 77f7303aa2
commit 24785bab66
2 changed files with 70 additions and 3 deletions

View File

@ -22,10 +22,12 @@ import java.util.ArrayList;
import java.util.Calendar;
import java.util.Collections;
import java.util.Date;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Random;
import java.util.Set;
import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap;
@ -53,6 +55,16 @@ public class Account implements BaseAccount {
private static final String DEFAULT_QUOTE_PREFIX = ">";
private static final boolean DEFAULT_REPLY_AFTER_QUOTE = false;
public static final Set<String> IDENTITY_KEYS = new HashSet<String>();
static {
IDENTITY_KEYS.add("name");
IDENTITY_KEYS.add("email");
IDENTITY_KEYS.add("description");
IDENTITY_KEYS.add("signatureUse");
IDENTITY_KEYS.add("signature");
IDENTITY_KEYS.add("replyTo");
}
/**
* <pre>
* 0 - Never (DELETE_POLICY_NEVER)
@ -1018,7 +1030,6 @@ public class Account implements BaseAccount {
return mUuid.hashCode();
}
private synchronized List<Identity> loadIdentities(SharedPreferences prefs) {
List<Identity> newIdentities = new ArrayList<Identity>();
int ident = 0;

View File

@ -29,6 +29,8 @@ public class StorageExporter {
private static final String SETTINGS_ELEMENT = "settings";
private static final String ACCOUNTS_ELEMENT = "accounts";
private static final String ACCOUNT_ELEMENT = "account";
private static final String IDENTITIES_ELEMENT = "identities";
private static final String IDENTITY_ELEMENT = "identity";
private static final String UUID_ATTRIBUTE = "uuid";
private static final String VALUE_ELEMENT = "value";
private static final String KEY_ATTRIBUTE = "key";
@ -133,19 +135,34 @@ public class StorageExporter {
private static void writeAccount(XmlSerializer serializer, String accountUuid,
Map<String, ? extends Object> prefs) throws IOException {
Set<String> identities = new HashSet<String>();
serializer.startTag(null, ACCOUNT_ELEMENT);
serializer.attribute(null, UUID_ATTRIBUTE, accountUuid);
serializer.startTag(null, SETTINGS_ELEMENT);
for (Map.Entry<String, ? extends Object> entry : prefs.entrySet()) {
String key = entry.getKey();
String value = entry.getValue().toString();
String[] comps = key.split("\\.");
if (comps.length > 1) {
if (comps.length >= 2) {
String keyUuid = comps[0];
if (!keyUuid.equals(accountUuid)) {
continue;
}
if (comps.length == 3) {
String identityKey = comps[1];
String identityIndex = comps[2];
if (Account.IDENTITY_KEYS.contains(identityKey)) {
// This is an identity key. Save identity index for later...
identities.add(identityIndex);
// ... but don't write it now.
continue;
}
}
} else {
// Skip global config entries
// Skip global config entries and identity entries
continue;
}
@ -157,6 +174,45 @@ public class StorageExporter {
serializer.text(value);
serializer.endTag(null, VALUE_ELEMENT);
}
serializer.endTag(null, SETTINGS_ELEMENT);
if (identities.size() > 0) {
serializer.startTag(null, IDENTITIES_ELEMENT);
for (String identityIndex : identities) {
writeIdentity(serializer, accountUuid, identityIndex, prefs);
}
serializer.endTag(null, IDENTITIES_ELEMENT);
}
serializer.endTag(null, ACCOUNT_ELEMENT);
}
private static void writeIdentity(XmlSerializer serializer, String accountUuid,
String identity, Map<String, ? extends Object> prefs) throws IOException {
serializer.startTag(null, IDENTITY_ELEMENT);
for (Map.Entry<String, ? extends Object> entry : prefs.entrySet()) {
String key = entry.getKey();
String value = entry.getValue().toString();
String[] comps = key.split("\\.");
if (comps.length >= 3) {
String keyUuid = comps[0];
String identityKey = comps[1];
String identityIndex = comps[2];
if (!keyUuid.equals(accountUuid) || !identityIndex.equals(identity)
|| !Account.IDENTITY_KEYS.contains(identityKey)) {
continue;
}
} else {
// Skip non-identity config entries
continue;
}
serializer.startTag(null, VALUE_ELEMENT);
serializer.attribute(null, KEY_ATTRIBUTE, comps[1]);
serializer.text(value);
serializer.endTag(null, VALUE_ELEMENT);
}
serializer.endTag(null, IDENTITY_ELEMENT);
}
}