2021-02-01 16:17:16 +00:00
|
|
|
package basic
|
|
|
|
|
|
|
|
import (
|
2021-02-02 13:45:13 +00:00
|
|
|
"math/big"
|
2021-02-01 16:17:16 +00:00
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/mr-tron/base58"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/encoding/address"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/util"
|
|
|
|
"github.com/nspcc-dev/neofs-api-go/pkg/owner"
|
|
|
|
"github.com/nspcc-dev/neofs-node/pkg/innerring/processors/settlement/common"
|
|
|
|
"github.com/nspcc-dev/neofs-node/pkg/morph/client/container/wrapper"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
)
|
|
|
|
|
|
|
|
type (
|
|
|
|
EstimationFetcher interface {
|
|
|
|
Estimations(uint64) ([]*wrapper.Estimations, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
RateFetcher interface {
|
2021-02-02 11:12:41 +00:00
|
|
|
BasicRate() (uint64, error)
|
2021-02-01 16:17:16 +00:00
|
|
|
}
|
|
|
|
|
2021-02-02 13:45:13 +00:00
|
|
|
// BalanceFetcher uses NEP-17 compatible balance contract
|
|
|
|
BalanceFetcher interface {
|
|
|
|
Balance(id *owner.ID) (*big.Int, error)
|
|
|
|
}
|
|
|
|
|
2021-02-01 16:17:16 +00:00
|
|
|
IncomeSettlementContext struct {
|
|
|
|
mu sync.Mutex // lock to prevent collection and distribution in the same time
|
|
|
|
|
|
|
|
log *zap.Logger
|
|
|
|
epoch uint64
|
|
|
|
|
|
|
|
rate RateFetcher
|
|
|
|
estimations EstimationFetcher
|
2021-02-02 13:45:13 +00:00
|
|
|
balances BalanceFetcher
|
2021-02-01 16:17:16 +00:00
|
|
|
container common.ContainerStorage
|
|
|
|
placement common.PlacementCalculator
|
|
|
|
exchange common.Exchanger
|
2021-02-02 17:23:01 +00:00
|
|
|
accounts common.AccountStorage
|
2021-02-01 16:17:16 +00:00
|
|
|
|
|
|
|
bankOwner *owner.ID
|
2021-02-02 17:23:01 +00:00
|
|
|
|
|
|
|
// this table is not thread safe, make sure you use it with mu.Lock()
|
|
|
|
distributeTable *NodeSizeTable
|
2021-02-01 16:17:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
IncomeSettlementContextPrms struct {
|
|
|
|
Log *zap.Logger
|
|
|
|
Epoch uint64
|
|
|
|
Rate RateFetcher
|
|
|
|
Estimations EstimationFetcher
|
2021-02-02 13:45:13 +00:00
|
|
|
Balances BalanceFetcher
|
2021-02-01 16:17:16 +00:00
|
|
|
Container common.ContainerStorage
|
|
|
|
Placement common.PlacementCalculator
|
|
|
|
Exchange common.Exchanger
|
2021-02-02 17:23:01 +00:00
|
|
|
Accounts common.AccountStorage
|
2021-02-01 16:17:16 +00:00
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
func NewIncomeSettlementContext(p *IncomeSettlementContextPrms) (*IncomeSettlementContext, error) {
|
|
|
|
bankingAccount, err := bankOwnerID()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err // should never happen
|
|
|
|
}
|
|
|
|
|
|
|
|
return &IncomeSettlementContext{
|
2021-02-02 17:23:01 +00:00
|
|
|
log: p.Log,
|
|
|
|
epoch: p.Epoch,
|
|
|
|
rate: p.Rate,
|
|
|
|
estimations: p.Estimations,
|
|
|
|
balances: p.Balances,
|
|
|
|
container: p.Container,
|
|
|
|
placement: p.Placement,
|
|
|
|
exchange: p.Exchange,
|
|
|
|
accounts: p.Accounts,
|
|
|
|
bankOwner: bankingAccount,
|
|
|
|
distributeTable: NewNodeSizeTable(),
|
2021-02-01 16:17:16 +00:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func bankOwnerID() (*owner.ID, error) {
|
|
|
|
u := util.Uint160{1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // todo: define const
|
|
|
|
1, 1, 1, 1, 1, 1, 1, 1, 1, 1}
|
|
|
|
|
|
|
|
d, err := base58.Decode(address.Uint160ToString(u))
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var w owner.NEO3Wallet
|
|
|
|
copy(w[:], d)
|
|
|
|
|
|
|
|
o := owner.NewID()
|
|
|
|
o.SetNeo3Wallet(&w)
|
|
|
|
|
|
|
|
return o, nil
|
|
|
|
}
|