diff options
author | Vincent Breitmoser <valodim@mugenguild.com> | 2016-05-17 20:59:07 +0200 |
---|---|---|
committer | Vincent Breitmoser <valodim@mugenguild.com> | 2016-05-17 20:59:07 +0200 |
commit | 1da8e4c1edd71b2ddbe95a58060c1be20bd13dd7 (patch) | |
tree | 884eed850d90f3f17af26a1b49a20b2e9a4e3102 /OpenKeychain/src | |
parent | f833b0f2ef206f9dc2656628bca460fd2a8ab54b (diff) | |
download | open-keychain-1da8e4c1edd71b2ddbe95a58060c1be20bd13dd7.tar.gz open-keychain-1da8e4c1edd71b2ddbe95a58060c1be20bd13dd7.tar.bz2 open-keychain-1da8e4c1edd71b2ddbe95a58060c1be20bd13dd7.zip |
make unencrypted backup an explicit parameter
Diffstat (limited to 'OpenKeychain/src')
4 files changed, 21 insertions, 16 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/BackupOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/BackupOperation.java index 0ea7e7e59..21c519925 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/BackupOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/BackupOperation.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.operations; import java.io.BufferedOutputStream; -import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.FileNotFoundException; import java.io.IOException; @@ -113,23 +112,25 @@ public class BackupOperation extends BaseOperation<BackupKeyringParcel> { log.add(LogType.MSG_BACKUP_ALL, 0); } - try { - - boolean nonEncryptedOutput = cryptoInput == null; + if (backupInput.mIsEncrypted && cryptoInput == null) { + throw new IllegalStateException("Encrypted backup must supply cryptoInput parameter"); + } + try { Uri plainUri = null; OutputStream plainOut; - if (nonEncryptedOutput && backupInput.mOutputUri == null) { - plainOut = outputStream; - } else if (nonEncryptedOutput) { - plainOut = mContext.getContentResolver().openOutputStream(backupInput.mOutputUri); - } else { + if (backupInput.mIsEncrypted) { plainUri = TemporaryFileProvider.createFile(mContext); plainOut = mContext.getContentResolver().openOutputStream(plainUri); + } else { + if (backupInput.mOutputUri == null) { + throw new IllegalArgumentException("Unencrypted export to output stream is not supported!"); + } else { + plainOut = mContext.getContentResolver().openOutputStream(backupInput.mOutputUri); + } } int exportedDataSize; - { // export key data, and possibly return if we don't encrypt DataOutputStream outStream = new DataOutputStream(new BufferedOutputStream(plainOut)); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java index 45e4db622..c85774ead 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java @@ -757,7 +757,7 @@ public class OpenPgpService extends Service { // after user interaction with RemoteBackupActivity, // the backup code is cached in CryptoInputParcelCacheService, now we can proceed - BackupKeyringParcel input = new BackupKeyringParcel(masterKeyIds, backupSecret, null); + BackupKeyringParcel input = new BackupKeyringParcel(masterKeyIds, backupSecret, true, null); BackupOperation op = new BackupOperation(this, mProviderHelper, null); ExportResult pgpResult = op.execute(input, inputParcel, outputStream); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/BackupKeyringParcel.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/BackupKeyringParcel.java index 3660ea432..48ea4196b 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/BackupKeyringParcel.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/BackupKeyringParcel.java @@ -29,14 +29,16 @@ import org.sufficientlysecure.keychain.util.Passphrase; public class BackupKeyringParcel implements Parcelable { public Uri mCanonicalizedPublicKeyringUri; - public boolean mExportSecret; - public long mMasterKeyIds[]; - public Uri mOutputUri; + public final boolean mExportSecret; + public final boolean mIsEncrypted; + public final long mMasterKeyIds[]; + public final Uri mOutputUri; - public BackupKeyringParcel(long[] masterKeyIds, boolean exportSecret, Uri outputUri) { + public BackupKeyringParcel(long[] masterKeyIds, boolean exportSecret, boolean isEncrypted, Uri outputUri) { mMasterKeyIds = masterKeyIds; mExportSecret = exportSecret; mOutputUri = outputUri; + mIsEncrypted = isEncrypted; } protected BackupKeyringParcel(Parcel in) { @@ -44,6 +46,7 @@ public class BackupKeyringParcel implements Parcelable { mExportSecret = in.readByte() != 0x00; mOutputUri = (Uri) in.readValue(Uri.class.getClassLoader()); mMasterKeyIds = in.createLongArray(); + mIsEncrypted = in.readInt() != 0; } @Override @@ -57,6 +60,7 @@ public class BackupKeyringParcel implements Parcelable { dest.writeByte((byte) (mExportSecret ? 0x01 : 0x00)); dest.writeValue(mOutputUri); dest.writeLongArray(mMasterKeyIds); + dest.writeInt(mIsEncrypted ? 1 : 0); } public static final Parcelable.Creator<BackupKeyringParcel> CREATOR = new Parcelable.Creator<BackupKeyringParcel>() { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/BackupCodeFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/BackupCodeFragment.java index fb332563d..012ea0610 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/BackupCodeFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/BackupCodeFragment.java @@ -606,7 +606,7 @@ public class BackupCodeFragment extends CryptoOperationFragment<BackupKeyringPar @Nullable @Override public BackupKeyringParcel createOperationInput() { - return new BackupKeyringParcel(mMasterKeyIds, mExportSecret, mCachedBackupUri); + return new BackupKeyringParcel(mMasterKeyIds, mExportSecret, true, mCachedBackupUri); } @Override |