This message should be issued when a message is received but cannot be properly processed due to a session-level rule violation. For example, upon receipt of a message with an invalid MsgType (35) that is otherwise valid. As a rule, messages should be forwarded to the trading application for business-level rejections whenever possible.
Rejected messages should be logged and the incoming sequence number should be incremented.
The receiving application should disregard any message that is garbled, cannot be parsed or fails a data integrity check. Processing of the next valid FIX message will cause detection of a sequence gap and a Resend Request <35=2> will be generated. FIX engines should be implemented to recognize a possibly infinite resend loop, which may be encountered in this situation.
Generation and receipt of a Reject message indicates a serious error that may be the result of faulty logic in one or both applications.
If the sending application chooses to retransmit the rejected message, it should be assigned a new sequence number and sent with PossResend (97)=Y.
It is strongly recommended that the cause of the failure be described in the Text (58) field. For example, "Invalid data - field 35".
If an application-level message fulfills session-level rules then it should then be processed at a business-message level. If this processing detects a rule violation, a business-level reject should be issued. Many business-level messages have specific rejection message types which should be used. All others can be rejected at a business-level with the Business Message Reject <35=j> message.
In the event that a business message is received, fulfills session-level rules, but cannot be processed by the business-level processing system, a Business Message Reject <35=j> with BusinessRejectReason (380) = "Application not available at this time" should be sent.
Scenarios for a session-level Reject are listed in the documentation for SessionRejectReason (373).
Tag | Name | Type | Required | Description |
---|---|---|---|---|
Component | ||||
45 | SeqNum | MsgSeqNum of rejected message | ||
371 | Int | The tag number of the FIX field being referenced | ||
372 | String Enum | The MsgType of the FIX message being referenced | ||
1130 | String Enum | Recommended when rejecting an application message that does not explicitly provide ApplVerID ( 1128) on the message being rejected. In this case the value from the DefaultApplVerID(1137) or the default value specified in the NoMsgTypes repeating group on the logon message should be provided | ||
1406 | Int | Recommended when rejecting an application message that does not explicitly provide ApplExtID(1156) on the rejected message. In this case the value from the DefaultApplExtID(1407) or the default value specified in the NoMsgTypes repeating group on the logon message should be provided | ||
1131 | String | Recommended when rejecting an application message that does not explicitly provide CstmApplVerID(1129) on the message being rejected. In this case the value from the DefaultCstmApplVerID(1408) or the default value specified in the NoMsgTypes repeating group on the logon message should be provided | ||
373 | Int Enum | Code to identify reason for a session-level Reject message | ||
58 | String | Where possible, message to explain reason for rejection | ||
354 | Length | Must be set if EncodedText field is specified and must immediately precede it | ||
355 | Data | Encoded (non-ASCII characters) representation of the Text field in the encoded format specified via the MessageEncoding field | ||
Component |