mirror of
https://github.com/moparisthebest/k-9
synced 2025-01-11 21:58:35 -05:00
Merge branch 'crypto-view'
* crypto-view: Move as much of the Apg code as possible to its own "view" class (should eventually be a fragment?) Bumped manifest to 3.702
This commit is contained in:
commit
a3793ac651
@ -1,5 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<LinearLayout
|
<com.fsck.k9.view.MessageCryptoView
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:id="@+id/layout_decrypt"
|
android:id="@+id/layout_decrypt"
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
@ -55,4 +55,4 @@
|
|||||||
android:layout_width="0dip"
|
android:layout_width="0dip"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_weight="1"/>
|
android:layout_weight="1"/>
|
||||||
</LinearLayout>
|
</com.fsck.k9.view.MessageCryptoView>
|
||||||
|
@ -20,7 +20,6 @@ import android.widget.*;
|
|||||||
import com.fsck.k9.*;
|
import com.fsck.k9.*;
|
||||||
import com.fsck.k9.controller.MessagingController;
|
import com.fsck.k9.controller.MessagingController;
|
||||||
import com.fsck.k9.controller.MessagingListener;
|
import com.fsck.k9.controller.MessagingListener;
|
||||||
import com.fsck.k9.crypto.CryptoProvider;
|
|
||||||
import com.fsck.k9.crypto.PgpData;
|
import com.fsck.k9.crypto.PgpData;
|
||||||
import com.fsck.k9.helper.Contacts;
|
import com.fsck.k9.helper.Contacts;
|
||||||
import com.fsck.k9.helper.Utility;
|
import com.fsck.k9.helper.Utility;
|
||||||
@ -34,6 +33,7 @@ import com.fsck.k9.view.AttachmentView;
|
|||||||
import com.fsck.k9.view.MessageWebView;
|
import com.fsck.k9.view.MessageWebView;
|
||||||
import com.fsck.k9.view.ToggleScrollView;
|
import com.fsck.k9.view.ToggleScrollView;
|
||||||
import com.fsck.k9.view.MessageHeader;
|
import com.fsck.k9.view.MessageHeader;
|
||||||
|
import com.fsck.k9.view.MessageCryptoView;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -46,12 +46,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
private static final String STATE_PGP_DATA = "pgpData";
|
private static final String STATE_PGP_DATA = "pgpData";
|
||||||
private static final int ACTIVITY_CHOOSE_FOLDER_MOVE = 1;
|
private static final int ACTIVITY_CHOOSE_FOLDER_MOVE = 1;
|
||||||
private static final int ACTIVITY_CHOOSE_FOLDER_COPY = 2;
|
private static final int ACTIVITY_CHOOSE_FOLDER_COPY = 2;
|
||||||
private View mDecryptLayout;
|
private MessageCryptoView mCryptoView;
|
||||||
private Button mDecryptButton;
|
|
||||||
private LinearLayout mCryptoSignatureLayout = null;
|
|
||||||
private ImageView mCryptoSignatureStatusImage = null;
|
|
||||||
private TextView mCryptoSignatureUserId = null;
|
|
||||||
private TextView mCryptoSignatureUserIdRest = null;
|
|
||||||
private MessageWebView mMessageContentView;
|
private MessageWebView mMessageContentView;
|
||||||
private boolean mScreenReaderEnabled;
|
private boolean mScreenReaderEnabled;
|
||||||
private AccessibleWebView mAccessibleMessageContentView;
|
private AccessibleWebView mAccessibleMessageContentView;
|
||||||
@ -71,7 +66,6 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
private MessageReference mMessageReference;
|
private MessageReference mMessageReference;
|
||||||
private ArrayList<MessageReference> mMessageReferences;
|
private ArrayList<MessageReference> mMessageReferences;
|
||||||
private Message mMessage;
|
private Message mMessage;
|
||||||
private PgpData mPgpData = null;
|
|
||||||
private static final int PREVIOUS = 1;
|
private static final int PREVIOUS = 1;
|
||||||
private static final int NEXT = 2;
|
private static final int NEXT = 2;
|
||||||
private int mLastDirection = PREVIOUS;
|
private int mLastDirection = PREVIOUS;
|
||||||
@ -377,6 +371,9 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
mAttachments = (LinearLayout) findViewById(R.id.attachments);
|
mAttachments = (LinearLayout) findViewById(R.id.attachments);
|
||||||
|
|
||||||
mHeaderContainer = (MessageHeader) findViewById(R.id.header_container);
|
mHeaderContainer = (MessageHeader) findViewById(R.id.header_container);
|
||||||
|
mCryptoView = (MessageCryptoView) findViewById(R.id.layout_decrypt);
|
||||||
|
mCryptoView.setActivity(this);
|
||||||
|
mCryptoView.setupChildViews();
|
||||||
|
|
||||||
mScreenReaderEnabled = isScreenReaderActive();
|
mScreenReaderEnabled = isScreenReaderActive();
|
||||||
if (mScreenReaderEnabled) {
|
if (mScreenReaderEnabled) {
|
||||||
@ -387,15 +384,13 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
mMessageContentView.setVisibility(View.VISIBLE);
|
mMessageContentView.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
setupDecryptLayout();
|
|
||||||
|
|
||||||
setTitle("");
|
setTitle("");
|
||||||
Intent intent = getIntent();
|
Intent intent = getIntent();
|
||||||
Uri uri = intent.getData();
|
Uri uri = intent.getData();
|
||||||
if (icicle != null) {
|
if (icicle != null) {
|
||||||
restoreMessageReferences(icicle);
|
restoreMessageReferences(icicle);
|
||||||
mPgpData = (PgpData) icicle.getSerializable(STATE_PGP_DATA);
|
mCryptoView.setCryptoData((PgpData) icicle.getSerializable(STATE_PGP_DATA));
|
||||||
updateDecryptLayout();
|
|
||||||
} else {
|
} else {
|
||||||
if (uri == null) {
|
if (uri == null) {
|
||||||
restoreMessageReferencesExtra(intent);
|
restoreMessageReferencesExtra(intent);
|
||||||
@ -532,33 +527,6 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void setupDecryptLayout() {
|
|
||||||
mDecryptLayout = findViewById(R.id.layout_decrypt);
|
|
||||||
mDecryptButton = (Button) findViewById(R.id.btn_decrypt);
|
|
||||||
mDecryptButton.setOnClickListener(new OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(View v) {
|
|
||||||
try {
|
|
||||||
String data = null;
|
|
||||||
Part part = MimeUtility.findFirstPartByMimeType(mMessage, "text/plain");
|
|
||||||
if (part == null) {
|
|
||||||
part = MimeUtility.findFirstPartByMimeType(mMessage, "text/html");
|
|
||||||
}
|
|
||||||
if (part != null) {
|
|
||||||
data = MimeUtility.getTextFromPart(part);
|
|
||||||
}
|
|
||||||
mAccount.getCryptoProvider().decrypt(MessageView.this, data, mPgpData);
|
|
||||||
} catch (MessagingException me) {
|
|
||||||
Log.e(K9.LOG_TAG, "Unable to decrypt email.", me);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
mCryptoSignatureLayout = (LinearLayout) findViewById(R.id.crypto_signature);
|
|
||||||
mCryptoSignatureStatusImage = (ImageView) findViewById(R.id.ic_crypto_signature_status);
|
|
||||||
mCryptoSignatureUserId = (TextView) findViewById(R.id.userId);
|
|
||||||
mCryptoSignatureUserIdRest = (TextView) findViewById(R.id.userIdRest);
|
|
||||||
mCryptoSignatureLayout.setVisibility(View.INVISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean isScreenReaderActive() {
|
private boolean isScreenReaderActive() {
|
||||||
final String SCREENREADER_INTENT_ACTION = "android.accessibilityservice.AccessibilityService";
|
final String SCREENREADER_INTENT_ACTION = "android.accessibilityservice.AccessibilityService";
|
||||||
@ -597,7 +565,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
protected void onSaveInstanceState(Bundle outState) {
|
protected void onSaveInstanceState(Bundle outState) {
|
||||||
outState.putSerializable(EXTRA_MESSAGE_REFERENCE, mMessageReference);
|
outState.putSerializable(EXTRA_MESSAGE_REFERENCE, mMessageReference);
|
||||||
outState.putSerializable(EXTRA_MESSAGE_REFERENCES, mMessageReferences);
|
outState.putSerializable(EXTRA_MESSAGE_REFERENCES, mMessageReferences);
|
||||||
outState.putSerializable(STATE_PGP_DATA, mPgpData);
|
outState.putSerializable(STATE_PGP_DATA, mCryptoView.getCryptoData());
|
||||||
outState.putBoolean(SHOW_PICTURES, mShowPictures);
|
outState.putBoolean(SHOW_PICTURES, mShowPictures);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -605,8 +573,9 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
protected void onRestoreInstanceState(Bundle savedInstanceState) {
|
protected void onRestoreInstanceState(Bundle savedInstanceState) {
|
||||||
super.onRestoreInstanceState(savedInstanceState);
|
super.onRestoreInstanceState(savedInstanceState);
|
||||||
setLoadPictures(savedInstanceState.getBoolean(SHOW_PICTURES));
|
setLoadPictures(savedInstanceState.getBoolean(SHOW_PICTURES));
|
||||||
initializeCrypto((PgpData) savedInstanceState.getSerializable(STATE_PGP_DATA));
|
mCryptoView.setCryptoData((PgpData) savedInstanceState.getSerializable(STATE_PGP_DATA));
|
||||||
updateDecryptLayout();
|
mCryptoView.setCryptoProvider(mAccount.getCryptoProvider());
|
||||||
|
mCryptoView.updateLayout(mMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void displayMessage(MessageReference ref) {
|
private void displayMessage(MessageReference ref) {
|
||||||
@ -624,7 +593,8 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
mAttachments.removeAllViews();
|
mAttachments.removeAllViews();
|
||||||
findSurroundingMessagesUid();
|
findSurroundingMessagesUid();
|
||||||
// start with fresh, empty PGP data
|
// start with fresh, empty PGP data
|
||||||
initializeCrypto(null);
|
mCryptoView.setCryptoData(null);
|
||||||
|
mCryptoView.setCryptoProvider(mAccount.getCryptoProvider());
|
||||||
mTopView.setVisibility(View.VISIBLE);
|
mTopView.setVisibility(View.VISIBLE);
|
||||||
mController.loadMessageForView(
|
mController.loadMessageForView(
|
||||||
mAccount,
|
mAccount,
|
||||||
@ -844,21 +814,21 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
|
|
||||||
private void onReply() {
|
private void onReply() {
|
||||||
if (mMessage != null) {
|
if (mMessage != null) {
|
||||||
MessageCompose.actionReply(this, mAccount, mMessage, false, mPgpData.getDecryptedData());
|
MessageCompose.actionReply(this, mAccount, mMessage, false, mCryptoView.getDecryptedContent());
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onReplyAll() {
|
private void onReplyAll() {
|
||||||
if (mMessage != null) {
|
if (mMessage != null) {
|
||||||
MessageCompose.actionReply(this, mAccount, mMessage, true, mPgpData.getDecryptedData());
|
MessageCompose.actionReply(this, mAccount, mMessage, true, mCryptoView.getDecryptedContent());
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onForward() {
|
private void onForward() {
|
||||||
if (mMessage != null) {
|
if (mMessage != null) {
|
||||||
MessageCompose.actionForward(this, mAccount, mMessage, mPgpData.getDecryptedData());
|
MessageCompose.actionForward(this, mAccount, mMessage, mCryptoView.getDecryptedContent());
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -917,7 +887,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
|
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||||
if (mAccount.getCryptoProvider().onActivityResult(this, requestCode, resultCode, data, mPgpData)) {
|
if (mAccount.getCryptoProvider().onActivityResult(this, requestCode, resultCode, data, mCryptoView.getCryptoData())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (resultCode != RESULT_OK)
|
if (resultCode != RESULT_OK)
|
||||||
@ -1160,6 +1130,11 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public MessageCryptoView getDecryptLayout() {
|
||||||
|
return mCryptoView;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPrepareOptionsMenu(Menu menu) {
|
public boolean onPrepareOptionsMenu(Menu menu) {
|
||||||
prepareMenuItems();
|
prepareMenuItems();
|
||||||
@ -1207,8 +1182,8 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
MessageView.this.mMessage = message;
|
MessageView.this.mMessage = message;
|
||||||
mHandler.removeAllAttachments();
|
mHandler.removeAllAttachments();
|
||||||
String text, type;
|
String text, type;
|
||||||
if (mPgpData.getDecryptedData() != null) {
|
if (mCryptoView.getDecryptedContent() != null) {
|
||||||
text = mPgpData.getDecryptedData();
|
text = mCryptoView.getDecryptedContent();
|
||||||
type = "text/plain";
|
type = "text/plain";
|
||||||
} else {
|
} else {
|
||||||
// getTextForDisplay() always returns HTML-ified content.
|
// getTextForDisplay() always returns HTML-ified content.
|
||||||
@ -1229,7 +1204,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
contentType, "utf-8", null);
|
contentType, "utf-8", null);
|
||||||
mMessageContentView.scrollTo(0, 0);
|
mMessageContentView.scrollTo(0, 0);
|
||||||
}
|
}
|
||||||
updateDecryptLayout();
|
mCryptoView.updateLayout(mMessage);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// If the message contains external pictures and the "Show pictures"
|
// If the message contains external pictures and the "Show pictures"
|
||||||
@ -1248,7 +1223,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
mHandler.post(new Runnable() {
|
mHandler.post(new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
mMessageContentView.loadUrl("file:///android_asset/empty.html");
|
mMessageContentView.loadUrl("file:///android_asset/empty.html");
|
||||||
updateDecryptLayout();
|
mCryptoView.updateLayout(mMessage);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1302,7 +1277,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
mHandler.post(new Runnable() {
|
mHandler.post(new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
mMessageContentView.loadUrl("file:///android_asset/downloading.html");
|
mMessageContentView.loadUrl("file:///android_asset/downloading.html");
|
||||||
updateDecryptLayout();
|
mCryptoView.updateLayout(mMessage);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1340,7 +1315,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
if ((MessageView.this.mMessage == null) ||
|
if ((MessageView.this.mMessage == null) ||
|
||||||
!MessageView.this.mMessage.isSet(Flag.X_DOWNLOADED_PARTIAL)) {
|
!MessageView.this.mMessage.isSet(Flag.X_DOWNLOADED_PARTIAL)) {
|
||||||
mMessageContentView.loadUrl("file:///android_asset/empty.html");
|
mMessageContentView.loadUrl("file:///android_asset/empty.html");
|
||||||
updateDecryptLayout();
|
mCryptoView.updateLayout(mMessage);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -1368,7 +1343,7 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
}
|
}
|
||||||
mHandler.post(new Runnable() {
|
mHandler.post(new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
updateDecryptLayout();
|
mCryptoView.updateLayout(mMessage);
|
||||||
setProgressBarIndeterminateVisibility(true);
|
setProgressBarIndeterminateVisibility(true);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -1419,86 +1394,12 @@ public class MessageView extends K9Activity implements OnClickListener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void initializeCrypto(PgpData data) {
|
// This REALLY should be in MessageCryptoView
|
||||||
if (data == null) {
|
public void onDecryptDone(PgpData pgpData) {
|
||||||
if (mAccount == null) {
|
|
||||||
mAccount = Preferences.getPreferences(this).getAccount(mMessageReference.accountUuid);
|
|
||||||
}
|
|
||||||
mPgpData = new PgpData();
|
|
||||||
} else {
|
|
||||||
mPgpData = data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Fill the decrypt layout with signature data, if known, make controls visible, if
|
|
||||||
* they should be visible.
|
|
||||||
*/
|
|
||||||
public void updateDecryptLayout() {
|
|
||||||
if (mPgpData.getSignatureKeyId() != 0) {
|
|
||||||
mCryptoSignatureUserIdRest.setText(
|
|
||||||
getString(R.string.key_id, Long.toHexString(mPgpData.getSignatureKeyId() & 0xffffffffL)));
|
|
||||||
String userId = mPgpData.getSignatureUserId();
|
|
||||||
if (userId == null) {
|
|
||||||
userId = getString(R.string.unknown_crypto_signature_user_id);
|
|
||||||
}
|
|
||||||
String chunks[] = userId.split(" <", 2);
|
|
||||||
String name = chunks[0];
|
|
||||||
if (chunks.length > 1) {
|
|
||||||
mCryptoSignatureUserIdRest.setText("<" + chunks[1]);
|
|
||||||
}
|
|
||||||
mCryptoSignatureUserId.setText(name);
|
|
||||||
if (mPgpData.getSignatureSuccess()) {
|
|
||||||
mCryptoSignatureStatusImage.setImageResource(R.drawable.overlay_ok);
|
|
||||||
} else if (mPgpData.getSignatureUnknown()) {
|
|
||||||
mCryptoSignatureStatusImage.setImageResource(R.drawable.overlay_error);
|
|
||||||
} else {
|
|
||||||
mCryptoSignatureStatusImage.setImageResource(R.drawable.overlay_error);
|
|
||||||
}
|
|
||||||
mCryptoSignatureLayout.setVisibility(View.VISIBLE);
|
|
||||||
mDecryptLayout.setVisibility(View.VISIBLE);
|
|
||||||
} else {
|
|
||||||
mCryptoSignatureLayout.setVisibility(View.INVISIBLE);
|
|
||||||
}
|
|
||||||
if (false || ((mMessage == null) && (mPgpData.getDecryptedData() == null))) {
|
|
||||||
mDecryptLayout.setVisibility(View.GONE);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (mPgpData.getDecryptedData() != null) {
|
|
||||||
if (mPgpData.getSignatureKeyId() == 0) {
|
|
||||||
mDecryptLayout.setVisibility(View.GONE);
|
|
||||||
} else {
|
|
||||||
// no need to show this after decryption/verification
|
|
||||||
mDecryptButton.setVisibility(View.GONE);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
mDecryptButton.setVisibility(View.VISIBLE);
|
|
||||||
CryptoProvider crypto = mAccount.getCryptoProvider();
|
|
||||||
if (crypto.isEncrypted(mMessage)) {
|
|
||||||
mDecryptButton.setText(R.string.btn_decrypt);
|
|
||||||
mDecryptLayout.setVisibility(View.VISIBLE);
|
|
||||||
} else if (crypto.isSigned(mMessage)) {
|
|
||||||
mDecryptButton.setText(R.string.btn_verify);
|
|
||||||
mDecryptLayout.setVisibility(View.VISIBLE);
|
|
||||||
} else {
|
|
||||||
mDecryptLayout.setVisibility(View.GONE);
|
|
||||||
try {
|
|
||||||
// check for PGP/MIME encryption
|
|
||||||
Part pgp = MimeUtility.findFirstPartByMimeType(mMessage, "application/pgp-encrypted");
|
|
||||||
if (pgp != null) {
|
|
||||||
Toast.makeText(this, R.string.pgp_mime_unsupported, Toast.LENGTH_LONG).show();
|
|
||||||
}
|
|
||||||
} catch (MessagingException e) {
|
|
||||||
// nothing to do...
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void onDecryptDone() {
|
|
||||||
// TODO: this might not be enough if the orientation was changed while in APG,
|
// TODO: this might not be enough if the orientation was changed while in APG,
|
||||||
// sometimes shows the original encrypted content
|
// sometimes shows the original encrypted content
|
||||||
mMessageContentView.loadDataWithBaseURL("email://", mPgpData.getDecryptedData(), "text/plain", "utf-8", null);
|
mMessageContentView.loadDataWithBaseURL("email://", pgpData.getDecryptedData(), "text/plain", "utf-8", null);
|
||||||
updateDecryptLayout();
|
mCryptoView.updateLayout(mMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -327,7 +327,7 @@ public class Apg extends CryptoProvider {
|
|||||||
pgpData.setSignatureUnknown(data.getBooleanExtra(Apg.EXTRA_SIGNATURE_UNKNOWN, false));
|
pgpData.setSignatureUnknown(data.getBooleanExtra(Apg.EXTRA_SIGNATURE_UNKNOWN, false));
|
||||||
|
|
||||||
pgpData.setDecryptedData(data.getStringExtra(Apg.EXTRA_DECRYPTED_MESSAGE));
|
pgpData.setDecryptedData(data.getStringExtra(Apg.EXTRA_DECRYPTED_MESSAGE));
|
||||||
((MessageView) activity).onDecryptDone();
|
((MessageView) activity).onDecryptDone(pgpData);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -386,9 +386,7 @@ public class Apg extends CryptoProvider {
|
|||||||
activity.startActivityForResult(intent, Apg.DECRYPT_MESSAGE);
|
activity.startActivityForResult(intent, Apg.DECRYPT_MESSAGE);
|
||||||
return true;
|
return true;
|
||||||
} catch (ActivityNotFoundException e) {
|
} catch (ActivityNotFoundException e) {
|
||||||
Toast.makeText(activity,
|
Toast.makeText(activity, R.string.error_activity_not_found, Toast.LENGTH_SHORT).show();
|
||||||
R.string.error_activity_not_found,
|
|
||||||
Toast.LENGTH_SHORT).show();
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
176
src/com/fsck/k9/view/MessageCryptoView.java
Normal file
176
src/com/fsck/k9/view/MessageCryptoView.java
Normal file
@ -0,0 +1,176 @@
|
|||||||
|
package com.fsck.k9.view;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.graphics.Bitmap;
|
||||||
|
import android.graphics.BitmapFactory;
|
||||||
|
import android.net.Uri;
|
||||||
|
import android.os.Environment;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.LinearLayout;
|
||||||
|
import android.widget.*;
|
||||||
|
import com.fsck.k9.Account;
|
||||||
|
import com.fsck.k9.K9;
|
||||||
|
import com.fsck.k9.R;
|
||||||
|
import com.fsck.k9.controller.MessagingController;
|
||||||
|
import com.fsck.k9.controller.MessagingListener;
|
||||||
|
import com.fsck.k9.crypto.CryptoProvider;
|
||||||
|
import com.fsck.k9.crypto.PgpData;
|
||||||
|
import com.fsck.k9.helper.MediaScannerNotifier;
|
||||||
|
import com.fsck.k9.helper.SizeFormatter;
|
||||||
|
import com.fsck.k9.helper.Utility;
|
||||||
|
import com.fsck.k9.mail.Message;
|
||||||
|
import com.fsck.k9.mail.MessagingException;
|
||||||
|
import com.fsck.k9.mail.Part;
|
||||||
|
import com.fsck.k9.mail.internet.MimeUtility;
|
||||||
|
import com.fsck.k9.mail.store.LocalStore.LocalAttachmentBodyPart;
|
||||||
|
import com.fsck.k9.provider.AttachmentProvider;
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public class MessageCryptoView extends LinearLayout {
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
private Activity mActivity;
|
||||||
|
private PgpData mPgpData = null;
|
||||||
|
private CryptoProvider mCryptoProvider = null;
|
||||||
|
private View mMessageContentView;
|
||||||
|
private Button mDecryptButton;
|
||||||
|
private LinearLayout mCryptoSignatureLayout = null;
|
||||||
|
private ImageView mCryptoSignatureStatusImage = null;
|
||||||
|
private TextView mCryptoSignatureUserId = null;
|
||||||
|
private TextView mCryptoSignatureUserIdRest = null;
|
||||||
|
|
||||||
|
|
||||||
|
public MessageCryptoView(Context context, AttributeSet attrs) {
|
||||||
|
super(context, attrs);
|
||||||
|
mContext = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setupChildViews() {
|
||||||
|
mCryptoSignatureLayout = (LinearLayout) findViewById(R.id.crypto_signature);
|
||||||
|
mCryptoSignatureStatusImage = (ImageView) findViewById(R.id.ic_crypto_signature_status);
|
||||||
|
mCryptoSignatureUserId = (TextView) findViewById(R.id.userId);
|
||||||
|
mCryptoSignatureUserIdRest = (TextView) findViewById(R.id.userIdRest);
|
||||||
|
mCryptoSignatureLayout.setVisibility(View.INVISIBLE);
|
||||||
|
mDecryptButton = (Button) findViewById(R.id.btn_decrypt);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setActivity(Activity activity) {
|
||||||
|
mActivity = activity;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCryptoProvider(CryptoProvider provider){
|
||||||
|
mCryptoProvider = provider;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PgpData getCryptoData() {
|
||||||
|
return mPgpData;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCryptoData(PgpData data) {
|
||||||
|
if (data == null) {
|
||||||
|
mPgpData = new PgpData();
|
||||||
|
} else {
|
||||||
|
mPgpData = data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fill the decrypt layout with signature data, if known, make controls visible, if
|
||||||
|
* they should be visible.
|
||||||
|
*/
|
||||||
|
public void updateLayout(final Message message) {
|
||||||
|
if (mPgpData.getSignatureKeyId() != 0) {
|
||||||
|
mCryptoSignatureUserIdRest.setText(
|
||||||
|
mContext.getString(R.string.key_id, Long.toHexString(mPgpData.getSignatureKeyId() & 0xffffffffL)));
|
||||||
|
String userId = mPgpData.getSignatureUserId();
|
||||||
|
if (userId == null) {
|
||||||
|
userId = mContext.getString(R.string.unknown_crypto_signature_user_id);
|
||||||
|
}
|
||||||
|
String chunks[] = userId.split(" <", 2);
|
||||||
|
String name = chunks[0];
|
||||||
|
if (chunks.length > 1) {
|
||||||
|
mCryptoSignatureUserIdRest.setText("<" + chunks[1]);
|
||||||
|
}
|
||||||
|
mCryptoSignatureUserId.setText(name);
|
||||||
|
if (mPgpData.getSignatureSuccess()) {
|
||||||
|
mCryptoSignatureStatusImage.setImageResource(R.drawable.overlay_ok);
|
||||||
|
} else if (mPgpData.getSignatureUnknown()) {
|
||||||
|
mCryptoSignatureStatusImage.setImageResource(R.drawable.overlay_error);
|
||||||
|
} else {
|
||||||
|
mCryptoSignatureStatusImage.setImageResource(R.drawable.overlay_error);
|
||||||
|
}
|
||||||
|
mCryptoSignatureLayout.setVisibility(View.VISIBLE);
|
||||||
|
this.setVisibility(View.VISIBLE);
|
||||||
|
} else {
|
||||||
|
mCryptoSignatureLayout.setVisibility(View.INVISIBLE);
|
||||||
|
}
|
||||||
|
if (false || ((message == null) && (getDecryptedContent() == null))) {
|
||||||
|
this.setVisibility(View.GONE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (getDecryptedContent() != null) {
|
||||||
|
if (mPgpData.getSignatureKeyId() == 0) {
|
||||||
|
this.setVisibility(View.GONE);
|
||||||
|
} else {
|
||||||
|
// no need to show this after decryption/verification
|
||||||
|
mDecryptButton.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
mDecryptButton.setOnClickListener(new OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
try {
|
||||||
|
String data = null;
|
||||||
|
Part part = MimeUtility.findFirstPartByMimeType(message, "text/plain");
|
||||||
|
if (part == null) {
|
||||||
|
part = MimeUtility.findFirstPartByMimeType(message, "text/html");
|
||||||
|
}
|
||||||
|
if (part != null) {
|
||||||
|
data = MimeUtility.getTextFromPart(part);
|
||||||
|
}
|
||||||
|
mCryptoProvider.decrypt(mActivity, data, mPgpData);
|
||||||
|
} catch (MessagingException me) {
|
||||||
|
Log.e(K9.LOG_TAG, "Unable to decrypt email.", me);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
mDecryptButton.setVisibility(View.VISIBLE);
|
||||||
|
if (mCryptoProvider.isEncrypted(message)) {
|
||||||
|
mDecryptButton.setText(R.string.btn_decrypt);
|
||||||
|
this.setVisibility(View.VISIBLE);
|
||||||
|
} else if (mCryptoProvider.isSigned(message)) {
|
||||||
|
mDecryptButton.setText(R.string.btn_verify);
|
||||||
|
this.setVisibility(View.VISIBLE);
|
||||||
|
} else {
|
||||||
|
this.setVisibility(View.GONE);
|
||||||
|
try {
|
||||||
|
// check for PGP/MIME encryption
|
||||||
|
Part pgp = MimeUtility.findFirstPartByMimeType(message, "application/pgp-encrypted");
|
||||||
|
if (pgp != null) {
|
||||||
|
Toast.makeText(mContext, R.string.pgp_mime_unsupported, Toast.LENGTH_LONG).show();
|
||||||
|
}
|
||||||
|
} catch (MessagingException e) {
|
||||||
|
// nothing to do...
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public String getDecryptedContent() {
|
||||||
|
return mPgpData.getDecryptedData();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user