mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-12 00:53:39 +00:00
Merge pull request #1248 from mcginty/wrong-group-secure
outgoing group MMS should not be encrypted and considered push
This commit is contained in:
commit
d4ac0c077d
@ -93,6 +93,7 @@ import org.thoughtcrime.securesms.util.BitmapDecodingException;
|
|||||||
import org.thoughtcrime.securesms.util.BitmapUtil;
|
import org.thoughtcrime.securesms.util.BitmapUtil;
|
||||||
import org.thoughtcrime.securesms.util.CharacterCalculator;
|
import org.thoughtcrime.securesms.util.CharacterCalculator;
|
||||||
import org.thoughtcrime.securesms.util.Dialogs;
|
import org.thoughtcrime.securesms.util.Dialogs;
|
||||||
|
import org.thoughtcrime.securesms.util.DirectoryHelper;
|
||||||
import org.thoughtcrime.securesms.util.DynamicLanguage;
|
import org.thoughtcrime.securesms.util.DynamicLanguage;
|
||||||
import org.thoughtcrime.securesms.util.DynamicTheme;
|
import org.thoughtcrime.securesms.util.DynamicTheme;
|
||||||
import org.thoughtcrime.securesms.util.EncryptedCharacterCalculator;
|
import org.thoughtcrime.securesms.util.EncryptedCharacterCalculator;
|
||||||
@ -564,7 +565,7 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void handleAddAttachment() {
|
private void handleAddAttachment() {
|
||||||
if (this.isMmsEnabled || isPushDestination()) {
|
if (this.isMmsEnabled || DirectoryHelper.isPushDestination(this, getRecipients())) {
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(new ContextThemeWrapper(this, R.style.TextSecure_Light_Dialog));
|
AlertDialog.Builder builder = new AlertDialog.Builder(new ContextThemeWrapper(this, R.style.TextSecure_Light_Dialog));
|
||||||
builder.setIcon(R.drawable.ic_dialog_attach);
|
builder.setIcon(R.drawable.ic_dialog_attach);
|
||||||
builder.setTitle(R.string.ConversationActivity_add_attachment);
|
builder.setTitle(R.string.ConversationActivity_add_attachment);
|
||||||
@ -691,7 +692,7 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
|
|||||||
this.characterCalculator = new CharacterCalculator();
|
this.characterCalculator = new CharacterCalculator();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isPushDestination()) {
|
if (DirectoryHelper.isPushDestination(this, getRecipients())) {
|
||||||
sendButton.setImageDrawable(drawables.getDrawable(0));
|
sendButton.setImageDrawable(drawables.getDrawable(0));
|
||||||
} else if (isEncryptedConversation) {
|
} else if (isEncryptedConversation) {
|
||||||
sendButton.setImageDrawable(drawables.getDrawable(1));
|
sendButton.setImageDrawable(drawables.getDrawable(1));
|
||||||
@ -1007,30 +1008,6 @@ public class ConversationActivity extends PassphraseRequiredSherlockFragmentActi
|
|||||||
return getRecipients() != null && getRecipients().isGroupRecipient();
|
return getRecipients() != null && getRecipients().isGroupRecipient();
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isPushDestination() {
|
|
||||||
try {
|
|
||||||
if (!TextSecurePreferences.isPushRegistered(this))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (getRecipients() == null)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (isPushGroupConversation())
|
|
||||||
return true;
|
|
||||||
|
|
||||||
String number = getRecipients().getPrimaryRecipient().getNumber();
|
|
||||||
String e164number = org.thoughtcrime.securesms.util.Util.canonicalizeNumber(this, number);
|
|
||||||
|
|
||||||
return Directory.getInstance(this).isActiveNumber(e164number);
|
|
||||||
} catch (InvalidNumberException e) {
|
|
||||||
Log.w(TAG, e);
|
|
||||||
return false;
|
|
||||||
} catch (NotInDirectoryException e) {
|
|
||||||
Log.w(TAG, e);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private Recipients getRecipients() {
|
private Recipients getRecipients() {
|
||||||
try {
|
try {
|
||||||
if (isExistingConversation()) return this.recipients;
|
if (isExistingConversation()) return this.recipients;
|
||||||
|
@ -210,7 +210,7 @@ public class ConversationFragment extends SherlockListFragment
|
|||||||
this.setListAdapter(new ConversationAdapter(getActivity(), masterSecret,
|
this.setListAdapter(new ConversationAdapter(getActivity(), masterSecret,
|
||||||
new FailedIconClickHandler(),
|
new FailedIconClickHandler(),
|
||||||
(!this.recipients.isSingleRecipient()) || this.recipients.isGroupRecipient(),
|
(!this.recipients.isSingleRecipient()) || this.recipients.isGroupRecipient(),
|
||||||
DirectoryHelper.isPushDestination(getActivity(), this.recipients.getPrimaryRecipient())));
|
DirectoryHelper.isPushDestination(getActivity(), this.recipients)));
|
||||||
getListView().setRecyclerListener((ConversationAdapter)getListAdapter());
|
getListView().setRecyclerListener((ConversationAdapter)getListAdapter());
|
||||||
getLoaderManager().initLoader(0, null, this);
|
getLoaderManager().initLoader(0, null, this);
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,7 @@ import android.widget.Toast;
|
|||||||
import org.thoughtcrime.securesms.R;
|
import org.thoughtcrime.securesms.R;
|
||||||
import org.thoughtcrime.securesms.push.PushServiceSocketFactory;
|
import org.thoughtcrime.securesms.push.PushServiceSocketFactory;
|
||||||
import org.thoughtcrime.securesms.recipients.Recipient;
|
import org.thoughtcrime.securesms.recipients.Recipient;
|
||||||
|
import org.thoughtcrime.securesms.recipients.Recipients;
|
||||||
import org.whispersystems.textsecure.directory.Directory;
|
import org.whispersystems.textsecure.directory.Directory;
|
||||||
import org.whispersystems.textsecure.directory.NotInDirectoryException;
|
import org.whispersystems.textsecure.directory.NotInDirectoryException;
|
||||||
import org.whispersystems.textsecure.push.ContactTokenDetails;
|
import org.whispersystems.textsecure.push.ContactTokenDetails;
|
||||||
@ -77,15 +78,22 @@ public class DirectoryHelper {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isPushDestination(Context context, Recipient recipient) {
|
public static boolean isPushDestination(Context context, Recipients recipients) {
|
||||||
if (recipient == null) return false;
|
|
||||||
try {
|
try {
|
||||||
final String number = recipient.getNumber();
|
if (recipients == null) {
|
||||||
|
return false;
|
||||||
if (number == null) return false;
|
}
|
||||||
if (!TextSecurePreferences.isPushRegistered(context)) return false;
|
if (!TextSecurePreferences.isPushRegistered(context)) {
|
||||||
if (GroupUtil.isEncodedGroup(number)) return true;
|
return false;
|
||||||
|
}
|
||||||
|
if (!recipients.isSingleRecipient()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (recipients.isGroupRecipient()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
final String number = recipients.getPrimaryRecipient().getNumber();
|
||||||
final String e164number = Util.canonicalizeNumber(context, number);
|
final String e164number = Util.canonicalizeNumber(context, number);
|
||||||
|
|
||||||
return Directory.getInstance(context).isActiveNumber(e164number);
|
return Directory.getInstance(context).isActiveNumber(e164number);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user