Added PGP encrypt-only

pull/212/head
M66B 2 years ago
parent 0496bdb167
commit e436a46928

@ -102,6 +102,7 @@ public class EntityMessage implements Serializable {
static final Integer PGP_SIGNONLY = 2; static final Integer PGP_SIGNONLY = 2;
static final Integer SMIME_SIGNENCRYPT = 3; static final Integer SMIME_SIGNENCRYPT = 3;
static final Integer SMIME_SIGNONLY = 4; static final Integer SMIME_SIGNONLY = 4;
static final Integer PGP_ENCRYPTONLY = 5;
static final Integer PRIORITIY_LOW = 0; static final Integer PRIORITIY_LOW = 0;
static final Integer PRIORITIY_NORMAL = 1; static final Integer PRIORITIY_NORMAL = 1;

@ -1835,10 +1835,12 @@ public class FragmentCompose extends FragmentBase {
ibEncrypt.setImageResource(R.drawable.twotone_gesture_24); ibEncrypt.setImageResource(R.drawable.twotone_gesture_24);
ibEncrypt.setImageTintList(ColorStateList.valueOf(colorActionForeground)); ibEncrypt.setImageTintList(ColorStateList.valueOf(colorActionForeground));
tv.setText(EntityMessage.PGP_SIGNONLY.equals(encrypt) ? "P" : "S"); tv.setText(EntityMessage.PGP_SIGNONLY.equals(encrypt) ? "P" : "S");
} else if (EntityMessage.PGP_SIGNENCRYPT.equals(encrypt) || EntityMessage.SMIME_SIGNENCRYPT.equals(encrypt)) { } else if (EntityMessage.PGP_ENCRYPTONLY.equals(encrypt) ||
EntityMessage.PGP_SIGNENCRYPT.equals(encrypt) ||
EntityMessage.SMIME_SIGNENCRYPT.equals(encrypt)) {
ibEncrypt.setImageResource(R.drawable.twotone_lock_24); ibEncrypt.setImageResource(R.drawable.twotone_lock_24);
ibEncrypt.setImageTintList(ColorStateList.valueOf(colorEncrypt)); ibEncrypt.setImageTintList(ColorStateList.valueOf(colorEncrypt));
tv.setText(EntityMessage.PGP_SIGNENCRYPT.equals(encrypt) ? "P" : "S"); tv.setText(EntityMessage.SMIME_SIGNENCRYPT.equals(encrypt) ? "S" : "P");
} else { } else {
ibEncrypt.setImageResource(R.drawable.twotone_lock_open_24); ibEncrypt.setImageResource(R.drawable.twotone_lock_open_24);
ibEncrypt.setImageTintList(ColorStateList.valueOf(colorActionForeground)); ibEncrypt.setImageTintList(ColorStateList.valueOf(colorActionForeground));
@ -1880,7 +1882,8 @@ public class FragmentCompose extends FragmentBase {
if (EntityMessage.PGP_SIGNONLY.equals(encrypt) || if (EntityMessage.PGP_SIGNONLY.equals(encrypt) ||
EntityMessage.SMIME_SIGNONLY.equals(encrypt)) EntityMessage.SMIME_SIGNONLY.equals(encrypt))
bottom_navigation.getMenu().findItem(R.id.action_send).setTitle(R.string.title_sign); bottom_navigation.getMenu().findItem(R.id.action_send).setTitle(R.string.title_sign);
else if (EntityMessage.PGP_SIGNENCRYPT.equals(encrypt) || else if (EntityMessage.PGP_ENCRYPTONLY.equals(encrypt) ||
EntityMessage.PGP_SIGNENCRYPT.equals(encrypt) ||
EntityMessage.SMIME_SIGNENCRYPT.equals(encrypt)) EntityMessage.SMIME_SIGNENCRYPT.equals(encrypt))
bottom_navigation.getMenu().findItem(R.id.action_send).setTitle(R.string.title_encrypt); bottom_navigation.getMenu().findItem(R.id.action_send).setTitle(R.string.title_encrypt);
else else
@ -1995,7 +1998,8 @@ public class FragmentCompose extends FragmentBase {
if (identity == null || identity.encrypt == 0) { if (identity == null || identity.encrypt == 0) {
if (EntityMessage.ENCRYPT_NONE.equals(encrypt) || encrypt == null) if (EntityMessage.ENCRYPT_NONE.equals(encrypt) || encrypt == null)
encrypt = EntityMessage.PGP_SIGNENCRYPT; encrypt = EntityMessage.PGP_SIGNENCRYPT;
else if (EntityMessage.PGP_SIGNENCRYPT.equals(encrypt)) else if (EntityMessage.PGP_ENCRYPTONLY.equals(encrypt) ||
EntityMessage.PGP_SIGNENCRYPT.equals(encrypt))
encrypt = EntityMessage.PGP_SIGNONLY; encrypt = EntityMessage.PGP_SIGNONLY;
else else
encrypt = EntityMessage.ENCRYPT_NONE; encrypt = EntityMessage.ENCRYPT_NONE;
@ -2010,6 +2014,7 @@ public class FragmentCompose extends FragmentBase {
final Context context = getContext(); final Context context = getContext();
if ((EntityMessage.PGP_SIGNONLY.equals(encrypt) || if ((EntityMessage.PGP_SIGNONLY.equals(encrypt) ||
EntityMessage.PGP_ENCRYPTONLY.equals(encrypt) ||
EntityMessage.PGP_SIGNENCRYPT.equals(encrypt)) EntityMessage.PGP_SIGNENCRYPT.equals(encrypt))
&& !Helper.isOpenKeychainInstalled(context)) { && !Helper.isOpenKeychainInstalled(context)) {
encrypt = EntityMessage.ENCRYPT_NONE; encrypt = EntityMessage.ENCRYPT_NONE;
@ -2951,7 +2956,8 @@ public class FragmentCompose extends FragmentBase {
Intent intent; Intent intent;
if (EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt)) if (EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt))
intent = new Intent(OpenPgpApi.ACTION_GET_SIGN_KEY_ID); intent = new Intent(OpenPgpApi.ACTION_GET_SIGN_KEY_ID);
else if (EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt)) { else if (EntityMessage.PGP_ENCRYPTONLY.equals(draft.ui_encrypt) ||
EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt)) {
intent = new Intent(OpenPgpApi.ACTION_GET_KEY_IDS); intent = new Intent(OpenPgpApi.ACTION_GET_KEY_IDS);
intent.putExtra(OpenPgpApi.EXTRA_USER_IDS, pgpUserIds); intent.putExtra(OpenPgpApi.EXTRA_USER_IDS, pgpUserIds);
} else } else
@ -3544,6 +3550,8 @@ public class FragmentCompose extends FragmentBase {
// Serializing messages is NOT reproducible // Serializing messages is NOT reproducible
if ((EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt) && if ((EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt) &&
OpenPgpApi.ACTION_GET_SIGN_KEY_ID.equals(data.getAction())) || OpenPgpApi.ACTION_GET_SIGN_KEY_ID.equals(data.getAction())) ||
(EntityMessage.PGP_ENCRYPTONLY.equals(draft.ui_encrypt) &&
OpenPgpApi.ACTION_GET_KEY_IDS.equals(data.getAction())) ||
(EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt) && (EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt) &&
OpenPgpApi.ACTION_GET_KEY_IDS.equals(data.getAction()))) { OpenPgpApi.ACTION_GET_KEY_IDS.equals(data.getAction()))) {
// Get/clean attachments // Get/clean attachments
@ -3643,6 +3651,7 @@ public class FragmentCompose extends FragmentBase {
// Attach key, signed/encrypted data // Attach key, signed/encrypted data
if (OpenPgpApi.ACTION_GET_KEY.equals(data.getAction()) || if (OpenPgpApi.ACTION_GET_KEY.equals(data.getAction()) ||
OpenPgpApi.ACTION_DETACHED_SIGN.equals(data.getAction()) || OpenPgpApi.ACTION_DETACHED_SIGN.equals(data.getAction()) ||
OpenPgpApi.ACTION_ENCRYPT.equals(data.getAction()) ||
OpenPgpApi.ACTION_SIGN_AND_ENCRYPT.equals(data.getAction())) OpenPgpApi.ACTION_SIGN_AND_ENCRYPT.equals(data.getAction()))
try { try {
db.beginTransaction(); db.beginTransaction();
@ -3661,7 +3670,8 @@ public class FragmentCompose extends FragmentBase {
throw new IllegalArgumentException("micalg missing"); throw new IllegalArgumentException("micalg missing");
ct = new ContentType("application/pgp-signature"); ct = new ContentType("application/pgp-signature");
ct.setParameter("micalg", micalg); ct.setParameter("micalg", micalg);
} else if (OpenPgpApi.ACTION_SIGN_AND_ENCRYPT.equals(data.getAction())) { } else if (OpenPgpApi.ACTION_ENCRYPT.equals(data.getAction()) ||
OpenPgpApi.ACTION_SIGN_AND_ENCRYPT.equals(data.getAction())) {
name = "encrypted.asc"; name = "encrypted.asc";
encryption = EntityAttachment.PGP_MESSAGE; encryption = EntityAttachment.PGP_MESSAGE;
} else } else
@ -3707,6 +3717,14 @@ public class FragmentCompose extends FragmentBase {
throw new IllegalArgumentException(context.getString(R.string.title_key_missing, throw new IllegalArgumentException(context.getString(R.string.title_key_missing,
TextUtils.join(", ", pgpUserIds))); TextUtils.join(", ", pgpUserIds)));
if (EntityMessage.PGP_ENCRYPTONLY.equals(draft.ui_encrypt)) {
// Encrypt message
Intent intent = new Intent(OpenPgpApi.ACTION_ENCRYPT);
intent.putExtra(OpenPgpApi.EXTRA_KEY_IDS, pgpKeyIds);
intent.putExtra(OpenPgpApi.EXTRA_REQUEST_ASCII_ARMOR, true);
intent.putExtra(BuildConfig.APPLICATION_ID, largs);
return intent;
} else {
if (identity.sign_key != null) { if (identity.sign_key != null) {
pgpSignKeyId = identity.sign_key; pgpSignKeyId = identity.sign_key;
@ -3724,6 +3742,7 @@ public class FragmentCompose extends FragmentBase {
intent.putExtra(BuildConfig.APPLICATION_ID, largs); intent.putExtra(BuildConfig.APPLICATION_ID, largs);
return intent; return intent;
} }
}
} else if (OpenPgpApi.ACTION_GET_SIGN_KEY_ID.equals(data.getAction())) { } else if (OpenPgpApi.ACTION_GET_SIGN_KEY_ID.equals(data.getAction())) {
pgpSignKeyId = result.getLongExtra(OpenPgpApi.EXTRA_SIGN_KEY_ID, -1); pgpSignKeyId = result.getLongExtra(OpenPgpApi.EXTRA_SIGN_KEY_ID, -1);
if (pgpSignKeyId == 0) if (pgpSignKeyId == 0)
@ -3775,7 +3794,8 @@ public class FragmentCompose extends FragmentBase {
args.putInt("action", largs.getInt("action")); args.putInt("action", largs.getInt("action"));
args.putBundle("extras", largs.getBundle("extras")); args.putBundle("extras", largs.getBundle("extras"));
return null; return null;
} else if (OpenPgpApi.ACTION_SIGN_AND_ENCRYPT.equals(data.getAction())) { } else if (OpenPgpApi.ACTION_ENCRYPT.equals(data.getAction()) ||
OpenPgpApi.ACTION_SIGN_AND_ENCRYPT.equals(data.getAction())) {
input.delete(); input.delete();
// send message // send message
@ -6233,6 +6253,9 @@ public class FragmentCompose extends FragmentBase {
!eparts.contains(EntityAttachment.PGP_SIGNATURE) || !eparts.contains(EntityAttachment.PGP_SIGNATURE) ||
!eparts.contains(EntityAttachment.PGP_CONTENT)) !eparts.contains(EntityAttachment.PGP_CONTENT))
dirty = true; dirty = true;
} else if (EntityMessage.PGP_ENCRYPTONLY.equals(draft.ui_encrypt)) {
if (!eparts.contains(EntityAttachment.PGP_MESSAGE))
dirty = true;
} else if (EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt)) { } else if (EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt)) {
if (!eparts.contains(EntityAttachment.PGP_KEY) || if (!eparts.contains(EntityAttachment.PGP_KEY) ||
!eparts.contains(EntityAttachment.PGP_MESSAGE)) !eparts.contains(EntityAttachment.PGP_MESSAGE))
@ -6440,7 +6463,8 @@ public class FragmentCompose extends FragmentBase {
// Execute action // Execute action
boolean encrypted = extras.getBoolean("encrypted"); boolean encrypted = extras.getBoolean("encrypted");
boolean shouldEncrypt = EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt) || boolean shouldEncrypt = EntityMessage.PGP_ENCRYPTONLY.equals(draft.ui_encrypt) ||
EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt) ||
(EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt) && action == R.id.action_send) || (EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt) && action == R.id.action_send) ||
EntityMessage.SMIME_SIGNENCRYPT.equals(draft.ui_encrypt) || EntityMessage.SMIME_SIGNENCRYPT.equals(draft.ui_encrypt) ||
(EntityMessage.SMIME_SIGNONLY.equals(draft.ui_encrypt) && action == R.id.action_send); (EntityMessage.SMIME_SIGNONLY.equals(draft.ui_encrypt) && action == R.id.action_send);
@ -6462,7 +6486,8 @@ public class FragmentCompose extends FragmentBase {
action == R.id.action_redo || action == R.id.action_redo ||
action == R.id.action_check) { action == R.id.action_check) {
boolean unencrypted = boolean unencrypted =
(!EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt) && (!EntityMessage.PGP_ENCRYPTONLY.equals(draft.ui_encrypt) &&
!EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt) &&
!EntityMessage.SMIME_SIGNENCRYPT.equals(draft.ui_encrypt)); !EntityMessage.SMIME_SIGNENCRYPT.equals(draft.ui_encrypt));
if ((dirty && unencrypted) || encrypted) { if ((dirty && unencrypted) || encrypted) {
if (save_drafts) { if (save_drafts) {
@ -6825,6 +6850,7 @@ public class FragmentCompose extends FragmentBase {
if (needsEncryption) { if (needsEncryption) {
if (ActivityBilling.isPro(getContext()) || if (ActivityBilling.isPro(getContext()) ||
EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt) || EntityMessage.PGP_SIGNONLY.equals(draft.ui_encrypt) ||
EntityMessage.PGP_ENCRYPTONLY.equals(draft.ui_encrypt) ||
EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt)) { EntityMessage.PGP_SIGNENCRYPT.equals(draft.ui_encrypt)) {
boolean interactive = args.getBoolean("interactive"); boolean interactive = args.getBoolean("interactive");
onEncrypt(draft, action, extras, interactive); onEncrypt(draft, action, extras, interactive);
@ -7935,6 +7961,7 @@ public class FragmentCompose extends FragmentBase {
setEncrypt(encryptValues[position]); setEncrypt(encryptValues[position]);
if ((encryptValues[position] == EntityMessage.PGP_SIGNONLY || if ((encryptValues[position] == EntityMessage.PGP_SIGNONLY ||
encryptValues[position] == EntityMessage.PGP_ENCRYPTONLY ||
encryptValues[position] == EntityMessage.PGP_SIGNENCRYPT) && encryptValues[position] == EntityMessage.PGP_SIGNENCRYPT) &&
Helper.isOpenKeychainInstalled(context)) { Helper.isOpenKeychainInstalled(context)) {
tvEncrypt.setPaintFlags(tvEncrypt.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG); tvEncrypt.setPaintFlags(tvEncrypt.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG);
@ -7980,6 +8007,13 @@ public class FragmentCompose extends FragmentBase {
db.message().setMessageUiEncrypt(message.id, encrypt); db.message().setMessageUiEncrypt(message.id, encrypt);
List<EntityAttachment> attachments = db.attachment().getAttachments(message.id);
if (attachments == null)
return null;
for (EntityAttachment attachment : attachments)
if (attachment.isEncryption())
db.attachment().deleteAttachment(attachment.id);
if (encrypt != EntityMessage.ENCRYPT_NONE && if (encrypt != EntityMessage.ENCRYPT_NONE &&
message.identity != null) { message.identity != null) {
int iencrypt = int iencrypt =

@ -2491,6 +2491,7 @@
<string-array name="encryptNames"> <string-array name="encryptNames">
<item>None</item> <item>None</item>
<item>PGP sign-only</item> <item>PGP sign-only</item>
<item>PGP encrypt-only</item>
<item>PGP sign+encrypt</item> <item>PGP sign+encrypt</item>
<item>S/MIME sign-only</item> <item>S/MIME sign-only</item>
<item>S/MIME sign+encrypt</item> <item>S/MIME sign+encrypt</item>
@ -2499,6 +2500,7 @@
<integer-array name="encryptValues" translatable="false"> <integer-array name="encryptValues" translatable="false">
<item>0</item> <item>0</item>
<item>2</item> <item>2</item>
<item>5</item>
<item>1</item> <item>1</item>
<item>4</item> <item>4</item>
<item>3</item> <item>3</item>

Loading…
Cancel
Save