mirror of
https://github.com/ditatompel/xmr-remote-nodes.git
synced 2025-01-08 05:52:10 +07:00
Add sort order for prober data table
Allowed sort order by `id` and `last_submit_ts`
This commit is contained in:
parent
dbc07e66a8
commit
949db1573b
3 changed files with 26 additions and 10 deletions
|
@ -12,7 +12,7 @@ const getParams = ({ pageNumber, rowsPerPage, sort, filters }) => {
|
||||||
let params = `page=${pageNumber}&limit=${rowsPerPage}`;
|
let params = `page=${pageNumber}&limit=${rowsPerPage}`;
|
||||||
|
|
||||||
if (sort) {
|
if (sort) {
|
||||||
params += `&orderBy=${sort.orderBy}&orderDir=${sort.direction}`;
|
params += `&sort_by=${sort.orderBy}&sort_direction=${sort.direction}`;
|
||||||
}
|
}
|
||||||
if (filters) {
|
if (filters) {
|
||||||
params += filters.map(({ filterBy, value }) => `&${filterBy}=${value}`).join('');
|
params += filters.map(({ filterBy, value }) => `&${filterBy}=${value}`).join('');
|
||||||
|
|
|
@ -92,6 +92,8 @@ func Prober(c *fiber.Ctx) error {
|
||||||
query := repo.ProbersQueryParams{
|
query := repo.ProbersQueryParams{
|
||||||
RowsPerPage: c.QueryInt("limit", 10),
|
RowsPerPage: c.QueryInt("limit", 10),
|
||||||
Page: c.QueryInt("page", 1),
|
Page: c.QueryInt("page", 1),
|
||||||
|
SortBy: c.Query("sort_by", "id"),
|
||||||
|
SortDirection: c.Query("sort_direction", "desc"),
|
||||||
Name: c.Query("name"),
|
Name: c.Query("name"),
|
||||||
ApiKey: c.Query("api_key"),
|
ApiKey: c.Query("api_key"),
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package repo
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"slices"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/ditatompel/xmr-nodes/internal/database"
|
"github.com/ditatompel/xmr-nodes/internal/database"
|
||||||
|
@ -28,8 +29,11 @@ type Prober struct {
|
||||||
type ProbersQueryParams struct {
|
type ProbersQueryParams struct {
|
||||||
Name string
|
Name string
|
||||||
ApiKey string
|
ApiKey string
|
||||||
|
|
||||||
RowsPerPage int
|
RowsPerPage int
|
||||||
Page int
|
Page int
|
||||||
|
SortBy string
|
||||||
|
SortDirection string
|
||||||
}
|
}
|
||||||
|
|
||||||
type Probers struct {
|
type Probers struct {
|
||||||
|
@ -80,7 +84,17 @@ func (repo *ProberRepo) Probers(q ProbersQueryParams) (Probers, error) {
|
||||||
}
|
}
|
||||||
queryParams = append(queryParams, q.RowsPerPage, (q.Page-1)*q.RowsPerPage)
|
queryParams = append(queryParams, q.RowsPerPage, (q.Page-1)*q.RowsPerPage)
|
||||||
|
|
||||||
query := fmt.Sprintf("SELECT id, name, api_key, last_submit_ts FROM tbl_prober %s ORDER BY id DESC LIMIT ? OFFSET ?", where)
|
allowedSort := []string{"id", "last_submit_ts"}
|
||||||
|
sortBy := "id"
|
||||||
|
if slices.Contains(allowedSort, q.SortBy) {
|
||||||
|
sortBy = q.SortBy
|
||||||
|
}
|
||||||
|
sortDirection := "DESC"
|
||||||
|
if q.SortDirection == "asc" {
|
||||||
|
sortDirection = "ASC"
|
||||||
|
}
|
||||||
|
|
||||||
|
query := fmt.Sprintf("SELECT id, name, api_key, last_submit_ts FROM tbl_prober %s ORDER BY %s %s LIMIT ? OFFSET ?", where, sortBy, sortDirection)
|
||||||
|
|
||||||
row, err := repo.db.Query(query, queryParams...)
|
row, err := repo.db.Query(query, queryParams...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in a new issue