mirror of
https://github.com/oxen-io/session-android.git
synced 2025-04-16 16:31:25 +00:00
Use expiration in message instead of config
This commit is contained in:
parent
5a047daefc
commit
6b1628df6b
@ -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 })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user