mirror of
https://github.com/logos-storage/logos-storage-network-crawler.git
synced 2026-01-02 13:33:08 +00:00
66 lines
1.5 KiB
Nim
66 lines
1.5 KiB
Nim
import pkg/chronicles
|
|
import pkg/chronos
|
|
|
|
import ./codexcrawler/main
|
|
import ./codexcrawler/config
|
|
|
|
when defined(posix):
|
|
import system/ansi_c
|
|
|
|
type
|
|
ApplicationStatus {.pure.} = enum
|
|
Stopped,
|
|
Stopping,
|
|
Running
|
|
|
|
Application = ref object
|
|
status: ApplicationStatus
|
|
|
|
proc run(app: Application) =
|
|
let config = parseConfig()
|
|
info "Loaded configuration", config
|
|
|
|
app.status = ApplicationStatus.Running
|
|
|
|
waitFor startApplication()
|
|
|
|
while app.status == ApplicationStatus.Running:
|
|
try:
|
|
chronos.poll()
|
|
except Exception as exc:
|
|
error "Unhandled exception", msg = exc.msg
|
|
quit QuitFailure
|
|
notice "Done"
|
|
|
|
when isMainModule:
|
|
let app = Application()
|
|
|
|
# Stopping code must be in scope of app declaration.
|
|
# Else capture of the instance is not allowed due to {.noconv.}.
|
|
proc onStopSignal() =
|
|
app.status = ApplicationStatus.Stopping
|
|
notice "Stopping Crawler..."
|
|
|
|
proc controlCHandler() {.noconv.} =
|
|
when defined(windows):
|
|
# workaround for https://github.com/nim-lang/Nim/issues/4057
|
|
try:
|
|
setupForeignThreadGc()
|
|
except Exception as exc: raiseAssert exc.msg
|
|
notice "Shutting down after having received SIGINT"
|
|
onStopSignal()
|
|
|
|
try:
|
|
setControlCHook(controlCHandler)
|
|
except Exception as exc:
|
|
warn "Cannot set ctrl-c handler", msg = exc.msg
|
|
|
|
when defined(posix):
|
|
proc SIGTERMHandler(signal: cint) {.noconv.} =
|
|
notice "Shutting down after having received SIGTERM"
|
|
onStopSignal()
|
|
|
|
c_signal(ansi_c.SIGTERM, SIGTERMHandler)
|
|
|
|
app.run()
|