fixer-fix 0.10.1

Generated FIX protocol types for fixer
Documentation
// Code generated by fixer-gen. DO NOT EDIT.
#![allow(clippy::new_without_default)]
#![allow(clippy::needless_pass_by_value)]
#![allow(clippy::too_many_arguments)]
#![allow(unused_imports)]

use fixer::message::Message;
use fixer::fix_string::FIXString;
use fixer::errors::MessageRejectErrorEnum;
use fixer::session::session_id::SessionID;


use crate::field;
use crate::tag;

/// `SecurityListUpdateReport` is the `fix50sp1` `SecurityListUpdateReport` type, `MsgType` = BK.
pub struct SecurityListUpdateReport {
    pub message: Message,
}

impl SecurityListUpdateReport {
    /// Creates a new `SecurityListUpdateReport` with required fields.
    pub fn new() -> Self {
        let mut msg = Message::new();
        msg.header.set_field(tag::MSG_TYPE, FIXString::from("BK".to_string()));

        Self { message: msg }
    }

    /// Creates a `SecurityListUpdateReport` from an existing `Message`.
    pub fn from_message(msg: Message) -> Self {
        Self { message: msg }
    }

    /// Returns the underlying `Message`.
    pub fn to_message(self) -> Message {
        self.message
    }




    /// Sets `ApplID`, Tag 1180.
    pub fn set_appl_id(&mut self, v: String) {
        self.message.body.set_field(tag::APPL_ID, FIXString::from(v));
    }

