|
|
@ -2,6 +2,7 @@ package org.thoughtcrime.securesms.conversation.disappearingmessages
|
|
|
|
|
|
|
|
|
|
|
|
import android.content.Context
|
|
|
|
import android.content.Context
|
|
|
|
import dagger.hilt.android.qualifiers.ApplicationContext
|
|
|
|
import dagger.hilt.android.qualifiers.ApplicationContext
|
|
|
|
|
|
|
|
import network.loki.messenger.R
|
|
|
|
import network.loki.messenger.libsession_util.util.ExpiryMode
|
|
|
|
import network.loki.messenger.libsession_util.util.ExpiryMode
|
|
|
|
import org.session.libsession.messaging.MessagingModuleConfiguration
|
|
|
|
import org.session.libsession.messaging.MessagingModuleConfiguration
|
|
|
|
import org.session.libsession.messaging.messages.ExpirationConfiguration
|
|
|
|
import org.session.libsession.messaging.messages.ExpirationConfiguration
|
|
|
@ -9,11 +10,15 @@ import org.session.libsession.messaging.messages.control.ExpirationTimerUpdate
|
|
|
|
import org.session.libsession.messaging.sending_receiving.MessageSender
|
|
|
|
import org.session.libsession.messaging.sending_receiving.MessageSender
|
|
|
|
import org.session.libsession.snode.SnodeAPI
|
|
|
|
import org.session.libsession.snode.SnodeAPI
|
|
|
|
import org.session.libsession.utilities.Address
|
|
|
|
import org.session.libsession.utilities.Address
|
|
|
|
import org.session.libsession.utilities.SSKEnvironment
|
|
|
|
import org.session.libsession.utilities.ExpirationUtil
|
|
|
|
import org.session.libsession.utilities.SSKEnvironment.MessageExpirationManagerProtocol
|
|
|
|
import org.session.libsession.utilities.SSKEnvironment.MessageExpirationManagerProtocol
|
|
|
|
import org.session.libsession.utilities.TextSecurePreferences
|
|
|
|
import org.session.libsession.utilities.TextSecurePreferences
|
|
|
|
|
|
|
|
import org.session.libsession.utilities.getExpirationTypeDisplayValue
|
|
|
|
|
|
|
|
import org.thoughtcrime.securesms.database.model.MessageRecord
|
|
|
|
|
|
|
|
import org.thoughtcrime.securesms.showSessionDialog
|
|
|
|
import org.thoughtcrime.securesms.util.ConfigurationMessageUtilities
|
|
|
|
import org.thoughtcrime.securesms.util.ConfigurationMessageUtilities
|
|
|
|
import javax.inject.Inject
|
|
|
|
import javax.inject.Inject
|
|
|
|
|
|
|
|
import kotlin.time.Duration.Companion.milliseconds
|
|
|
|
|
|
|
|
|
|
|
|
class DisappearingMessages @Inject constructor(
|
|
|
|
class DisappearingMessages @Inject constructor(
|
|
|
|
@ApplicationContext private val context: Context,
|
|
|
|
@ApplicationContext private val context: Context,
|
|
|
@ -35,4 +40,30 @@ class DisappearingMessages @Inject constructor(
|
|
|
|
MessageSender.send(message, address)
|
|
|
|
MessageSender.send(message, address)
|
|
|
|
ConfigurationMessageUtilities.forceSyncConfigurationNowIfNeeded(context)
|
|
|
|
ConfigurationMessageUtilities.forceSyncConfigurationNowIfNeeded(context)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fun showFollowSettingDialog(context: Context, message: MessageRecord) = context.showSessionDialog {
|
|
|
|
|
|
|
|
title(R.string.dialog_disappearing_messages_follow_setting_title)
|
|
|
|
|
|
|
|
if (message.expiresIn == 0L) {
|
|
|
|
|
|
|
|
text(R.string.dialog_disappearing_messages_follow_setting_off_body)
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
text(
|
|
|
|
|
|
|
|
context.getString(
|
|
|
|
|
|
|
|
R.string.dialog_disappearing_messages_follow_setting_on_body,
|
|
|
|
|
|
|
|
ExpirationUtil.getExpirationDisplayValue(
|
|
|
|
|
|
|
|
context,
|
|
|
|
|
|
|
|
message.expiresIn.milliseconds
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
context.getExpirationTypeDisplayValue(message.isNotDisappearAfterRead)
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
destructiveButton(if (message.expiresIn == 0L) R.string.dialog_disappearing_messages_follow_setting_confirm else R.string.dialog_disappearing_messages_follow_setting_set) {
|
|
|
|
|
|
|
|
set(message.threadId, message.recipient.address, message.expiryMode)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
cancelButton()
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
val MessageRecord.expiryMode get() = if (expiresIn <= 0) ExpiryMode.NONE
|
|
|
|
|
|
|
|
else if (expireStarted == timestamp) ExpiryMode.AfterSend(expiresIn / 1000)
|
|
|
|
|
|
|
|
else ExpiryMode.AfterRead(expiresIn / 1000)
|
|
|
|