Skip to main content

fixer_fix/fix44/
quote_request.rs

1// Code generated by fixer-gen. DO NOT EDIT.
2#![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
16/// `QuoteRequest` is the `fix44` `QuoteRequest` type, `MsgType` = R.
17pub struct QuoteRequest {
18    pub message: Message,
19}
20
21impl QuoteRequest {
22    /// Creates a new `QuoteRequest` with required fields.
23    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    /// Creates a `QuoteRequest` from an existing `Message`.
35    pub fn from_message(msg: Message) -> Self {
36        Self { message: msg }
37    }
38
39    /// Returns the underlying `Message`.
40    pub fn to_message(self) -> Message {
41        self.message
42    }
43
44
45
46
47    /// Sets `ClOrdID`, Tag 11.
48    pub fn set_cl_ord_id(&mut self, v: String) {
49        self.message.body.set_field(tag::CL_ORD_ID, FIXString::from(v));
50    }
51
52    /// Gets `ClOrdID`, Tag 11.
53    pub fn get_cl_ord_id(&self) -> Result<String, MessageRejectErrorEnum> {
54        let mut fld = field::ClOrdIDField::new(String::new());
55        self.message.body.get_field(tag::CL_ORD_ID, &mut fld.0)?;
56        Ok(fld.value().to_string())
57    }
58
59
60    /// Returns true if `ClOrdID` is present, Tag 11.
61    pub fn has_cl_ord_id(&self) -> bool {
62        self.message.body.has(tag::CL_ORD_ID)
63    }
64
65
66
67
68    /// Sets `EncodedText`, Tag 355.
69    pub fn set_encoded_text(&mut self, v: String) {
70        self.message.body.set_field(tag::ENCODED_TEXT, FIXString::from(v));
71    }
72
73    /// Gets `EncodedText`, Tag 355.
74    pub fn get_encoded_text(&self) -> Result<String, MessageRejectErrorEnum> {
75        let mut fld = field::EncodedTextField::new(String::new());
76        self.message.body.get_field(tag::ENCODED_TEXT, &mut fld.0)?;
77        Ok(fld.value().to_string())
78    }
79
80
81    /// Returns true if `EncodedText` is present, Tag 355.
82    pub fn has_encoded_text(&self) -> bool {
83        self.message.body.has(tag::ENCODED_TEXT)
84    }
85
86
87
88
89    /// Sets `EncodedTextLen`, Tag 354.
90    pub fn set_encoded_text_len(&mut self, v: isize) {
91        self.message.body.set_field(tag::ENCODED_TEXT_LEN, fixer::fix_int::FIXInt::from(v));
92    }
93
94    /// Gets `EncodedTextLen`, Tag 354.
95    pub fn get_encoded_text_len(&self) -> Result<isize, MessageRejectErrorEnum> {
96        let mut fld = field::EncodedTextLenField::new(0);
97        self.message.body.get_field(tag::ENCODED_TEXT_LEN, &mut fld.0)?;
98        Ok(fld.value())
99    }
100
101
102    /// Returns true if `EncodedTextLen` is present, Tag 354.
103    pub fn has_encoded_text_len(&self) -> bool {
104        self.message.body.has(tag::ENCODED_TEXT_LEN)
105    }
106
107
108
109
110    /// Sets `NoRelatedSym`, Tag 146.
111    pub fn set_no_related_sym(&mut self, v: isize) {
112        self.message.body.set_field(tag::NO_RELATED_SYM, fixer::fix_int::FIXInt::from(v));
113    }
114
115    /// Gets `NoRelatedSym`, Tag 146.
116    pub fn get_no_related_sym(&self) -> Result<isize, MessageRejectErrorEnum> {
117        let mut fld = field::NoRelatedSymField::new(0);
118        self.message.body.get_field(tag::NO_RELATED_SYM, &mut fld.0)?;
119        Ok(fld.value())
120    }
121
122
123    /// Returns true if `NoRelatedSym` is present, Tag 146.
124    pub fn has_no_related_sym(&self) -> bool {
125        self.message.body.has(tag::NO_RELATED_SYM)
126    }
127
128
129
130
131    /// Sets `OrderCapacity`, Tag 528.
132    pub fn set_order_capacity(&mut self, v: String) {
133        self.message.body.set_field(tag::ORDER_CAPACITY, FIXString::from(v));
134    }
135
136    /// Gets `OrderCapacity`, Tag 528.
137    pub fn get_order_capacity(&self) -> Result<String, MessageRejectErrorEnum> {
138        let mut fld = field::OrderCapacityField::new(String::new());
139        self.message.body.get_field(tag::ORDER_CAPACITY, &mut fld.0)?;
140        Ok(fld.value().to_string())
141    }
142
143
144    /// Returns true if `OrderCapacity` is present, Tag 528.
145    pub fn has_order_capacity(&self) -> bool {
146        self.message.body.has(tag::ORDER_CAPACITY)
147    }
148
149
150
151
152    /// Sets `QuoteReqID`, Tag 131.
153    pub fn set_quote_req_id(&mut self, v: String) {
154        self.message.body.set_field(tag::QUOTE_REQ_ID, FIXString::from(v));
155    }
156
157    /// Gets `QuoteReqID`, Tag 131.
158    pub fn get_quote_req_id(&self) -> Result<String, MessageRejectErrorEnum> {
159        let mut fld = field::QuoteReqIDField::new(String::new());
160        self.message.body.get_field(tag::QUOTE_REQ_ID, &mut fld.0)?;
161        Ok(fld.value().to_string())
162    }
163
164
165    /// Returns true if `QuoteReqID` is present, Tag 131.
166    pub fn has_quote_req_id(&self) -> bool {
167        self.message.body.has(tag::QUOTE_REQ_ID)
168    }
169
170
171
172
173    /// Sets `RFQReqID`, Tag 644.
174    pub fn set_rfq_req_id(&mut self, v: String) {
175        self.message.body.set_field(tag::RFQ_REQ_ID, FIXString::from(v));
176    }
177
178    /// Gets `RFQReqID`, Tag 644.
179    pub fn get_rfq_req_id(&self) -> Result<String, MessageRejectErrorEnum> {
180        let mut fld = field::RFQReqIDField::new(String::new());
181        self.message.body.get_field(tag::RFQ_REQ_ID, &mut fld.0)?;
182        Ok(fld.value().to_string())
183    }
184
185
186    /// Returns true if `RFQReqID` is present, Tag 644.
187    pub fn has_rfq_req_id(&self) -> bool {
188        self.message.body.has(tag::RFQ_REQ_ID)
189    }
190
191
192
193
194    /// Sets `Text`, Tag 58.
195    pub fn set_text(&mut self, v: String) {
196        self.message.body.set_field(tag::TEXT, FIXString::from(v));
197    }
198
199    /// Gets `Text`, Tag 58.
200    pub fn get_text(&self) -> Result<String, MessageRejectErrorEnum> {
201        let mut fld = field::TextField::new(String::new());
202        self.message.body.get_field(tag::TEXT, &mut fld.0)?;
203        Ok(fld.value().to_string())
204    }
205
206
207    /// Returns true if `Text` is present, Tag 58.
208    pub fn has_text(&self) -> bool {
209        self.message.body.has(tag::TEXT)
210    }
211
212
213}
214
215/// `RouteOut` is the callback type for routing `QuoteRequest` messages.
216pub type RouteOut = fn(msg: QuoteRequest, session_id: SessionID) -> Result<(), MessageRejectErrorEnum>;
217
218/// Route type returned by the `route` function.
219pub type Route = (&'static str, &'static str, Box<dyn Fn(&Message, SessionID) -> Result<(), MessageRejectErrorEnum> + Send>);
220
221/// Returns the begin string, message type, and route function for `QuoteRequest`.
222pub fn route(router: RouteOut) -> Route {
223    let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
224        router(QuoteRequest::from_message(msg.clone()), session_id)
225    };
226    ("FIX.4.4", "R", Box::new(r))
227}