mirror of
https://github.com/ditatompel/xmr-remote-nodes.git
synced 2025-01-08 05:52:10 +07:00
refactor!: Use function method for routes
Will be useful for future development using standard `net/http`.
This commit is contained in:
parent
2e31824910
commit
b68f626ce2
3 changed files with 26 additions and 27 deletions
|
@ -6,7 +6,8 @@ import (
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
func CheckProber(c *fiber.Ctx) error {
|
// checkProberMW is a middleware to check prober API key
|
||||||
|
func (s *fiberServer) checkProberMW(c *fiber.Ctx) error {
|
||||||
key := c.Get(monero.ProberAPIKey)
|
key := c.Get(monero.ProberAPIKey)
|
||||||
if key == "" {
|
if key == "" {
|
||||||
return c.Status(fiber.StatusUnauthorized).JSON(fiber.Map{
|
return c.Status(fiber.StatusUnauthorized).JSON(fiber.Map{
|
||||||
|
|
|
@ -85,8 +85,8 @@ func (s *fiberServer) addNodeHandler(c *fiber.Ctx) error {
|
||||||
return handler(c)
|
return handler(c)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns a single node information based on `id` query param
|
// Returns a single node information based on `id` query param (API endpoint, JSON data)
|
||||||
func Node(c *fiber.Ctx) error {
|
func (s *fiberServer) nodeAPI(c *fiber.Ctx) error {
|
||||||
nodeId, err := c.ParamsInt("id", 0)
|
nodeId, err := c.ParamsInt("id", 0)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return c.Status(fiber.StatusUnprocessableEntity).JSON(fiber.Map{
|
return c.Status(fiber.StatusUnprocessableEntity).JSON(fiber.Map{
|
||||||
|
@ -264,8 +264,8 @@ func (s *fiberServer) nodeHandler(c *fiber.Ctx) error {
|
||||||
return handler(c)
|
return handler(c)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns a list of nodes (API)
|
// Returns list of nodes (API endpoint, JSON data)
|
||||||
func Nodes(c *fiber.Ctx) error {
|
func (s *fiberServer) nodesAPI(c *fiber.Ctx) error {
|
||||||
moneroRepo := monero.New()
|
moneroRepo := monero.New()
|
||||||
query := monero.QueryNodes{
|
query := monero.QueryNodes{
|
||||||
Paging: paging.Paging{
|
Paging: paging.Paging{
|
||||||
|
@ -299,10 +299,8 @@ func Nodes(c *fiber.Ctx) error {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns probe logs reported by nodes
|
// Returns probe logs reported by nodes (API endpoint, JSON data)
|
||||||
//
|
func (s *fiberServer) probeLogsAPI(c *fiber.Ctx) error {
|
||||||
// The embadded web UI use `node_id` query param to filter logs
|
|
||||||
func ProbeLogs(c *fiber.Ctx) error {
|
|
||||||
moneroRepo := monero.New()
|
moneroRepo := monero.New()
|
||||||
query := monero.QueryLogs{
|
query := monero.QueryLogs{
|
||||||
Paging: paging.Paging{
|
Paging: paging.Paging{
|
||||||
|
@ -336,7 +334,7 @@ func ProbeLogs(c *fiber.Ctx) error {
|
||||||
// Handles `POST /nodes` request to add a new node
|
// Handles `POST /nodes` request to add a new node
|
||||||
//
|
//
|
||||||
// Deprecated: AddNode is deprecated, use s.addNodeHandler with put method instead
|
// Deprecated: AddNode is deprecated, use s.addNodeHandler with put method instead
|
||||||
func AddNode(c *fiber.Ctx) error {
|
func (s *fiberServer) addNodeAPI(c *fiber.Ctx) error {
|
||||||
formPort := c.FormValue("port")
|
formPort := c.FormValue("port")
|
||||||
port, err := strconv.Atoi(formPort)
|
port, err := strconv.Atoi(formPort)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -366,8 +364,8 @@ func AddNode(c *fiber.Ctx) error {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns majority network fees
|
// Returns majority network fees (API endpoint, JSON data)
|
||||||
func NetFees(c *fiber.Ctx) error {
|
func (s *fiberServer) netFeesAPI(c *fiber.Ctx) error {
|
||||||
moneroRepo := monero.New()
|
moneroRepo := monero.New()
|
||||||
return c.JSON(fiber.Map{
|
return c.JSON(fiber.Map{
|
||||||
"status": "ok",
|
"status": "ok",
|
||||||
|
@ -376,8 +374,8 @@ func NetFees(c *fiber.Ctx) error {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns list of countries (count by nodes)
|
// Returns list of countries, count by nodes (API endpoint, JSON data)
|
||||||
func Countries(c *fiber.Ctx) error {
|
func (s *fiberServer) countriesAPI(c *fiber.Ctx) error {
|
||||||
moneroRepo := monero.New()
|
moneroRepo := monero.New()
|
||||||
countries, err := moneroRepo.Countries()
|
countries, err := moneroRepo.Countries()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -394,10 +392,10 @@ func Countries(c *fiber.Ctx) error {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns node to be probed by the client (prober)
|
// Returns node to be probed by the prober (API endpoint, JSON data)
|
||||||
//
|
//
|
||||||
// This handler should protected by `CheckProber` middleware.
|
// This handler should protected by `s.checkProberMW` middleware.
|
||||||
func GiveJob(c *fiber.Ctx) error {
|
func (s *fiberServer) giveJobAPI(c *fiber.Ctx) error {
|
||||||
acceptTor := c.QueryInt("accept_tor", 0)
|
acceptTor := c.QueryInt("accept_tor", 0)
|
||||||
acceptIPv6 := c.QueryInt("accept_ipv6", 0)
|
acceptIPv6 := c.QueryInt("accept_ipv6", 0)
|
||||||
|
|
||||||
|
@ -418,10 +416,10 @@ func GiveJob(c *fiber.Ctx) error {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handles probe report submission by the prober
|
// Handles probe report submission by the prober (API endpoint, JSON data)
|
||||||
//
|
//
|
||||||
// This handler should protected by `CheckProber` middleware.
|
// This handler should protected by `CheckProber` middleware.
|
||||||
func ProcessJob(c *fiber.Ctx) error {
|
func (s *fiberServer) processJobAPI(c *fiber.Ctx) error {
|
||||||
var report monero.ProbeReport
|
var report monero.ProbeReport
|
||||||
|
|
||||||
if err := c.BodyParser(&report); err != nil {
|
if err := c.BodyParser(&report); err != nil {
|
||||||
|
|
|
@ -15,14 +15,14 @@ func (s *fiberServer) Routes() {
|
||||||
v1 := s.App.Group("/api/v1")
|
v1 := s.App.Group("/api/v1")
|
||||||
|
|
||||||
// these routes are public, they don't require a prober api key
|
// these routes are public, they don't require a prober api key
|
||||||
v1.Get("/nodes", Nodes)
|
v1.Get("/nodes", s.nodesAPI)
|
||||||
v1.Post("/nodes", AddNode) // old add node form action endpoint. Deprecated: Use PUT /add-node instead
|
v1.Post("/nodes", s.addNodeAPI) // old add node form action endpoint. Deprecated: Use PUT /add-node instead
|
||||||
v1.Get("/nodes/id/:id", Node)
|
v1.Get("/nodes/id/:id", s.nodeAPI)
|
||||||
v1.Get("/nodes/logs", ProbeLogs)
|
v1.Get("/nodes/logs", s.probeLogsAPI)
|
||||||
v1.Get("/fees", NetFees)
|
v1.Get("/fees", s.netFeesAPI)
|
||||||
v1.Get("/countries", Countries)
|
v1.Get("/countries", s.countriesAPI)
|
||||||
|
|
||||||
// these routes are for prober, they require a prober api key
|
// these routes are for prober, they require a prober api key
|
||||||
v1.Get("/job", CheckProber, GiveJob)
|
v1.Get("/job", s.checkProberMW, s.giveJobAPI)
|
||||||
v1.Post("/job", CheckProber, ProcessJob)
|
v1.Post("/job", s.checkProberMW, s.processJobAPI)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue