2021-09-08 14:05:39 -04:00
|
|
|
import json
|
|
|
|
|
|
|
|
import base
|
2021-09-08 16:55:37 -04:00
|
|
|
import signal_type
|
2021-09-08 14:05:39 -04:00
|
|
|
|
|
|
|
type MailserverRequestCompletedSignal* = ref object of Signal
|
|
|
|
requestID*: string
|
|
|
|
lastEnvelopeHash*: string
|
|
|
|
cursor*: string
|
|
|
|
errorMessage*: string
|
|
|
|
error*: bool
|
|
|
|
|
|
|
|
type MailserverRequestExpiredSignal* = ref object of Signal
|
|
|
|
# TODO
|
|
|
|
|
2021-09-28 14:41:40 -04:00
|
|
|
type HistoryRequestStartedSignal* = ref object of Signal
|
2021-11-09 17:19:29 -04:00
|
|
|
requestId*: string
|
|
|
|
numBatches*: int
|
|
|
|
|
|
|
|
type HistoryRequestBatchProcessedSignal* = ref object of Signal
|
|
|
|
requestId*: string
|
|
|
|
batchIndex*: int
|
|
|
|
numBatches*: int
|
|
|
|
|
2021-09-28 14:41:40 -04:00
|
|
|
type HistoryRequestCompletedSignal* = ref object of Signal
|
2021-11-09 17:19:29 -04:00
|
|
|
requestId*: string
|
|
|
|
|
2021-09-28 14:41:40 -04:00
|
|
|
type HistoryRequestFailedSignal* = ref object of Signal
|
2021-11-09 17:19:29 -04:00
|
|
|
requestId*: string
|
2021-09-28 14:41:40 -04:00
|
|
|
errorMessage*: string
|
|
|
|
error*: bool
|
|
|
|
|
2021-09-08 16:55:37 -04:00
|
|
|
proc fromEvent*(T: type MailserverRequestCompletedSignal, jsonSignal: JsonNode): MailserverRequestCompletedSignal =
|
|
|
|
result = MailserverRequestCompletedSignal()
|
|
|
|
result.signalType = SignalType.MailserverRequestCompleted
|
2021-09-08 14:05:39 -04:00
|
|
|
if jsonSignal["event"].kind != JNull:
|
2021-09-08 16:55:37 -04:00
|
|
|
result.requestID = jsonSignal["event"]{"requestID"}.getStr()
|
|
|
|
result.lastEnvelopeHash = jsonSignal["event"]{"lastEnvelopeHash"}.getStr()
|
|
|
|
result.cursor = jsonSignal["event"]{"cursor"}.getStr()
|
|
|
|
result.errorMessage = jsonSignal["event"]{"errorMessage"}.getStr()
|
|
|
|
result.error = result.errorMessage != ""
|
2021-09-08 14:05:39 -04:00
|
|
|
|
2021-09-08 16:55:37 -04:00
|
|
|
proc fromEvent*(T: type MailserverRequestExpiredSignal, jsonSignal: JsonNode): MailserverRequestExpiredSignal =
|
2021-09-08 14:05:39 -04:00
|
|
|
# TODO: parse signal
|
2021-09-08 16:55:37 -04:00
|
|
|
result = MailserverRequestExpiredSignal()
|
2021-09-28 14:41:40 -04:00
|
|
|
result.signalType = SignalType.MailserverRequestExpired
|
|
|
|
|
|
|
|
proc fromEvent*(T: type HistoryRequestStartedSignal, jsonSignal: JsonNode): HistoryRequestStartedSignal =
|
|
|
|
result = HistoryRequestStartedSignal()
|
|
|
|
result.signalType = SignalType.HistoryRequestStarted
|
2021-11-09 17:19:29 -04:00
|
|
|
result.requestId = jsonSignal["event"]{"requestId"}.getStr()
|
|
|
|
result.numBatches = jsonSIgnal["event"]{"numBatches"}.getInt()
|
|
|
|
|
|
|
|
proc fromEvent*(T: type HistoryRequestBatchProcessedSignal, jsonSignal: JsonNode): HistoryRequestBatchProcessedSignal =
|
|
|
|
result = HistoryRequestBatchProcessedSignal()
|
|
|
|
result.signalType = SignalType.HistoryRequestBatchProcessed
|
|
|
|
result.requestId = jsonSignal["event"]{"requestId"}.getStr()
|
|
|
|
result.batchIndex = jsonSIgnal["event"]{"batchIndex"}.getInt()
|
|
|
|
result.numBatches = jsonSIgnal["event"]{"numBatches"}.getInt()
|
2021-09-28 14:41:40 -04:00
|
|
|
|
|
|
|
proc fromEvent*(T: type HistoryRequestCompletedSignal, jsonSignal: JsonNode): HistoryRequestCompletedSignal =
|
|
|
|
result = HistoryRequestCompletedSignal()
|
|
|
|
result.signalType = SignalType.HistoryRequestCompleted
|
2021-11-09 17:19:29 -04:00
|
|
|
result.requestId = jsonSignal["event"]{"requestId"}.getStr()
|
2021-09-28 14:41:40 -04:00
|
|
|
|
|
|
|
proc fromEvent*(T: type HistoryRequestFailedSignal, jsonSignal: JsonNode): HistoryRequestFailedSignal =
|
|
|
|
result = HistoryRequestFailedSignal()
|
|
|
|
result.signalType = SignalType.HistoryRequestStarted
|
2021-11-09 17:19:29 -04:00
|
|
|
result.requestId = jsonSignal["event"]{"requestId"}.getStr()
|
2021-09-28 14:41:40 -04:00
|
|
|
if jsonSignal["event"].kind != JNull:
|
|
|
|
result.errorMessage = jsonSignal["event"]{"errorMessage"}.getStr()
|
|
|
|
result.error = result.errorMessage != ""
|