/
callorderupdate.go
60 lines (48 loc) · 1.58 KB
/
callorderupdate.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
package objects
import (
"github.com/juju/errors"
"github.com/opentradingnetworkfoundation/otn-go/util"
)
// CallOrderUpdate can be used to add collateral, cover, and adjust the margin call price for a particular user
type CallOrderUpdate struct {
Fee AssetAmount `json:"fee"`
FundingAccount GrapheneID `json:"funding_account"`
DeltaCollateral AssetAmount `json:"delta_collateral"`
DeltaDebt AssetAmount `json:"delta_debt"`
Extensions Extensions `json:"extensions"`
}
// ApplyFee implements Operation interface
func (p *CallOrderUpdate) ApplyFee(fee AssetAmount) {
p.Fee = fee
}
// Type implements Operation interface
func (p CallOrderUpdate) Type() OperationType {
return OperationTypeCallOrderUpdate
}
// Marshal implements Operation interface
func (p CallOrderUpdate) Marshal(enc *util.TypeEncoder) error {
if err := enc.Encode(int8(p.Type())); err != nil {
return errors.Annotate(err, "encode operation id")
}
if err := enc.Encode(p.Fee); err != nil {
return errors.Annotate(err, "encode fee")
}
if err := enc.Encode(p.FundingAccount); err != nil {
return errors.Annotate(err, "encode borrower")
}
if err := enc.Encode(p.DeltaCollateral); err != nil {
return errors.Annotate(err, "encode collateral")
}
if err := enc.Encode(p.DeltaDebt); err != nil {
return errors.Annotate(err, "encode debt")
}
if err := enc.Encode(p.Extensions); err != nil {
return errors.Annotate(err, "encode extensions")
}
return nil
}
//NewCallOrderUpdate creates a new CallOrderUpdate
func NewCallOrderUpdate() *CallOrderUpdate {
tx := CallOrderUpdate{}
return &tx
}