4c704ea9a4
Change-Id: Ibb049c0ad9b09dd89852234b601d7577735c4d34
87 lines
2.8 KiB
Go
87 lines
2.8 KiB
Go
// Copyright (C) 2020 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package nodes
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/zeebo/errs"
|
|
|
|
"storj.io/common/storj"
|
|
)
|
|
|
|
// DB exposes needed by MND NodesDB functionality.
|
|
//
|
|
// architecture: Database
|
|
type DB interface {
|
|
// Get return node from NodesDB by its id.
|
|
Get(ctx context.Context, id storj.NodeID) (Node, error)
|
|
// List returns all connected nodes.
|
|
List(ctx context.Context) ([]Node, error)
|
|
// ListPaged returns paginated nodes list.
|
|
ListPaged(ctx context.Context, cursor Cursor) (page Page, err error)
|
|
// Add creates new node in NodesDB.
|
|
// TODO: pass Node entity instead of set of a parameters.
|
|
Add(ctx context.Context, id storj.NodeID, apiSecret []byte, publicAddress string) error
|
|
// Remove removed node from NodesDB.
|
|
Remove(ctx context.Context, id storj.NodeID) error
|
|
// UpdateName will update name of the specified node in database.
|
|
UpdateName(ctx context.Context, id storj.NodeID, name string) error
|
|
}
|
|
|
|
// ErrNoNode is a special error type that indicates about absence of node in NodesDB.
|
|
var ErrNoNode = errs.Class("no such node")
|
|
|
|
// Node is a representation of storagenode, that SNO could add to the Multinode Dashboard.
|
|
type Node struct {
|
|
ID storj.NodeID `json:"id"`
|
|
// APISecret is a secret issued by storagenode, that will be main auth mechanism in MND <-> SNO api.
|
|
APISecret []byte `json:"apiSecret"`
|
|
PublicAddress string `json:"publicAddress"`
|
|
Name string `json:"name"`
|
|
}
|
|
|
|
// NodeInfo contains basic node internal state.
|
|
type NodeInfo struct {
|
|
ID storj.NodeID `json:"id"`
|
|
Name string `json:"name"`
|
|
Version string `json:"version"`
|
|
LastContact time.Time `json:"lastContact"`
|
|
DiskSpaceUsed int64 `json:"diskSpaceUsed"`
|
|
DiskSpaceLeft int64 `json:"diskSpaceLeft"`
|
|
BandwidthUsed int64 `json:"bandwidthUsed"`
|
|
TotalEarned int64 `json:"totalEarned"`
|
|
}
|
|
|
|
// NodeInfoSatellite contains satellite specific node internal state.
|
|
type NodeInfoSatellite struct {
|
|
ID storj.NodeID `json:"id"`
|
|
Name string `json:"name"`
|
|
Version string `json:"version"`
|
|
LastContact time.Time `json:"lastContact"`
|
|
OnlineScore float64 `json:"onlineScore"`
|
|
AuditScore float64 `json:"auditScore"`
|
|
SuspensionScore float64 `json:"suspensionScore"`
|
|
TotalEarned int64 `json:"totalEarned"`
|
|
}
|
|
|
|
// TODO: separate common types and logic from nodes and operators and place it in private/pkg.
|
|
|
|
// Cursor holds cursor entity which is used to create listed page.
|
|
type Cursor struct {
|
|
Limit uint64
|
|
Page uint64
|
|
}
|
|
|
|
// Page holds nodes page entity which is used to show listed page of nodes.
|
|
type Page struct {
|
|
Nodes []Node
|
|
Limit uint64
|
|
Offset uint64
|
|
PageCount uint64
|
|
CurrentPage uint64
|
|
TotalCount uint64
|
|
}
|