Give job api response

This commit is contained in:
Cristian Ditaputratama 2024-05-04 19:27:21 +07:00
parent ca759fc1d0
commit 6430e37548
Signed by: ditatompel
GPG key ID: 31D3D06D77950979
3 changed files with 53 additions and 0 deletions

View file

@ -171,6 +171,26 @@ func AddNode(c *fiber.Ctx) error {
}) })
} }
func GiveJob(c *fiber.Ctx) error {
acceptTor := c.QueryInt("accept_tor", 0)
moneroRepo := repo.NewMoneroRepo(database.GetDB())
node, err := moneroRepo.GiveJob(acceptTor)
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,
})
}
func Crons(c *fiber.Ctx) error { func Crons(c *fiber.Ctx) error {
cronRepo := repo.NewCron(database.GetDB()) cronRepo := repo.NewCron(database.GetDB())

View file

@ -16,5 +16,6 @@ func V1Api(app *fiber.App) {
v1.Post("/prober", Prober) v1.Post("/prober", Prober)
v1.Get("/nodes", MoneroNodes) v1.Get("/nodes", MoneroNodes)
v1.Post("/nodes", AddNode) v1.Post("/nodes", AddNode)
v1.Get("/job", GiveJob)
v1.Get("/crons", Crons) v1.Get("/crons", Crons)
} }

View file

@ -17,6 +17,7 @@ import (
type MoneroRepository interface { type MoneroRepository interface {
Add(protocol string, host string, port uint) error Add(protocol string, host string, port uint) error
Nodes(q MoneroQueryParams) (MoneroNodes, error) Nodes(q MoneroQueryParams) (MoneroNodes, error)
GiveJob(acceptTor int) (MoneroNode, error)
} }
type MoneroRepo struct { type MoneroRepo struct {
@ -187,3 +188,34 @@ func (repo *MoneroRepo) Add(protocol string, hostname string, port uint) error {
return nil return nil
} }
func (repo *MoneroRepo) GiveJob(acceptTor int) (MoneroNode, error) {
queryParams := []interface{}{}
whereQueries := []string{}
where := ""
if acceptTor != 1 {
whereQueries = append(whereQueries, "is_tor = ?")
queryParams = append(queryParams, 0)
}
if len(whereQueries) > 0 {
where = "WHERE " + strings.Join(whereQueries, " AND ")
}
node := MoneroNode{}
query := fmt.Sprintf(`SELECT id, hostname, port, protocol, is_tor FROM tbl_node %s ORDER BY last_checked ASC LIMIT 1`, where)
err := repo.db.QueryRow(query, queryParams...).Scan(&node.Id, &node.Hostname, &node.Port, &node.Protocol, &node.IsTor)
if err != nil {
return node, err
}
update := `UPDATE tbl_node SET last_checked = ? WHERE id = ?`
_, err = repo.db.Exec(update, time.Now().Unix(), node.Id)
if err != nil {
return node, err
}
return node, nil
}