Skip to content

Commit

Permalink
feat: add reserveSizeWithinRadius to status protocol
Browse files Browse the repository at this point in the history
  • Loading branch information
acha-bill committed Feb 19, 2024
1 parent 4950c31 commit a239d3d
Show file tree
Hide file tree
Showing 6 changed files with 144 additions and 76 deletions.
43 changes: 23 additions & 20 deletions pkg/api/status.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,17 +17,18 @@ import (
)

type statusSnapshotResponse struct {
Peer string `json:"peer"`
Proximity uint8 `json:"proximity"`
BeeMode string `json:"beeMode"`
ReserveSize uint64 `json:"reserveSize"`
PullsyncRate float64 `json:"pullsyncRate"`
StorageRadius uint8 `json:"storageRadius"`
ConnectedPeers uint64 `json:"connectedPeers"`
NeighborhoodSize uint64 `json:"neighborhoodSize"`
RequestFailed bool `json:"requestFailed,omitempty"`
BatchCommitment uint64 `json:"batchCommitment"`
IsReachable bool `json:"isReachable"`
Peer string `json:"peer"`
Proximity uint8 `json:"proximity"`
BeeMode string `json:"beeMode"`
ReserveSize uint64 `json:"reserveSize"`
ReserveSizeWithinRadius uint64 `json:"reserveSizeWithinRadius"`
PullsyncRate float64 `json:"pullsyncRate"`
StorageRadius uint8 `json:"storageRadius"`
ConnectedPeers uint64 `json:"connectedPeers"`
NeighborhoodSize uint64 `json:"neighborhoodSize"`
RequestFailed bool `json:"requestFailed,omitempty"`
BatchCommitment uint64 `json:"batchCommitment"`
IsReachable bool `json:"isReachable"`
}

type statusResponse struct {
Expand Down Expand Up @@ -70,15 +71,16 @@ func (s *Service) statusGetHandler(w http.ResponseWriter, _ *http.Request) {
}

jsonhttp.OK(w, statusSnapshotResponse{
Peer: s.overlay.String(),
BeeMode: ss.BeeMode,
ReserveSize: ss.ReserveSize,
PullsyncRate: ss.PullsyncRate,
StorageRadius: uint8(ss.StorageRadius),
ConnectedPeers: ss.ConnectedPeers,
NeighborhoodSize: ss.NeighborhoodSize,
BatchCommitment: ss.BatchCommitment,
IsReachable: ss.IsReachable,
Peer: s.overlay.String(),
BeeMode: ss.BeeMode,
ReserveSize: ss.ReserveSize,
ReserveSizeWithinRadius: ss.ReserveSizeWithinRadius,
PullsyncRate: ss.PullsyncRate,
StorageRadius: uint8(ss.StorageRadius),
ConnectedPeers: ss.ConnectedPeers,
NeighborhoodSize: ss.NeighborhoodSize,
BatchCommitment: ss.BatchCommitment,
IsReachable: ss.IsReachable,
})
}

