Use recognize identity for sign key alias

pull/168/head
M66B 5 years ago
parent 77e32ce5ca
commit 818cb45457

@ -2700,17 +2700,13 @@ public class AdapterMessage extends RecyclerView.Adapter<AdapterMessage.ViewHold
private void onActionDecrypt(TupleMessageEx message, boolean auto) { private void onActionDecrypt(TupleMessageEx message, boolean auto) {
int encrypt = (message.encrypt == null ? EntityMessage.PGP_SIGNENCRYPT /* Inline */ : message.encrypt); int encrypt = (message.encrypt == null ? EntityMessage.PGP_SIGNENCRYPT /* Inline */ : message.encrypt);
String recipient = null;
if (message.to != null && message.to.length == 1)
recipient = ((InternetAddress) message.to[0]).getAddress();
LocalBroadcastManager lbm = LocalBroadcastManager.getInstance(context); LocalBroadcastManager lbm = LocalBroadcastManager.getInstance(context);
lbm.sendBroadcast( lbm.sendBroadcast(
new Intent(FragmentMessages.ACTION_DECRYPT) new Intent(FragmentMessages.ACTION_DECRYPT)
.putExtra("id", message.id) .putExtra("id", message.id)
.putExtra("auto", auto) .putExtra("auto", auto)
.putExtra("type", encrypt) .putExtra("type", encrypt));
.putExtra("recipient", recipient));
} }
private void onActionReplyMenu(TupleMessageEx message) { private void onActionReplyMenu(TupleMessageEx message) {

@ -3896,7 +3896,6 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
long id = intent.getLongExtra("id", -1); long id = intent.getLongExtra("id", -1);
boolean auto = intent.getBooleanExtra("auto", false); boolean auto = intent.getBooleanExtra("auto", false);
int type = intent.getIntExtra("type", EntityMessage.ENCRYPT_NONE); int type = intent.getIntExtra("type", EntityMessage.ENCRYPT_NONE);
String recipient = intent.getStringExtra("recipient");
final Bundle args = new Bundle(); final Bundle args = new Bundle();
args.putLong("id", id); args.putLong("id", id);
@ -3905,27 +3904,50 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
if (EntityMessage.SMIME_SIGNONLY.equals(type)) if (EntityMessage.SMIME_SIGNONLY.equals(type))
onSmime(args); onSmime(args);
else if (EntityMessage.SMIME_SIGNENCRYPT.equals(type)) { else if (EntityMessage.SMIME_SIGNENCRYPT.equals(type)) {
Helper.selectKeyAlias(getActivity(), recipient, new Helper.IKeyAlias() { new SimpleTask<EntityIdentity>() {
@Override @Override
public void onSelected(String alias) { protected EntityIdentity onExecute(Context context, Bundle args) {
args.putString("alias", alias); long id = args.getLong("id");
onSmime(args);
DB db = DB.getInstance(context);
EntityMessage message = db.message().getMessage(id);
if (message == null || message.identity == null)
return null;
return db.identity().getIdentity(message.identity);
} }
@Override @Override
public void onNothingSelected() { protected void onExecuted(Bundle args, EntityIdentity identity) {
Snackbar snackbar = Snackbar.make(view, R.string.title_no_key, Snackbar.LENGTH_LONG); Helper.selectKeyAlias(getActivity(), identity == null ? null : identity.sign_key_alias, new Helper.IKeyAlias() {
final Intent intent = KeyChain.createInstallIntent(); @Override
if (intent.resolveActivity(getContext().getPackageManager()) != null) public void onSelected(String alias) {
snackbar.setAction(R.string.title_fix, new View.OnClickListener() { args.putString("alias", alias);
@Override onSmime(args);
public void onClick(View v) { }
startActivity(intent);
} @Override
}); public void onNothingSelected() {
snackbar.show(); Snackbar snackbar = Snackbar.make(view, R.string.title_no_key, Snackbar.LENGTH_LONG);
final Intent intent = KeyChain.createInstallIntent();
if (intent.resolveActivity(getContext().getPackageManager()) != null)
snackbar.setAction(R.string.title_fix, new View.OnClickListener() {
@Override
public void onClick(View v) {
startActivity(intent);
}
});
snackbar.show();
}
});
} }
});
@Override
protected void onException(Bundle args, Throwable ex) {
Helper.unexpectedError(getParentFragmentManager(), ex);
}
}.execute(this, args, "messages:alias");
} else { } else {
if (pgpService.isBound()) { if (pgpService.isBound()) {
Intent data = new Intent(); Intent data = new Intent();

Loading…
Cancel
Save