Versions in this module Expand all Collapse all v1 v1.0.6 Apr 12, 2022 Changes in this version + type BalanceTracker struct + func NewBalanceTracker(ns *nodestate.NodeStateMachine, setup BalanceTrackerSetup, ...) *BalanceTracker + func (bt *BalanceTracker) GetExpirationTCs() (pos, neg uint64) + func (bt *BalanceTracker) GetPosBalanceIDs(start, stop enode.ID, maxCount int) (result []enode.ID) + func (bt *BalanceTracker) SetExpirationTCs(pos, neg uint64) + func (bt *BalanceTracker) Stop() + func (bt *BalanceTracker) TotalTokenAmount() uint64 + type BalanceTrackerSetup struct + BalanceField nodestate.Field + PriorityFlag nodestate.Flags + UpdateFlag nodestate.Flags + func NewBalanceTrackerSetup(setup *nodestate.Setup) BalanceTrackerSetup + func (bts *BalanceTrackerSetup) Connect(connAddressField, capacityField nodestate.Field) + type CapacityCurve struct + func (cc *CapacityCurve) Exclude(id enode.ID) *CapacityCurve + func (cc *CapacityCurve) MaxCapacity(priority func(cap uint64) int64) uint64 + type NodeBalance struct + func (n *NodeBalance) AddBalance(amount int64) (uint64, uint64, error) + func (n *NodeBalance) EstimatePriority(capacity uint64, addBalance int64, future, bias time.Duration, update bool) int64 + func (n *NodeBalance) GetBalance() (uint64, uint64) + func (n *NodeBalance) GetPriceFactors() (posFactor, negFactor PriceFactors) + func (n *NodeBalance) GetRawBalance() (utils.ExpiredValue, utils.ExpiredValue) + func (n *NodeBalance) PosBalanceMissing(targetPriority int64, targetCapacity uint64, after time.Duration) uint64 + func (n *NodeBalance) Priority(capacity uint64) int64 + func (n *NodeBalance) RequestServed(cost uint64) uint64 + func (n *NodeBalance) SetBalance(pos, neg uint64) error + func (n *NodeBalance) SetPriceFactors(posFactor, negFactor PriceFactors) + type PriceFactors struct + CapacityFactor float64 + RequestFactor float64 + TimeFactor float64 + type PriorityPool struct + func NewPriorityPool(ns *nodestate.NodeStateMachine, setup PriorityPoolSetup, clock mclock.Clock, ...) *PriorityPool + func (pp *PriorityPool) Active() (uint64, uint64) + func (pp *PriorityPool) GetCapacityCurve() *CapacityCurve + func (pp *PriorityPool) RequestCapacity(node *enode.Node, targetCap uint64, bias time.Duration, setCap bool) (minPriority int64, allowed bool) + func (pp *PriorityPool) SetActiveBias(bias time.Duration) + func (pp *PriorityPool) SetLimits(maxCount, maxCap uint64) + type PriorityPoolSetup struct + ActiveFlag nodestate.Flags + CapacityField nodestate.Field + InactiveFlag nodestate.Flags + func NewPriorityPoolSetup(setup *nodestate.Setup) PriorityPoolSetup + func (pps *PriorityPoolSetup) Connect(priorityField nodestate.Field, updateFlag nodestate.Flags) + type Server struct + func NewServer(delayPerRequest time.Duration) *Server + func (s *Server) Register(b Service) + func (s *Server) Serve(id enode.ID, address string, requests vflux.Requests) vflux.Replies + func (s *Server) ServeEncoded(id enode.ID, addr *net.UDPAddr, req []byte) []byte + func (s *Server) Stop() + type Service interface + Handle func(id enode.ID, address string, name string, data []byte) []byte + ServiceInfo func() (id, desc string)