2024-06-28 16:04:57 +05:30
|
|
|
{.push raises: [].}
|
2022-11-22 19:40:24 +01:00
|
|
|
|
2024-07-09 13:14:28 +02:00
|
|
|
import std/times, results, chronicles, chronos
|
2024-03-16 00:08:47 +01:00
|
|
|
import ../../waku_core, ../driver, ../retention_policy
|
2022-11-22 19:40:24 +01:00
|
|
|
|
|
|
|
logScope:
|
|
|
|
topics = "waku archive retention_policy"
|
|
|
|
|
|
|
|
const DefaultRetentionTime*: int64 = 30.days.seconds
|
|
|
|
|
|
|
|
type TimeRetentionPolicy* = ref object of RetentionPolicy
|
2024-03-16 00:08:47 +01:00
|
|
|
retentionTime: chronos.Duration
|
2022-11-22 19:40:24 +01:00
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
proc new*(T: type TimeRetentionPolicy, retentionTime = DefaultRetentionTime): T =
|
|
|
|
TimeRetentionPolicy(retentionTime: retentionTime.seconds)
|
2022-11-22 19:40:24 +01:00
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
method execute*(
|
|
|
|
p: TimeRetentionPolicy, driver: ArchiveDriver
|
|
|
|
): Future[RetentionPolicyResult[void]] {.async.} =
|
2022-11-22 19:40:24 +01:00
|
|
|
## Delete messages that exceed the retention time by 10% and more (batch delete for efficiency)
|
2024-07-15 20:58:31 +02:00
|
|
|
debug "beginning of executing message retention policy - time"
|
2022-11-22 19:40:24 +01:00
|
|
|
|
2023-05-25 17:34:34 +02:00
|
|
|
let omtRes = await driver.getOldestMessageTimestamp()
|
|
|
|
if omtRes.isErr():
|
|
|
|
return err("failed to get oldest message timestamp: " & omtRes.error)
|
2022-11-22 19:40:24 +01:00
|
|
|
|
|
|
|
let now = getNanosecondTime(getTime().toUnixFloat())
|
|
|
|
let retentionTimestamp = now - p.retentionTime.nanoseconds
|
|
|
|
let thresholdTimestamp = retentionTimestamp - p.retentionTime.nanoseconds div 10
|
|
|
|
|
2023-05-25 17:34:34 +02:00
|
|
|
if thresholdTimestamp <= omtRes.value:
|
2022-11-22 19:40:24 +01:00
|
|
|
return ok()
|
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
let res = await driver.deleteMessagesOlderThanTimestamp(ts = retentionTimestamp)
|
2022-11-22 19:40:24 +01:00
|
|
|
if res.isErr():
|
2023-05-25 17:34:34 +02:00
|
|
|
return err("failed to delete oldest messages: " & res.error)
|
2022-11-22 19:40:24 +01:00
|
|
|
|
2024-07-15 20:58:31 +02:00
|
|
|
debug "end of executing message retention policy - time"
|
2023-05-25 17:34:34 +02:00
|
|
|
return ok()
|