Struct MT103

Source
pub struct MT103 {
Show 36 fields pub field_20: GenericReferenceField, pub field_23b: GenericTextField, pub field_32a: Field32A, pub field_50: Field50, pub field_59: Field59, pub field_71a: GenericTextField, pub field_13c: Option<Field13C>, pub field_23e: Option<Field23E>, pub field_26t: Option<GenericTextField>, pub field_33b: Option<Field33B>, pub field_36: Option<Field36>, pub field_51a: Option<GenericBicField>, pub field_52a: Option<GenericBicField>, pub field_52d: Option<GenericNameAddressField>, pub field_53a: Option<GenericBicField>, pub field_53b: Option<GenericPartyField>, pub field_53d: Option<GenericNameAddressField>, pub field_54a: Option<GenericBicField>, pub field_54b: Option<GenericPartyField>, pub field_54d: Option<GenericNameAddressField>, pub field_55a: Option<GenericBicField>, pub field_55b: Option<GenericPartyField>, pub field_55d: Option<GenericNameAddressField>, pub field_56a: Option<GenericBicField>, pub field_56c: Option<GenericAccountField>, pub field_56d: Option<GenericNameAddressField>, pub field_57a: Option<GenericBicField>, pub field_57b: Option<GenericPartyField>, pub field_57c: Option<GenericAccountField>, pub field_57d: Option<GenericNameAddressField>, pub field_70: Option<GenericMultiLine4x35>, pub field_71f: Option<Field71F>, pub field_71g: Option<Field71G>, pub field_72: Option<GenericMultiLine6x35>, pub field_77b: Option<GenericMultiLine3x35>, pub field_77t: Option<Field77T>,
}
Expand description

MT103: Customer Credit Transfer (Standard and STP variants)

Unified structure supporting both standard MT103 and MT103 STP variants. Use is_stp_compliant() to check if the message meets STP requirements.

Fields§

§field_20: GenericReferenceField§field_23b: GenericTextField§field_32a: Field32A§field_50: Field50§field_59: Field59§field_71a: GenericTextField§field_13c: Option<Field13C>§field_23e: Option<Field23E>§field_26t: Option<GenericTextField>§field_33b: Option<Field33B>§field_36: Option<Field36>§field_51a: Option<GenericBicField>§field_52a: Option<GenericBicField>§field_52d: Option<GenericNameAddressField>§field_53a: Option<GenericBicField>§field_53b: Option<GenericPartyField>§field_53d: Option<GenericNameAddressField>§field_54a: Option<GenericBicField>§field_54b: Option<GenericPartyField>§field_54d: Option<GenericNameAddressField>§field_55a: Option<GenericBicField>§field_55b: Option<GenericPartyField>§field_55d: Option<GenericNameAddressField>§field_56a: Option<GenericBicField>§field_56c: Option<GenericAccountField>§field_56d: Option<GenericNameAddressField>§field_57a: Option<GenericBicField>§field_57b: Option<GenericPartyField>§field_57c: Option<GenericAccountField>§field_57d: Option<GenericNameAddressField>§field_70: Option<GenericMultiLine4x35>§field_71f: Option<Field71F>§field_71g: Option<Field71G>§field_72: Option<GenericMultiLine6x35>§field_77b: Option<GenericMultiLine3x35>§field_77t: Option<Field77T>

Implementations§

Source§

impl MT103

Source

pub fn validation_rules() -> &'static str

Get the validation rules for this message type

Source§

impl MT103

Source

pub fn is_stp_compliant(&self) -> bool

Check if this MT103 message is compliant with STP (Straight Through Processing) requirements

STP compliance requires:

  • Field 51A must not be present
  • Field 52: Only option A allowed (no D)
  • Field 53: Only options A/B allowed (no D)
  • Field 54: Only option A allowed (no B/D)
  • Field 23E: Limited to CORT, INTC, SDVA, REPA
  • Field 56a: Not allowed if 23B is SPRI
  • Field 59: Account information mandatory
  • Additional conditional rules (C4, C6)
Source

pub fn is_remit_message(&self) -> bool

Check if this MT103 message is a REMIT message with enhanced remittance information

REMIT messages are distinguished by:

  • Field 77T must be present and contain structured remittance information
  • Field 70 is typically not used (replaced by 77T)
  • Enhanced remittance data for regulatory compliance
Source

pub fn has_reject_codes(&self) -> bool

Check if this MT103 message contains reject codes

Reject messages are identified by checking:

  1. Field 20 (Sender’s Reference) for “REJT” prefix
  2. Block 3 field 108 (MUR - Message User Reference) for “REJT”
  3. Field 72 (Sender to Receiver Information) containing /REJT/ code
Source

pub fn has_return_codes(&self) -> bool

Check if this MT103 message contains return codes

Return messages are identified by checking:

  1. Field 20 (Sender’s Reference) for “RETN” prefix
  2. Block 3 field 108 (MUR - Message User Reference) for “RETN”
  3. Field 72 (Sender to Receiver Information) containing /RETN/ code

Trait Implementations§

Source§

impl Clone for MT103

Source§

fn clone(&self) -> MT103

Returns a duplicate of the value. Read more
1.0.0 · Source§

const fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for MT103

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for MT103

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for MT103

Source§

fn eq(&self, other: &MT103) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for MT103

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl SwiftMessageBody for MT103

Source§

fn message_type() -> &'static str

Get the message type identifier (e.g., “103”, “202”)
Source§

fn from_fields(fields: HashMap<String, Vec<String>>) -> SwiftResult<Self>

Create from field map
Source§

fn to_fields(&self) -> HashMap<String, Vec<String>>

Convert to field map
Source§

fn required_fields() -> Vec<&'static str>

Get required field tags for this message type
Source§

fn optional_fields() -> Vec<&'static str>

Get optional field tags for this message type
Source§

fn is_cover_message(&self) -> bool

Check if this message is a cover message (default: false)
Source§

fn has_reject_codes(&self) -> bool

Source§

fn has_return_codes(&self) -> bool

Source§

fn is_stp_message(&self) -> bool

Source§

impl StructuralPartialEq for MT103

Auto Trait Implementations§

§

impl Freeze for MT103

§

impl RefUnwindSafe for MT103

§

impl Send for MT103

§

impl Sync for MT103

§

impl Unpin for MT103

§

impl UnwindSafe for MT103

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,