2022-05-11 15:57:56 +02:00
|
|
|
package dashboard
|
|
|
|
|
|
|
|
import (
|
2022-05-26 08:35:39 +02:00
|
|
|
"cic-dw/pkg/date_range"
|
2022-05-11 15:57:56 +02:00
|
|
|
"context"
|
|
|
|
"net/http"
|
|
|
|
"time"
|
2022-05-23 14:41:24 +02:00
|
|
|
|
|
|
|
"github.com/georgysavva/scany/pgxscan"
|
2022-08-26 09:23:26 +02:00
|
|
|
"github.com/jackc/pgx/v4"
|
2022-05-23 14:41:24 +02:00
|
|
|
"github.com/labstack/echo/v4"
|
2022-05-11 15:57:56 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type lineChartRes struct {
|
|
|
|
X time.Time `db:"x" json:"x"`
|
|
|
|
Y int `db:"y" json:"y"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func handleNewRegistrations(c echo.Context) error {
|
|
|
|
var (
|
2022-05-23 14:41:24 +02:00
|
|
|
api = c.Get("api").(*api)
|
2022-08-26 09:23:26 +02:00
|
|
|
qP = c.QueryParams()
|
2022-05-23 14:41:24 +02:00
|
|
|
|
2022-08-26 09:23:26 +02:00
|
|
|
rows pgx.Rows
|
|
|
|
err error
|
2022-05-11 15:57:56 +02:00
|
|
|
data []lineChartRes
|
|
|
|
)
|
|
|
|
|
2022-08-26 09:23:26 +02:00
|
|
|
from, to := date_range.ParseDateRange(qP)
|
|
|
|
|
|
|
|
if qP.Get("country") == "cmr" {
|
|
|
|
rows, err = api.db.Query(context.Background(), api.q["new-user-registrations-cmr"], from, to)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
rows, err = api.db.Query(context.Background(), api.q["new-user-registrations"], from, to)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-05-11 15:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := pgxscan.ScanAll(&data, rows); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(http.StatusOK, data)
|
|
|
|
}
|
|
|
|
|
|
|
|
func handleTransactionsCount(c echo.Context) error {
|
|
|
|
var (
|
2022-05-23 14:41:24 +02:00
|
|
|
api = c.Get("api").(*api)
|
2022-08-26 09:23:26 +02:00
|
|
|
qP = c.QueryParams()
|
2022-05-23 14:41:24 +02:00
|
|
|
|
2022-08-26 09:23:26 +02:00
|
|
|
rows pgx.Rows
|
|
|
|
err error
|
2022-05-11 15:57:56 +02:00
|
|
|
data []lineChartRes
|
|
|
|
)
|
|
|
|
|
2022-08-26 09:23:26 +02:00
|
|
|
from, to := date_range.ParseDateRange(qP)
|
|
|
|
|
|
|
|
if qP.Get("country") == "cmr" {
|
|
|
|
rows, err = api.db.Query(context.Background(), api.q["transactions-count-cmr"], from, to)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
rows, err = api.db.Query(context.Background(), api.q["transactions-count"], from, to)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-05-11 15:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := pgxscan.ScanAll(&data, rows); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(http.StatusOK, data)
|
|
|
|
}
|
2022-05-23 14:41:24 +02:00
|
|
|
|
|
|
|
func handleTokenTransactionsCount(c echo.Context) error {
|
|
|
|
var (
|
|
|
|
api = c.Get("api").(*api)
|
|
|
|
token = c.Param("address")
|
|
|
|
|
|
|
|
data []lineChartRes
|
|
|
|
)
|
|
|
|
|
2022-05-26 08:35:39 +02:00
|
|
|
from, to := date_range.ParseDateRange(c.QueryParams())
|
2022-05-23 14:41:24 +02:00
|
|
|
|
|
|
|
rows, err := api.db.Query(context.Background(), api.q["token-transactions-count"], from, to, token)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := pgxscan.ScanAll(&data, rows); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(http.StatusOK, data)
|
|
|
|
}
|
|
|
|
|
|
|
|
func handleTokenVolume(c echo.Context) error {
|
|
|
|
var (
|
|
|
|
api = c.Get("api").(*api)
|
|
|
|
token = c.Param("address")
|
|
|
|
|
|
|
|
data []lineChartRes
|
|
|
|
)
|
|
|
|
|
2022-05-26 08:35:39 +02:00
|
|
|
from, to := date_range.ParseDateRange(c.QueryParams())
|
2022-05-23 14:41:24 +02:00
|
|
|
|
|
|
|
rows, err := api.db.Query(context.Background(), api.q["token-volume"], from, to, token)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := pgxscan.ScanAll(&data, rows); err != nil {
|
|
|
|
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.JSON(http.StatusOK, data)
|
|
|
|
}
|