/
cashout.go
69 lines (55 loc) · 2.02 KB
/
cashout.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package cheque
import (
"context"
"errors"
"github.com/FavorLabs/favorX/pkg/boson"
"github.com/FavorLabs/favorX/pkg/settlement/chain"
"github.com/FavorLabs/favorX/pkg/storage"
"github.com/ethereum/go-ethereum/common"
)
// CashoutService is the service responsible for managing cashout actions
type CashoutService interface {
// CashCheque
CashCheque(ctx context.Context, peer boson.Address, beneficiary common.Address, recipient common.Address) (common.Hash, error)
//WaitForReceipt
WaitForReceipt(ctx context.Context, ctxHash common.Hash) (uint64, error)
}
type cashoutService struct {
store storage.StateStorer
transactionService chain.Transaction
trafficService chain.Traffic
chequeStore ChequeStore
trafficContractAddr common.Address
}
// NewCashoutService creates a new CashoutService
func NewCashoutService(store storage.StateStorer, transactionService chain.Transaction, trafficService chain.Traffic, chequeStore ChequeStore, trafficContractAddr common.Address) CashoutService {
return &cashoutService{
store: store,
transactionService: transactionService,
trafficService: trafficService,
chequeStore: chequeStore,
trafficContractAddr: trafficContractAddr,
}
}
// CashCheque
func (s *cashoutService) CashCheque(ctx context.Context, peer boson.Address, beneficiary, recipient common.Address) (common.Hash, error) {
cheque, err := s.chequeStore.LastReceivedCheque(beneficiary)
if err != nil {
return common.Hash{}, err
}
if beneficiary != cheque.Beneficiary {
return common.Hash{}, errors.New("exchange failed")
}
tx, err := s.trafficService.CashChequeBeneficiary(ctx, peer, beneficiary, recipient, cheque.CumulativePayout, cheque.Signature)
if err != nil {
return common.Hash{}, err
}
if err != nil {
return common.Hash{}, err
}
return tx.Hash(), nil
}
func (s *cashoutService) WaitForReceipt(ctx context.Context, ctxHash common.Hash) (uint64, error) {
receipt, err := s.transactionService.WaitForReceipt(ctx, ctxHash)
return receipt.Status, err
}