|
|
|
@ -38,16 +38,23 @@ import org.session.libsignal.protos.SignalServiceProtos.Content.ExpirationType;
|
|
|
|
|
import org.session.libsignal.utilities.Log;
|
|
|
|
|
import org.thoughtcrime.securesms.ApplicationContext;
|
|
|
|
|
import org.thoughtcrime.securesms.database.MessagingDatabase.MarkedMessageInfo;
|
|
|
|
|
import org.thoughtcrime.securesms.database.MmsDatabase;
|
|
|
|
|
import org.thoughtcrime.securesms.database.SmsDatabase;
|
|
|
|
|
import org.thoughtcrime.securesms.database.Storage;
|
|
|
|
|
import org.thoughtcrime.securesms.database.ThreadDatabase;
|
|
|
|
|
import org.thoughtcrime.securesms.dependencies.DatabaseComponent;
|
|
|
|
|
import org.thoughtcrime.securesms.mms.MmsException;
|
|
|
|
|
|
|
|
|
|
import java.util.Collections;
|
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
|
|
import javax.inject.Inject;
|
|
|
|
|
|
|
|
|
|
import dagger.hilt.android.AndroidEntryPoint;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the response text from the Wearable Device and sends an message as a reply
|
|
|
|
|
*/
|
|
|
|
|
@AndroidEntryPoint
|
|
|
|
|
public class RemoteReplyReceiver extends BroadcastReceiver {
|
|
|
|
|
|
|
|
|
|
public static final String TAG = RemoteReplyReceiver.class.getSimpleName();
|
|
|
|
@ -55,6 +62,15 @@ public class RemoteReplyReceiver extends BroadcastReceiver {
|
|
|
|
|
public static final String ADDRESS_EXTRA = "address";
|
|
|
|
|
public static final String REPLY_METHOD = "reply_method";
|
|
|
|
|
|
|
|
|
|
@Inject
|
|
|
|
|
ThreadDatabase threadDatabase;
|
|
|
|
|
@Inject
|
|
|
|
|
MmsDatabase mmsDatabase;
|
|
|
|
|
@Inject
|
|
|
|
|
SmsDatabase smsDatabase;
|
|
|
|
|
@Inject
|
|
|
|
|
Storage storage;
|
|
|
|
|
|
|
|
|
|
@SuppressLint("StaticFieldLeak")
|
|
|
|
|
@Override
|
|
|
|
|
public void onReceive(final Context context, Intent intent) {
|
|
|
|
@ -76,19 +92,19 @@ public class RemoteReplyReceiver extends BroadcastReceiver {
|
|
|
|
|
@Override
|
|
|
|
|
protected Void doInBackground(Void... params) {
|
|
|
|
|
Recipient recipient = Recipient.from(context, address, false);
|
|
|
|
|
ThreadDatabase threadDatabase = DatabaseComponent.get(context).threadDatabase();
|
|
|
|
|
long threadId = threadDatabase.getOrCreateThreadIdFor(recipient);
|
|
|
|
|
VisibleMessage message = new VisibleMessage();
|
|
|
|
|
message.setSentTimestamp(SnodeAPI.getNowWithOffset());
|
|
|
|
|
message.setText(responseText.toString());
|
|
|
|
|
ExpirationConfiguration config = DatabaseComponent.get(context).expirationConfigurationDatabase().getExpirationConfiguration(threadId);
|
|
|
|
|
ExpirationConfiguration config = storage.getExpirationConfiguration(threadId);
|
|
|
|
|
|
|
|
|
|
long expiresInMillis = config == null ? 0 : config.getDurationSeconds() * 1000L;
|
|
|
|
|
long expireStartedAt = config.getExpirationType() == ExpirationType.DELETE_AFTER_SEND ? message.getSentTimestamp() : 0L;
|
|
|
|
|
switch (replyMethod) {
|
|
|
|
|
case GroupMessage: {
|
|
|
|
|
OutgoingMediaMessage reply = OutgoingMediaMessage.from(message, recipient, Collections.emptyList(), null, null, expiresInMillis, 0);
|
|
|
|
|
try {
|
|
|
|
|
DatabaseComponent.get(context).mmsDatabase().insertMessageOutbox(reply, threadId, false, null, true);
|
|
|
|
|
mmsDatabase.insertMessageOutbox(reply, threadId, false, null, true);
|
|
|
|
|
MessageSender.send(message, address);
|
|
|
|
|
} catch (MmsException e) {
|
|
|
|
|
Log.w(TAG, e);
|
|
|
|
@ -97,7 +113,7 @@ public class RemoteReplyReceiver extends BroadcastReceiver {
|
|
|
|
|
}
|
|
|
|
|
case SecureMessage: {
|
|
|
|
|
OutgoingTextMessage reply = OutgoingTextMessage.from(message, recipient, expiresInMillis, expireStartedAt);
|
|
|
|
|
DatabaseComponent.get(context).smsDatabase().insertMessageOutbox(threadId, reply, false, System.currentTimeMillis(), null, true);
|
|
|
|
|
smsDatabase.insertMessageOutbox(threadId, reply, false, System.currentTimeMillis(), null, true);
|
|
|
|
|
MessageSender.send(message, address);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|