Expand Down Expand Up @@ -118,6 +120,7 @@ func (s *Service) statusGetPeersHandler(w http.ResponseWriter, r *http.Request)
} else {
snapshot.BeeMode = ss.BeeMode
snapshot.ReserveSize = ss.ReserveSize
snapshot.ReserveSizeWithinRadius = ss.ReserveSizeWithinRadius
snapshot.PullsyncRate = ss.PullsyncRate
snapshot.StorageRadius = uint8(ss.StorageRadius)
snapshot.ConnectedPeers = ss.ConnectedPeers
Expand Down
38 changes: 22 additions & 16 deletions pkg/api/status_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,21 +26,23 @@ func TestGetStatus(t *testing.T) {

mode := api.FullMode
ssr := api.StatusSnapshotResponse{
BeeMode: mode.String(),
ReserveSize: 128,
PullsyncRate: 64,
StorageRadius: 8,
ConnectedPeers: 0,
NeighborhoodSize: 0,
BatchCommitment: 1,
IsReachable: true,
BeeMode: mode.String(),
ReserveSize: 128,
ReserveSizeWithinRadius: 64,
PullsyncRate: 64,
StorageRadius: 8,
ConnectedPeers: 0,
NeighborhoodSize: 0,
BatchCommitment: 1,
IsReachable: true,
}

ssMock := &statusSnapshotMock{
syncRate: ssr.PullsyncRate,
reserveSize: int(ssr.ReserveSize),
storageRadius: ssr.StorageRadius,
commitment: ssr.BatchCommitment,
syncRate: ssr.PullsyncRate,
reserveSize: int(ssr.ReserveSize),
reserveSizeWithinRadius: ssr.ReserveSizeWithinRadius,
storageRadius: ssr.StorageRadius,
commitment: ssr.BatchCommitment,
}

statusSvc := status.NewService(
Expand Down Expand Up @@ -109,13 +111,17 @@ func (m *topologyPeersIterNoopMock) IsReachable() bool {
// - status.SyncReporter
// - postage.CommitmentGetter
type statusSnapshotMock struct {
syncRate float64
reserveSize int
storageRadius uint8
commitment uint64
syncRate float64
reserveSize int
reserveSizeWithinRadius uint64
storageRadius uint8
commitment uint64
}

func (m *statusSnapshotMock) SyncRate() float64 { return m.syncRate }
func (m *statusSnapshotMock) ReserveSize() int { return m.reserveSize }
func (m *statusSnapshotMock) StorageRadius() uint8 { return m.storageRadius }
func (m *statusSnapshotMock) Commitment() (uint64, error) { return m.commitment, nil }
func (m *statusSnapshotMock) ReserveSizeWithinRadius(uint8) (uint64, error) {
return m.reserveSizeWithinRadius, nil
}
90 changes: 63 additions & 27 deletions pkg/status/internal/pb/status.pb.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions pkg/status/internal/pb/status.proto
Original file line number Diff line number Diff line change
Expand Up @@ -23,4 +23,5 @@ message Snapshot {
string BeeMode = 6;
uint64 BatchCommitment = 7;
bool IsReachable = 8;
uint64 ReserveSizeWithinRadius = 9;
}
34 changes: 21 additions & 13 deletions pkg/status/status.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ type SyncReporter interface {
// Reserve defines the reserve storage related information required.
type Reserve interface {
ReserveSize() int
ReserveSizeWithinRadius(uint8) (uint64, error)
StorageRadius() uint8
}

Expand Down Expand Up @@ -79,16 +80,22 @@ func NewService(
// LocalSnapshot returns the current status snapshot of this node.
func (s *Service) LocalSnapshot() (*Snapshot, error) {
var (
storageRadius uint8
syncRate float64
reserveSize uint64
connectedPeers uint64
neighborhoodSize uint64
storageRadius uint8
syncRate float64
reserveSize uint64
reserveSizeWithinRadius uint64
connectedPeers uint64
neighborhoodSize uint64
)

if s.reserve != nil {
storageRadius = s.reserve.StorageRadius()
reserveSize = uint64(s.reserve.ReserveSize())
sizeWithinRadius, err := s.reserve.ReserveSizeWithinRadius(storageRadius)
if err != nil {
return nil, fmt.Errorf("reserve size within radius: %w", err)
}
reserveSizeWithinRadius = sizeWithinRadius
}

if s.sync != nil {
Expand All @@ -115,14 +122,15 @@ func (s *Service) LocalSnapshot() (*Snapshot, error) {
}

return &Snapshot{
BeeMode: s.beeMode,
ReserveSize: reserveSize,
PullsyncRate: syncRate,
StorageRadius: uint32(storageRadius),
ConnectedPeers: connectedPeers,
NeighborhoodSize: neighborhoodSize,
BatchCommitment: commitment,
IsReachable: s.topologyDriver.IsReachable(),
BeeMode: s.beeMode,
ReserveSize: reserveSize,
ReserveSizeWithinRadius: reserveSizeWithinRadius,
PullsyncRate: syncRate,
StorageRadius: uint32(storageRadius),
ConnectedPeers: connectedPeers,
NeighborhoodSize: neighborhoodSize,
BatchCommitment: commitment,
IsReachable: s.topologyDriver.IsReachable(),
}, nil
}

Expand Down
14 changes: 14 additions & 0 deletions pkg/storer/reserve.go
Original file line number Diff line number Diff line change
Expand Up @@ -474,6 +474,20 @@ func (db *DB) ReserveSize() int {
return db.reserve.Size()
}

func (db *DB) ReserveSizeWithinRadius(radius uint8) (uint64, error) {
var count uint64
err := db.reserve.IterateChunksItems(db.repo, 0, func(ci reserve.ChunkItem) (bool, error) {
if ci.Bin >= radius {
count++
}
return false, nil
})
if err != nil {
return 0, err
}
return count, nil
}

func (db *DB) IsWithinStorageRadius(addr swarm.Address) bool {
if db.reserve == nil {
return false
Expand Down

0 comments on commit a239d3d

Please sign in to comment.