mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-13 16:13:39 +00:00
Clean up MessageRecord
This commit is contained in:
parent
1952b0e3be
commit
7e9116df9c
@ -187,8 +187,6 @@ public class MessageDetailsActivity extends PassphraseRequiredActionBarActivity
|
|||||||
transportText = "-";
|
transportText = "-";
|
||||||
} else if (messageRecord.isPending()) {
|
} else if (messageRecord.isPending()) {
|
||||||
transportText = getString(R.string.ConversationFragment_pending);
|
transportText = getString(R.string.ConversationFragment_pending);
|
||||||
} else if (messageRecord.isPush()) {
|
|
||||||
transportText = getString(R.string.ConversationFragment_push);
|
|
||||||
} else if (messageRecord.isMms()) {
|
} else if (messageRecord.isMms()) {
|
||||||
transportText = getString(R.string.ConversationFragment_mms);
|
transportText = getString(R.string.ConversationFragment_mms);
|
||||||
} else {
|
} else {
|
||||||
@ -252,9 +250,7 @@ public class MessageDetailsActivity extends PassphraseRequiredActionBarActivity
|
|||||||
|
|
||||||
private void updateRecipients(MessageRecord messageRecord, Recipient recipient, List<RecipientDeliveryStatus> recipients) {
|
private void updateRecipients(MessageRecord messageRecord, Recipient recipient, List<RecipientDeliveryStatus> recipients) {
|
||||||
final int toFromRes;
|
final int toFromRes;
|
||||||
if (messageRecord.isMms() && !messageRecord.isPush() && !messageRecord.isOutgoing()) {
|
if (messageRecord.isOutgoing()) {
|
||||||
toFromRes = R.string.message_details_header__with;
|
|
||||||
} else if (messageRecord.isOutgoing()) {
|
|
||||||
toFromRes = R.string.message_details_header__to;
|
toFromRes = R.string.message_details_header__to;
|
||||||
} else {
|
} else {
|
||||||
toFromRes = R.string.message_details_header__from;
|
toFromRes = R.string.message_details_header__from;
|
||||||
@ -360,7 +356,7 @@ public class MessageDetailsActivity extends PassphraseRequiredActionBarActivity
|
|||||||
List<RecipientDeliveryStatus> recipients = new LinkedList<>();
|
List<RecipientDeliveryStatus> recipients = new LinkedList<>();
|
||||||
|
|
||||||
if (!messageRecord.getRecipient().isGroupRecipient()) {
|
if (!messageRecord.getRecipient().isGroupRecipient()) {
|
||||||
recipients.add(new RecipientDeliveryStatus(messageRecord.getRecipient(), getStatusFor(messageRecord.getDeliveryReceiptCount(), messageRecord.getReadReceiptCount(), messageRecord.isPending()), messageRecord.isUnidentified(), -1));
|
recipients.add(new RecipientDeliveryStatus(messageRecord.getRecipient(), getStatusFor(messageRecord.getDeliveryReceiptCount(), messageRecord.getReadReceiptCount(), messageRecord.isPending()), true, -1));
|
||||||
} else {
|
} else {
|
||||||
List<GroupReceiptInfo> receiptInfoList = DatabaseFactory.getGroupReceiptDatabase(context).getGroupReceiptInfo(messageRecord.getId());
|
List<GroupReceiptInfo> receiptInfoList = DatabaseFactory.getGroupReceiptDatabase(context).getGroupReceiptInfo(messageRecord.getId());
|
||||||
|
|
||||||
@ -394,7 +390,7 @@ public class MessageDetailsActivity extends PassphraseRequiredActionBarActivity
|
|||||||
updateRecipients(messageRecord, messageRecord.getRecipient(), recipients);
|
updateRecipients(messageRecord, messageRecord.getRecipient(), recipients);
|
||||||
|
|
||||||
boolean isGroupNetworkFailure = messageRecord.isFailed() && !messageRecord.getNetworkFailures().isEmpty();
|
boolean isGroupNetworkFailure = messageRecord.isFailed() && !messageRecord.getNetworkFailures().isEmpty();
|
||||||
boolean isIndividualNetworkFailure = messageRecord.isFailed() && !isPushGroup && messageRecord.getIdentityKeyMismatches().isEmpty();
|
boolean isIndividualNetworkFailure = messageRecord.isFailed() && !isPushGroup;
|
||||||
|
|
||||||
LokiMessageDatabase lokiMessageDatabase = DatabaseFactory.getLokiMessageDatabase(getContext());
|
LokiMessageDatabase lokiMessageDatabase = DatabaseFactory.getLokiMessageDatabase(getContext());
|
||||||
String errorMessage = lokiMessageDatabase.getErrorMessage(messageRecord.id);
|
String errorMessage = lokiMessageDatabase.getErrorMessage(messageRecord.id);
|
||||||
|
@ -130,7 +130,7 @@ public class ConversationItemFooter extends LinearLayout {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void presentInsecureIndicator(@NonNull MessageRecord messageRecord) {
|
private void presentInsecureIndicator(@NonNull MessageRecord messageRecord) {
|
||||||
insecureIndicatorView.setVisibility(messageRecord.isSecure() ? View.GONE : View.VISIBLE);
|
insecureIndicatorView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void presentDeliveryStatus(@NonNull MessageRecord messageRecord) {
|
private void presentDeliveryStatus(@NonNull MessageRecord messageRecord) {
|
||||||
|
@ -351,9 +351,7 @@ public class ConversationFragment extends Fragment
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (MessageRecord messageRecord : messageRecords) {
|
for (MessageRecord messageRecord : messageRecords) {
|
||||||
if (messageRecord.isCallLog() || messageRecord.isExpirationTimerUpdate() ||
|
if (messageRecord.isCallLog() || messageRecord.isExpirationTimerUpdate())
|
||||||
messageRecord.isIdentityUpdate() || messageRecord.isIdentityVerified() ||
|
|
||||||
messageRecord.isIdentityDefault())
|
|
||||||
{
|
{
|
||||||
actionMessage = true;
|
actionMessage = true;
|
||||||
}
|
}
|
||||||
@ -384,8 +382,7 @@ public class ConversationFragment extends Fragment
|
|||||||
|
|
||||||
menu.findItem(R.id.menu_context_reply).setVisible(!actionMessage &&
|
menu.findItem(R.id.menu_context_reply).setVisible(!actionMessage &&
|
||||||
!messageRecord.isPending() &&
|
!messageRecord.isPending() &&
|
||||||
!messageRecord.isFailed() &&
|
!messageRecord.isFailed());
|
||||||
messageRecord.isSecure());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
menu.findItem(R.id.menu_context_copy).setVisible(!actionMessage && hasText);
|
menu.findItem(R.id.menu_context_copy).setVisible(!actionMessage && hasText);
|
||||||
@ -625,7 +622,7 @@ public class ConversationFragment extends Fragment
|
|||||||
intent.putExtra(MessageDetailsActivity.THREAD_ID_EXTRA, threadId);
|
intent.putExtra(MessageDetailsActivity.THREAD_ID_EXTRA, threadId);
|
||||||
intent.putExtra(MessageDetailsActivity.TYPE_EXTRA, message.isMms() ? MmsSmsDatabase.MMS_TRANSPORT : MmsSmsDatabase.SMS_TRANSPORT);
|
intent.putExtra(MessageDetailsActivity.TYPE_EXTRA, message.isMms() ? MmsSmsDatabase.MMS_TRANSPORT : MmsSmsDatabase.SMS_TRANSPORT);
|
||||||
intent.putExtra(MessageDetailsActivity.ADDRESS_EXTRA, recipient.getAddress());
|
intent.putExtra(MessageDetailsActivity.ADDRESS_EXTRA, recipient.getAddress());
|
||||||
intent.putExtra(MessageDetailsActivity.IS_PUSH_GROUP_EXTRA, recipient.isGroupRecipient() && message.isPush());
|
intent.putExtra(MessageDetailsActivity.IS_PUSH_GROUP_EXTRA, recipient.isGroupRecipient());
|
||||||
startActivity(intent);
|
startActivity(intent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -857,7 +857,7 @@ public class ConversationItem extends LinearLayout
|
|||||||
|
|
||||||
boolean differentTimestamps = next.isPresent() && !DateUtils.isSameExtendedRelativeTimestamp(context, locale, next.get().getTimestamp(), current.getTimestamp());
|
boolean differentTimestamps = next.isPresent() && !DateUtils.isSameExtendedRelativeTimestamp(context, locale, next.get().getTimestamp(), current.getTimestamp());
|
||||||
|
|
||||||
if (current.getExpiresIn() > 0 || !current.isSecure() || current.isPending() ||
|
if (current.getExpiresIn() > 0 || current.isPending() ||
|
||||||
current.isFailed() || differentTimestamps || isEndOfMessageCluster(current, next, isGroupThread))
|
current.isFailed() || differentTimestamps || isEndOfMessageCluster(current, next, isGroupThread))
|
||||||
{
|
{
|
||||||
ConversationItemFooter activeFooter = getActiveFooter(current);
|
ConversationItemFooter activeFooter = getActiveFooter(current);
|
||||||
@ -879,9 +879,7 @@ public class ConversationItem extends LinearLayout
|
|||||||
}
|
}
|
||||||
|
|
||||||
private boolean shouldInterceptClicks(MessageRecord messageRecord) {
|
private boolean shouldInterceptClicks(MessageRecord messageRecord) {
|
||||||
return batchSelected.isEmpty() &&
|
return batchSelected.isEmpty() && (messageRecord.isFailed() && !messageRecord.isMmsNotification());
|
||||||
((messageRecord.isFailed() && !messageRecord.isMmsNotification()) ||
|
|
||||||
messageRecord.isBundleKeyExchange());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressLint("SetTextI18n")
|
@SuppressLint("SetTextI18n")
|
||||||
@ -1196,7 +1194,7 @@ public class ConversationItem extends LinearLayout
|
|||||||
intent.putExtra(MessageDetailsActivity.MESSAGE_ID_EXTRA, messageRecord.getId());
|
intent.putExtra(MessageDetailsActivity.MESSAGE_ID_EXTRA, messageRecord.getId());
|
||||||
intent.putExtra(MessageDetailsActivity.THREAD_ID_EXTRA, messageRecord.getThreadId());
|
intent.putExtra(MessageDetailsActivity.THREAD_ID_EXTRA, messageRecord.getThreadId());
|
||||||
intent.putExtra(MessageDetailsActivity.TYPE_EXTRA, messageRecord.isMms() ? MmsSmsDatabase.MMS_TRANSPORT : MmsSmsDatabase.SMS_TRANSPORT);
|
intent.putExtra(MessageDetailsActivity.TYPE_EXTRA, messageRecord.isMms() ? MmsSmsDatabase.MMS_TRANSPORT : MmsSmsDatabase.SMS_TRANSPORT);
|
||||||
intent.putExtra(MessageDetailsActivity.IS_PUSH_GROUP_EXTRA, groupThread && messageRecord.isPush());
|
intent.putExtra(MessageDetailsActivity.IS_PUSH_GROUP_EXTRA, groupThread);
|
||||||
intent.putExtra(MessageDetailsActivity.ADDRESS_EXTRA, conversationRecipient.getAddress());
|
intent.putExtra(MessageDetailsActivity.ADDRESS_EXTRA, conversationRecipient.getAddress());
|
||||||
context.startActivity(intent);
|
context.startActivity(intent);
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
package org.thoughtcrime.securesms.conversation;
|
package org.thoughtcrime.securesms.conversation;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Color;
|
|
||||||
import android.graphics.PorterDuff;
|
import android.graphics.PorterDuff;
|
||||||
import android.graphics.PorterDuffColorFilter;
|
import android.graphics.PorterDuffColorFilter;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
@ -15,17 +14,16 @@ import androidx.annotation.NonNull;
|
|||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
import org.session.libsession.messaging.sending_receiving.data_extraction.DataExtractionNotificationInfoMessage;
|
import org.session.libsession.messaging.sending_receiving.data_extraction.DataExtractionNotificationInfoMessage;
|
||||||
|
import org.session.libsession.utilities.ExpirationUtil;
|
||||||
|
import org.session.libsession.utilities.Util;
|
||||||
|
import org.session.libsession.utilities.recipients.Recipient;
|
||||||
|
import org.session.libsession.utilities.recipients.RecipientModifiedListener;
|
||||||
|
import org.session.libsignal.utilities.guava.Optional;
|
||||||
import org.thoughtcrime.securesms.BindableConversationItem;
|
import org.thoughtcrime.securesms.BindableConversationItem;
|
||||||
import org.thoughtcrime.securesms.database.model.MessageRecord;
|
import org.thoughtcrime.securesms.database.model.MessageRecord;
|
||||||
import org.thoughtcrime.securesms.loki.utilities.GeneralUtilitiesKt;
|
import org.thoughtcrime.securesms.loki.utilities.GeneralUtilitiesKt;
|
||||||
import org.thoughtcrime.securesms.mms.GlideRequests;
|
import org.thoughtcrime.securesms.mms.GlideRequests;
|
||||||
import org.thoughtcrime.securesms.util.DateUtils;
|
import org.thoughtcrime.securesms.util.DateUtils;
|
||||||
import org.session.libsignal.utilities.guava.Optional;
|
|
||||||
|
|
||||||
import org.session.libsession.utilities.recipients.Recipient;
|
|
||||||
import org.session.libsession.utilities.recipients.RecipientModifiedListener;
|
|
||||||
import org.session.libsession.utilities.ExpirationUtil;
|
|
||||||
import org.session.libsession.utilities.Util;
|
|
||||||
|
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@ -105,9 +103,6 @@ public class ConversationUpdateItem extends LinearLayout
|
|||||||
else if (messageRecord.isExpirationTimerUpdate()) setTimerRecord(messageRecord);
|
else if (messageRecord.isExpirationTimerUpdate()) setTimerRecord(messageRecord);
|
||||||
else if (messageRecord.isScreenshotNotification()) setDataExtractionRecord(messageRecord, DataExtractionNotificationInfoMessage.Kind.SCREENSHOT);
|
else if (messageRecord.isScreenshotNotification()) setDataExtractionRecord(messageRecord, DataExtractionNotificationInfoMessage.Kind.SCREENSHOT);
|
||||||
else if (messageRecord.isMediaSavedNotification()) setDataExtractionRecord(messageRecord, DataExtractionNotificationInfoMessage.Kind.MEDIA_SAVED);
|
else if (messageRecord.isMediaSavedNotification()) setDataExtractionRecord(messageRecord, DataExtractionNotificationInfoMessage.Kind.MEDIA_SAVED);
|
||||||
else if (messageRecord.isIdentityUpdate()) setIdentityRecord(messageRecord);
|
|
||||||
else if (messageRecord.isIdentityVerified() ||
|
|
||||||
messageRecord.isIdentityDefault()) setIdentityVerifyUpdate(messageRecord);
|
|
||||||
else throw new AssertionError("Neither group nor log nor joined.");
|
else throw new AssertionError("Neither group nor log nor joined.");
|
||||||
|
|
||||||
if (batchSelected.contains(messageRecord)) setSelected(true);
|
if (batchSelected.contains(messageRecord)) setSelected(true);
|
||||||
@ -161,58 +156,6 @@ public class ConversationUpdateItem extends LinearLayout
|
|||||||
date.setVisibility(GONE);
|
date.setVisibility(GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setIdentityRecord(final MessageRecord messageRecord) {
|
|
||||||
icon.setImageResource(R.drawable.ic_security_white_24dp);
|
|
||||||
icon.setColorFilter(new PorterDuffColorFilter(Color.parseColor("#757575"), PorterDuff.Mode.MULTIPLY));
|
|
||||||
body.setText(messageRecord.getDisplayBody(getContext()));
|
|
||||||
|
|
||||||
title.setVisibility(GONE);
|
|
||||||
body.setVisibility(VISIBLE);
|
|
||||||
date.setVisibility(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setIdentityVerifyUpdate(final MessageRecord messageRecord) {
|
|
||||||
if (messageRecord.isIdentityVerified()) icon.setImageResource(R.drawable.ic_check_white_24dp);
|
|
||||||
else icon.setImageResource(R.drawable.ic_info_outline_white_24dp);
|
|
||||||
|
|
||||||
icon.setColorFilter(new PorterDuffColorFilter(Color.parseColor("#757575"), PorterDuff.Mode.MULTIPLY));
|
|
||||||
body.setText(messageRecord.getDisplayBody(getContext()));
|
|
||||||
|
|
||||||
title.setVisibility(GONE);
|
|
||||||
body.setVisibility(VISIBLE);
|
|
||||||
date.setVisibility(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setGroupRecord(MessageRecord messageRecord) {
|
|
||||||
icon.setImageResource(R.drawable.ic_group_grey600_24dp);
|
|
||||||
icon.clearColorFilter();
|
|
||||||
body.setText(messageRecord.getDisplayBody(getContext()));
|
|
||||||
|
|
||||||
title.setVisibility(GONE);
|
|
||||||
body.setVisibility(VISIBLE);
|
|
||||||
date.setVisibility(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setJoinedRecord(MessageRecord messageRecord) {
|
|
||||||
icon.setImageResource(R.drawable.ic_favorite_grey600_24dp);
|
|
||||||
icon.clearColorFilter();
|
|
||||||
body.setText(messageRecord.getDisplayBody(getContext()));
|
|
||||||
|
|
||||||
title.setVisibility(GONE);
|
|
||||||
body.setVisibility(VISIBLE);
|
|
||||||
date.setVisibility(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setEndSessionRecord(MessageRecord messageRecord) {
|
|
||||||
icon.setImageResource(R.drawable.ic_refresh_white_24dp);
|
|
||||||
icon.setColorFilter(new PorterDuffColorFilter(Color.parseColor("#757575"), PorterDuff.Mode.MULTIPLY));
|
|
||||||
body.setText(messageRecord.getDisplayBody(getContext()));
|
|
||||||
|
|
||||||
title.setVisibility(GONE);
|
|
||||||
body.setVisibility(VISIBLE);
|
|
||||||
date.setVisibility(GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setTextMessageRecord(MessageRecord messageRecord) {
|
private void setTextMessageRecord(MessageRecord messageRecord) {
|
||||||
body.setText(messageRecord.getDisplayBody(getContext()));
|
body.setText(messageRecord.getDisplayBody(getContext()));
|
||||||
|
|
||||||
@ -249,36 +192,7 @@ public class ConversationUpdateItem extends LinearLayout
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
if ((!messageRecord.isIdentityUpdate() &&
|
|
||||||
!messageRecord.isIdentityDefault() &&
|
|
||||||
!messageRecord.isIdentityVerified()) ||
|
|
||||||
!batchSelected.isEmpty())
|
|
||||||
{
|
|
||||||
if (parent != null) parent.onClick(v);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
final Recipient sender = ConversationUpdateItem.this.sender;
|
|
||||||
|
|
||||||
// IdentityUtil.getRemoteIdentityKey(getContext(), sender).addListener(new ListenableFuture.Listener<Optional<IdentityRecord>>() {
|
|
||||||
// @Override
|
|
||||||
// public void onSuccess(Optional<IdentityRecord> result) {
|
|
||||||
// if (result.isPresent()) {
|
|
||||||
// Intent intent = new Intent(getContext(), VerifyIdentityActivity.class);
|
|
||||||
// intent.putExtra(VerifyIdentityActivity.ADDRESS_EXTRA, sender.getAddress());
|
|
||||||
// intent.putExtra(VerifyIdentityActivity.IDENTITY_EXTRA, new IdentityKeyParcelable(result.get().getIdentityKey()));
|
|
||||||
// intent.putExtra(VerifyIdentityActivity.VERIFIED_EXTRA, result.get().getVerifiedStatus() == IdentityDatabase.VerifiedStatus.VERIFIED);
|
|
||||||
//
|
|
||||||
// getContext().startActivity(intent);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// @Override
|
|
||||||
// public void onFailure(ExecutionException e) {
|
|
||||||
// Log.w(TAG, e);
|
|
||||||
// }
|
|
||||||
// });
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -28,23 +28,21 @@ import com.annimon.stream.Stream;
|
|||||||
import net.sqlcipher.database.SQLiteDatabase;
|
import net.sqlcipher.database.SQLiteDatabase;
|
||||||
import net.sqlcipher.database.SQLiteStatement;
|
import net.sqlcipher.database.SQLiteStatement;
|
||||||
|
|
||||||
import org.session.libsignal.utilities.Log;
|
|
||||||
import org.thoughtcrime.securesms.ApplicationContext;
|
|
||||||
import org.session.libsession.utilities.IdentityKeyMismatch;
|
|
||||||
import org.session.libsession.utilities.IdentityKeyMismatchList;
|
|
||||||
import org.thoughtcrime.securesms.database.helpers.SQLCipherOpenHelper;
|
|
||||||
import org.thoughtcrime.securesms.database.model.MessageRecord;
|
|
||||||
import org.thoughtcrime.securesms.database.model.SmsMessageRecord;
|
|
||||||
import org.session.libsession.messaging.messages.signal.IncomingGroupMessage;
|
import org.session.libsession.messaging.messages.signal.IncomingGroupMessage;
|
||||||
import org.session.libsession.messaging.messages.signal.IncomingTextMessage;
|
import org.session.libsession.messaging.messages.signal.IncomingTextMessage;
|
||||||
import org.session.libsession.messaging.messages.signal.OutgoingTextMessage;
|
import org.session.libsession.messaging.messages.signal.OutgoingTextMessage;
|
||||||
|
|
||||||
import org.session.libsession.utilities.Address;
|
import org.session.libsession.utilities.Address;
|
||||||
import org.session.libsession.utilities.recipients.Recipient;
|
import org.session.libsession.utilities.IdentityKeyMismatch;
|
||||||
import org.session.libsignal.utilities.JsonUtil;
|
import org.session.libsession.utilities.IdentityKeyMismatchList;
|
||||||
import org.session.libsession.utilities.TextSecurePreferences;
|
import org.session.libsession.utilities.TextSecurePreferences;
|
||||||
import org.session.libsession.utilities.Util;
|
import org.session.libsession.utilities.Util;
|
||||||
|
import org.session.libsession.utilities.recipients.Recipient;
|
||||||
|
import org.session.libsignal.utilities.JsonUtil;
|
||||||
|
import org.session.libsignal.utilities.Log;
|
||||||
import org.session.libsignal.utilities.guava.Optional;
|
import org.session.libsignal.utilities.guava.Optional;
|
||||||
|
import org.thoughtcrime.securesms.database.helpers.SQLCipherOpenHelper;
|
||||||
|
import org.thoughtcrime.securesms.database.model.MessageRecord;
|
||||||
|
import org.thoughtcrime.securesms.database.model.SmsMessageRecord;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.security.SecureRandom;
|
import java.security.SecureRandom;
|
||||||
@ -641,10 +639,10 @@ public class SmsDatabase extends MessagingDatabase {
|
|||||||
public MessageRecord getCurrent() {
|
public MessageRecord getCurrent() {
|
||||||
return new SmsMessageRecord(id, message.getMessageBody(),
|
return new SmsMessageRecord(id, message.getMessageBody(),
|
||||||
message.getRecipient(), message.getRecipient(),
|
message.getRecipient(), message.getRecipient(),
|
||||||
1, System.currentTimeMillis(), System.currentTimeMillis(),
|
System.currentTimeMillis(), System.currentTimeMillis(),
|
||||||
0, message.isSecureMessage() ? MmsSmsColumns.Types.getOutgoingEncryptedMessageType() : MmsSmsColumns.Types.getOutgoingSmsMessageType(),
|
0, message.isSecureMessage() ? MmsSmsColumns.Types.getOutgoingEncryptedMessageType() : MmsSmsColumns.Types.getOutgoingSmsMessageType(),
|
||||||
threadId, 0, new LinkedList<IdentityKeyMismatch>(),
|
threadId, 0, new LinkedList<IdentityKeyMismatch>(),
|
||||||
message.getSubscriptionId(), message.getExpiresIn(),
|
message.getExpiresIn(),
|
||||||
System.currentTimeMillis(), 0, false);
|
System.currentTimeMillis(), 0, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -696,9 +694,8 @@ public class SmsDatabase extends MessagingDatabase {
|
|||||||
|
|
||||||
return new SmsMessageRecord(messageId, body, recipient,
|
return new SmsMessageRecord(messageId, body, recipient,
|
||||||
recipient,
|
recipient,
|
||||||
addressDeviceId,
|
|
||||||
dateSent, dateReceived, deliveryReceiptCount, type,
|
dateSent, dateReceived, deliveryReceiptCount, type,
|
||||||
threadId, status, mismatches, subscriptionId,
|
threadId, status, mismatches,
|
||||||
expiresIn, expireStarted, readReceiptCount, unidentified);
|
expiresIn, expireStarted, readReceiptCount, unidentified);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,22 +17,24 @@
|
|||||||
package org.thoughtcrime.securesms.database.model;
|
package org.thoughtcrime.securesms.database.model;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.annotation.Nullable;
|
|
||||||
import android.text.SpannableString;
|
import android.text.SpannableString;
|
||||||
|
|
||||||
import network.loki.messenger.R;
|
import androidx.annotation.NonNull;
|
||||||
import org.session.libsession.utilities.Contact;
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
import org.session.libsession.messaging.sending_receiving.link_preview.LinkPreview;
|
import org.session.libsession.messaging.sending_receiving.link_preview.LinkPreview;
|
||||||
import org.thoughtcrime.securesms.database.MmsDatabase;
|
import org.session.libsession.utilities.Contact;
|
||||||
import org.thoughtcrime.securesms.database.SmsDatabase.Status;
|
|
||||||
import org.session.libsession.utilities.IdentityKeyMismatch;
|
import org.session.libsession.utilities.IdentityKeyMismatch;
|
||||||
import org.session.libsession.utilities.NetworkFailure;
|
import org.session.libsession.utilities.NetworkFailure;
|
||||||
import org.thoughtcrime.securesms.mms.SlideDeck;
|
|
||||||
import org.session.libsession.utilities.recipients.Recipient;
|
import org.session.libsession.utilities.recipients.Recipient;
|
||||||
|
import org.thoughtcrime.securesms.database.MmsDatabase;
|
||||||
|
import org.thoughtcrime.securesms.database.SmsDatabase.Status;
|
||||||
|
import org.thoughtcrime.securesms.mms.SlideDeck;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import network.loki.messenger.R;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents the message record model for MMS messages that contain
|
* Represents the message record model for MMS messages that contain
|
||||||
* media (ie: they've been downloaded).
|
* media (ie: they've been downloaded).
|
||||||
@ -58,9 +60,9 @@ public class MediaMmsMessageRecord extends MmsMessageRecord {
|
|||||||
@Nullable Quote quote, @NonNull List<Contact> contacts,
|
@Nullable Quote quote, @NonNull List<Contact> contacts,
|
||||||
@NonNull List<LinkPreview> linkPreviews, boolean unidentified)
|
@NonNull List<LinkPreview> linkPreviews, boolean unidentified)
|
||||||
{
|
{
|
||||||
super(id, body, conversationRecipient, individualRecipient, recipientDeviceId, dateSent,
|
super(id, body, conversationRecipient, individualRecipient, dateSent,
|
||||||
dateReceived, threadId, Status.STATUS_NONE, deliveryReceiptCount, mailbox, mismatches, failures,
|
dateReceived, threadId, Status.STATUS_NONE, deliveryReceiptCount, mailbox, mismatches, failures,
|
||||||
subscriptionId, expiresIn, expireStarted, slideDeck, readReceiptCount, quote, contacts,
|
expiresIn, expireStarted, slideDeck, readReceiptCount, quote, contacts,
|
||||||
linkPreviews, unidentified);
|
linkPreviews, unidentified);
|
||||||
this.partCount = partCount;
|
this.partCount = partCount;
|
||||||
}
|
}
|
||||||
@ -82,8 +84,6 @@ public class MediaMmsMessageRecord extends MmsMessageRecord {
|
|||||||
return emphasisAdded(context.getString(R.string.SmsMessageRecord_duplicate_message));
|
return emphasisAdded(context.getString(R.string.SmsMessageRecord_duplicate_message));
|
||||||
} else if (MmsDatabase.Types.isNoRemoteSessionType(type)) {
|
} else if (MmsDatabase.Types.isNoRemoteSessionType(type)) {
|
||||||
return emphasisAdded(context.getString(R.string.MmsMessageRecord_mms_message_encrypted_for_non_existing_session));
|
return emphasisAdded(context.getString(R.string.MmsMessageRecord_mms_message_encrypted_for_non_existing_session));
|
||||||
} else if (isLegacyMessage()) {
|
|
||||||
return emphasisAdded(context.getString(R.string.MessageRecord_message_encrypted_with_a_legacy_protocol_version_that_is_no_longer_supported));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return super.getDisplayBody(context);
|
return super.getDisplayBody(context);
|
||||||
|
@ -30,8 +30,6 @@ import org.session.libsession.messaging.utilities.UpdateMessageData;
|
|||||||
import org.session.libsession.utilities.IdentityKeyMismatch;
|
import org.session.libsession.utilities.IdentityKeyMismatch;
|
||||||
import org.session.libsession.utilities.NetworkFailure;
|
import org.session.libsession.utilities.NetworkFailure;
|
||||||
import org.session.libsession.utilities.recipients.Recipient;
|
import org.session.libsession.utilities.recipients.Recipient;
|
||||||
import org.thoughtcrime.securesms.database.MmsSmsColumns;
|
|
||||||
import org.thoughtcrime.securesms.database.SmsDatabase;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -44,48 +42,62 @@ import java.util.List;
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public abstract class MessageRecord extends DisplayRecord {
|
public abstract class MessageRecord extends DisplayRecord {
|
||||||
|
|
||||||
private final Recipient individualRecipient;
|
private final Recipient individualRecipient;
|
||||||
private final int recipientDeviceId;
|
|
||||||
public final long id;
|
|
||||||
private final List<IdentityKeyMismatch> mismatches;
|
private final List<IdentityKeyMismatch> mismatches;
|
||||||
private final List<NetworkFailure> networkFailures;
|
private final List<NetworkFailure> networkFailures;
|
||||||
private final int subscriptionId;
|
|
||||||
private final long expiresIn;
|
private final long expiresIn;
|
||||||
private final long expireStarted;
|
private final long expireStarted;
|
||||||
private final boolean unidentified;
|
private final boolean unidentified;
|
||||||
|
public final long id;
|
||||||
|
|
||||||
|
public abstract boolean isMms();
|
||||||
|
public abstract boolean isMmsNotification();
|
||||||
|
|
||||||
MessageRecord(long id, String body, Recipient conversationRecipient,
|
MessageRecord(long id, String body, Recipient conversationRecipient,
|
||||||
Recipient individualRecipient, int recipientDeviceId,
|
Recipient individualRecipient,
|
||||||
long dateSent, long dateReceived, long threadId,
|
long dateSent, long dateReceived, long threadId,
|
||||||
int deliveryStatus, int deliveryReceiptCount, long type,
|
int deliveryStatus, int deliveryReceiptCount, long type,
|
||||||
List<IdentityKeyMismatch> mismatches,
|
List<IdentityKeyMismatch> mismatches,
|
||||||
List<NetworkFailure> networkFailures,
|
List<NetworkFailure> networkFailures,
|
||||||
int subscriptionId, long expiresIn, long expireStarted,
|
long expiresIn, long expireStarted,
|
||||||
int readReceiptCount, boolean unidentified)
|
int readReceiptCount, boolean unidentified)
|
||||||
{
|
{
|
||||||
super(body, conversationRecipient, dateSent, dateReceived,
|
super(body, conversationRecipient, dateSent, dateReceived,
|
||||||
threadId, deliveryStatus, deliveryReceiptCount, type, readReceiptCount);
|
threadId, deliveryStatus, deliveryReceiptCount, type, readReceiptCount);
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.individualRecipient = individualRecipient;
|
this.individualRecipient = individualRecipient;
|
||||||
this.recipientDeviceId = recipientDeviceId;
|
|
||||||
this.mismatches = mismatches;
|
this.mismatches = mismatches;
|
||||||
this.networkFailures = networkFailures;
|
this.networkFailures = networkFailures;
|
||||||
this.subscriptionId = subscriptionId;
|
|
||||||
this.expiresIn = expiresIn;
|
this.expiresIn = expiresIn;
|
||||||
this.expireStarted = expireStarted;
|
this.expireStarted = expireStarted;
|
||||||
this.unidentified = unidentified;
|
this.unidentified = unidentified;
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract boolean isMms();
|
public long getId() {
|
||||||
public abstract boolean isMmsNotification();
|
return id;
|
||||||
|
}
|
||||||
public boolean isSecure() {
|
public long getTimestamp() {
|
||||||
return MmsSmsColumns.Types.isSecureType(type);
|
return getDateSent();
|
||||||
|
}
|
||||||
|
public Recipient getIndividualRecipient() {
|
||||||
|
return individualRecipient;
|
||||||
|
}
|
||||||
|
public long getType() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
public List<NetworkFailure> getNetworkFailures() {
|
||||||
|
return networkFailures;
|
||||||
|
}
|
||||||
|
public long getExpiresIn() {
|
||||||
|
return expiresIn;
|
||||||
|
}
|
||||||
|
public long getExpireStarted() { return expireStarted; }
|
||||||
|
public boolean isMediaPending() {
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isLegacyMessage() {
|
public boolean isUpdate() {
|
||||||
return MmsSmsColumns.Types.isLegacyType(type);
|
return isExpirationTimerUpdate() || isCallLog() || isDataExtractionNotification();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -104,77 +116,6 @@ public abstract class MessageRecord extends DisplayRecord {
|
|||||||
return new SpannableString(getBody());
|
return new SpannableString(getBody());
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isPush() {
|
|
||||||
return SmsDatabase.Types.isPushType(type) && !SmsDatabase.Types.isForcedSms(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getTimestamp() {
|
|
||||||
if (getRecipient().getAddress().isOpenGroup()) {
|
|
||||||
return getDateReceived();
|
|
||||||
}
|
|
||||||
if (isPush() && getDateSent() < getDateReceived()) {
|
|
||||||
return getDateSent();
|
|
||||||
}
|
|
||||||
return getDateReceived();
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isForcedSms() {
|
|
||||||
return SmsDatabase.Types.isForcedSms(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isIdentityVerified() {
|
|
||||||
return SmsDatabase.Types.isIdentityVerified(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isIdentityDefault() {
|
|
||||||
return SmsDatabase.Types.isIdentityDefault(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isBundleKeyExchange() {
|
|
||||||
return SmsDatabase.Types.isBundleKeyExchange(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isIdentityUpdate() {
|
|
||||||
return SmsDatabase.Types.isIdentityUpdate(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isCorruptedKeyExchange() {
|
|
||||||
return SmsDatabase.Types.isCorruptedKeyExchange(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isInvalidVersionKeyExchange() {
|
|
||||||
return SmsDatabase.Types.isInvalidVersionKeyExchange(type);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isUpdate() {
|
|
||||||
return isExpirationTimerUpdate() || isCallLog() || isDataExtractionNotification() ||
|
|
||||||
isIdentityUpdate() || isIdentityVerified() || isIdentityDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isMediaPending() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Recipient getIndividualRecipient() {
|
|
||||||
return individualRecipient;
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getType() {
|
|
||||||
return type;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<IdentityKeyMismatch> getIdentityKeyMismatches() {
|
|
||||||
return mismatches;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<NetworkFailure> getNetworkFailures() {
|
|
||||||
return networkFailures;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected SpannableString emphasisAdded(String sequence) {
|
protected SpannableString emphasisAdded(String sequence) {
|
||||||
SpannableString spannable = new SpannableString(sequence);
|
SpannableString spannable = new SpannableString(sequence);
|
||||||
spannable.setSpan(new RelativeSizeSpan(0.9f), 0, sequence.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
|
spannable.setSpan(new RelativeSizeSpan(0.9f), 0, sequence.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
|
||||||
@ -184,25 +125,12 @@ public abstract class MessageRecord extends DisplayRecord {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean equals(Object other) {
|
public boolean equals(Object other) {
|
||||||
return other != null &&
|
return other instanceof MessageRecord
|
||||||
other instanceof MessageRecord &&
|
&& ((MessageRecord) other).getId() == getId()
|
||||||
((MessageRecord) other).getId() == getId() &&
|
&& ((MessageRecord) other).isMms() == isMms();
|
||||||
((MessageRecord) other).isMms() == isMms();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return (int)getId();
|
return (int)getId();
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getExpiresIn() {
|
|
||||||
return expiresIn;
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getExpireStarted() {
|
|
||||||
return expireStarted;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isUnidentified() {
|
|
||||||
return unidentified;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -25,15 +25,15 @@ public abstract class MmsMessageRecord extends MessageRecord {
|
|||||||
private final @NonNull List<LinkPreview> linkPreviews = new LinkedList<>();
|
private final @NonNull List<LinkPreview> linkPreviews = new LinkedList<>();
|
||||||
|
|
||||||
MmsMessageRecord(long id, String body, Recipient conversationRecipient,
|
MmsMessageRecord(long id, String body, Recipient conversationRecipient,
|
||||||
Recipient individualRecipient, int recipientDeviceId, long dateSent,
|
Recipient individualRecipient, long dateSent,
|
||||||
long dateReceived, long threadId, int deliveryStatus, int deliveryReceiptCount,
|
long dateReceived, long threadId, int deliveryStatus, int deliveryReceiptCount,
|
||||||
long type, List<IdentityKeyMismatch> mismatches,
|
long type, List<IdentityKeyMismatch> mismatches,
|
||||||
List<NetworkFailure> networkFailures, int subscriptionId, long expiresIn,
|
List<NetworkFailure> networkFailures, long expiresIn,
|
||||||
long expireStarted, @NonNull SlideDeck slideDeck, int readReceiptCount,
|
long expireStarted, @NonNull SlideDeck slideDeck, int readReceiptCount,
|
||||||
@Nullable Quote quote, @NonNull List<Contact> contacts,
|
@Nullable Quote quote, @NonNull List<Contact> contacts,
|
||||||
@NonNull List<LinkPreview> linkPreviews, boolean unidentified)
|
@NonNull List<LinkPreview> linkPreviews, boolean unidentified)
|
||||||
{
|
{
|
||||||
super(id, body, conversationRecipient, individualRecipient, recipientDeviceId, dateSent, dateReceived, threadId, deliveryStatus, deliveryReceiptCount, type, mismatches, networkFailures, subscriptionId, expiresIn, expireStarted, readReceiptCount, unidentified);
|
super(id, body, conversationRecipient, individualRecipient, dateSent, dateReceived, threadId, deliveryStatus, deliveryReceiptCount, type, mismatches, networkFailures, expiresIn, expireStarted, readReceiptCount, unidentified);
|
||||||
|
|
||||||
this.slideDeck = slideDeck;
|
this.slideDeck = slideDeck;
|
||||||
this.quote = quote;
|
this.quote = quote;
|
||||||
|
@ -17,20 +17,22 @@
|
|||||||
package org.thoughtcrime.securesms.database.model;
|
package org.thoughtcrime.securesms.database.model;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import android.text.SpannableString;
|
import android.text.SpannableString;
|
||||||
|
|
||||||
import network.loki.messenger.R;
|
import androidx.annotation.NonNull;
|
||||||
import org.thoughtcrime.securesms.database.MmsDatabase;
|
|
||||||
import org.thoughtcrime.securesms.database.SmsDatabase.Status;
|
|
||||||
import org.session.libsession.utilities.IdentityKeyMismatch;
|
import org.session.libsession.utilities.IdentityKeyMismatch;
|
||||||
import org.session.libsession.utilities.NetworkFailure;
|
import org.session.libsession.utilities.NetworkFailure;
|
||||||
import org.thoughtcrime.securesms.mms.SlideDeck;
|
|
||||||
import org.session.libsession.utilities.recipients.Recipient;
|
import org.session.libsession.utilities.recipients.Recipient;
|
||||||
|
import org.thoughtcrime.securesms.database.MmsDatabase;
|
||||||
|
import org.thoughtcrime.securesms.database.SmsDatabase.Status;
|
||||||
|
import org.thoughtcrime.securesms.mms.SlideDeck;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
|
|
||||||
|
import network.loki.messenger.R;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents the message record model for MMS messages that are
|
* Represents the message record model for MMS messages that are
|
||||||
* notifications (ie: they're pointers to undownloaded media).
|
* notifications (ie: they're pointers to undownloaded media).
|
||||||
@ -54,9 +56,9 @@ public class NotificationMmsMessageRecord extends MmsMessageRecord {
|
|||||||
long expiry, int status, byte[] transactionId, long mailbox,
|
long expiry, int status, byte[] transactionId, long mailbox,
|
||||||
int subscriptionId, SlideDeck slideDeck, int readReceiptCount)
|
int subscriptionId, SlideDeck slideDeck, int readReceiptCount)
|
||||||
{
|
{
|
||||||
super(id, "", conversationRecipient, individualRecipient, recipientDeviceId,
|
super(id, "", conversationRecipient, individualRecipient,
|
||||||
dateSent, dateReceived, threadId, Status.STATUS_NONE, deliveryReceiptCount, mailbox,
|
dateSent, dateReceived, threadId, Status.STATUS_NONE, deliveryReceiptCount, mailbox,
|
||||||
new LinkedList<IdentityKeyMismatch>(), new LinkedList<NetworkFailure>(), subscriptionId,
|
new LinkedList<IdentityKeyMismatch>(), new LinkedList<NetworkFailure>(),
|
||||||
0, 0, slideDeck, readReceiptCount, null, Collections.emptyList(), Collections.emptyList(), false);
|
0, 0, slideDeck, readReceiptCount, null, Collections.emptyList(), Collections.emptyList(), false);
|
||||||
|
|
||||||
this.contentLocation = contentLocation;
|
this.contentLocation = contentLocation;
|
||||||
@ -91,11 +93,6 @@ public class NotificationMmsMessageRecord extends MmsMessageRecord {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isSecure() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isPending() {
|
public boolean isPending() {
|
||||||
return false;
|
return false;
|
||||||
|
@ -22,10 +22,9 @@ import android.text.SpannableString;
|
|||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.database.MmsSmsColumns;
|
|
||||||
import org.thoughtcrime.securesms.database.SmsDatabase;
|
|
||||||
import org.session.libsession.utilities.IdentityKeyMismatch;
|
import org.session.libsession.utilities.IdentityKeyMismatch;
|
||||||
import org.session.libsession.utilities.recipients.Recipient;
|
import org.session.libsession.utilities.recipients.Recipient;
|
||||||
|
import org.thoughtcrime.securesms.database.SmsDatabase;
|
||||||
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -43,17 +42,16 @@ public class SmsMessageRecord extends MessageRecord {
|
|||||||
public SmsMessageRecord(long id,
|
public SmsMessageRecord(long id,
|
||||||
String body, Recipient recipient,
|
String body, Recipient recipient,
|
||||||
Recipient individualRecipient,
|
Recipient individualRecipient,
|
||||||
int recipientDeviceId,
|
|
||||||
long dateSent, long dateReceived,
|
long dateSent, long dateReceived,
|
||||||
int deliveryReceiptCount,
|
int deliveryReceiptCount,
|
||||||
long type, long threadId,
|
long type, long threadId,
|
||||||
int status, List<IdentityKeyMismatch> mismatches,
|
int status, List<IdentityKeyMismatch> mismatches,
|
||||||
int subscriptionId, long expiresIn, long expireStarted,
|
long expiresIn, long expireStarted,
|
||||||
int readReceiptCount, boolean unidentified)
|
int readReceiptCount, boolean unidentified)
|
||||||
{
|
{
|
||||||
super(id, body, recipient, individualRecipient, recipientDeviceId,
|
super(id, body, recipient, individualRecipient,
|
||||||
dateSent, dateReceived, threadId, status, deliveryReceiptCount, type,
|
dateSent, dateReceived, threadId, status, deliveryReceiptCount, type,
|
||||||
mismatches, new LinkedList<>(), subscriptionId,
|
mismatches, new LinkedList<>(),
|
||||||
expiresIn, expireStarted, readReceiptCount, unidentified);
|
expiresIn, expireStarted, readReceiptCount, unidentified);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -63,17 +61,8 @@ public class SmsMessageRecord extends MessageRecord {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public SpannableString getDisplayBody(@NonNull Context context) {
|
public SpannableString getDisplayBody(@NonNull Context context) {
|
||||||
Recipient recipient = getRecipient();
|
|
||||||
if (SmsDatabase.Types.isFailedDecryptType(type)) {
|
if (SmsDatabase.Types.isFailedDecryptType(type)) {
|
||||||
return emphasisAdded(context.getString(R.string.MessageDisplayHelper_bad_encrypted_message));
|
return emphasisAdded(context.getString(R.string.MessageDisplayHelper_bad_encrypted_message));
|
||||||
} else if (isCorruptedKeyExchange()) {
|
|
||||||
return emphasisAdded(context.getString(R.string.SmsMessageRecord_received_corrupted_key_exchange_message));
|
|
||||||
} else if (isInvalidVersionKeyExchange()) {
|
|
||||||
return emphasisAdded(context.getString(R.string.SmsMessageRecord_received_key_exchange_message_for_invalid_protocol_version));
|
|
||||||
} else if (MmsSmsColumns.Types.isLegacyType(type)) {
|
|
||||||
return emphasisAdded(context.getString(R.string.MessageRecord_message_encrypted_with_a_legacy_protocol_version_that_is_no_longer_supported));
|
|
||||||
} else if (isBundleKeyExchange()) {
|
|
||||||
return emphasisAdded(context.getString(R.string.SmsMessageRecord_received_message_with_new_safety_number_tap_to_process));
|
|
||||||
} else if (SmsDatabase.Types.isDuplicateMessageType(type)) {
|
} else if (SmsDatabase.Types.isDuplicateMessageType(type)) {
|
||||||
return emphasisAdded(context.getString(R.string.SmsMessageRecord_duplicate_message));
|
return emphasisAdded(context.getString(R.string.SmsMessageRecord_duplicate_message));
|
||||||
} else if (SmsDatabase.Types.isNoRemoteSessionType(type)) {
|
} else if (SmsDatabase.Types.isNoRemoteSessionType(type)) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user