2024-05-04 00:11:56 +07:00
|
|
|
package handler
|
|
|
|
|
|
|
|
import (
|
2024-05-04 17:24:47 +07:00
|
|
|
"strconv"
|
2024-07-07 01:28:44 +07:00
|
|
|
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/monero"
|
2024-05-04 00:11:56 +07:00
|
|
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
)
|
|
|
|
|
2024-06-03 14:17:51 +07:00
|
|
|
// Returns a single node information based on `id` query param
|
|
|
|
func Node(c *fiber.Ctx) error {
|
2024-05-07 01:08:01 +07:00
|
|
|
nodeId, err := c.ParamsInt("id", 0)
|
|
|
|
if err != nil {
|
|
|
|
return c.Status(fiber.StatusUnprocessableEntity).JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
if nodeId == 0 {
|
|
|
|
return c.Status(fiber.StatusUnprocessableEntity).JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": "Invalid node id",
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-05-27 06:15:40 +07:00
|
|
|
moneroRepo := monero.New()
|
2024-05-07 01:08:01 +07:00
|
|
|
node, err := moneroRepo.Node(nodeId)
|
|
|
|
if err != nil {
|
|
|
|
return c.Status(fiber.StatusInternalServerError).JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Success",
|
|
|
|
"data": node,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:17:51 +07:00
|
|
|
// Returns a list of nodes
|
|
|
|
func Nodes(c *fiber.Ctx) error {
|
2024-05-27 06:15:40 +07:00
|
|
|
moneroRepo := monero.New()
|
2024-05-27 05:13:03 +07:00
|
|
|
query := monero.QueryNodes{
|
2024-05-04 18:52:47 +07:00
|
|
|
RowsPerPage: c.QueryInt("limit", 10),
|
|
|
|
Page: c.QueryInt("page", 1),
|
|
|
|
SortBy: c.Query("sort_by", "id"),
|
|
|
|
SortDirection: c.Query("sort_direction", "desc"),
|
|
|
|
Host: c.Query("host"),
|
2024-05-22 22:45:38 +07:00
|
|
|
Nettype: c.Query("nettype", "any"),
|
2024-05-06 14:33:13 +07:00
|
|
|
Protocol: c.Query("protocol", "any"),
|
|
|
|
CC: c.Query("cc", "any"),
|
|
|
|
Status: c.QueryInt("status", -1),
|
2024-05-22 22:45:38 +07:00
|
|
|
CORS: c.QueryInt("cors", -1),
|
2024-05-04 18:52:47 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
nodes, err := moneroRepo.Nodes(query)
|
|
|
|
if err != nil {
|
|
|
|
return c.Status(fiber.StatusInternalServerError).JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Success",
|
|
|
|
"data": nodes,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:20:10 +07:00
|
|
|
// Returns probe logs reported by nodes
|
|
|
|
//
|
|
|
|
// The embadded web UI use `node_id` query param to filter logs
|
2024-05-06 17:19:17 +07:00
|
|
|
func ProbeLogs(c *fiber.Ctx) error {
|
2024-05-27 06:15:40 +07:00
|
|
|
moneroRepo := monero.New()
|
2024-05-27 06:38:11 +07:00
|
|
|
query := monero.QueryLogs{
|
2024-05-06 17:19:17 +07:00
|
|
|
RowsPerPage: c.QueryInt("limit", 10),
|
|
|
|
Page: c.QueryInt("page", 1),
|
|
|
|
SortBy: c.Query("sort_by", "id"),
|
|
|
|
SortDirection: c.Query("sort_direction", "desc"),
|
2024-05-22 22:45:38 +07:00
|
|
|
NodeID: c.QueryInt("node_id", 0),
|
2024-05-07 21:31:40 +07:00
|
|
|
Status: c.QueryInt("status", -1),
|
|
|
|
FailedReason: c.Query("failed_reason"),
|
2024-05-06 17:19:17 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
logs, err := moneroRepo.Logs(query)
|
|
|
|
if err != nil {
|
|
|
|
return c.Status(fiber.StatusInternalServerError).JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Success",
|
|
|
|
"data": logs,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:20:10 +07:00
|
|
|
// Handles `POST /nodes` request to add a new node
|
2024-05-04 17:24:47 +07:00
|
|
|
func AddNode(c *fiber.Ctx) error {
|
|
|
|
formPort := c.FormValue("port")
|
|
|
|
port, err := strconv.Atoi(formPort)
|
|
|
|
if err != nil {
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": "Invalid port number",
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
protocol := c.FormValue("protocol")
|
|
|
|
hostname := c.FormValue("hostname")
|
|
|
|
|
2024-05-27 06:15:40 +07:00
|
|
|
moneroRepo := monero.New()
|
2024-05-04 17:24:47 +07:00
|
|
|
if err := moneroRepo.Add(protocol, hostname, uint(port)); err != nil {
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Query Ok",
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:20:10 +07:00
|
|
|
// Returns majority network fees
|
2024-05-31 13:30:56 +07:00
|
|
|
func NetFees(c *fiber.Ctx) error {
|
2024-05-27 06:15:40 +07:00
|
|
|
moneroRepo := monero.New()
|
2024-05-06 13:19:48 +07:00
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Success",
|
2024-05-31 13:30:56 +07:00
|
|
|
"data": moneroRepo.NetFees(),
|
2024-05-06 13:19:48 +07:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:20:10 +07:00
|
|
|
// Returns list of countries (count by nodes)
|
2024-05-06 13:35:15 +07:00
|
|
|
func Countries(c *fiber.Ctx) error {
|
2024-05-27 06:15:40 +07:00
|
|
|
moneroRepo := monero.New()
|
2024-05-06 13:35:15 +07:00
|
|
|
countries, err := moneroRepo.Countries()
|
|
|
|
if err != nil {
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Success",
|
|
|
|
"data": countries,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:20:10 +07:00
|
|
|
// Returns node to be probed by the client (prober)
|
|
|
|
//
|
|
|
|
// This handler should protected by `CheckProber` middleware.
|
2024-05-04 19:27:21 +07:00
|
|
|
func GiveJob(c *fiber.Ctx) error {
|
|
|
|
acceptTor := c.QueryInt("accept_tor", 0)
|
2024-09-06 00:08:59 +07:00
|
|
|
acceptIPv6 := c.QueryInt("accept_ipv6", 0)
|
2024-05-04 19:27:21 +07:00
|
|
|
|
2024-05-27 06:15:40 +07:00
|
|
|
moneroRepo := monero.New()
|
2024-09-06 00:08:59 +07:00
|
|
|
node, err := moneroRepo.GiveJob(acceptTor, acceptIPv6)
|
2024-05-04 19:27:21 +07:00
|
|
|
if err != nil {
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Success",
|
|
|
|
"data": node,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:20:10 +07:00
|
|
|
// Handles probe report submission by the prober
|
|
|
|
//
|
|
|
|
// This handler should protected by `CheckProber` middleware.
|
2024-05-05 01:42:47 +07:00
|
|
|
func ProcessJob(c *fiber.Ctx) error {
|
2024-06-03 14:20:10 +07:00
|
|
|
var report monero.ProbeReport
|
2024-05-05 01:42:47 +07:00
|
|
|
|
|
|
|
if err := c.BodyParser(&report); err != nil {
|
|
|
|
return c.Status(fiber.StatusUnprocessableEntity).JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 14:20:10 +07:00
|
|
|
moneroRepo := monero.New()
|
|
|
|
|
2024-05-05 01:42:47 +07:00
|
|
|
if err := moneroRepo.ProcessJob(report, c.Locals("prober_id").(int64)); err != nil {
|
|
|
|
return c.Status(fiber.StatusInternalServerError).JSON(fiber.Map{
|
|
|
|
"status": "error",
|
|
|
|
"message": err.Error(),
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(fiber.Map{
|
|
|
|
"status": "ok",
|
|
|
|
"message": "Success",
|
|
|
|
"data": nil,
|
|
|
|
})
|
|
|
|
}
|