forked from quickfixgo/quickfix
/
BusinessMessageReject.go
72 lines (65 loc) · 2.98 KB
/
BusinessMessageReject.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
//Package businessmessagereject msg type = j.
package businessmessagereject
import (
"github.com/quickfixgo/quickfix"
"github.com/quickfixgo/quickfix/enum"
"github.com/quickfixgo/quickfix/fixt11"
)
//Message is a BusinessMessageReject FIX Message
type Message struct {
FIXMsgType string `fix:"j"`
fixt11.Header
//RefSeqNum is a non-required field for BusinessMessageReject.
RefSeqNum *int `fix:"45"`
//RefMsgType is a required field for BusinessMessageReject.
RefMsgType string `fix:"372"`
//BusinessRejectRefID is a non-required field for BusinessMessageReject.
BusinessRejectRefID *string `fix:"379"`
//BusinessRejectReason is a required field for BusinessMessageReject.
BusinessRejectReason int `fix:"380"`
//Text is a non-required field for BusinessMessageReject.
Text *string `fix:"58"`
//EncodedTextLen is a non-required field for BusinessMessageReject.
EncodedTextLen *int `fix:"354"`
//EncodedText is a non-required field for BusinessMessageReject.
EncodedText *string `fix:"355"`
//RefApplVerID is a non-required field for BusinessMessageReject.
RefApplVerID *string `fix:"1130"`
//RefApplExtID is a non-required field for BusinessMessageReject.
RefApplExtID *int `fix:"1406"`
//RefCstmApplVerID is a non-required field for BusinessMessageReject.
RefCstmApplVerID *string `fix:"1131"`
fixt11.Trailer
}
//Marshal converts Message to a quickfix.Message instance
func (m Message) Marshal() quickfix.Message { return quickfix.Marshal(m) }
//New returns an initialized BusinessMessageReject instance
func New(refmsgtype string, businessrejectreason int) *Message {
var m Message
m.SetRefMsgType(refmsgtype)
m.SetBusinessRejectReason(businessrejectreason)
return &m
}
func (m *Message) SetRefSeqNum(v int) { m.RefSeqNum = &v }
func (m *Message) SetRefMsgType(v string) { m.RefMsgType = v }
func (m *Message) SetBusinessRejectRefID(v string) { m.BusinessRejectRefID = &v }
func (m *Message) SetBusinessRejectReason(v int) { m.BusinessRejectReason = v }
func (m *Message) SetText(v string) { m.Text = &v }
func (m *Message) SetEncodedTextLen(v int) { m.EncodedTextLen = &v }
func (m *Message) SetEncodedText(v string) { m.EncodedText = &v }
func (m *Message) SetRefApplVerID(v string) { m.RefApplVerID = &v }
func (m *Message) SetRefApplExtID(v int) { m.RefApplExtID = &v }
func (m *Message) SetRefCstmApplVerID(v string) { m.RefCstmApplVerID = &v }
//A RouteOut is the callback type that should be implemented for routing Message
type RouteOut func(msg Message, 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 {
m := new(Message)
if err := quickfix.Unmarshal(msg, m); err != nil {
return err
}
return router(*m, sessionID)
}
return enum.ApplVerID_FIX50SP1, "j", r
}