2023-09-08 09:19:47 +00:00
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
else:
|
|
|
|
{.push raises: [].}
|
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
import chronicles, json_serialization, presto/route
|
2024-04-23 16:53:18 +00:00
|
|
|
import ../../../waku_node, ../responses, ../serdes, ./types
|
2023-09-08 09:19:47 +00:00
|
|
|
|
|
|
|
logScope:
|
|
|
|
topics = "waku node rest health_api"
|
|
|
|
|
|
|
|
const ROUTE_HEALTH* = "/health"
|
|
|
|
|
2024-04-23 16:53:18 +00:00
|
|
|
const FutHealthReportTimeout = 5.seconds
|
2023-09-08 09:19:47 +00:00
|
|
|
|
2024-04-23 16:53:18 +00:00
|
|
|
proc installHealthApiHandler*(
|
|
|
|
router: var RestRouter, nodeHealthMonitor: WakuNodeHealthMonitor
|
|
|
|
) =
|
2024-03-15 23:08:47 +00:00
|
|
|
router.api(MethodGet, ROUTE_HEALTH) do() -> RestApiResponse:
|
2024-04-23 16:53:18 +00:00
|
|
|
let healthReportFut = nodeHealthMonitor.getNodeHealthReport()
|
|
|
|
if not await healthReportFut.withTimeout(FutHealthReportTimeout):
|
2024-03-15 23:08:47 +00:00
|
|
|
return RestApiResponse.internalServerError("Health check timed out")
|
2023-09-08 09:19:47 +00:00
|
|
|
|
2024-04-23 16:53:18 +00:00
|
|
|
var msg = ""
|
2023-09-08 09:19:47 +00:00
|
|
|
var status = Http200
|
|
|
|
|
2023-12-14 06:16:39 +00:00
|
|
|
try:
|
2024-04-23 16:53:18 +00:00
|
|
|
if healthReportFut.completed():
|
|
|
|
let healthReport = healthReportFut.read()
|
|
|
|
return RestApiResponse.jsonResponse(healthReport, Http200).valueOr:
|
|
|
|
debug "An error ocurred while building the json healthReport response",
|
|
|
|
error = error
|
|
|
|
return
|
|
|
|
RestApiResponse.internalServerError("Failed to serialize health report")
|
|
|
|
else:
|
|
|
|
msg = "Health check failed"
|
2023-12-14 06:16:39 +00:00
|
|
|
status = Http503
|
|
|
|
except:
|
|
|
|
msg = "exception reading state: " & getCurrentExceptionMsg()
|
|
|
|
status = Http500
|
2023-09-08 09:19:47 +00:00
|
|
|
|
|
|
|
return RestApiResponse.textResponse(msg, status)
|