fixer_fix/fix44/
market_data_request.rs1#![allow(clippy::new_without_default)]
3#![allow(clippy::needless_pass_by_value)]
4#![allow(clippy::too_many_arguments)]
5#![allow(unused_imports)]
6
7use fixer::message::Message;
8use fixer::fix_string::FIXString;
9use fixer::errors::MessageRejectErrorEnum;
10use fixer::session::session_id::SessionID;
11
12
13use crate::field;
14use crate::tag;
15
16pub struct MarketDataRequest {
18 pub message: Message,
19}
20
21impl MarketDataRequest {
22 pub fn new(md_req_id: field::MDReqIDField, subscription_request_type: field::SubscriptionRequestTypeField, market_depth: field::MarketDepthField, no_md_entry_types: field::NoMDEntryTypesField, no_related_sym: field::NoRelatedSymField) -> Self {
24 let mut msg = Message::new();
25 msg.header.set_field(tag::MSG_TYPE, FIXString::from("V".to_string()));
26
27 msg.body.set_field(tag::MD_REQ_ID, md_req_id.0);
28
29 msg.body.set_field(tag::SUBSCRIPTION_REQUEST_TYPE, subscription_request_type.0);
30
31 msg.body.set_field(tag::MARKET_DEPTH, market_depth.0);
32
33 msg.body.set_field(tag::NO_MD_ENTRY_TYPES, no_md_entry_types.0);
34
35 msg.body.set_field(tag::NO_RELATED_SYM, no_related_sym.0);
36
37 Self { message: msg }
38 }
39
40 pub fn from_message(msg: Message) -> Self {
42 Self { message: msg }
43 }
44
45 pub fn to_message(self) -> Message {
47 self.message
48 }
49
50
51
52
53 pub fn set_aggregated_book(&mut self, v: bool) {
55 self.message.body.set_field(tag::AGGREGATED_BOOK, fixer::fix_boolean::FIXBoolean::from(v));
56 }
57
58 pub fn get_aggregated_book(&self) -> Result<bool, MessageRejectErrorEnum> {
60 let mut fld = field::AggregatedBookField::new(false);
61 self.message.body.get_field(tag::AGGREGATED_BOOK, &mut fld.0)?;
62 Ok(fld.value())
63 }
64
65
66 pub fn has_aggregated_book(&self) -> bool {
68 self.message.body.has(tag::AGGREGATED_BOOK)
69 }
70
71
72
73
74 pub fn set_md_implicit_delete(&mut self, v: bool) {
76 self.message.body.set_field(tag::MD_IMPLICIT_DELETE, fixer::fix_boolean::FIXBoolean::from(v));
77 }
78
79 pub fn get_md_implicit_delete(&self) -> Result<bool, MessageRejectErrorEnum> {
81 let mut fld = field::MDImplicitDeleteField::new(false);
82 self.message.body.get_field(tag::MD_IMPLICIT_DELETE, &mut fld.0)?;
83 Ok(fld.value())
84 }
85
86
87 pub fn has_md_implicit_delete(&self) -> bool {
89 self.message.body.has(tag::MD_IMPLICIT_DELETE)
90 }
91
92
93
94
95 pub fn set_md_req_id(&mut self, v: String) {
97 self.message.body.set_field(tag::MD_REQ_ID, FIXString::from(v));
98 }
99
100 pub fn get_md_req_id(&self) -> Result<String, MessageRejectErrorEnum> {
102 let mut fld = field::MDReqIDField::new(String::new());
103 self.message.body.get_field(tag::MD_REQ_ID, &mut fld.0)?;
104 Ok(fld.value().to_string())
105 }
106
107
108 pub fn has_md_req_id(&self) -> bool {
110 self.message.body.has(tag::MD_REQ_ID)
111 }
112
113
114
115
116 pub fn set_md_update_type(&mut self, v: isize) {
118 self.message.body.set_field(tag::MD_UPDATE_TYPE, fixer::fix_int::FIXInt::from(v));
119 }
120
121 pub fn get_md_update_type(&self) -> Result<isize, MessageRejectErrorEnum> {
123 let mut fld = field::MDUpdateTypeField::new(0);
124 self.message.body.get_field(tag::MD_UPDATE_TYPE, &mut fld.0)?;
125 Ok(fld.value())
126 }
127
128
129 pub fn has_md_update_type(&self) -> bool {
131 self.message.body.has(tag::MD_UPDATE_TYPE)
132 }
133
134
135
136
137 pub fn set_market_depth(&mut self, v: isize) {
139 self.message.body.set_field(tag::MARKET_DEPTH, fixer::fix_int::FIXInt::from(v));
140 }
141
142 pub fn get_market_depth(&self) -> Result<isize, MessageRejectErrorEnum> {
144 let mut fld = field::MarketDepthField::new(0);
145 self.message.body.get_field(tag::MARKET_DEPTH, &mut fld.0)?;
146 Ok(fld.value())
147 }
148
149
150 pub fn has_market_depth(&self) -> bool {
152 self.message.body.has(tag::MARKET_DEPTH)
153 }
154
155
156
157
158 pub fn set_no_md_entry_types(&mut self, v: isize) {
160 self.message.body.set_field(tag::NO_MD_ENTRY_TYPES, fixer::fix_int::FIXInt::from(v));
161 }
162
163 pub fn get_no_md_entry_types(&self) -> Result<isize, MessageRejectErrorEnum> {
165 let mut fld = field::NoMDEntryTypesField::new(0);
166 self.message.body.get_field(tag::NO_MD_ENTRY_TYPES, &mut fld.0)?;
167 Ok(fld.value())
168 }
169
170
171 pub fn has_no_md_entry_types(&self) -> bool {
173 self.message.body.has(tag::NO_MD_ENTRY_TYPES)
174 }
175
176
177
178
179 pub fn set_no_related_sym(&mut self, v: isize) {
181 self.message.body.set_field(tag::NO_RELATED_SYM, fixer::fix_int::FIXInt::from(v));
182 }
183
184 pub fn get_no_related_sym(&self) -> Result<isize, MessageRejectErrorEnum> {
186 let mut fld = field::NoRelatedSymField::new(0);
187 self.message.body.get_field(tag::NO_RELATED_SYM, &mut fld.0)?;
188 Ok(fld.value())
189 }
190
191
192 pub fn has_no_related_sym(&self) -> bool {
194 self.message.body.has(tag::NO_RELATED_SYM)
195 }
196
197
198
199
200 pub fn set_open_close_settl_flag(&mut self, v: String) {
202 self.message.body.set_field(tag::OPEN_CLOSE_SETTL_FLAG, FIXString::from(v));
203 }
204
205 pub fn get_open_close_settl_flag(&self) -> Result<String, MessageRejectErrorEnum> {
207 let mut fld = field::OpenCloseSettlFlagField::new(String::new());
208 self.message.body.get_field(tag::OPEN_CLOSE_SETTL_FLAG, &mut fld.0)?;
209 Ok(fld.value().to_string())
210 }
211
212
213 pub fn has_open_close_settl_flag(&self) -> bool {
215 self.message.body.has(tag::OPEN_CLOSE_SETTL_FLAG)
216 }
217
218
219
220
221 pub fn set_scope(&mut self, v: String) {
223 self.message.body.set_field(tag::SCOPE, FIXString::from(v));
224 }
225
226 pub fn get_scope(&self) -> Result<String, MessageRejectErrorEnum> {
228 let mut fld = field::ScopeField::new(String::new());
229 self.message.body.get_field(tag::SCOPE, &mut fld.0)?;
230 Ok(fld.value().to_string())
231 }
232
233
234 pub fn has_scope(&self) -> bool {
236 self.message.body.has(tag::SCOPE)
237 }
238
239
240
241
242 pub fn set_subscription_request_type(&mut self, v: String) {
244 self.message.body.set_field(tag::SUBSCRIPTION_REQUEST_TYPE, FIXString::from(v));
245 }
246
247 pub fn get_subscription_request_type(&self) -> Result<String, MessageRejectErrorEnum> {
249 let mut fld = field::SubscriptionRequestTypeField::new(String::new());
250 self.message.body.get_field(tag::SUBSCRIPTION_REQUEST_TYPE, &mut fld.0)?;
251 Ok(fld.value().to_string())
252 }
253
254
255 pub fn has_subscription_request_type(&self) -> bool {
257 self.message.body.has(tag::SUBSCRIPTION_REQUEST_TYPE)
258 }
259
260
261}
262
263pub type RouteOut = fn(msg: MarketDataRequest, session_id: SessionID) -> Result<(), MessageRejectErrorEnum>;
265
266pub type Route = (&'static str, &'static str, Box<dyn Fn(&Message, SessionID) -> Result<(), MessageRejectErrorEnum> + Send>);
268
269pub fn route(router: RouteOut) -> Route {
271 let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
272 router(MarketDataRequest::from_message(msg.clone()), session_id)
273 };
274 ("FIX.4.4", "V", Box::new(r))
275}