forked from quickfixgo/quickfix
/
ListStatusRequest.go
126 lines (104 loc) · 3.44 KB
/
ListStatusRequest.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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
package liststatusrequest
import (
"time"
"github.com/quickfixgo/quickfix"
"github.com/quickfixgo/quickfix/field"
"github.com/quickfixgo/quickfix/fix42"
"github.com/quickfixgo/quickfix/tag"
)
//ListStatusRequest is the fix42 ListStatusRequest type, MsgType = M
type ListStatusRequest struct {
fix42.Header
quickfix.Body
fix42.Trailer
//ReceiveTime is the time that this message was read from the socket connection
ReceiveTime time.Time
}
//FromMessage creates a ListStatusRequest from a quickfix.Message instance
func FromMessage(m quickfix.Message) ListStatusRequest {
return ListStatusRequest{
Header: fix42.Header{Header: m.Header},
Body: m.Body,
Trailer: fix42.Trailer{Trailer: m.Trailer},
ReceiveTime: m.ReceiveTime,
}
}
//ToMessage returns a quickfix.Message instance
func (m ListStatusRequest) ToMessage() quickfix.Message {
return quickfix.Message{
Header: m.Header.Header,
Body: m.Body,
Trailer: m.Trailer.Trailer,
ReceiveTime: m.ReceiveTime,
}
}
//New returns a ListStatusRequest initialized with the required fields for ListStatusRequest
func New(listid field.ListIDField) (m ListStatusRequest) {
m.Header = fix42.NewHeader()
m.Init()
m.Trailer.Init()
m.Header.Set(field.NewMsgType("M"))
m.Set(listid)
return
}
//A RouteOut is the callback type that should be implemented for routing Message
type RouteOut func(msg ListStatusRequest, sessionID quickfix.SessionID) quickfix.MessageRejectError
//Route returns the beginstring, message type, and MessageRoute for this Message type
func Route(router RouteOut) (string, string, quickfix.MessageRoute) {
r := func(msg quickfix.Message, sessionID quickfix.SessionID) quickfix.MessageRejectError {
return router(FromMessage(msg), sessionID)
}
return "FIX.4.2", "M", r
}
//SetText sets Text, Tag 58
func (m ListStatusRequest) SetText(v string) {
m.Set(field.NewText(v))
}
//SetListID sets ListID, Tag 66
func (m ListStatusRequest) SetListID(v string) {
m.Set(field.NewListID(v))
}
//SetEncodedTextLen sets EncodedTextLen, Tag 354
func (m ListStatusRequest) SetEncodedTextLen(v int) {
m.Set(field.NewEncodedTextLen(v))
}
//SetEncodedText sets EncodedText, Tag 355
func (m ListStatusRequest) SetEncodedText(v string) {
m.Set(field.NewEncodedText(v))
}
//GetText gets Text, Tag 58
func (m ListStatusRequest) GetText() (f field.TextField, err quickfix.MessageRejectError) {
err = m.Get(&f)
return
}
//GetListID gets ListID, Tag 66
func (m ListStatusRequest) GetListID() (f field.ListIDField, err quickfix.MessageRejectError) {
err = m.Get(&f)
return
}
//GetEncodedTextLen gets EncodedTextLen, Tag 354
func (m ListStatusRequest) GetEncodedTextLen() (f field.EncodedTextLenField, err quickfix.MessageRejectError) {
err = m.Get(&f)
return
}
//GetEncodedText gets EncodedText, Tag 355
func (m ListStatusRequest) GetEncodedText() (f field.EncodedTextField, err quickfix.MessageRejectError) {
err = m.Get(&f)
return
}
//HasText returns true if Text is present, Tag 58
func (m ListStatusRequest) HasText() bool {
return m.Has(tag.Text)
}
//HasListID returns true if ListID is present, Tag 66
func (m ListStatusRequest) HasListID() bool {
return m.Has(tag.ListID)
}
//HasEncodedTextLen returns true if EncodedTextLen is present, Tag 354
func (m ListStatusRequest) HasEncodedTextLen() bool {
return m.Has(tag.EncodedTextLen)
}
//HasEncodedText returns true if EncodedText is present, Tag 355
func (m ListStatusRequest) HasEncodedText() bool {
return m.Has(tag.EncodedText)
}