mirror of
https://github.com/logos-messaging/logos-delivery.git
synced 2026-04-24 09:03:42 +00:00
47 lines
1.3 KiB
Nim
47 lines
1.3 KiB
Nim
## This module helps to ensure the correct transmission and reception of messages
|
|
|
|
import results
|
|
import chronos
|
|
import
|
|
./recv_service,
|
|
./send_service,
|
|
./subscription_service,
|
|
waku/[
|
|
waku_core,
|
|
waku_node,
|
|
waku_store/client,
|
|
waku_relay/protocol,
|
|
waku_lightpush/client,
|
|
waku_filter_v2/client,
|
|
]
|
|
|
|
type DeliveryService* = ref object
|
|
sendService*: SendService
|
|
recvService: RecvService
|
|
subscriptionService*: SubscriptionService
|
|
|
|
proc new*(
|
|
T: type DeliveryService, useP2PReliability: bool, w: WakuNode
|
|
): Result[T, string] =
|
|
## storeClient is needed to give store visitility to DeliveryService
|
|
## wakuRelay and wakuLightpushClient are needed to give a mechanism to SendService to re-publish
|
|
let subscriptionService = SubscriptionService.new(w)
|
|
let sendService = ?SendService.new(useP2PReliability, w, subscriptionService)
|
|
let recvService = RecvService.new(w, subscriptionService)
|
|
|
|
return ok(
|
|
DeliveryService(
|
|
sendService: sendService,
|
|
recvService: recvService,
|
|
subscriptionService: subscriptionService,
|
|
)
|
|
)
|
|
|
|
proc startDeliveryService*(self: DeliveryService) =
|
|
self.sendService.startSendService()
|
|
self.recvService.startRecvService()
|
|
|
|
proc stopDeliveryService*(self: DeliveryService) {.async.} =
|
|
await self.sendService.stopSendService()
|
|
await self.recvService.stopRecvService()
|