Use expiration in message instead of config

This commit is contained in:
Andrew 2024-01-11 12:11:43 +10:30
parent 5a047daefc
commit 6b1628df6b

View File

@ -53,7 +53,7 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
Log.d(TAG, "scheduleDeletion() called with: id = $id, mms = $mms, startedAtTimestamp = $startedAtTimestamp, expiresInMillis = $expiresInMillis") Log.d(TAG, "scheduleDeletion() called with: id = $id, mms = $mms, startedAtTimestamp = $startedAtTimestamp, expiresInMillis = $expiresInMillis")
val expiresAtMillis = startedAtTimestamp + expiresInMillis val expiresAtMillis = startedAtTimestamp + expiresInMillis
synchronized(expiringMessageReferences) { synchronized(expiringMessageReferences) {
expiringMessageReferences.add(ExpiringMessageReference(id, mms, expiresAtMillis)) expiringMessageReferences += ExpiringMessageReference(id, mms, expiresAtMillis)
(expiringMessageReferences as Object).notifyAll() (expiringMessageReferences as Object).notifyAll()
} }
} }
@ -62,28 +62,6 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
synchronized(expiringMessageReferences) { (expiringMessageReferences as Object).notifyAll() } synchronized(expiringMessageReferences) { (expiringMessageReferences as Object).notifyAll() }
} }
override fun setExpirationTimer(message: ExpirationTimerUpdate) {
val expiryMode: ExpiryMode = message.expiryMode
Log.d(TAG, "setExpirationTimer() called with: message = $message, expiryMode = $expiryMode")
val userPublicKey = getLocalNumber(context)
val senderPublicKey = message.sender
val sentTimestamp = if (message.sentTimestamp == null) 0 else message.sentTimestamp!!
val expireStartedAt =
if (expiryMode is AfterSend || message.isSenderSelf) sentTimestamp else 0
// Notify the user
if (senderPublicKey == null || userPublicKey == senderPublicKey) {
// sender is self or a linked device
insertOutgoingExpirationTimerMessage(message, expireStartedAt)
} else {
insertIncomingExpirationTimerMessage(message, expireStartedAt)
}
if (expiryMode!!.expirySeconds > 0 && message.sentTimestamp != null && senderPublicKey != null) {
startAnyExpiration(message.sentTimestamp!!, senderPublicKey, expireStartedAt)
}
}
private fun insertIncomingExpirationTimerMessage( private fun insertIncomingExpirationTimerMessage(
message: ExpirationTimerUpdate, message: ExpirationTimerUpdate,
expireStartedAt: Long expireStartedAt: Long
@ -94,9 +72,7 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
val groupId = message.groupPublicKey val groupId = message.groupPublicKey
val expiresInMillis = message.expiryMode.expiryMillis val expiresInMillis = message.expiryMode.expiryMillis
var groupInfo = Optional.absent<SignalServiceGroup?>() var groupInfo = Optional.absent<SignalServiceGroup?>()
val address = fromSerialized( val address = fromSerialized(senderPublicKey!!)
senderPublicKey!!
)
var recipient = Recipient.from(context, address, false) var recipient = Recipient.from(context, address, false)
// if the sender is blocked, we don't display the update, except if it's in a closed group // if the sender is blocked, we don't display the update, except if it's in a closed group
@ -145,16 +121,14 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
val sentTimestamp = message.sentTimestamp val sentTimestamp = message.sentTimestamp
val groupId = message.groupPublicKey val groupId = message.groupPublicKey
val duration = message.expiryMode.expiryMillis val duration = message.expiryMode.expiryMillis
val address: Address
try { try {
address = if (groupId != null) { val serializedAddress = groupId?.let(::doubleEncodeGroupID)
fromSerialized(doubleEncodeGroupID(groupId)) ?: message.syncTarget?.takeIf { it.isNotEmpty() }
} else { ?: message.recipient!!
fromSerialized((if (message.syncTarget != null && !message.syncTarget!!.isEmpty()) message.syncTarget else message.recipient)!!) val address = fromSerialized(serializedAddress)
}
val recipient = Recipient.from(context, address, false) val recipient = Recipient.from(context, address, false)
val storage = shared.storage
message.threadID = storage.getOrCreateThreadIdFor(address) message.threadID = shared.storage.getOrCreateThreadIdFor(address)
val timerUpdateMessage = OutgoingExpirationUpdateMessage( val timerUpdateMessage = OutgoingExpirationUpdateMessage(
recipient, recipient,
sentTimestamp!!, sentTimestamp!!,
@ -175,15 +149,35 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
} }
} }
override fun setExpirationTimer(message: ExpirationTimerUpdate) {
val expiryMode: ExpiryMode = message.expiryMode
Log.d(TAG, "setExpirationTimer() called with: message = $message, expiryMode = $expiryMode")
val userPublicKey = getLocalNumber(context)
val senderPublicKey = message.sender
val sentTimestamp = if (message.sentTimestamp == null) 0 else message.sentTimestamp!!
val expireStartedAt =
if (expiryMode is AfterSend || message.isSenderSelf) sentTimestamp else 0
// Notify the user
if (senderPublicKey == null || userPublicKey == senderPublicKey) {
// sender is self or a linked device
insertOutgoingExpirationTimerMessage(message, expireStartedAt)
} else {
insertIncomingExpirationTimerMessage(message, expireStartedAt)
}
if (expiryMode is AfterSend && expiryMode.expirySeconds > 0 && message.sentTimestamp != null && senderPublicKey != null) {
startAnyExpiration(message.sentTimestamp!!, senderPublicKey, expireStartedAt)
}
}
override fun startAnyExpiration(timestamp: Long, author: String, expireStartedAt: Long) { override fun startAnyExpiration(timestamp: Long, author: String, expireStartedAt: Long) {
Log.d(TAG, "startAnyExpiration() called with: timestamp = $timestamp, author = $author, expireStartedAt = $expireStartedAt") Log.d(TAG, "startAnyExpiration() called with: timestamp = $timestamp, author = $author, expireStartedAt = $expireStartedAt")
val messageRecord = mmsSmsDatabase.getMessageFor(timestamp, author) ?: return val messageRecord = mmsSmsDatabase.getMessageFor(timestamp, author) ?: return
val mms = messageRecord.isMms() val mms = messageRecord.isMms()
val config = get(context).storage().getExpirationConfiguration(messageRecord.threadId)
if (config == null || !config.isEnabled) return
val mode = config.expiryMode
getDatabase(mms).markExpireStarted(messageRecord.getId(), expireStartedAt) getDatabase(mms).markExpireStarted(messageRecord.getId(), expireStartedAt)
scheduleDeletion(messageRecord.getId(), mms, expireStartedAt, mode?.expiryMillis ?: 0) scheduleDeletion(messageRecord.getId(), mms, expireStartedAt, messageRecord.expiresIn)
} }
private inner class LoadTask : Runnable { private inner class LoadTask : Runnable {
@ -195,13 +189,11 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
val mmsMessages = mmsReader.use { generateSequence { it.next }.toList() } val mmsMessages = mmsReader.use { generateSequence { it.next }.toList() }
(smsMessages + mmsMessages).forEach { messageRecord -> (smsMessages + mmsMessages).forEach { messageRecord ->
expiringMessageReferences.add( expiringMessageReferences += ExpiringMessageReference(
ExpiringMessageReference(
messageRecord.getId(), messageRecord.getId(),
messageRecord.isMms, messageRecord.isMms,
messageRecord.expireStarted + messageRecord.expiresIn messageRecord.expireStarted + messageRecord.expiresIn
) )
)
} }
} }
} }
@ -219,7 +211,7 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
(expiringMessageReferences as Object).wait(waitTime) (expiringMessageReferences as Object).wait(waitTime)
null null
} else { } else {
expiringMessageReferences.remove(nextReference) expiringMessageReferences -= nextReference
nextReference nextReference
} }
} catch (e: InterruptedException) { } catch (e: InterruptedException) {
@ -236,6 +228,6 @@ class ExpiringMessageManager(context: Context) : MessageExpirationManagerProtoco
val mms: Boolean, val mms: Boolean,
val expiresAtMillis: Long val expiresAtMillis: Long
): Comparable<ExpiringMessageReference> { ): Comparable<ExpiringMessageReference> {
override fun compareTo(other: ExpiringMessageReference) = compareValuesBy(this, other, { it.id }, { it.mms }, { it.expiresAtMillis}) override fun compareTo(other: ExpiringMessageReference) = compareValuesBy(this, other, { it.expiresAtMillis }, { it.id }, { it.mms })
} }
} }