mirror of
https://github.com/ditatompel/xmr-remote-nodes.git
synced 2025-01-08 05:52:10 +07:00
Moving monero.go to its own internal package
This commit is contained in:
parent
7d69e9af95
commit
ddc448e90c
7 changed files with 117 additions and 116 deletions
|
@ -13,7 +13,7 @@ import (
|
|||
"os"
|
||||
"time"
|
||||
"xmr-remote-nodes/internal/config"
|
||||
"xmr-remote-nodes/internal/repo"
|
||||
"xmr-remote-nodes/internal/monero"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
"golang.org/x/net/proxy"
|
||||
|
@ -66,13 +66,13 @@ func RunProbe() {
|
|||
slog.Debug(fmt.Sprintf("[PROBE] fetchNode: %s", prettyPrint(fetchNode)))
|
||||
}
|
||||
|
||||
func (p *proberClient) getJob() (repo.MoneroNode, error) {
|
||||
func (p *proberClient) getJob() (monero.Node, error) {
|
||||
queryParams := ""
|
||||
if p.config.AcceptTor {
|
||||
queryParams = "?accept_tor=1"
|
||||
}
|
||||
|
||||
node := repo.MoneroNode{}
|
||||
var node monero.Node
|
||||
|
||||
endpoint := fmt.Sprintf("%s/api/v1/job%s", p.config.ServerEndpoint, queryParams)
|
||||
slog.Info(fmt.Sprintf("[PROBE] Getting node from %s", endpoint))
|
||||
|
@ -96,7 +96,7 @@ func (p *proberClient) getJob() (repo.MoneroNode, error) {
|
|||
}
|
||||
|
||||
response := struct {
|
||||
Data repo.MoneroNode `json:"data"`
|
||||
Data monero.Node `json:"data"`
|
||||
}{}
|
||||
|
||||
err = json.NewDecoder(resp.Body).Decode(&response)
|
||||
|
@ -110,7 +110,7 @@ func (p *proberClient) getJob() (repo.MoneroNode, error) {
|
|||
return node, nil
|
||||
}
|
||||
|
||||
func (p *proberClient) fetchNode(node repo.MoneroNode) (repo.MoneroNode, error) {
|
||||
func (p *proberClient) fetchNode(node monero.Node) (monero.Node, error) {
|
||||
startTime := time.Now()
|
||||
endpoint := fmt.Sprintf("%s://%s:%d/json_rpc", node.Protocol, node.Hostname, node.Port)
|
||||
rpcParam := []byte(`{"jsonrpc": "2.0","id": "0","method": "get_info"}`)
|
||||
|
@ -167,7 +167,7 @@ func (p *proberClient) fetchNode(node repo.MoneroNode) (repo.MoneroNode, error)
|
|||
}
|
||||
|
||||
reportNode := struct {
|
||||
repo.MoneroNode `json:"result"`
|
||||
monero.Node `json:"result"`
|
||||
}{}
|
||||
|
||||
if err := json.Unmarshal(body, &reportNode); err != nil {
|
||||
|
@ -178,7 +178,7 @@ func (p *proberClient) fetchNode(node repo.MoneroNode) (repo.MoneroNode, error)
|
|||
if reportNode.Status == "OK" {
|
||||
node.IsAvailable = true
|
||||
}
|
||||
node.NetType = reportNode.NetType
|
||||
node.Nettype = reportNode.Nettype
|
||||
node.AdjustedTime = reportNode.AdjustedTime
|
||||
node.DatabaseSize = reportNode.DatabaseSize
|
||||
node.Difficulty = reportNode.Difficulty
|
||||
|
@ -186,7 +186,7 @@ func (p *proberClient) fetchNode(node repo.MoneroNode) (repo.MoneroNode, error)
|
|||
node.Version = reportNode.Version
|
||||
|
||||
if resp.Header.Get("Access-Control-Allow-Origin") == "*" || resp.Header.Get("Access-Control-Allow-Origin") == "https://xmr.ditatompel.com" {
|
||||
node.CorsCapable = true
|
||||
node.CORSCapable = true
|
||||
}
|
||||
|
||||
if !node.IsTor {
|
||||
|
@ -194,7 +194,7 @@ func (p *proberClient) fetchNode(node repo.MoneroNode) (repo.MoneroNode, error)
|
|||
if err != nil {
|
||||
fmt.Println("Warning: Could not resolve hostname: " + node.Hostname)
|
||||
} else {
|
||||
node.Ip = hostIp[0].String()
|
||||
node.IP = hostIp[0].String()
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -245,8 +245,8 @@ func (p *proberClient) fetchNode(node repo.MoneroNode) (repo.MoneroNode, error)
|
|||
return node, nil
|
||||
}
|
||||
|
||||
func (p *proberClient) reportResult(node repo.MoneroNode, tookTime float64) error {
|
||||
jsonData, err := json.Marshal(repo.ProbeReport{
|
||||
func (p *proberClient) reportResult(node monero.Node, tookTime float64) error {
|
||||
jsonData, err := json.Marshal(monero.ProbeReport{
|
||||
TookTime: tookTime,
|
||||
Message: p.message,
|
||||
NodeInfo: node,
|
||||
|
|
|
@ -8,7 +8,7 @@ import (
|
|||
"text/tabwriter"
|
||||
"time"
|
||||
"xmr-remote-nodes/internal/database"
|
||||
"xmr-remote-nodes/internal/repo"
|
||||
"xmr-remote-nodes/internal/monero"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
@ -43,8 +43,8 @@ xmr-nodes probers list -s last_submit_ts -d asc sin1`,
|
|||
sortBy, _ := cmd.Flags().GetString("sort-by")
|
||||
sortDir, _ := cmd.Flags().GetString("sort-dir")
|
||||
|
||||
probersRepo := repo.NewProberRepo(database.GetDB())
|
||||
probers, err := probersRepo.Probers(repo.ProbersQueryParams{
|
||||
probersRepo := monero.NewProberRepo(database.GetDB())
|
||||
probers, err := probersRepo.Probers(monero.ProbersQueryParams{
|
||||
Search: strings.Join(args, " "),
|
||||
SortBy: sortBy,
|
||||
SortDirection: sortDir,
|
||||
|
@ -90,7 +90,7 @@ This command will display the prober name and API key when successfully executed
|
|||
proberName = stringPrompt("Prober Name:")
|
||||
}
|
||||
|
||||
proberRepo := repo.NewProberRepo(database.GetDB())
|
||||
proberRepo := monero.NewProberRepo(database.GetDB())
|
||||
prober, err := proberRepo.Add(proberName)
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
|
@ -117,7 +117,7 @@ var editProbersCmd = &cobra.Command{
|
|||
}
|
||||
|
||||
proberName := stringPrompt("Prober Name:")
|
||||
proberRepo := repo.NewProberRepo(database.GetDB())
|
||||
proberRepo := monero.NewProberRepo(database.GetDB())
|
||||
err = proberRepo.Edit(proberId, proberName)
|
||||
if err != nil {
|
||||
fmt.Println("Failed to update prober:", err)
|
||||
|
@ -143,7 +143,7 @@ var deleteProbersCmd = &cobra.Command{
|
|||
return
|
||||
}
|
||||
|
||||
proberRepo := repo.NewProberRepo(database.GetDB())
|
||||
proberRepo := monero.NewProberRepo(database.GetDB())
|
||||
err = proberRepo.Delete(proberId)
|
||||
if err != nil {
|
||||
fmt.Println("Failed to delete prober:", err)
|
||||
|
|
|
@ -2,7 +2,7 @@ package handler
|
|||
|
||||
import (
|
||||
"xmr-remote-nodes/internal/database"
|
||||
"xmr-remote-nodes/internal/repo"
|
||||
"xmr-remote-nodes/internal/monero"
|
||||
|
||||
"github.com/gofiber/fiber/v2"
|
||||
)
|
||||
|
@ -17,7 +17,7 @@ func CheckProber(c *fiber.Ctx) error {
|
|||
})
|
||||
}
|
||||
|
||||
proberRepo := repo.NewProberRepo(database.GetDB())
|
||||
proberRepo := monero.NewProberRepo(database.GetDB())
|
||||
|
||||
prober, err := proberRepo.CheckApi(key)
|
||||
if err != nil {
|
||||
|
|
|
@ -3,7 +3,7 @@ package handler
|
|||
import (
|
||||
"strconv"
|
||||
"xmr-remote-nodes/internal/database"
|
||||
"xmr-remote-nodes/internal/repo"
|
||||
"xmr-remote-nodes/internal/monero"
|
||||
|
||||
"github.com/gofiber/fiber/v2"
|
||||
)
|
||||
|
@ -26,7 +26,7 @@ func MoneroNode(c *fiber.Ctx) error {
|
|||
})
|
||||
}
|
||||
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
node, err := moneroRepo.Node(nodeId)
|
||||
if err != nil {
|
||||
return c.Status(fiber.StatusInternalServerError).JSON(fiber.Map{
|
||||
|
@ -44,18 +44,18 @@ func MoneroNode(c *fiber.Ctx) error {
|
|||
}
|
||||
|
||||
func MoneroNodes(c *fiber.Ctx) error {
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
query := repo.MoneroQueryParams{
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
query := monero.MoneroQueryParams{
|
||||
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"),
|
||||
NetType: c.Query("nettype", "any"),
|
||||
Nettype: c.Query("nettype", "any"),
|
||||
Protocol: c.Query("protocol", "any"),
|
||||
CC: c.Query("cc", "any"),
|
||||
Status: c.QueryInt("status", -1),
|
||||
Cors: c.QueryInt("cors", -1),
|
||||
CORS: c.QueryInt("cors", -1),
|
||||
}
|
||||
|
||||
nodes, err := moneroRepo.Nodes(query)
|
||||
|
@ -75,13 +75,13 @@ func MoneroNodes(c *fiber.Ctx) error {
|
|||
}
|
||||
|
||||
func ProbeLogs(c *fiber.Ctx) error {
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
query := repo.MoneroLogQueryParams{
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
query := monero.MoneroLogQueryParams{
|
||||
RowsPerPage: c.QueryInt("limit", 10),
|
||||
Page: c.QueryInt("page", 1),
|
||||
SortBy: c.Query("sort_by", "id"),
|
||||
SortDirection: c.Query("sort_direction", "desc"),
|
||||
NodeId: c.QueryInt("node_id", 0),
|
||||
NodeID: c.QueryInt("node_id", 0),
|
||||
Status: c.QueryInt("status", -1),
|
||||
FailedReason: c.Query("failed_reason"),
|
||||
}
|
||||
|
@ -116,7 +116,7 @@ func AddNode(c *fiber.Ctx) error {
|
|||
protocol := c.FormValue("protocol")
|
||||
hostname := c.FormValue("hostname")
|
||||
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
if err := moneroRepo.Add(protocol, hostname, uint(port)); err != nil {
|
||||
return c.JSON(fiber.Map{
|
||||
"status": "error",
|
||||
|
@ -133,7 +133,7 @@ func AddNode(c *fiber.Ctx) error {
|
|||
}
|
||||
|
||||
func NetFee(c *fiber.Ctx) error {
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
return c.JSON(fiber.Map{
|
||||
"status": "ok",
|
||||
"message": "Success",
|
||||
|
@ -142,7 +142,7 @@ func NetFee(c *fiber.Ctx) error {
|
|||
}
|
||||
|
||||
func Countries(c *fiber.Ctx) error {
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
countries, err := moneroRepo.Countries()
|
||||
if err != nil {
|
||||
return c.JSON(fiber.Map{
|
||||
|
@ -161,7 +161,7 @@ func Countries(c *fiber.Ctx) error {
|
|||
func GiveJob(c *fiber.Ctx) error {
|
||||
acceptTor := c.QueryInt("accept_tor", 0)
|
||||
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
node, err := moneroRepo.GiveJob(acceptTor)
|
||||
if err != nil {
|
||||
return c.JSON(fiber.Map{
|
||||
|
@ -179,8 +179,8 @@ func GiveJob(c *fiber.Ctx) error {
|
|||
}
|
||||
|
||||
func ProcessJob(c *fiber.Ctx) error {
|
||||
moneroRepo := repo.NewMoneroRepo(database.GetDB())
|
||||
report := repo.ProbeReport{}
|
||||
moneroRepo := monero.NewMoneroRepo(database.GetDB())
|
||||
report := monero.ProbeReport{}
|
||||
|
||||
if err := c.BodyParser(&report); err != nil {
|
||||
return c.Status(fiber.StatusUnprocessableEntity).JSON(fiber.Map{
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
package repo
|
||||
package geo
|
||||
|
||||
import (
|
||||
"errors"
|
||||
|
@ -7,7 +7,7 @@ import (
|
|||
"github.com/oschwald/geoip2-golang"
|
||||
)
|
||||
|
||||
type GeoIpInfo struct {
|
||||
type IPInfo struct {
|
||||
Ip string `json:"ip"`
|
||||
IsAnonymousProxy bool `json:"is_anonymous_proxy"`
|
||||
IsSatelliteProvider bool `json:"is_satellite_provider"`
|
||||
|
@ -25,7 +25,7 @@ type GeoIpInfo struct {
|
|||
Asn uint `json:"asn"`
|
||||
}
|
||||
|
||||
func GetGeoIpInfo(ipAddr string) (*GeoIpInfo, error) {
|
||||
func IpInfo(ipAddr string) (*IPInfo, error) {
|
||||
ip := net.ParseIP(ipAddr)
|
||||
if ip == nil {
|
||||
return nil, errors.New("Invalid IP address")
|
||||
|
@ -52,7 +52,7 @@ func GetGeoIpInfo(ipAddr string) (*GeoIpInfo, error) {
|
|||
return nil, errors.New("Cannot read GeoIP ASN database")
|
||||
}
|
||||
|
||||
qip := GeoIpInfo{
|
||||
qip := IPInfo{
|
||||
Ip: ipAddr,
|
||||
IsAnonymousProxy: cityRecord.Traits.IsAnonymousProxy,
|
||||
IsSatelliteProvider: cityRecord.Traits.IsSatelliteProvider,
|
|
@ -1,4 +1,4 @@
|
|||
package repo
|
||||
package monero
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
|
@ -11,18 +11,19 @@ import (
|
|||
"strings"
|
||||
"time"
|
||||
"xmr-remote-nodes/internal/database"
|
||||
"xmr-remote-nodes/internal/geo"
|
||||
|
||||
"github.com/jmoiron/sqlx/types"
|
||||
)
|
||||
|
||||
type MoneroRepository interface {
|
||||
Node(id int) (MoneroNode, error)
|
||||
Node(id int) (Node, error)
|
||||
Add(protocol string, host string, port uint) error
|
||||
Nodes(q MoneroQueryParams) (MoneroNodes, error)
|
||||
GiveJob(acceptTor int) (MoneroNode, error)
|
||||
Nodes(q MoneroQueryParams) (Nodes, error)
|
||||
GiveJob(acceptTor int) (Node, error)
|
||||
ProcessJob(report ProbeReport, proberId int64) error
|
||||
NetFee() []NetFee
|
||||
Countries() ([]MoneroCountries, error)
|
||||
Countries() ([]Countries, error)
|
||||
Logs(q MoneroLogQueryParams) (MoneroNodeFetchLogs, error)
|
||||
}
|
||||
|
||||
|
@ -34,15 +35,15 @@ func NewMoneroRepo(db *database.DB) MoneroRepository {
|
|||
return &MoneroRepo{db}
|
||||
}
|
||||
|
||||
type MoneroNode struct {
|
||||
Id uint `json:"id,omitempty" db:"id"`
|
||||
type Node struct {
|
||||
ID uint `json:"id,omitempty" db:"id"`
|
||||
Hostname string `json:"hostname" db:"hostname"`
|
||||
Ip string `json:"ip" db:"ip_addr"`
|
||||
IP string `json:"ip" db:"ip_addr"`
|
||||
Port uint `json:"port" db:"port"`
|
||||
Protocol string `json:"protocol" db:"protocol"`
|
||||
IsTor bool `json:"is_tor" db:"is_tor"`
|
||||
IsAvailable bool `json:"is_available" db:"is_available"`
|
||||
NetType string `json:"nettype" db:"nettype"`
|
||||
Nettype string `json:"nettype" db:"nettype"`
|
||||
Height uint `json:"height" db:"height"`
|
||||
AdjustedTime uint `json:"adjusted_time" db:"adjusted_time"`
|
||||
DatabaseSize uint `json:"database_size" db:"database_size"`
|
||||
|
@ -51,22 +52,22 @@ type MoneroNode struct {
|
|||
Status string `json:"status,omitempty"`
|
||||
Uptime float64 `json:"uptime" db:"uptime"`
|
||||
EstimateFee uint `json:"estimate_fee" db:"estimate_fee"`
|
||||
Asn uint `json:"asn" db:"asn"`
|
||||
AsnName string `json:"asn_name" db:"asn_name"`
|
||||
ASN uint `json:"asn" db:"asn"`
|
||||
ASNName string `json:"asn_name" db:"asn_name"`
|
||||
CountryCode string `json:"cc" db:"country"`
|
||||
CountryName string `json:"country_name" db:"country_name"`
|
||||
City string `json:"city" db:"city"`
|
||||
Lat float64 `json:"latitude" db:"lat"`
|
||||
Lon float64 `json:"longitude" db:"lon"`
|
||||
Latitude float64 `json:"latitude" db:"lat"`
|
||||
Longitude float64 `json:"longitude" db:"lon"`
|
||||
DateEntered uint `json:"date_entered,omitempty" db:"date_entered"`
|
||||
LastChecked uint `json:"last_checked" db:"last_checked"`
|
||||
FailedCount uint `json:"failed_count,omitempty" db:"failed_count"`
|
||||
LastCheckStatus types.JSONText `json:"last_check_statuses" db:"last_check_status"`
|
||||
CorsCapable bool `json:"cors" db:"cors_capable"`
|
||||
CORSCapable bool `json:"cors" db:"cors_capable"`
|
||||
}
|
||||
|
||||
func (repo *MoneroRepo) Node(id int) (MoneroNode, error) {
|
||||
node := MoneroNode{}
|
||||
func (repo *MoneroRepo) Node(id int) (Node, error) {
|
||||
var node Node
|
||||
err := repo.db.Get(&node, `SELECT * FROM tbl_node WHERE id = ?`, id)
|
||||
if err != nil && err != sql.ErrNoRows {
|
||||
fmt.Println("WARN:", err)
|
||||
|
@ -78,26 +79,26 @@ func (repo *MoneroRepo) Node(id int) (MoneroNode, error) {
|
|||
return node, err
|
||||
}
|
||||
|
||||
type MoneroNodes struct {
|
||||
TotalRows int `json:"total_rows"`
|
||||
RowsPerPage int `json:"rows_per_page"`
|
||||
Items []*MoneroNode `json:"items"`
|
||||
type Nodes struct {
|
||||
TotalRows int `json:"total_rows"`
|
||||
RowsPerPage int `json:"rows_per_page"`
|
||||
Items []*Node `json:"items"`
|
||||
}
|
||||
|
||||
type MoneroQueryParams struct {
|
||||
Host string
|
||||
NetType string
|
||||
Nettype string
|
||||
Protocol string
|
||||
CC string // 2 letter country code
|
||||
Status int
|
||||
Cors int
|
||||
CORS int
|
||||
RowsPerPage int
|
||||
Page int
|
||||
SortBy string
|
||||
SortDirection string
|
||||
}
|
||||
|
||||
func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (MoneroNodes, error) {
|
||||
func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (Nodes, error) {
|
||||
queryParams := []interface{}{}
|
||||
whereQueries := []string{}
|
||||
where := ""
|
||||
|
@ -107,17 +108,17 @@ func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (MoneroNodes, error) {
|
|||
queryParams = append(queryParams, "%"+q.Host+"%")
|
||||
queryParams = append(queryParams, "%"+q.Host+"%")
|
||||
}
|
||||
if q.NetType != "any" {
|
||||
if q.NetType != "mainnet" && q.NetType != "stagenet" && q.NetType != "testnet" {
|
||||
return MoneroNodes{}, errors.New("Invalid nettype, must be one of 'mainnet', 'stagenet', 'testnet' or 'any'")
|
||||
if q.Nettype != "any" {
|
||||
if q.Nettype != "mainnet" && q.Nettype != "stagenet" && q.Nettype != "testnet" {
|
||||
return Nodes{}, errors.New("Invalid nettype, must be one of 'mainnet', 'stagenet', 'testnet' or 'any'")
|
||||
}
|
||||
whereQueries = append(whereQueries, "nettype = ?")
|
||||
queryParams = append(queryParams, q.NetType)
|
||||
queryParams = append(queryParams, q.Nettype)
|
||||
}
|
||||
if q.Protocol != "any" {
|
||||
allowedProtocols := []string{"tor", "http", "https"}
|
||||
if !slices.Contains(allowedProtocols, q.Protocol) {
|
||||
return MoneroNodes{}, errors.New("Invalid protocol, must be one of '" + strings.Join(allowedProtocols, "', '") + "' or 'any'")
|
||||
return Nodes{}, errors.New("Invalid protocol, must be one of '" + strings.Join(allowedProtocols, "', '") + "' or 'any'")
|
||||
}
|
||||
if q.Protocol == "tor" {
|
||||
whereQueries = append(whereQueries, "is_tor = ?")
|
||||
|
@ -140,7 +141,7 @@ func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (MoneroNodes, error) {
|
|||
whereQueries = append(whereQueries, "is_available = ?")
|
||||
queryParams = append(queryParams, q.Status)
|
||||
}
|
||||
if q.Cors != -1 {
|
||||
if q.CORS != -1 {
|
||||
whereQueries = append(whereQueries, "cors_capable = ?")
|
||||
queryParams = append(queryParams, 1)
|
||||
}
|
||||
|
@ -149,7 +150,7 @@ func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (MoneroNodes, error) {
|
|||
where = "WHERE " + strings.Join(whereQueries, " AND ")
|
||||
}
|
||||
|
||||
nodes := MoneroNodes{}
|
||||
nodes := Nodes{}
|
||||
|
||||
queryTotalRows := fmt.Sprintf(`
|
||||
SELECT
|
||||
|
@ -220,15 +221,15 @@ func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (MoneroNodes, error) {
|
|||
nodes.RowsPerPage = q.RowsPerPage
|
||||
|
||||
for row.Next() {
|
||||
node := MoneroNode{}
|
||||
var node Node
|
||||
err = row.Scan(
|
||||
&node.Id,
|
||||
&node.ID,
|
||||
&node.Protocol,
|
||||
&node.Hostname,
|
||||
&node.Port,
|
||||
&node.IsTor,
|
||||
&node.IsAvailable,
|
||||
&node.NetType,
|
||||
&node.Nettype,
|
||||
&node.Height,
|
||||
&node.AdjustedTime,
|
||||
&node.DatabaseSize,
|
||||
|
@ -236,18 +237,18 @@ func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (MoneroNodes, error) {
|
|||
&node.Version,
|
||||
&node.Uptime,
|
||||
&node.EstimateFee,
|
||||
&node.Ip,
|
||||
&node.Asn,
|
||||
&node.AsnName,
|
||||
&node.IP,
|
||||
&node.ASN,
|
||||
&node.ASNName,
|
||||
&node.CountryCode,
|
||||
&node.CountryName,
|
||||
&node.City,
|
||||
&node.Lat,
|
||||
&node.Lon,
|
||||
&node.Latitude,
|
||||
&node.Longitude,
|
||||
&node.DateEntered,
|
||||
&node.LastChecked,
|
||||
&node.LastCheckStatus,
|
||||
&node.CorsCapable)
|
||||
&node.CORSCapable)
|
||||
if err != nil {
|
||||
return nodes, err
|
||||
}
|
||||
|
@ -258,8 +259,8 @@ func (repo *MoneroRepo) Nodes(q MoneroQueryParams) (MoneroNodes, error) {
|
|||
}
|
||||
|
||||
type MoneroLogQueryParams struct {
|
||||
NodeId int // 0 fpr all, >0 for specific node
|
||||
WorkerId int // 0 for all, >0 for specific worker
|
||||
NodeID int // 0 fpr all, >0 for specific node
|
||||
WorkerID int // 0 for all, >0 for specific worker
|
||||
Status int // -1 for all, 0 for failed, 1 for success
|
||||
FailedReason string // empty for all, if not empty, will be used as search from failed_reaso
|
||||
|
||||
|
@ -270,9 +271,9 @@ type MoneroLogQueryParams struct {
|
|||
}
|
||||
|
||||
type ProbeLog struct {
|
||||
Id int `db:"id" json:"id,omitempty"`
|
||||
NodeId int `db:"node_id" json:"node_id"`
|
||||
ProberId int `db:"prober_id" json:"prober_id"`
|
||||
ID int `db:"id" json:"id,omitempty"`
|
||||
NodeID int `db:"node_id" json:"node_id"`
|
||||
ProberID int `db:"prober_id" json:"prober_id"`
|
||||
Status int `db:"is_available" json:"status"`
|
||||
Height int `db:"height" json:"height"`
|
||||
AdjustedTime int `db:"adjusted_time" json:"adjusted_time"`
|
||||
|
@ -295,9 +296,9 @@ func (repo *MoneroRepo) Logs(q MoneroLogQueryParams) (MoneroNodeFetchLogs, error
|
|||
whereQueries := []string{}
|
||||
where := ""
|
||||
|
||||
if q.NodeId != 0 {
|
||||
if q.NodeID != 0 {
|
||||
whereQueries = append(whereQueries, "node_id = ?")
|
||||
queryParams = append(queryParams, q.NodeId)
|
||||
queryParams = append(queryParams, q.NodeID)
|
||||
}
|
||||
if q.Status != -1 {
|
||||
whereQueries = append(whereQueries, "is_available = ?")
|
||||
|
@ -365,9 +366,9 @@ func (repo *MoneroRepo) Logs(q MoneroLogQueryParams) (MoneroNodeFetchLogs, error
|
|||
for row.Next() {
|
||||
probeLog := ProbeLog{}
|
||||
err = row.Scan(
|
||||
&probeLog.Id,
|
||||
&probeLog.NodeId,
|
||||
&probeLog.ProberId,
|
||||
&probeLog.ID,
|
||||
&probeLog.NodeID,
|
||||
&probeLog.ProberID,
|
||||
&probeLog.Status,
|
||||
&probeLog.Height,
|
||||
&probeLog.AdjustedTime,
|
||||
|
@ -496,7 +497,7 @@ func (repo *MoneroRepo) Delete(id uint) error {
|
|||
return nil
|
||||
}
|
||||
|
||||
func (repo *MoneroRepo) GiveJob(acceptTor int) (MoneroNode, error) {
|
||||
func (repo *MoneroRepo) GiveJob(acceptTor int) (Node, error) {
|
||||
queryParams := []interface{}{}
|
||||
whereQueries := []string{}
|
||||
where := ""
|
||||
|
@ -510,7 +511,7 @@ func (repo *MoneroRepo) GiveJob(acceptTor int) (MoneroNode, error) {
|
|||
where = "WHERE " + strings.Join(whereQueries, " AND ")
|
||||
}
|
||||
|
||||
node := MoneroNode{}
|
||||
var node Node
|
||||
|
||||
query := fmt.Sprintf(`
|
||||
SELECT
|
||||
|
@ -527,7 +528,7 @@ func (repo *MoneroRepo) GiveJob(acceptTor int) (MoneroNode, error) {
|
|||
last_checked ASC
|
||||
LIMIT 1`, where)
|
||||
err := repo.db.QueryRow(query, queryParams...).Scan(
|
||||
&node.Id,
|
||||
&node.ID,
|
||||
&node.Hostname,
|
||||
&node.Port,
|
||||
&node.Protocol,
|
||||
|
@ -540,7 +541,7 @@ func (repo *MoneroRepo) GiveJob(acceptTor int) (MoneroNode, error) {
|
|||
_, err = repo.db.Exec(`
|
||||
UPDATE tbl_node
|
||||
SET last_checked = ?
|
||||
WHERE id = ?`, time.Now().Unix(), node.Id)
|
||||
WHERE id = ?`, time.Now().Unix(), node.ID)
|
||||
if err != nil {
|
||||
return node, err
|
||||
}
|
||||
|
@ -549,13 +550,13 @@ func (repo *MoneroRepo) GiveJob(acceptTor int) (MoneroNode, error) {
|
|||
}
|
||||
|
||||
type ProbeReport struct {
|
||||
TookTime float64 `json:"took_time"`
|
||||
Message string `json:"message"`
|
||||
NodeInfo MoneroNode `json:"node_info"`
|
||||
TookTime float64 `json:"took_time"`
|
||||
Message string `json:"message"`
|
||||
NodeInfo Node `json:"node_info"`
|
||||
}
|
||||
|
||||
func (repo *MoneroRepo) ProcessJob(report ProbeReport, proberId int64) error {
|
||||
if report.NodeInfo.Id == 0 {
|
||||
if report.NodeInfo.ID == 0 {
|
||||
return errors.New("Invalid node")
|
||||
}
|
||||
|
||||
|
@ -586,7 +587,7 @@ func (repo *MoneroRepo) ProcessJob(report ProbeReport, proberId int64) error {
|
|||
?
|
||||
)`
|
||||
_, err := repo.db.Exec(qInsertLog,
|
||||
report.NodeInfo.Id,
|
||||
report.NodeInfo.ID,
|
||||
proberId,
|
||||
report.NodeInfo.IsAvailable,
|
||||
report.NodeInfo.Height,
|
||||
|
@ -620,7 +621,7 @@ func (repo *MoneroRepo) ProcessJob(report ProbeReport, proberId int64) error {
|
|||
WHERE
|
||||
node_id = ?
|
||||
AND date_checked > ?`
|
||||
repo.db.Get(&nodeStats, qstats, report.NodeInfo.Id, limitTs)
|
||||
repo.db.Get(&nodeStats, qstats, report.NodeInfo.ID, limitTs)
|
||||
|
||||
avgUptime := (float64(nodeStats.OnlineCount) / float64(nodeStats.TotalFetched)) * 100
|
||||
report.NodeInfo.Uptime = math.Ceil(avgUptime*100) / 100
|
||||
|
@ -645,17 +646,17 @@ func (repo *MoneroRepo) ProcessJob(report ProbeReport, proberId int64) error {
|
|||
}
|
||||
|
||||
// recheck IP
|
||||
if report.NodeInfo.Ip != "" {
|
||||
if ipInfo, errGeoIp := GetGeoIpInfo(report.NodeInfo.Ip); errGeoIp != nil {
|
||||
if report.NodeInfo.IP != "" {
|
||||
if ipInfo, errGeoIp := geo.IpInfo(report.NodeInfo.IP); errGeoIp != nil {
|
||||
fmt.Println("WARN:", errGeoIp.Error())
|
||||
} else {
|
||||
report.NodeInfo.Asn = ipInfo.Asn
|
||||
report.NodeInfo.AsnName = ipInfo.AsnOrg
|
||||
report.NodeInfo.ASN = ipInfo.Asn
|
||||
report.NodeInfo.ASNName = ipInfo.AsnOrg
|
||||
report.NodeInfo.CountryCode = ipInfo.CountryCode
|
||||
report.NodeInfo.CountryName = ipInfo.CountryName
|
||||
report.NodeInfo.City = ipInfo.City
|
||||
report.NodeInfo.Lon = ipInfo.Longitude
|
||||
report.NodeInfo.Lat = ipInfo.Latitude
|
||||
report.NodeInfo.Longitude = ipInfo.Longitude
|
||||
report.NodeInfo.Latitude = ipInfo.Latitude
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -685,7 +686,7 @@ func (repo *MoneroRepo) ProcessJob(report ProbeReport, proberId int64) error {
|
|||
id = ?`
|
||||
_, err = repo.db.Exec(update,
|
||||
nodeAvailable,
|
||||
report.NodeInfo.NetType,
|
||||
report.NodeInfo.Nettype,
|
||||
report.NodeInfo.Height,
|
||||
report.NodeInfo.AdjustedTime,
|
||||
report.NodeInfo.DatabaseSize,
|
||||
|
@ -693,16 +694,16 @@ func (repo *MoneroRepo) ProcessJob(report ProbeReport, proberId int64) error {
|
|||
report.NodeInfo.Version,
|
||||
report.NodeInfo.Uptime,
|
||||
report.NodeInfo.EstimateFee,
|
||||
report.NodeInfo.Ip,
|
||||
report.NodeInfo.Asn,
|
||||
report.NodeInfo.AsnName,
|
||||
report.NodeInfo.IP,
|
||||
report.NodeInfo.ASN,
|
||||
report.NodeInfo.ASNName,
|
||||
report.NodeInfo.CountryCode,
|
||||
report.NodeInfo.CountryName,
|
||||
report.NodeInfo.City,
|
||||
now.Unix(),
|
||||
string(statuesValueToDb),
|
||||
report.NodeInfo.CorsCapable,
|
||||
report.NodeInfo.Id)
|
||||
report.NodeInfo.CORSCapable,
|
||||
report.NodeInfo.ID)
|
||||
} else {
|
||||
update := `
|
||||
UPDATE tbl_node
|
||||
|
@ -713,12 +714,12 @@ func (repo *MoneroRepo) ProcessJob(report ProbeReport, proberId int64) error {
|
|||
last_check_status = ?
|
||||
WHERE
|
||||
id = ?`
|
||||
_, err = repo.db.Exec(update, nodeAvailable, report.NodeInfo.Uptime, now.Unix(), string(statuesValueToDb), report.NodeInfo.Id)
|
||||
_, err = repo.db.Exec(update, nodeAvailable, report.NodeInfo.Uptime, now.Unix(), string(statuesValueToDb), report.NodeInfo.ID)
|
||||
}
|
||||
|
||||
if avgUptime <= 0 && nodeStats.TotalFetched > 300 {
|
||||
fmt.Println("Deleting Monero node (0% uptime from > 300 records)")
|
||||
repo.Delete(report.NodeInfo.Id)
|
||||
repo.Delete(report.NodeInfo.ID)
|
||||
}
|
||||
|
||||
repo.db.Exec(`
|
||||
|
@ -765,14 +766,14 @@ func (repo *MoneroRepo) NetFee() []NetFee {
|
|||
return netFees
|
||||
}
|
||||
|
||||
type MoneroCountries struct {
|
||||
type Countries struct {
|
||||
TotalNodes int `json:"total_nodes" db:"total_nodes"`
|
||||
Cc string `json:"cc" db:"country"`
|
||||
CC string `json:"cc" db:"country"` // country code
|
||||
Name string `json:"name" db:"country_name"`
|
||||
}
|
||||
|
||||
func (repo *MoneroRepo) Countries() ([]MoneroCountries, error) {
|
||||
countries := []MoneroCountries{}
|
||||
func (repo *MoneroRepo) Countries() ([]Countries, error) {
|
||||
countries := []Countries{}
|
||||
err := repo.db.Select(&countries, `
|
||||
SELECT
|
||||
COUNT(id) AS total_nodes,
|
|
@ -1,4 +1,4 @@
|
|||
package repo
|
||||
package monero
|
||||
|
||||
import (
|
||||
"fmt"
|
Loading…
Reference in a new issue