2020-03-12 14:42:01 +00:00
|
|
|
// Copyright (C) 2020 Storj Labs, Inc.
|
|
|
|
// See LICENSE for copying information.
|
|
|
|
|
2020-09-10 15:08:25 +01:00
|
|
|
package payout
|
2020-03-12 14:42:01 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"time"
|
|
|
|
|
2020-03-16 04:28:03 +00:00
|
|
|
"github.com/zeebo/errs"
|
|
|
|
|
2020-03-12 14:42:01 +00:00
|
|
|
"storj.io/common/storj"
|
|
|
|
)
|
|
|
|
|
2020-09-10 15:08:25 +01:00
|
|
|
// DB works with payout database
|
2020-03-12 14:42:01 +00:00
|
|
|
//
|
|
|
|
// architecture: Database
|
|
|
|
type DB interface {
|
2020-09-08 16:15:08 +01:00
|
|
|
// StorePayStub inserts or updates paystub into the DB.
|
2020-03-12 14:42:01 +00:00
|
|
|
StorePayStub(ctx context.Context, paystub PayStub) error
|
2020-09-08 16:15:08 +01:00
|
|
|
// GetPayStub retrieves paystub for specific satellite and period.
|
2020-03-12 14:42:01 +00:00
|
|
|
GetPayStub(ctx context.Context, satelliteID storj.NodeID, period string) (*PayStub, error)
|
2020-09-08 16:15:08 +01:00
|
|
|
// AllPayStubs retrieves paystubs from all satellites in specific period from DB.
|
2020-03-12 14:42:01 +00:00
|
|
|
AllPayStubs(ctx context.Context, period string) ([]PayStub, error)
|
2020-04-28 14:07:50 +01:00
|
|
|
// SatellitesHeldbackHistory retrieves heldback history for specific satellite from DB.
|
2020-09-10 15:08:25 +01:00
|
|
|
SatellitesHeldbackHistory(ctx context.Context, satelliteID storj.NodeID) ([]HoldForPeriod, error)
|
2020-06-24 16:57:22 +01:00
|
|
|
// SatellitesDisposedHistory returns all disposed amount for specific satellite from DB.
|
|
|
|
SatellitesDisposedHistory(ctx context.Context, satelliteID storj.NodeID) (int64, error)
|
2020-09-10 15:08:25 +01:00
|
|
|
// SatellitePeriods retrieves all periods for concrete satellite in which we have some payout data.
|
2020-05-18 19:37:16 +01:00
|
|
|
SatellitePeriods(ctx context.Context, satelliteID storj.NodeID) ([]string, error)
|
2020-09-10 15:08:25 +01:00
|
|
|
// AllPeriods retrieves all periods in which we have some payout data.
|
2020-05-18 19:37:16 +01:00
|
|
|
AllPeriods(ctx context.Context) ([]string, error)
|
2020-06-24 18:05:43 +01:00
|
|
|
// StorePayment inserts or updates payment into the DB
|
|
|
|
StorePayment(ctx context.Context, payment Payment) error
|
2020-09-08 16:15:08 +01:00
|
|
|
// GetReceipt retrieves receipt for specific satellite and period.
|
|
|
|
GetReceipt(ctx context.Context, satelliteID storj.NodeID, period string) (string, error)
|
2020-03-12 14:42:01 +00:00
|
|
|
}
|
|
|
|
|
2020-09-10 15:08:25 +01:00
|
|
|
// ErrNoPayStubForPeriod represents errors from the payout database.
|
2020-03-16 04:28:03 +00:00
|
|
|
var ErrNoPayStubForPeriod = errs.Class("no payStub for period error")
|
|
|
|
|
2020-09-10 15:08:25 +01:00
|
|
|
// PayStub is node payout data for satellite by specific period.
|
2020-03-12 14:42:01 +00:00
|
|
|
type PayStub struct {
|
|
|
|
SatelliteID storj.NodeID `json:"satelliteId"`
|
|
|
|
Period string `json:"period"`
|
|
|
|
Created time.Time `json:"created"`
|
|
|
|
Codes string `json:"codes"`
|
|
|
|
UsageAtRest float64 `json:"usageAtRest"`
|
|
|
|
UsageGet int64 `json:"usageGet"`
|
|
|
|
UsagePut int64 `json:"usagePut"`
|
|
|
|
UsageGetRepair int64 `json:"usageGetRepair"`
|
|
|
|
UsagePutRepair int64 `json:"usagePutRepair"`
|
|
|
|
UsageGetAudit int64 `json:"usageGetAudit"`
|
|
|
|
CompAtRest int64 `json:"compAtRest"`
|
|
|
|
CompGet int64 `json:"compGet"`
|
|
|
|
CompPut int64 `json:"compPut"`
|
|
|
|
CompGetRepair int64 `json:"compGetRepair"`
|
|
|
|
CompPutRepair int64 `json:"compPutRepair"`
|
|
|
|
CompGetAudit int64 `json:"compGetAudit"`
|
|
|
|
SurgePercent int64 `json:"surgePercent"`
|
|
|
|
Held int64 `json:"held"`
|
|
|
|
Owed int64 `json:"owed"`
|
|
|
|
Disposed int64 `json:"disposed"`
|
|
|
|
Paid int64 `json:"paid"`
|
|
|
|
}
|
2020-04-28 14:07:50 +01:00
|
|
|
|
2020-09-10 15:08:25 +01:00
|
|
|
// HoldForPeriod is node's held amount for period.
|
|
|
|
type HoldForPeriod struct {
|
2020-04-28 14:07:50 +01:00
|
|
|
Period string `json:"period"`
|
2020-09-10 15:08:25 +01:00
|
|
|
Amount int64 `json:"amount"`
|
2020-04-28 14:07:50 +01:00
|
|
|
}
|
2020-05-10 12:23:13 +01:00
|
|
|
|
2020-06-24 18:05:43 +01:00
|
|
|
// Payment is node payment data for specific period.
|
|
|
|
type Payment struct {
|
|
|
|
ID int64 `json:"id"`
|
|
|
|
Created time.Time `json:"created"`
|
|
|
|
SatelliteID storj.NodeID `json:"satelliteId"`
|
|
|
|
Period string `json:"period"`
|
|
|
|
Amount int64 `json:"amount"`
|
|
|
|
Receipt string `json:"receipt"`
|
|
|
|
Notes string `json:"notes"`
|
|
|
|
}
|
2020-09-14 15:40:52 +01:00
|
|
|
|
2020-09-10 15:08:25 +01:00
|
|
|
// SatelliteHeldHistory amount of held for specific satellite for all time since join.
|
|
|
|
type SatelliteHeldHistory struct {
|
|
|
|
SatelliteID storj.NodeID `json:"satelliteID"`
|
|
|
|
SatelliteName string `json:"satelliteName"`
|
|
|
|
HoldForFirstPeriod int64 `json:"holdForFirstPeriod"`
|
|
|
|
HoldForSecondPeriod int64 `json:"holdForSecondPeriod"`
|
|
|
|
HoldForThirdPeriod int64 `json:"holdForThirdPeriod"`
|
|
|
|
TotalHeld int64 `json:"totalHeld"`
|
|
|
|
TotalDisposed int64 `json:"totalDisposed"`
|
|
|
|
JoinedAt time.Time `json:"joinedAt"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// SatellitePayoutForPeriod contains payout information for specific period for specific satellite.
|
|
|
|
type SatellitePayoutForPeriod struct {
|
|
|
|
SatelliteID string `json:"satelliteID"`
|
|
|
|
SatelliteURL string `json:"satelliteURL"`
|
|
|
|
Age int64 `json:"age"`
|
|
|
|
Earned int64 `json:"earned"`
|
|
|
|
Surge int64 `json:"surge"`
|
|
|
|
SurgePercent int64 `json:"surgePercent"`
|
|
|
|
Held int64 `json:"held"`
|
|
|
|
HeldPercent int64 `json:"heldPercent"`
|
|
|
|
AfterHeld int64 `json:"afterHeld"`
|
|
|
|
Disposed int64 `json:"disposed"`
|
|
|
|
Paid int64 `json:"paid"`
|
|
|
|
Receipt string `json:"receipt"`
|
|
|
|
IsExitComplete bool `json:"isExitComplete"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Period is a string that represents paystub period type in format yyyy-mm.
|
|
|
|
type Period string
|
|
|
|
|
|
|
|
// Time returns period in time.Time type from string.
|
|
|
|
func (p Period) Time() (time.Time, error) {
|
|
|
|
return time.Parse("2006-01", string(p))
|
|
|
|
}
|
|
|
|
|
2020-09-14 15:40:52 +01:00
|
|
|
// GetEarnedWithSurge returns paystub's total earned and surge.
|
|
|
|
func (paystub *PayStub) GetEarnedWithSurge() (earned int64, surge int64) {
|
|
|
|
earned = paystub.CompGetAudit + paystub.CompGet + paystub.CompGetRepair + paystub.CompAtRest
|
|
|
|
surge = earned * paystub.SurgePercent / 100
|
|
|
|
|
|
|
|
return earned, surge
|
|
|
|
}
|
|
|
|
|
|
|
|
// UsageAtRestTbM converts paystub's usage_at_rest from tbh to tbm.
|
|
|
|
func (paystub *PayStub) UsageAtRestTbM() {
|
|
|
|
paystub.UsageAtRest /= 720
|
|
|
|
}
|