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;

/// `UserRequest` is the `fix50sp2` `UserRequest` type, `MsgType` = BE.
pub struct UserRequest {
    pub message: Message,
}

impl UserRequest {
    /// Creates a new `UserRequest` with required fields.
    pub fn new(user_request_id: field::UserRequestIDField, user_request_type: field::UserRequestTypeField, username: field::UsernameField) -> Self {
        let mut msg = Message::new();
        msg.header.set_field(tag::MSG_TYPE, FIXString::from("BE".to_string()));

        msg.body.set_field(tag::USER_REQUEST_ID, user_request_id.0);

        msg.body.set_field(tag::USER_REQUEST_TYPE, user_request_type.0);

        msg.body.set_field(tag::USERNAME, username.0);

        Self { message: msg }
    }

    /// Creates a `UserRequest` 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 `EncryptedNewPassword`, Tag 1404.
    pub fn set_encrypted_new_password(&mut self, v: String) {
        self.message.body.set_field(tag::ENCRYPTED_NEW_PASSWORD, FIXString::from(v));
    }

    /// Gets `EncryptedNewPassword`, Tag 1404.
    pub fn get_encrypted_new_password(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::EncryptedNewPasswordField::new(String::new());
        self.message.body.get_field(tag::ENCRYPTED_NEW_PASSWORD, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `EncryptedNewPassword` is present, Tag 1404.
    pub fn has_encrypted_new_password(&self) -> bool {
        self.message.body.has(tag::ENCRYPTED_NEW_PASSWORD)
    }




    /// Sets `EncryptedNewPasswordLen`, Tag 1403.
    pub fn set_encrypted_new_password_len(&mut self, v: isize) {
        self.message.body.set_field(tag::ENCRYPTED_NEW_PASSWORD_LEN, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `EncryptedNewPasswordLen`, Tag 1403.
    pub fn get_encrypted_new_password_len(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::EncryptedNewPasswordLenField::new(0);
        self.message.body.get_field(tag::ENCRYPTED_NEW_PASSWORD_LEN, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `EncryptedNewPasswordLen` is present, Tag 1403.
    pub fn has_encrypted_new_password_len(&self) -> bool {
        self.message.body.has(tag::ENCRYPTED_NEW_PASSWORD_LEN)
    }




    /// Sets `EncryptedPassword`, Tag 1402.
    pub fn set_encrypted_password(&mut self, v: String) {
        self.message.body.set_field(tag::ENCRYPTED_PASSWORD, FIXString::from(v));
    }

    /// Gets `EncryptedPassword`, Tag 1402.
    pub fn get_encrypted_password(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::EncryptedPasswordField::new(String::new());
        self.message.body.get_field(tag::ENCRYPTED_PASSWORD, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `EncryptedPassword` is present, Tag 1402.
    pub fn has_encrypted_password(&self) -> bool {
        self.message.body.has(tag::ENCRYPTED_PASSWORD)
    }




    /// Sets `EncryptedPasswordLen`, Tag 1401.
    pub fn set_encrypted_password_len(&mut self, v: isize) {
        self.message.body.set_field(tag::ENCRYPTED_PASSWORD_LEN, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `EncryptedPasswordLen`, Tag 1401.
    pub fn get_encrypted_password_len(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::EncryptedPasswordLenField::new(0);
        self.message.body.get_field(tag::ENCRYPTED_PASSWORD_LEN, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `EncryptedPasswordLen` is present, Tag 1401.
    pub fn has_encrypted_password_len(&self) -> bool {
        self.message.body.has(tag::ENCRYPTED_PASSWORD_LEN)
    }




    /// Sets `EncryptedPasswordMethod`, Tag 1400.
    pub fn set_encrypted_password_method(&mut self, v: isize) {
        self.message.body.set_field(tag::ENCRYPTED_PASSWORD_METHOD, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `EncryptedPasswordMethod`, Tag 1400.
    pub fn get_encrypted_password_method(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::EncryptedPasswordMethodField::new(0);
        self.message.body.get_field(tag::ENCRYPTED_PASSWORD_METHOD, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `EncryptedPasswordMethod` is present, Tag 1400.
    pub fn has_encrypted_password_method(&self) -> bool {
        self.message.body.has(tag::ENCRYPTED_PASSWORD_METHOD)
    }




    /// Sets `NewPassword`, Tag 925.
    pub fn set_new_password(&mut self, v: String) {
        self.message.body.set_field(tag::NEW_PASSWORD, FIXString::from(v));
    }

    /// Gets `NewPassword`, Tag 925.
    pub fn get_new_password(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::NewPasswordField::new(String::new());
        self.message.body.get_field(tag::NEW_PASSWORD, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `NewPassword` is present, Tag 925.
    pub fn has_new_password(&self) -> bool {
        self.message.body.has(tag::NEW_PASSWORD)
    }




    /// Sets `Password`, Tag 554.
    pub fn set_password(&mut self, v: String) {
        self.message.body.set_field(tag::PASSWORD, FIXString::from(v));
    }

    /// Gets `Password`, Tag 554.
    pub fn get_password(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::PasswordField::new(String::new());
        self.message.body.get_field(tag::PASSWORD, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `Password` is present, Tag 554.
    pub fn has_password(&self) -> bool {
        self.message.body.has(tag::PASSWORD)
    }




    /// Sets `RawData`, Tag 96.
    pub fn set_raw_data(&mut self, v: String) {
        self.message.body.set_field(tag::RAW_DATA, FIXString::from(v));
    }

    /// Gets `RawData`, Tag 96.
    pub fn get_raw_data(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::RawDataField::new(String::new());
        self.message.body.get_field(tag::RAW_DATA, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `RawData` is present, Tag 96.
    pub fn has_raw_data(&self) -> bool {
        self.message.body.has(tag::RAW_DATA)
    }




    /// Sets `RawDataLength`, Tag 95.
    pub fn set_raw_data_length(&mut self, v: isize) {
        self.message.body.set_field(tag::RAW_DATA_LENGTH, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `RawDataLength`, Tag 95.
    pub fn get_raw_data_length(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::RawDataLengthField::new(0);
        self.message.body.get_field(tag::RAW_DATA_LENGTH, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `RawDataLength` is present, Tag 95.
    pub fn has_raw_data_length(&self) -> bool {
        self.message.body.has(tag::RAW_DATA_LENGTH)
    }




    /// Sets `UserRequestID`, Tag 923.
    pub fn set_user_request_id(&mut self, v: String) {
        self.message.body.set_field(tag::USER_REQUEST_ID, FIXString::from(v));
    }

    /// Gets `UserRequestID`, Tag 923.
    pub fn get_user_request_id(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::UserRequestIDField::new(String::new());
        self.message.body.get_field(tag::USER_REQUEST_ID, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `UserRequestID` is present, Tag 923.
    pub fn has_user_request_id(&self) -> bool {
        self.message.body.has(tag::USER_REQUEST_ID)
    }




    /// Sets `UserRequestType`, Tag 924.
    pub fn set_user_request_type(&mut self, v: isize) {
        self.message.body.set_field(tag::USER_REQUEST_TYPE, fixer::fix_int::FIXInt::from(v));
    }

    /// Gets `UserRequestType`, Tag 924.
    pub fn get_user_request_type(&self) -> Result<isize, MessageRejectErrorEnum> {
        let mut fld = field::UserRequestTypeField::new(0);
        self.message.body.get_field(tag::USER_REQUEST_TYPE, &mut fld.0)?;
        Ok(fld.value())
    }


    /// Returns true if `UserRequestType` is present, Tag 924.
    pub fn has_user_request_type(&self) -> bool {
        self.message.body.has(tag::USER_REQUEST_TYPE)
    }




    /// Sets `Username`, Tag 553.
    pub fn set_username(&mut self, v: String) {
        self.message.body.set_field(tag::USERNAME, FIXString::from(v));
    }

    /// Gets `Username`, Tag 553.
    pub fn get_username(&self) -> Result<String, MessageRejectErrorEnum> {
        let mut fld = field::UsernameField::new(String::new());
        self.message.body.get_field(tag::USERNAME, &mut fld.0)?;
        Ok(fld.value().to_string())
    }


    /// Returns true if `Username` is present, Tag 553.
    pub fn has_username(&self) -> bool {
        self.message.body.has(tag::USERNAME)
    }


}

/// `RouteOut` is the callback type for routing `UserRequest` messages.
pub type RouteOut = fn(msg: UserRequest, 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 `UserRequest`.
pub fn route(router: RouteOut) -> Route {
    let r = move |msg: &Message, session_id: SessionID| -> Result<(), MessageRejectErrorEnum> {
        router(UserRequest::from_message(msg.clone()), session_id)
    };
    ("9", "BE", Box::new(r))
}