mirror of
https://github.com/moparisthebest/open-keychain
synced 2025-01-12 05:58:07 -05:00
forgot a LogLevel piece
This commit is contained in:
parent
1ad36e2dbd
commit
6536ca825b
@ -54,7 +54,6 @@ import org.sufficientlysecure.keychain.provider.KeychainContract.Keys;
|
|||||||
import org.sufficientlysecure.keychain.provider.KeychainContract.UserIds;
|
import org.sufficientlysecure.keychain.provider.KeychainContract.UserIds;
|
||||||
import org.sufficientlysecure.keychain.remote.AccountSettings;
|
import org.sufficientlysecure.keychain.remote.AccountSettings;
|
||||||
import org.sufficientlysecure.keychain.remote.AppSettings;
|
import org.sufficientlysecure.keychain.remote.AppSettings;
|
||||||
import org.sufficientlysecure.keychain.service.results.OperationResult.LogLevel;
|
|
||||||
import org.sufficientlysecure.keychain.service.results.OperationResult.LogType;
|
import org.sufficientlysecure.keychain.service.results.OperationResult.LogType;
|
||||||
import org.sufficientlysecure.keychain.service.results.OperationResult.OperationLog;
|
import org.sufficientlysecure.keychain.service.results.OperationResult.OperationLog;
|
||||||
import org.sufficientlysecure.keychain.service.results.ConsolidateResult;
|
import org.sufficientlysecure.keychain.service.results.ConsolidateResult;
|
||||||
@ -122,12 +121,12 @@ public class ProviderHelper {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void log(LogLevel level, LogType type) {
|
public void log(LogType type) {
|
||||||
if(mLog != null) {
|
if(mLog != null) {
|
||||||
mLog.add(type, mIndent);
|
mLog.add(type, mIndent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public void log(LogLevel level, LogType type, Object... parameters) {
|
public void log(LogType type, Object... parameters) {
|
||||||
if(mLog != null) {
|
if(mLog != null) {
|
||||||
mLog.add(type, mIndent, parameters);
|
mLog.add(type, mIndent, parameters);
|
||||||
}
|
}
|
||||||
@ -313,20 +312,20 @@ public class ProviderHelper {
|
|||||||
ArrayList<ContentProviderOperation> operations;
|
ArrayList<ContentProviderOperation> operations;
|
||||||
try {
|
try {
|
||||||
|
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IP_PREPARE);
|
log(LogType.MSG_IP_PREPARE);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
// save all keys and userIds included in keyRing object in database
|
// save all keys and userIds included in keyRing object in database
|
||||||
operations = new ArrayList<ContentProviderOperation>();
|
operations = new ArrayList<ContentProviderOperation>();
|
||||||
|
|
||||||
log(LogLevel.INFO, LogType.MSG_IP_INSERT_KEYRING);
|
log(LogType.MSG_IP_INSERT_KEYRING);
|
||||||
{ // insert keyring
|
{ // insert keyring
|
||||||
ContentValues values = new ContentValues();
|
ContentValues values = new ContentValues();
|
||||||
values.put(KeyRingData.MASTER_KEY_ID, masterKeyId);
|
values.put(KeyRingData.MASTER_KEY_ID, masterKeyId);
|
||||||
try {
|
try {
|
||||||
values.put(KeyRingData.KEY_RING_DATA, keyRing.getEncoded());
|
values.put(KeyRingData.KEY_RING_DATA, keyRing.getEncoded());
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IP_ENCODE_FAIL);
|
log(LogType.MSG_IP_ENCODE_FAIL);
|
||||||
return SaveKeyringResult.RESULT_ERROR;
|
return SaveKeyringResult.RESULT_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -334,7 +333,7 @@ public class ProviderHelper {
|
|||||||
operations.add(ContentProviderOperation.newInsert(uri).withValues(values).build());
|
operations.add(ContentProviderOperation.newInsert(uri).withValues(values).build());
|
||||||
}
|
}
|
||||||
|
|
||||||
log(LogLevel.INFO, LogType.MSG_IP_INSERT_SUBKEYS);
|
log(LogType.MSG_IP_INSERT_SUBKEYS);
|
||||||
progress.setProgress(LogType.MSG_IP_INSERT_SUBKEYS.getMsgId(), 40, 100);
|
progress.setProgress(LogType.MSG_IP_INSERT_SUBKEYS.getMsgId(), 40, 100);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
{ // insert subkeys
|
{ // insert subkeys
|
||||||
@ -342,7 +341,7 @@ public class ProviderHelper {
|
|||||||
int rank = 0;
|
int rank = 0;
|
||||||
for (CanonicalizedPublicKey key : keyRing.publicKeyIterator()) {
|
for (CanonicalizedPublicKey key : keyRing.publicKeyIterator()) {
|
||||||
long keyId = key.getKeyId();
|
long keyId = key.getKeyId();
|
||||||
log(LogLevel.DEBUG, keyId == masterKeyId ? LogType.MSG_IP_MASTER : LogType.MSG_IP_SUBKEY,
|
log(keyId == masterKeyId ? LogType.MSG_IP_MASTER : LogType.MSG_IP_SUBKEY,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(keyId)
|
KeyFormattingUtils.convertKeyIdToHex(keyId)
|
||||||
);
|
);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
@ -365,36 +364,36 @@ public class ProviderHelper {
|
|||||||
if (masterKeyId == keyId) {
|
if (masterKeyId == keyId) {
|
||||||
if (c) {
|
if (c) {
|
||||||
if (e) {
|
if (e) {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_MASTER_FLAGS_CES
|
log(s ? LogType.MSG_IP_MASTER_FLAGS_CES
|
||||||
: LogType.MSG_IP_MASTER_FLAGS_CEX);
|
: LogType.MSG_IP_MASTER_FLAGS_CEX);
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_MASTER_FLAGS_CXS
|
log(s ? LogType.MSG_IP_MASTER_FLAGS_CXS
|
||||||
: LogType.MSG_IP_MASTER_FLAGS_CXX);
|
: LogType.MSG_IP_MASTER_FLAGS_CXX);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (e) {
|
if (e) {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_MASTER_FLAGS_XES
|
log(s ? LogType.MSG_IP_MASTER_FLAGS_XES
|
||||||
: LogType.MSG_IP_MASTER_FLAGS_XEX);
|
: LogType.MSG_IP_MASTER_FLAGS_XEX);
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_MASTER_FLAGS_XXS
|
log(s ? LogType.MSG_IP_MASTER_FLAGS_XXS
|
||||||
: LogType.MSG_IP_MASTER_FLAGS_XXX);
|
: LogType.MSG_IP_MASTER_FLAGS_XXX);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (c) {
|
if (c) {
|
||||||
if (e) {
|
if (e) {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_SUBKEY_FLAGS_CES
|
log(s ? LogType.MSG_IP_SUBKEY_FLAGS_CES
|
||||||
: LogType.MSG_IP_SUBKEY_FLAGS_CEX);
|
: LogType.MSG_IP_SUBKEY_FLAGS_CEX);
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_SUBKEY_FLAGS_CXS
|
log(s ? LogType.MSG_IP_SUBKEY_FLAGS_CXS
|
||||||
: LogType.MSG_IP_SUBKEY_FLAGS_CXX);
|
: LogType.MSG_IP_SUBKEY_FLAGS_CXX);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (e) {
|
if (e) {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_SUBKEY_FLAGS_XES
|
log(s ? LogType.MSG_IP_SUBKEY_FLAGS_XES
|
||||||
: LogType.MSG_IP_SUBKEY_FLAGS_XEX);
|
: LogType.MSG_IP_SUBKEY_FLAGS_XEX);
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.DEBUG, s ? LogType.MSG_IP_SUBKEY_FLAGS_XXS
|
log(s ? LogType.MSG_IP_SUBKEY_FLAGS_XXS
|
||||||
: LogType.MSG_IP_SUBKEY_FLAGS_XXX);
|
: LogType.MSG_IP_SUBKEY_FLAGS_XXX);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -406,11 +405,11 @@ public class ProviderHelper {
|
|||||||
if (expiryDate != null) {
|
if (expiryDate != null) {
|
||||||
values.put(Keys.EXPIRY, expiryDate.getTime() / 1000);
|
values.put(Keys.EXPIRY, expiryDate.getTime() / 1000);
|
||||||
if (key.isExpired()) {
|
if (key.isExpired()) {
|
||||||
log(LogLevel.DEBUG, keyId == masterKeyId ?
|
log(keyId == masterKeyId ?
|
||||||
LogType.MSG_IP_MASTER_EXPIRED : LogType.MSG_IP_SUBKEY_EXPIRED,
|
LogType.MSG_IP_MASTER_EXPIRED : LogType.MSG_IP_SUBKEY_EXPIRED,
|
||||||
expiryDate.toString());
|
expiryDate.toString());
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.DEBUG, keyId == masterKeyId ?
|
log(keyId == masterKeyId ?
|
||||||
LogType.MSG_IP_MASTER_EXPIRES : LogType.MSG_IP_SUBKEY_EXPIRES,
|
LogType.MSG_IP_MASTER_EXPIRES : LogType.MSG_IP_SUBKEY_EXPIRES,
|
||||||
expiryDate.toString());
|
expiryDate.toString());
|
||||||
}
|
}
|
||||||
@ -429,9 +428,9 @@ public class ProviderHelper {
|
|||||||
// classify and order user ids. primary are moved to the front, revoked to the back,
|
// classify and order user ids. primary are moved to the front, revoked to the back,
|
||||||
// otherwise the order in the keyfile is preserved.
|
// otherwise the order in the keyfile is preserved.
|
||||||
if (trustedKeys.size() == 0) {
|
if (trustedKeys.size() == 0) {
|
||||||
log(LogLevel.INFO, LogType.MSG_IP_UID_CLASSIFYING_ZERO);
|
log(LogType.MSG_IP_UID_CLASSIFYING_ZERO);
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.INFO, LogType.MSG_IP_UID_CLASSIFYING, trustedKeys.size());
|
log(LogType.MSG_IP_UID_CLASSIFYING, trustedKeys.size());
|
||||||
}
|
}
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
List<UserIdItem> uids = new ArrayList<UserIdItem>();
|
List<UserIdItem> uids = new ArrayList<UserIdItem>();
|
||||||
@ -445,7 +444,7 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
int unknownCerts = 0;
|
int unknownCerts = 0;
|
||||||
|
|
||||||
log(LogLevel.INFO, LogType.MSG_IP_UID_PROCESSING, userId);
|
log(LogType.MSG_IP_UID_PROCESSING, userId);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
// look through signatures for this specific key
|
// look through signatures for this specific key
|
||||||
for (WrappedSignature cert : new IterableIterator<WrappedSignature>(
|
for (WrappedSignature cert : new IterableIterator<WrappedSignature>(
|
||||||
@ -462,7 +461,7 @@ public class ProviderHelper {
|
|||||||
item.isPrimary = cert.isPrimaryUserId();
|
item.isPrimary = cert.isPrimaryUserId();
|
||||||
} else {
|
} else {
|
||||||
item.isRevoked = true;
|
item.isRevoked = true;
|
||||||
log(LogLevel.INFO, LogType.MSG_IP_UID_REVOKED);
|
log(LogType.MSG_IP_UID_REVOKED);
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@ -478,24 +477,24 @@ public class ProviderHelper {
|
|||||||
cert.init(trustedKey);
|
cert.init(trustedKey);
|
||||||
if (cert.verifySignature(masterKey, rawUserId)) {
|
if (cert.verifySignature(masterKey, rawUserId)) {
|
||||||
item.trustedCerts.add(cert);
|
item.trustedCerts.add(cert);
|
||||||
log(LogLevel.INFO, LogType.MSG_IP_UID_CERT_GOOD,
|
log(LogType.MSG_IP_UID_CERT_GOOD,
|
||||||
KeyFormattingUtils.convertKeyIdToHexShort(trustedKey.getKeyId())
|
KeyFormattingUtils.convertKeyIdToHexShort(trustedKey.getKeyId())
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.WARN, LogType.MSG_IP_UID_CERT_BAD);
|
log(LogType.MSG_IP_UID_CERT_BAD);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unknownCerts += 1;
|
unknownCerts += 1;
|
||||||
|
|
||||||
} catch (PgpGeneralException e) {
|
} catch (PgpGeneralException e) {
|
||||||
log(LogLevel.WARN, LogType.MSG_IP_UID_CERT_ERROR,
|
log(LogType.MSG_IP_UID_CERT_ERROR,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(cert.getKeyId()));
|
KeyFormattingUtils.convertKeyIdToHex(cert.getKeyId()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unknownCerts > 0) {
|
if (unknownCerts > 0) {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IP_UID_CERTS_UNKNOWN, unknownCerts);
|
log(LogType.MSG_IP_UID_CERTS_UNKNOWN, unknownCerts);
|
||||||
}
|
}
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
|
|
||||||
@ -503,7 +502,7 @@ public class ProviderHelper {
|
|||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
|
|
||||||
progress.setProgress(LogType.MSG_IP_UID_REORDER.getMsgId(), 65, 100);
|
progress.setProgress(LogType.MSG_IP_UID_REORDER.getMsgId(), 65, 100);
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IP_UID_REORDER);
|
log(LogType.MSG_IP_UID_REORDER);
|
||||||
// primary before regular before revoked (see UserIdItem.compareTo)
|
// primary before regular before revoked (see UserIdItem.compareTo)
|
||||||
// this is a stable sort, so the order of keys is otherwise preserved.
|
// this is a stable sort, so the order of keys is otherwise preserved.
|
||||||
Collections.sort(uids);
|
Collections.sort(uids);
|
||||||
@ -526,7 +525,7 @@ public class ProviderHelper {
|
|||||||
}
|
}
|
||||||
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IP_ERROR_IO_EXC);
|
log(LogType.MSG_IP_ERROR_IO_EXC);
|
||||||
Log.e(Constants.TAG, "IOException during import", e);
|
Log.e(Constants.TAG, "IOException during import", e);
|
||||||
return SaveKeyringResult.RESULT_ERROR;
|
return SaveKeyringResult.RESULT_ERROR;
|
||||||
} finally {
|
} finally {
|
||||||
@ -538,26 +537,26 @@ public class ProviderHelper {
|
|||||||
int deleted = mContentResolver.delete(
|
int deleted = mContentResolver.delete(
|
||||||
KeyRingData.buildPublicKeyRingUri(masterKeyId), null, null);
|
KeyRingData.buildPublicKeyRingUri(masterKeyId), null, null);
|
||||||
if (deleted > 0) {
|
if (deleted > 0) {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IP_DELETE_OLD_OK);
|
log(LogType.MSG_IP_DELETE_OLD_OK);
|
||||||
result |= SaveKeyringResult.UPDATED;
|
result |= SaveKeyringResult.UPDATED;
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IP_DELETE_OLD_FAIL);
|
log(LogType.MSG_IP_DELETE_OLD_FAIL);
|
||||||
}
|
}
|
||||||
|
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IP_APPLY_BATCH);
|
log(LogType.MSG_IP_APPLY_BATCH);
|
||||||
progress.setProgress(LogType.MSG_IP_APPLY_BATCH.getMsgId(), 75, 100);
|
progress.setProgress(LogType.MSG_IP_APPLY_BATCH.getMsgId(), 75, 100);
|
||||||
mContentResolver.applyBatch(KeychainContract.CONTENT_AUTHORITY, operations);
|
mContentResolver.applyBatch(KeychainContract.CONTENT_AUTHORITY, operations);
|
||||||
|
|
||||||
log(LogLevel.OK, LogType.MSG_IP_SUCCESS);
|
log(LogType.MSG_IP_SUCCESS);
|
||||||
progress.setProgress(LogType.MSG_IP_SUCCESS.getMsgId(), 90, 100);
|
progress.setProgress(LogType.MSG_IP_SUCCESS.getMsgId(), 90, 100);
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
} catch (RemoteException e) {
|
} catch (RemoteException e) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IP_ERROR_REMOTE_EX);
|
log(LogType.MSG_IP_ERROR_REMOTE_EX);
|
||||||
Log.e(Constants.TAG, "RemoteException during import", e);
|
Log.e(Constants.TAG, "RemoteException during import", e);
|
||||||
return SaveKeyringResult.RESULT_ERROR;
|
return SaveKeyringResult.RESULT_ERROR;
|
||||||
} catch (OperationApplicationException e) {
|
} catch (OperationApplicationException e) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IP_ERROR_OP_EXC);
|
log(LogType.MSG_IP_ERROR_OP_EXC);
|
||||||
Log.e(Constants.TAG, "OperationApplicationException during import", e);
|
Log.e(Constants.TAG, "OperationApplicationException during import", e);
|
||||||
return SaveKeyringResult.RESULT_ERROR;
|
return SaveKeyringResult.RESULT_ERROR;
|
||||||
}
|
}
|
||||||
@ -591,7 +590,7 @@ public class ProviderHelper {
|
|||||||
private int saveCanonicalizedSecretKeyRing(CanonicalizedSecretKeyRing keyRing) {
|
private int saveCanonicalizedSecretKeyRing(CanonicalizedSecretKeyRing keyRing) {
|
||||||
|
|
||||||
long masterKeyId = keyRing.getMasterKeyId();
|
long masterKeyId = keyRing.getMasterKeyId();
|
||||||
log(LogLevel.START, LogType.MSG_IS, KeyFormattingUtils.convertKeyIdToHex(masterKeyId));
|
log(LogType.MSG_IS, KeyFormattingUtils.convertKeyIdToHex(masterKeyId));
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -607,12 +606,12 @@ public class ProviderHelper {
|
|||||||
// insert new version of this keyRing
|
// insert new version of this keyRing
|
||||||
Uri uri = KeyRingData.buildSecretKeyRingUri(masterKeyId);
|
Uri uri = KeyRingData.buildSecretKeyRingUri(masterKeyId);
|
||||||
if (mContentResolver.insert(uri, values) == null) {
|
if (mContentResolver.insert(uri, values) == null) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IS_DB_EXCEPTION);
|
log(LogType.MSG_IS_DB_EXCEPTION);
|
||||||
return SaveKeyringResult.RESULT_ERROR;
|
return SaveKeyringResult.RESULT_ERROR;
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.e(Constants.TAG, "Failed to encode key!", e);
|
Log.e(Constants.TAG, "Failed to encode key!", e);
|
||||||
log(LogLevel.ERROR, LogType.MSG_IS_ERROR_IO_EXC);
|
log(LogType.MSG_IS_ERROR_IO_EXC);
|
||||||
return SaveKeyringResult.RESULT_ERROR;
|
return SaveKeyringResult.RESULT_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -625,7 +624,7 @@ public class ProviderHelper {
|
|||||||
mContentResolver.update(uri, values, null, null);
|
mContentResolver.update(uri, values, null, null);
|
||||||
|
|
||||||
// then, mark exactly the keys we have available
|
// then, mark exactly the keys we have available
|
||||||
log(LogLevel.INFO, LogType.MSG_IS_IMPORTING_SUBKEYS);
|
log(LogType.MSG_IS_IMPORTING_SUBKEYS);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
for (CanonicalizedSecretKey sub : keyRing.secretKeyIterator()) {
|
for (CanonicalizedSecretKey sub : keyRing.secretKeyIterator()) {
|
||||||
long id = sub.getKeyId();
|
long id = sub.getKeyId();
|
||||||
@ -636,28 +635,28 @@ public class ProviderHelper {
|
|||||||
if (upd == 1) {
|
if (upd == 1) {
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case PASSPHRASE:
|
case PASSPHRASE:
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IS_SUBKEY_OK,
|
log(LogType.MSG_IS_SUBKEY_OK,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(id)
|
KeyFormattingUtils.convertKeyIdToHex(id)
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
case PASSPHRASE_EMPTY:
|
case PASSPHRASE_EMPTY:
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IS_SUBKEY_EMPTY,
|
log(LogType.MSG_IS_SUBKEY_EMPTY,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(id)
|
KeyFormattingUtils.convertKeyIdToHex(id)
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
case GNU_DUMMY:
|
case GNU_DUMMY:
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IS_SUBKEY_STRIPPED,
|
log(LogType.MSG_IS_SUBKEY_STRIPPED,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(id)
|
KeyFormattingUtils.convertKeyIdToHex(id)
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
case DIVERT_TO_CARD:
|
case DIVERT_TO_CARD:
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IS_SUBKEY_DIVERT,
|
log(LogType.MSG_IS_SUBKEY_DIVERT,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(id)
|
KeyFormattingUtils.convertKeyIdToHex(id)
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.WARN, LogType.MSG_IS_SUBKEY_NONEXISTENT,
|
log(LogType.MSG_IS_SUBKEY_NONEXISTENT,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(id)
|
KeyFormattingUtils.convertKeyIdToHex(id)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -668,7 +667,7 @@ public class ProviderHelper {
|
|||||||
// with has_secret = 0
|
// with has_secret = 0
|
||||||
}
|
}
|
||||||
|
|
||||||
log(LogLevel.OK, LogType.MSG_IS_SUCCESS);
|
log(LogType.MSG_IS_SUCCESS);
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
} finally {
|
} finally {
|
||||||
@ -690,11 +689,11 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
long masterKeyId = publicRing.getMasterKeyId();
|
long masterKeyId = publicRing.getMasterKeyId();
|
||||||
log(LogLevel.START, LogType.MSG_IP, KeyFormattingUtils.convertKeyIdToHex(masterKeyId));
|
log(LogType.MSG_IP, KeyFormattingUtils.convertKeyIdToHex(masterKeyId));
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
if (publicRing.isSecret()) {
|
if (publicRing.isSecret()) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IP_BAD_TYPE_SECRET);
|
log(LogType.MSG_IP_BAD_TYPE_SECRET);
|
||||||
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -721,7 +720,7 @@ public class ProviderHelper {
|
|||||||
// Early breakout if nothing changed
|
// Early breakout if nothing changed
|
||||||
if (Arrays.hashCode(publicRing.getEncoded())
|
if (Arrays.hashCode(publicRing.getEncoded())
|
||||||
== Arrays.hashCode(oldPublicRing.getEncoded())) {
|
== Arrays.hashCode(oldPublicRing.getEncoded())) {
|
||||||
log(LogLevel.OK, LogType.MSG_IP_SUCCESS_IDENTICAL);
|
log(LogType.MSG_IP_SUCCESS_IDENTICAL);
|
||||||
return new SaveKeyringResult(SaveKeyringResult.UPDATED, mLog, null);
|
return new SaveKeyringResult(SaveKeyringResult.UPDATED, mLog, null);
|
||||||
}
|
}
|
||||||
} catch (NotFoundException e) {
|
} catch (NotFoundException e) {
|
||||||
@ -770,7 +769,7 @@ public class ProviderHelper {
|
|||||||
return new SaveKeyringResult(result, mLog, canSecretRing);
|
return new SaveKeyringResult(result, mLog, canSecretRing);
|
||||||
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IP_ERROR_IO_EXC);
|
log(LogType.MSG_IP_ERROR_IO_EXC);
|
||||||
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
@ -782,11 +781,11 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
long masterKeyId = secretRing.getMasterKeyId();
|
long masterKeyId = secretRing.getMasterKeyId();
|
||||||
log(LogLevel.START, LogType.MSG_IS, KeyFormattingUtils.convertKeyIdToHex(masterKeyId));
|
log(LogType.MSG_IS, KeyFormattingUtils.convertKeyIdToHex(masterKeyId));
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
if ( ! secretRing.isSecret()) {
|
if ( ! secretRing.isSecret()) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IS_BAD_TYPE_PUBLIC);
|
log(LogType.MSG_IS_BAD_TYPE_PUBLIC);
|
||||||
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -814,7 +813,7 @@ public class ProviderHelper {
|
|||||||
// Early breakout if nothing changed
|
// Early breakout if nothing changed
|
||||||
if (Arrays.hashCode(secretRing.getEncoded())
|
if (Arrays.hashCode(secretRing.getEncoded())
|
||||||
== Arrays.hashCode(oldSecretRing.getEncoded())) {
|
== Arrays.hashCode(oldSecretRing.getEncoded())) {
|
||||||
log(LogLevel.OK, LogType.MSG_IS_SUCCESS_IDENTICAL,
|
log(LogType.MSG_IS_SUCCESS_IDENTICAL,
|
||||||
KeyFormattingUtils.convertKeyIdToHex(masterKeyId) );
|
KeyFormattingUtils.convertKeyIdToHex(masterKeyId) );
|
||||||
return new SaveKeyringResult(SaveKeyringResult.UPDATED, mLog, null);
|
return new SaveKeyringResult(SaveKeyringResult.UPDATED, mLog, null);
|
||||||
}
|
}
|
||||||
@ -842,7 +841,7 @@ public class ProviderHelper {
|
|||||||
}
|
}
|
||||||
|
|
||||||
} catch (NotFoundException e) {
|
} catch (NotFoundException e) {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_IS_PUBRING_GENERATE);
|
log(LogType.MSG_IS_PUBRING_GENERATE);
|
||||||
publicRing = secretRing.extractPublicKeyRing();
|
publicRing = secretRing.extractPublicKeyRing();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -864,7 +863,7 @@ public class ProviderHelper {
|
|||||||
return new SaveKeyringResult(result, mLog, canSecretRing);
|
return new SaveKeyringResult(result, mLog, canSecretRing);
|
||||||
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_IS_ERROR_IO_EXC);
|
log(LogType.MSG_IS_ERROR_IO_EXC);
|
||||||
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
return new SaveKeyringResult(SaveKeyringResult.RESULT_ERROR, mLog, null);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
@ -875,14 +874,14 @@ public class ProviderHelper {
|
|||||||
public ConsolidateResult consolidateDatabaseStep1(Progressable progress) {
|
public ConsolidateResult consolidateDatabaseStep1(Progressable progress) {
|
||||||
|
|
||||||
// 1a. fetch all secret keyrings into a cache file
|
// 1a. fetch all secret keyrings into a cache file
|
||||||
log(LogLevel.START, LogType.MSG_CON);
|
log(LogType.MSG_CON);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
progress.setProgress(R.string.progress_con_saving, 0, 100);
|
progress.setProgress(R.string.progress_con_saving, 0, 100);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_SAVE_SECRET);
|
log(LogType.MSG_CON_SAVE_SECRET);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
final Cursor cursor = mContentResolver.query(KeyRings.buildUnifiedKeyRingsUri(), new String[]{
|
final Cursor cursor = mContentResolver.query(KeyRings.buildUnifiedKeyRingsUri(), new String[]{
|
||||||
@ -890,7 +889,7 @@ public class ProviderHelper {
|
|||||||
}, KeyRings.HAS_ANY_SECRET + " = 1", null, null);
|
}, KeyRings.HAS_ANY_SECRET + " = 1", null, null);
|
||||||
|
|
||||||
if (cursor == null || !cursor.moveToFirst()) {
|
if (cursor == null || !cursor.moveToFirst()) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_DB);
|
log(LogType.MSG_CON_ERROR_DB);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -933,7 +932,7 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.e(Constants.TAG, "error saving secret", e);
|
Log.e(Constants.TAG, "error saving secret", e);
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_IO_SECRET);
|
log(LogType.MSG_CON_ERROR_IO_SECRET);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
@ -944,7 +943,7 @@ public class ProviderHelper {
|
|||||||
// 1b. fetch all public keyrings into a cache file
|
// 1b. fetch all public keyrings into a cache file
|
||||||
try {
|
try {
|
||||||
|
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_SAVE_PUBLIC);
|
log(LogType.MSG_CON_SAVE_PUBLIC);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
final Cursor cursor = mContentResolver.query(KeyRings.buildUnifiedKeyRingsUri(), new String[]{
|
final Cursor cursor = mContentResolver.query(KeyRings.buildUnifiedKeyRingsUri(), new String[]{
|
||||||
@ -952,7 +951,7 @@ public class ProviderHelper {
|
|||||||
}, null, null, null);
|
}, null, null, null);
|
||||||
|
|
||||||
if (cursor == null || !cursor.moveToFirst()) {
|
if (cursor == null || !cursor.moveToFirst()) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_DB);
|
log(LogType.MSG_CON_ERROR_DB);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -995,13 +994,13 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.e(Constants.TAG, "error saving public", e);
|
Log.e(Constants.TAG, "error saving public", e);
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_IO_PUBLIC);
|
log(LogType.MSG_CON_ERROR_IO_PUBLIC);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
log(LogLevel.INFO, LogType.MSG_CON_CRITICAL_IN);
|
log(LogType.MSG_CON_CRITICAL_IN);
|
||||||
Preferences.getPreferences(mContext).setCachedConsolidate(true);
|
Preferences.getPreferences(mContext).setCachedConsolidate(true);
|
||||||
|
|
||||||
return consolidateDatabaseStep2(progress, false);
|
return consolidateDatabaseStep2(progress, false);
|
||||||
@ -1017,7 +1016,7 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
synchronized (ProviderHelper.class) {
|
synchronized (ProviderHelper.class) {
|
||||||
if (mConsolidateCritical) {
|
if (mConsolidateCritical) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_CONCURRENT);
|
log(LogType.MSG_CON_ERROR_CONCURRENT);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
}
|
}
|
||||||
mConsolidateCritical = true;
|
mConsolidateCritical = true;
|
||||||
@ -1032,20 +1031,20 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
if (recovery) {
|
if (recovery) {
|
||||||
if (numSecrets >= 0 && numPublics >= 0) {
|
if (numSecrets >= 0 && numPublics >= 0) {
|
||||||
log(LogLevel.START, LogType.MSG_CON_RECOVER, numSecrets, numPublics);
|
log(LogType.MSG_CON_RECOVER, numSecrets, numPublics);
|
||||||
} else {
|
} else {
|
||||||
log(LogLevel.START, LogType.MSG_CON_RECOVER_UNKNOWN);
|
log(LogType.MSG_CON_RECOVER_UNKNOWN);
|
||||||
}
|
}
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!prefs.getCachedConsolidate()) {
|
if (!prefs.getCachedConsolidate()) {
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_BAD_STATE);
|
log(LogType.MSG_CON_ERROR_BAD_STATE);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. wipe database (IT'S DANGEROUS)
|
// 2. wipe database (IT'S DANGEROUS)
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_DB_CLEAR);
|
log(LogType.MSG_CON_DB_CLEAR);
|
||||||
mContentResolver.delete(KeyRings.buildUnifiedKeyRingsUri(), null, null);
|
mContentResolver.delete(KeyRings.buildUnifiedKeyRingsUri(), null, null);
|
||||||
|
|
||||||
ParcelableFileCache<ParcelableKeyRing> cacheSecret =
|
ParcelableFileCache<ParcelableKeyRing> cacheSecret =
|
||||||
@ -1055,7 +1054,7 @@ public class ProviderHelper {
|
|||||||
|
|
||||||
// 3. Re-Import secret keyrings from cache
|
// 3. Re-Import secret keyrings from cache
|
||||||
if (numSecrets > 0) try {
|
if (numSecrets > 0) try {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_REIMPORT_SECRET, numSecrets);
|
log(LogType.MSG_CON_REIMPORT_SECRET, numSecrets);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
new PgpImportExport(mContext, this,
|
new PgpImportExport(mContext, this,
|
||||||
@ -1063,18 +1062,18 @@ public class ProviderHelper {
|
|||||||
.importKeyRings(cacheSecret.readCache(false), numSecrets);
|
.importKeyRings(cacheSecret.readCache(false), numSecrets);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.e(Constants.TAG, "error importing secret", e);
|
Log.e(Constants.TAG, "error importing secret", e);
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_SECRET);
|
log(LogType.MSG_CON_ERROR_SECRET);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_REIMPORT_SECRET_SKIP);
|
log(LogType.MSG_CON_REIMPORT_SECRET_SKIP);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 4. Re-Import public keyrings from cache
|
// 4. Re-Import public keyrings from cache
|
||||||
if (numPublics > 0) try {
|
if (numPublics > 0) try {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_REIMPORT_PUBLIC, numPublics);
|
log(LogType.MSG_CON_REIMPORT_PUBLIC, numPublics);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
|
|
||||||
new PgpImportExport(mContext, this,
|
new PgpImportExport(mContext, this,
|
||||||
@ -1082,45 +1081,45 @@ public class ProviderHelper {
|
|||||||
.importKeyRings(cachePublic.readCache(false), numPublics);
|
.importKeyRings(cachePublic.readCache(false), numPublics);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.e(Constants.TAG, "error importing public", e);
|
Log.e(Constants.TAG, "error importing public", e);
|
||||||
log(LogLevel.ERROR, LogType.MSG_CON_ERROR_PUBLIC);
|
log(LogType.MSG_CON_ERROR_PUBLIC);
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_ERROR, mLog);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_REIMPORT_PUBLIC_SKIP);
|
log(LogType.MSG_CON_REIMPORT_PUBLIC_SKIP);
|
||||||
}
|
}
|
||||||
|
|
||||||
log(LogLevel.INFO, LogType.MSG_CON_CRITICAL_OUT);
|
log(LogType.MSG_CON_CRITICAL_OUT);
|
||||||
Preferences.getPreferences(mContext).setCachedConsolidate(false);
|
Preferences.getPreferences(mContext).setCachedConsolidate(false);
|
||||||
|
|
||||||
// 5. Delete caches
|
// 5. Delete caches
|
||||||
try {
|
try {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_DELETE_SECRET);
|
log(LogType.MSG_CON_DELETE_SECRET);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
cacheSecret.delete();
|
cacheSecret.delete();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// doesn't /really/ matter
|
// doesn't /really/ matter
|
||||||
Log.e(Constants.TAG, "IOException during delete of secret cache", e);
|
Log.e(Constants.TAG, "IOException during delete of secret cache", e);
|
||||||
log(LogLevel.WARN, LogType.MSG_CON_WARN_DELETE_SECRET);
|
log(LogType.MSG_CON_WARN_DELETE_SECRET);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
log(LogLevel.DEBUG, LogType.MSG_CON_DELETE_PUBLIC);
|
log(LogType.MSG_CON_DELETE_PUBLIC);
|
||||||
mIndent += 1;
|
mIndent += 1;
|
||||||
cachePublic.delete();
|
cachePublic.delete();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// doesn't /really/ matter
|
// doesn't /really/ matter
|
||||||
Log.e(Constants.TAG, "IOException during deletion of public cache", e);
|
Log.e(Constants.TAG, "IOException during deletion of public cache", e);
|
||||||
log(LogLevel.WARN, LogType.MSG_CON_WARN_DELETE_PUBLIC);
|
log(LogType.MSG_CON_WARN_DELETE_PUBLIC);
|
||||||
} finally {
|
} finally {
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
progress.setProgress(100, 100);
|
progress.setProgress(100, 100);
|
||||||
log(LogLevel.OK, LogType.MSG_CON_SUCCESS);
|
log(LogType.MSG_CON_SUCCESS);
|
||||||
mIndent -= 1;
|
mIndent -= 1;
|
||||||
|
|
||||||
return new ConsolidateResult(ConsolidateResult.RESULT_OK, mLog);
|
return new ConsolidateResult(ConsolidateResult.RESULT_OK, mLog);
|
||||||
|
Loading…
Reference in New Issue
Block a user