forked from quickfixgo/quickfix
/
RegistrationInstructionsResponse.go
75 lines (68 loc) · 3.23 KB
/
RegistrationInstructionsResponse.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
//Package registrationinstructionsresponse msg type = p.
package registrationinstructionsresponse
import (
"github.com/quickfixgo/quickfix"
"github.com/quickfixgo/quickfix/enum"
"github.com/quickfixgo/quickfix/fix50sp2/parties"
"github.com/quickfixgo/quickfix/fixt11"
)
//Message is a RegistrationInstructionsResponse FIX Message
type Message struct {
FIXMsgType string `fix:"p"`
fixt11.Header
//RegistID is a required field for RegistrationInstructionsResponse.
RegistID string `fix:"513"`
//RegistTransType is a required field for RegistrationInstructionsResponse.
RegistTransType string `fix:"514"`
//RegistRefID is a required field for RegistrationInstructionsResponse.
RegistRefID string `fix:"508"`
//ClOrdID is a non-required field for RegistrationInstructionsResponse.
ClOrdID *string `fix:"11"`
//Parties is a non-required component for RegistrationInstructionsResponse.
Parties *parties.Parties
//Account is a non-required field for RegistrationInstructionsResponse.
Account *string `fix:"1"`
//AcctIDSource is a non-required field for RegistrationInstructionsResponse.
AcctIDSource *int `fix:"660"`
//RegistStatus is a required field for RegistrationInstructionsResponse.
RegistStatus string `fix:"506"`
//RegistRejReasonCode is a non-required field for RegistrationInstructionsResponse.
RegistRejReasonCode *int `fix:"507"`
//RegistRejReasonText is a non-required field for RegistrationInstructionsResponse.
RegistRejReasonText *string `fix:"496"`
fixt11.Trailer
}
//Marshal converts Message to a quickfix.Message instance
func (m Message) Marshal() quickfix.Message { return quickfix.Marshal(m) }
//New returns an initialized RegistrationInstructionsResponse instance
func New(registid string, registtranstype string, registrefid string, registstatus string) *Message {
var m Message
m.SetRegistID(registid)
m.SetRegistTransType(registtranstype)
m.SetRegistRefID(registrefid)
m.SetRegistStatus(registstatus)
return &m
}
func (m *Message) SetRegistID(v string) { m.RegistID = v }
func (m *Message) SetRegistTransType(v string) { m.RegistTransType = v }
func (m *Message) SetRegistRefID(v string) { m.RegistRefID = v }
func (m *Message) SetClOrdID(v string) { m.ClOrdID = &v }
func (m *Message) SetParties(v parties.Parties) { m.Parties = &v }
func (m *Message) SetAccount(v string) { m.Account = &v }
func (m *Message) SetAcctIDSource(v int) { m.AcctIDSource = &v }
func (m *Message) SetRegistStatus(v string) { m.RegistStatus = v }
func (m *Message) SetRegistRejReasonCode(v int) { m.RegistRejReasonCode = &v }
func (m *Message) SetRegistRejReasonText(v string) { m.RegistRejReasonText = &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_FIX50SP2, "p", r
}