aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java
diff options
context:
space:
mode:
authorVincent Breitmoser <valodim@mugenguild.com>2015-09-16 00:05:21 +0200
committerVincent Breitmoser <valodim@mugenguild.com>2015-09-16 00:05:21 +0200
commit99fd1f4c22c51fe4967517c5cf69dc3af9fe5378 (patch)
tree53984b08cecae801d2d2939ec0dc02d1b015f4e8 /OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java
parent326834fd581861e0f8056eb0a5de8205088e7f09 (diff)
downloadopen-keychain-99fd1f4c22c51fe4967517c5cf69dc3af9fe5378.tar.gz
open-keychain-99fd1f4c22c51fe4967517c5cf69dc3af9fe5378.tar.bz2
open-keychain-99fd1f4c22c51fe4967517c5cf69dc3af9fe5378.zip
preliminary working mime parsing in DecryptListFragment! (beware WIP, here be dragons!)
Diffstat (limited to 'OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java20
1 files changed, 11 insertions, 9 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java
index cb26080e8..7e93ad0d0 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/InputDataOperation.java
@@ -70,6 +70,8 @@ public class InputDataOperation extends BaseOperation<InputDataParcel> {
Uri currentUri;
+ DecryptVerifyResult decryptResult = null;
+
PgpDecryptVerifyInputParcel decryptInput = input.getDecryptInput();
if (decryptInput != null) {
@@ -83,11 +85,11 @@ public class InputDataOperation extends BaseOperation<InputDataParcel> {
currentUri = TemporaryStorageProvider.createFile(mContext);
decryptInput.setOutputUri(currentUri);
- DecryptVerifyResult result = op.execute(decryptInput, cryptoInput);
- if (result.isPending()) {
- return new InputDataResult(log, result);
+ decryptResult = op.execute(decryptInput, cryptoInput);
+ if (decryptResult.isPending()) {
+ return new InputDataResult(log, decryptResult);
}
- log.addByMerge(result, 2);
+ log.addByMerge(decryptResult, 2);
} else {
currentUri = input.getInputUri();
@@ -106,7 +108,7 @@ public class InputDataOperation extends BaseOperation<InputDataParcel> {
uris.add(currentUri);
log.add(LogType.MSG_DATA_OK, 1);
- return new InputDataResult(InputDataResult.RESULT_OK, log, uris);
+ return new InputDataResult(InputDataResult.RESULT_OK, log, decryptResult, uris);
}
@@ -117,7 +119,7 @@ public class InputDataOperation extends BaseOperation<InputDataParcel> {
in = mContext.getContentResolver().openInputStream(currentUri);
} catch (FileNotFoundException e) {
log.add(LogType.MSG_DATA_ERROR_IO, 2);
- return new InputDataResult(InputDataResult.RESULT_ERROR, log, null);
+ return new InputDataResult(InputDataResult.RESULT_ERROR, log);
}
MimeStreamParser parser = new MimeStreamParser((MimeConfig) null);
@@ -176,16 +178,16 @@ public class InputDataOperation extends BaseOperation<InputDataParcel> {
log.add(LogType.MSG_DATA_MIME_OK, 2);
log.add(LogType.MSG_DATA_OK, 1);
- return new InputDataResult(InputDataResult.RESULT_OK, log, outputUris);
+ return new InputDataResult(InputDataResult.RESULT_OK, log, decryptResult, outputUris);
} catch (IOException e) {
e.printStackTrace();
log.add(LogType.MSG_DATA_MIME_ERROR, 2);
- return new InputDataResult(InputDataResult.RESULT_ERROR, log, null);
+ return new InputDataResult(InputDataResult.RESULT_ERROR, log);
} catch (MimeException e) {
e.printStackTrace();
log.add(LogType.MSG_DATA_MIME_ERROR, 2);
- return new InputDataResult(InputDataResult.RESULT_ERROR, log, outputUris);
+ return new InputDataResult(InputDataResult.RESULT_ERROR, log);
}
}