    /// Gets `ApplID`, Tag 1180.
    pub fn get_appl_id(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::ApplIDField::new(String::new());
        self.message.body.get_field(tag::APPL_ID, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `ApplID` is present, Tag 1180.
    pub fn has_appl_id(&self) -> bool {
        self.message.body.has(tag::APPL_ID)
    }




    /// Sets `ApplLastSeqNum`, Tag 1350.
    pub fn set_appl_last_seq_num(&mut self, v: isize) {
        self.message.body.set_field(tag::APPL_LAST_SEQ_NUM, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `ApplLastSeqNum`, Tag 1350.
    pub fn get_appl_last_seq_num(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::ApplLastSeqNumField::new(0);
        self.message.body.get_field(tag::APPL_LAST_SEQ_NUM, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `ApplLastSeqNum` is present, Tag 1350.
    pub fn has_appl_last_seq_num(&self) -> bool {
        self.message.body.has(tag::APPL_LAST_SEQ_NUM)
    }




    /// Sets `ApplResendFlag`, Tag 1352.
    pub fn set_appl_resend_flag(&mut self, v: bool) {
        self.message.body.set_field(tag::APPL_RESEND_FLAG, fixer::fix_boolean::FIXBoolean::from(v));
    }

    /// Gets `ApplResendFlag`, Tag 1352.
    pub fn get_appl_resend_flag(&self) -> Result<bool, MessageRejectErrorEnum> {
        let mut fld = field::ApplResendFlagField::new(false);
        self.message.body.get_field(tag::APPL_RESEND_FLAG, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `ApplResendFlag` is present, Tag 1352.
    pub fn has_appl_resend_flag(&self) -> bool {
        self.message.body.has(tag::APPL_RESEND_FLAG)
    }




    /// Sets `ApplSeqNum`, Tag 1181.
    pub fn set_appl_seq_num(&mut self, v: isize) {
        self.message.body.set_field(tag::APPL_SEQ_NUM, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `ApplSeqNum`, Tag 1181.
    pub fn get_appl_seq_num(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::ApplSeqNumField::new(0);
        self.message.body.get_field(tag::APPL_SEQ_NUM, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `ApplSeqNum` is present, Tag 1181.
    pub fn has_appl_seq_num(&self) -> bool {
        self.message.body.has(tag::APPL_SEQ_NUM)
    }




    /// Sets `ClearingBusinessDate`, Tag 715.
    pub fn set_clearing_business_date(&mut self, v: String) {
        self.message.body.set_field(tag::CLEARING_BUSINESS_DATE, FIXString::from(v));
    }

    /// Gets `ClearingBusinessDate`, Tag 715.
    pub fn get_clearing_business_date(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::ClearingBusinessDateField::new(String::new());
        self.message.body.get_field(tag::CLEARING_BUSINESS_DATE, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `ClearingBusinessDate` is present, Tag 715.
    pub fn has_clearing_business_date(&self) -> bool {
        self.message.body.has(tag::CLEARING_BUSINESS_DATE)
    }




    /// Sets `CorporateAction`, Tag 292.
    pub fn set_corporate_action(&mut self, v: String) {
        self.message.body.set_field(tag::CORPORATE_ACTION, FIXString::from(v));
    }

    /// Gets `CorporateAction`, Tag 292.
    pub fn get_corporate_action(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::CorporateActionField::new(String::new());
        self.message.body.get_field(tag::CORPORATE_ACTION, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `CorporateAction` is present, Tag 292.
    pub fn has_corporate_action(&self) -> bool {
        self.message.body.has(tag::CORPORATE_ACTION)
    }




    /// Sets `LastFragment`, Tag 893.
    pub fn set_last_fragment(&mut self, v: bool) {
        self.message.body.set_field(tag::LAST_FRAGMENT, fixer::fix_boolean::FIXBoolean::from(v));
    }

    /// Gets `LastFragment`, Tag 893.
    pub fn get_last_fragment(&self) -> Result<bool, MessageRejectErrorEnum> {
        let mut fld = field::LastFragmentField::new(false);
        self.message.body.get_field(tag::LAST_FRAGMENT, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `LastFragment` is present, Tag 893.
    pub fn has_last_fragment(&self) -> bool {
        self.message.body.has(tag::LAST_FRAGMENT)
    }




    /// Sets `MarketID`, Tag 1301.
    pub fn set_market_id(&mut self, v: String) {
        self.message.body.set_field(tag::MARKET_ID, FIXString::from(v));
    }

    /// Gets `MarketID`, Tag 1301.
    pub fn get_market_id(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::MarketIDField::new(String::new());
        self.message.body.get_field(tag::MARKET_ID, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `MarketID` is present, Tag 1301.
    pub fn has_market_id(&self) -> bool {
        self.message.body.has(tag::MARKET_ID)
    }




    /// Sets `MarketSegmentID`, Tag 1300.
    pub fn set_market_segment_id(&mut self, v: String) {
        self.message.body.set_field(tag::MARKET_SEGMENT_ID, FIXString::from(v));
    }

    /// Gets `MarketSegmentID`, Tag 1300.
    pub fn get_market_segment_id(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::MarketSegmentIDField::new(String::new());
        self.message.body.get_field(tag::MARKET_SEGMENT_ID, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `MarketSegmentID` is present, Tag 1300.
    pub fn has_market_segment_id(&self) -> bool {
        self.message.body.has(tag::MARKET_SEGMENT_ID)
    }




    /// Sets `NoRelatedSym`, Tag 146.
    pub fn set_no_related_sym(&mut self, v: isize) {
        self.message.body.set_field(tag::NO_RELATED_SYM, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `NoRelatedSym`, Tag 146.
    pub fn get_no_related_sym(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::NoRelatedSymField::new(0);
        self.message.body.get_field(tag::NO_RELATED_SYM, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `NoRelatedSym` is present, Tag 146.
    pub fn has_no_related_sym(&self) -> bool {
        self.message.body.has(tag::NO_RELATED_SYM)
    }




    /// Sets `SecurityReportID`, Tag 964.
    pub fn set_security_report_id(&mut self, v: isize) {
        self.message.body.set_field(tag::SECURITY_REPORT_ID, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `SecurityReportID`, Tag 964.
    pub fn get_security_report_id(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::SecurityReportIDField::new(0);
        self.message.body.get_field(tag::SECURITY_REPORT_ID, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `SecurityReportID` is present, Tag 964.
    pub fn has_security_report_id(&self) -> bool {
        self.message.body.has(tag::SECURITY_REPORT_ID)
    }




    /// Sets `SecurityReqID`, Tag 320.
    pub fn set_security_req_id(&mut self, v: String) {
        self.message.body.set_field(tag::SECURITY_REQ_ID, FIXString::from(v));
    }

    /// Gets `SecurityReqID`, Tag 320.
    pub fn get_security_req_id(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::SecurityReqIDField::new(String::new());
        self.message.body.get_field(tag::SECURITY_REQ_ID, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `SecurityReqID` is present, Tag 320.
    pub fn has_security_req_id(&self) -> bool {
        self.message.body.has(tag::SECURITY_REQ_ID)
    }




    /// Sets `SecurityRequestResult`, Tag 560.
    pub fn set_security_request_result(&mut self, v: isize) {
        self.message.body.set_field(tag::SECURITY_REQUEST_RESULT, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `SecurityRequestResult`, Tag 560.
    pub fn get_security_request_result(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::SecurityRequestResultField::new(0);
        self.message.body.get_field(tag::SECURITY_REQUEST_RESULT, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `SecurityRequestResult` is present, Tag 560.
    pub fn has_security_request_result(&self) -> bool {
        self.message.body.has(tag::SECURITY_REQUEST_RESULT)
    }




    /// Sets `SecurityResponseID`, Tag 322.
    pub fn set_security_response_id(&mut self, v: String) {
        self.message.body.set_field(tag::SECURITY_RESPONSE_ID, FIXString::from(v));
    }

    /// Gets `SecurityResponseID`, Tag 322.
    pub fn get_security_response_id(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::SecurityResponseIDField::new(String::new());
        self.message.body.get_field(tag::SECURITY_RESPONSE_ID, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `SecurityResponseID` is present, Tag 322.
    pub fn has_security_response_id(&self) -> bool {
        self.message.body.has(tag::SECURITY_RESPONSE_ID)
    }




    /// Sets `SecurityUpdateAction`, Tag 980.
    pub fn set_security_update_action(&mut self, v: String) {
        self.message.body.set_field(tag::SECURITY_UPDATE_ACTION, FIXString::from(v));
    }

    /// Gets `SecurityUpdateAction`, Tag 980.
    pub fn get_security_update_action(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::SecurityUpdateActionField::new(String::new());
        self.message.body.get_field(tag::SECURITY_UPDATE_ACTION, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `SecurityUpdateAction` is present, Tag 980.
    pub fn has_security_update_action(&self) -> bool {
        self.message.body.has(tag::SECURITY_UPDATE_ACTION)
    }




    /// Sets `TotNoRelatedSym`, Tag 393.
    pub fn set_tot_no_related_sym(&mut self, v: isize) {
        self.message.body.set_field(tag::TOT_NO_RELATED_SYM, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `TotNoRelatedSym`, Tag 393.
    pub fn get_tot_no_related_sym(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::TotNoRelatedSymField::new(0);
        self.message.body.get_field(tag::TOT_NO_RELATED_SYM, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `TotNoRelatedSym` is present, Tag 393.
    pub fn has_tot_no_related_sym(&self) -> bool {
        self.message.body.has(tag::TOT_NO_RELATED_SYM)
    }


}

/// `RouteOut` is the callback type for routing `SecurityListUpdateReport` messages.
pub type RouteOut = fn(msg: SecurityListUpdateReport, session_id: SessionID) -> Result<(), MessageRejectErrorEnum>;

/// Route type returned by the `route` function.
pub type Route = (&'static str, &'static str, Box<dyn Fn(&Message, SessionID) -> Result<(), MessageRejectErrorEnum> + Send>);

/// Returns the begin string, message type, and route function for `SecurityListUpdateReport`.
pub fn route(router: RouteOut) -> Route {
    let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
        router(SecurityListUpdateReport::from_message(msg.clone()), session_id)
    };
    ("8", "BK", Box::new(r))
}