Skip to main content

fixer_fix/fix44/
list_cancel_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 jiff::Timestamp;
14
15use crate::field;
16use crate::tag;
17
18/// `ListCancelRequest` is the `fix44` `ListCancelRequest` type, `MsgType` = K.
19pub struct ListCancelRequest {
20    pub message: Message,
21}
22
23impl ListCancelRequest {
24    /// Creates a new `ListCancelRequest` with required fields.
25    pub fn new(list_id: field::ListIDField, transact_time: field::TransactTimeField) -> Self {
26        let mut msg = Message::new();
27        msg.header.set_field(tag::MSG_TYPE, FIXString::from("K".to_string()));
28
29        msg.body.set_field(tag::LIST_ID, list_id.0);
30
31        msg.body.set_field(tag::TRANSACT_TIME, transact_time.0);
32
33        Self { message: msg }
34    }
35
36    /// Creates a `ListCancelRequest` from an existing `Message`.
37    pub fn from_message(msg: Message) -> Self {
38        Self { message: msg }
39    }
40
41    /// Returns the underlying `Message`.
42    pub fn to_message(self) -> Message {
43        self.message
44    }
45
46
47
48
49    /// Sets `EncodedText`, Tag 355.
50    pub fn set_encoded_text(&mut self, v: String) {
51        self.message.body.set_field(tag::ENCODED_TEXT, FIXString::from(v));
52    }
53
54    /// Gets `EncodedText`, Tag 355.
55    pub fn get_encoded_text(&self) -> Result<String, MessageRejectErrorEnum> {
56        let mut fld = field::EncodedTextField::new(String::new());
57        self.message.body.get_field(tag::ENCODED_TEXT, &mut fld.0)?;
58        Ok(fld.value().to_string())
59    }
60
61
62    /// Returns true if `EncodedText` is present, Tag 355.
63    pub fn has_encoded_text(&self) -> bool {
64        self.message.body.has(tag::ENCODED_TEXT)
65    }
66
67
68
69
70    /// Sets `EncodedTextLen`, Tag 354.
71    pub fn set_encoded_text_len(&mut self, v: isize) {
72        self.message.body.set_field(tag::ENCODED_TEXT_LEN, fixer::fix_int::FIXInt::from(v));
73    }
74
75    /// Gets `EncodedTextLen`, Tag 354.
76    pub fn get_encoded_text_len(&self) -> Result<isize, MessageRejectErrorEnum> {
77        let mut fld = field::EncodedTextLenField::new(0);
78        self.message.body.get_field(tag::ENCODED_TEXT_LEN, &mut fld.0)?;
79        Ok(fld.value())
80    }
81
82
83    /// Returns true if `EncodedTextLen` is present, Tag 354.
84    pub fn has_encoded_text_len(&self) -> bool {
85        self.message.body.has(tag::ENCODED_TEXT_LEN)
86    }
87
88
89
90
91    /// Sets `ListID`, Tag 66.
92    pub fn set_list_id(&mut self, v: String) {
93        self.message.body.set_field(tag::LIST_ID, FIXString::from(v));
94    }
95
96    /// Gets `ListID`, Tag 66.
97    pub fn get_list_id(&self) -> Result<String, MessageRejectErrorEnum> {
98        let mut fld = field::ListIDField::new(String::new());
99        self.message.body.get_field(tag::LIST_ID, &mut fld.0)?;
100        Ok(fld.value().to_string())
101    }
102
103
104    /// Returns true if `ListID` is present, Tag 66.
105    pub fn has_list_id(&self) -> bool {
106        self.message.body.has(tag::LIST_ID)
107    }
108
109
110
111
112    /// Sets `Text`, Tag 58.
113    pub fn set_text(&mut self, v: String) {
114        self.message.body.set_field(tag::TEXT, FIXString::from(v));
115    }
116
117    /// Gets `Text`, Tag 58.
118    pub fn get_text(&self) -> Result<String, MessageRejectErrorEnum> {
119        let mut fld = field::TextField::new(String::new());
120        self.message.body.get_field(tag::TEXT, &mut fld.0)?;
121        Ok(fld.value().to_string())
122    }
123
124
125    /// Returns true if `Text` is present, Tag 58.
126    pub fn has_text(&self) -> bool {
127        self.message.body.has(tag::TEXT)
128    }
129
130
131
132
133    /// Sets `TradeDate`, Tag 75.
134    pub fn set_trade_date(&mut self, v: String) {
135        self.message.body.set_field(tag::TRADE_DATE, FIXString::from(v));
136    }
137
138    /// Gets `TradeDate`, Tag 75.
139    pub fn get_trade_date(&self) -> Result<String, MessageRejectErrorEnum> {
140        let mut fld = field::TradeDateField::new(String::new());
141        self.message.body.get_field(tag::TRADE_DATE, &mut fld.0)?;
142        Ok(fld.value().to_string())
143    }
144
145
146    /// Returns true if `TradeDate` is present, Tag 75.
147    pub fn has_trade_date(&self) -> bool {
148        self.message.body.has(tag::TRADE_DATE)
149    }
150
151
152
153
154    /// Sets `TradeOriginationDate`, Tag 229.
155    pub fn set_trade_origination_date(&mut self, v: String) {
156        self.message.body.set_field(tag::TRADE_ORIGINATION_DATE, FIXString::from(v));
157    }
158
159    /// Gets `TradeOriginationDate`, Tag 229.
160    pub fn get_trade_origination_date(&self) -> Result<String, MessageRejectErrorEnum> {
161        let mut fld = field::TradeOriginationDateField::new(String::new());
162        self.message.body.get_field(tag::TRADE_ORIGINATION_DATE, &mut fld.0)?;
163        Ok(fld.value().to_string())
164    }
165
166
167    /// Returns true if `TradeOriginationDate` is present, Tag 229.
168    pub fn has_trade_origination_date(&self) -> bool {
169        self.message.body.has(tag::TRADE_ORIGINATION_DATE)
170    }
171
172
173
174
175    /// Sets `TransactTime`, Tag 60.
176    pub fn set_transact_time(&mut self, v: Timestamp) {
177        self.message.body.set_field(tag::TRANSACT_TIME, fixer::fix_utc_timestamp::FIXUTCTimestamp {
178            time: v,
179            precision: fixer::fix_utc_timestamp::TimestampPrecision::Millis,
180        });
181    }
182
183    /// Gets `TransactTime`, Tag 60.
184    pub fn get_transact_time(&self) -> Result<Timestamp, MessageRejectErrorEnum> {
185        let mut fld = field::TransactTimeField::new(Timestamp::UNIX_EPOCH);
186        self.message.body.get_field(tag::TRANSACT_TIME, &mut fld.0)?;
187        Ok(fld.value())
188    }
189
190
191    /// Returns true if `TransactTime` is present, Tag 60.
192    pub fn has_transact_time(&self) -> bool {
193        self.message.body.has(tag::TRANSACT_TIME)
194    }
195
196
197}
198
199/// `RouteOut` is the callback type for routing `ListCancelRequest` messages.
200pub type RouteOut = fn(msg: ListCancelRequest, session_id: SessionID) -> Result<(), MessageRejectErrorEnum>;
201
202/// Route type returned by the `route` function.
203pub type Route = (&'static str, &'static str, Box<dyn Fn(&Message, SessionID) -> Result<(), MessageRejectErrorEnum> + Send>);
204
205/// Returns the begin string, message type, and route function for `ListCancelRequest`.
206pub fn route(router: RouteOut) -> Route {
207    let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
208        router(ListCancelRequest::from_message(msg.clone()), session_id)
209    };
210    ("FIX.4.4", "K", Box::new(r))
211}