forked from stellar/go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
claim_claimable_balance.go
72 lines (60 loc) · 2.28 KB
/
claim_claimable_balance.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
70
71
72
//lint:file-ignore U1001 Ignore all unused code, staticcheck doesn't understand testify/suite
package txnbuild
import (
"github.com/stellar/go/support/errors"
"github.com/stellar/go/xdr"
)
// ClaimClaimableBalance represents the Stellar claim claimable balance operation. See
// https://developers.stellar.org/docs/start/list-of-operations/
type ClaimClaimableBalance struct {
BalanceID string
SourceAccount string
}
// BuildXDR for ClaimClaimableBalance returns a fully configured XDR Operation.
func (cb *ClaimClaimableBalance) BuildXDR() (xdr.Operation, error) {
var xdrBalanceID xdr.ClaimableBalanceId
err := xdr.SafeUnmarshalHex(cb.BalanceID, &xdrBalanceID)
if err != nil {
return xdr.Operation{}, errors.Wrap(err, "failed to set XDR 'ClaimableBalanceId' field")
}
xdrOp := xdr.ClaimClaimableBalanceOp{
BalanceId: xdrBalanceID,
}
opType := xdr.OperationTypeClaimClaimableBalance
body, err := xdr.NewOperationBody(opType, xdrOp)
if err != nil {
return xdr.Operation{}, errors.Wrap(err, "failed to build XDR OperationBody")
}
op := xdr.Operation{Body: body}
SetOpSourceAccount(&op, cb.SourceAccount)
return op, nil
}
// FromXDR for ClaimClaimableBalance initializes the txnbuild struct from the corresponding xdr Operation.
func (cb *ClaimClaimableBalance) FromXDR(xdrOp xdr.Operation) error {
result, ok := xdrOp.Body.GetClaimClaimableBalanceOp()
if !ok {
return errors.New("error parsing claim_claimable_balance operation from xdr")
}
cb.SourceAccount = accountFromXDR(xdrOp.SourceAccount)
balanceID, err := xdr.MarshalHex(result.BalanceId)
if err != nil {
return errors.New("error parsing BalanceID in claim_claimable_balance operation from xdr")
}
cb.BalanceID = balanceID
return nil
}
// Validate for ClaimClaimableBalance validates the required struct fields. It returns an error if any of the fields are
// invalid. Otherwise, it returns nil.
func (cb *ClaimClaimableBalance) Validate() error {
var xdrBalanceID xdr.ClaimableBalanceId
err := xdr.SafeUnmarshalHex(cb.BalanceID, &xdrBalanceID)
if err != nil {
return NewValidationError("BalanceID", err.Error())
}
return nil
}
// GetSourceAccount returns the source account of the operation, or the empty string if not
// set.
func (cb *ClaimClaimableBalance) GetSourceAccount() string {
return cb.SourceAccount
}