fixer_fix/fix50sp2/
quote_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 QuoteRequest {
18 pub message: Message,
19}
20
21impl QuoteRequest {
22 pub fn new(quote_req_id: field::QuoteReqIDField, no_related_sym: field::NoRelatedSymField) -> Self {
24 let mut msg = Message::new();
25 msg.header.set_field(tag::MSG_TYPE, FIXString::from("R".to_string()));
26
27 msg.body.set_field(tag::QUOTE_REQ_ID, quote_req_id.0);
28
29 msg.body.set_field(tag::NO_RELATED_SYM, no_related_sym.0);
30
31 Self { message: msg }
32 }
33
34 pub fn from_message(msg: Message) -> Self {
36 Self { message: msg }
37 }
38
39 pub fn to_message(self) -> Message {
41 self.message
42 }
43
44
45
46
47 pub fn set_booking_type(&mut self, v: isize) {
49 self.message.body.set_field(tag::BOOKING_TYPE, fixer::fix_int::FIXInt::from(v));
50 }
51
52 pub fn get_booking_type(&self) -> Result<isize, MessageRejectErrorEnum> {
54 let mut fld = field::BookingTypeField::new(0);
55 self.message.body.get_field(tag::BOOKING_TYPE, &mut fld.0)?;
56 Ok(fld.value())
57 }
58
59
60 pub fn has_booking_type(&self) -> bool {
62 self.message.body.has(tag::BOOKING_TYPE)
63 }
64
65
66
67
68 pub fn set_cl_ord_id(&mut self, v: String) {
70 self.message.body.set_field(tag::CL_ORD_ID, FIXString::from(v));
71 }
72
73 pub fn get_cl_ord_id(&self) -> Result<String, MessageRejectErrorEnum> {
75 let mut fld = field::ClOrdIDField::new(String::new());
76 self.message.body.get_field(tag::CL_ORD_ID, &mut fld.0)?;
77 Ok(fld.value().to_string())
78 }
79
80
81 pub fn has_cl_ord_id(&self) -> bool {
83 self.message.body.has(tag::CL_ORD_ID)
84 }
85
86
87
88
89 pub fn set_encoded_text(&mut self, v: String) {
91 self.message.body.set_field(tag::ENCODED_TEXT, FIXString::from(v));
92 }
93
94 pub fn get_encoded_text(&self) -> Result<String, MessageRejectErrorEnum> {
96 let mut fld = field::EncodedTextField::new(String::new());
97 self.message.body.get_field(tag::ENCODED_TEXT, &mut fld.0)?;
98 Ok(fld.value().to_string())
99 }
100
101
102 pub fn has_encoded_text(&self) -> bool {
104 self.message.body.has(tag::ENCODED_TEXT)
105 }
106
107
108
109
110 pub fn set_encoded_text_len(&mut self, v: isize) {
112 self.message.body.set_field(tag::ENCODED_TEXT_LEN, fixer::fix_int::FIXInt::from(v));
113 }
114
115 pub fn get_encoded_text_len(&self) -> Result<isize, MessageRejectErrorEnum> {
117 let mut fld = field::EncodedTextLenField::new(0);
118 self.message.body.get_field(tag::ENCODED_TEXT_LEN, &mut fld.0)?;
119 Ok(fld.value())
120 }
121
122
123 pub fn has_encoded_text_len(&self) -> bool {
125 self.message.body.has(tag::ENCODED_TEXT_LEN)
126 }
127
128
129
130
131 pub fn set_no_related_sym(&mut self, v: isize) {
133 self.message.body.set_field(tag::NO_RELATED_SYM, fixer::fix_int::FIXInt::from(v));
134 }
135
136 pub fn get_no_related_sym(&self) -> Result<isize, MessageRejectErrorEnum> {
138 let mut fld = field::NoRelatedSymField::new(0);
139 self.message.body.get_field(tag::NO_RELATED_SYM, &mut fld.0)?;
140 Ok(fld.value())
141 }
142
143
144 pub fn has_no_related_sym(&self) -> bool {
146 self.message.body.has(tag::NO_RELATED_SYM)
147 }
148
149
150
151
152 pub fn set_no_root_party_i_ds(&mut self, v: isize) {
154 self.message.body.set_field(tag::NO_ROOT_PARTY_I_DS, fixer::fix_int::FIXInt::from(v));
155 }
156
157 pub fn get_no_root_party_i_ds(&self) -> Result<isize, MessageRejectErrorEnum> {
159 let mut fld = field::NoRootPartyIDsField::new(0);
160 self.message.body.get_field(tag::NO_ROOT_PARTY_I_DS, &mut fld.0)?;
161 Ok(fld.value())
162 }
163
164
165 pub fn has_no_root_party_i_ds(&self) -> bool {
167 self.message.body.has(tag::NO_ROOT_PARTY_I_DS)
168 }
169
170
171
172
173 pub fn set_order_capacity(&mut self, v: String) {
175 self.message.body.set_field(tag::ORDER_CAPACITY, FIXString::from(v));
176 }
177
178 pub fn get_order_capacity(&self) -> Result<String, MessageRejectErrorEnum> {
180 let mut fld = field::OrderCapacityField::new(String::new());
181 self.message.body.get_field(tag::ORDER_CAPACITY, &mut fld.0)?;
182 Ok(fld.value().to_string())
183 }
184
185
186 pub fn has_order_capacity(&self) -> bool {
188 self.message.body.has(tag::ORDER_CAPACITY)
189 }
190
191
192
193
194 pub fn set_order_restrictions(&mut self, v: String) {
196 self.message.body.set_field(tag::ORDER_RESTRICTIONS, FIXString::from(v));
197 }
198
199 pub fn get_order_restrictions(&self) -> Result<String, MessageRejectErrorEnum> {
201 let mut fld = field::OrderRestrictionsField::new(String::new());
202 self.message.body.get_field(tag::ORDER_RESTRICTIONS, &mut fld.0)?;
203 Ok(fld.value().to_string())
204 }
205
206
207 pub fn has_order_restrictions(&self) -> bool {
209 self.message.body.has(tag::ORDER_RESTRICTIONS)
210 }
211
212
213
214
215 pub fn set_pre_trade_anonymity(&mut self, v: bool) {
217 self.message.body.set_field(tag::PRE_TRADE_ANONYMITY, fixer::fix_boolean::FIXBoolean::from(v));
218 }
219
220 pub fn get_pre_trade_anonymity(&self) -> Result<bool, MessageRejectErrorEnum> {
222 let mut fld = field::PreTradeAnonymityField::new(false);
223 self.message.body.get_field(tag::PRE_TRADE_ANONYMITY, &mut fld.0)?;
224 Ok(fld.value())
225 }
226
227
228 pub fn has_pre_trade_anonymity(&self) -> bool {
230 self.message.body.has(tag::PRE_TRADE_ANONYMITY)
231 }
232
233
234
235
236 pub fn set_private_quote(&mut self, v: bool) {
238 self.message.body.set_field(tag::PRIVATE_QUOTE, fixer::fix_boolean::FIXBoolean::from(v));
239 }
240
241 pub fn get_private_quote(&self) -> Result<bool, MessageRejectErrorEnum> {
243 let mut fld = field::PrivateQuoteField::new(false);
244 self.message.body.get_field(tag::PRIVATE_QUOTE, &mut fld.0)?;
245 Ok(fld.value())
246 }
247
248
249 pub fn has_private_quote(&self) -> bool {
251 self.message.body.has(tag::PRIVATE_QUOTE)
252 }
253
254
255
256
257 pub fn set_quote_req_id(&mut self, v: String) {
259 self.message.body.set_field(tag::QUOTE_REQ_ID, FIXString::from(v));
260 }
261
262 pub fn get_quote_req_id(&self) -> Result<String, MessageRejectErrorEnum> {
264 let mut fld = field::QuoteReqIDField::new(String::new());
265 self.message.body.get_field(tag::QUOTE_REQ_ID, &mut fld.0)?;
266 Ok(fld.value().to_string())
267 }
268
269
270 pub fn has_quote_req_id(&self) -> bool {
272 self.message.body.has(tag::QUOTE_REQ_ID)
273 }
274
275
276
277
278 pub fn set_rfq_req_id(&mut self, v: String) {
280 self.message.body.set_field(tag::RFQ_REQ_ID, FIXString::from(v));
281 }
282
283 pub fn get_rfq_req_id(&self) -> Result<String, MessageRejectErrorEnum> {
285 let mut fld = field::RFQReqIDField::new(String::new());
286 self.message.body.get_field(tag::RFQ_REQ_ID, &mut fld.0)?;
287 Ok(fld.value().to_string())
288 }
289
290
291 pub fn has_rfq_req_id(&self) -> bool {
293 self.message.body.has(tag::RFQ_REQ_ID)
294 }
295
296
297
298
299 pub fn set_respondent_type(&mut self, v: isize) {
301 self.message.body.set_field(tag::RESPONDENT_TYPE, fixer::fix_int::FIXInt::from(v));
302 }
303
304 pub fn get_respondent_type(&self) -> Result<isize, MessageRejectErrorEnum> {
306 let mut fld = field::RespondentTypeField::new(0);
307 self.message.body.get_field(tag::RESPONDENT_TYPE, &mut fld.0)?;
308 Ok(fld.value())
309 }
310
311
312 pub fn has_respondent_type(&self) -> bool {
314 self.message.body.has(tag::RESPONDENT_TYPE)
315 }
316
317
318
319
320 pub fn set_text(&mut self, v: String) {
322 self.message.body.set_field(tag::TEXT, FIXString::from(v));
323 }
324
325 pub fn get_text(&self) -> Result<String, MessageRejectErrorEnum> {
327 let mut fld = field::TextField::new(String::new());
328 self.message.body.get_field(tag::TEXT, &mut fld.0)?;
329 Ok(fld.value().to_string())
330 }
331
332
333 pub fn has_text(&self) -> bool {
335 self.message.body.has(tag::TEXT)
336 }
337
338
339}
340
341pub type RouteOut = fn(msg: QuoteRequest, session_id: SessionID) -> Result<(), MessageRejectErrorEnum>;
343
344pub type Route = (&'static str, &'static str, Box<dyn Fn(&Message, SessionID) -> Result<(), MessageRejectErrorEnum> + Send>);
346
347pub fn route(router: RouteOut) -> Route {
349 let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
350 router(QuoteRequest::from_message(msg.clone()), session_id)
351 };
352 ("9", "R", Box::new(r))
353}