[QFJ-474] Need Suppressing Tag not defined exception Created: 23/Sep/09  Updated: 20/Mar/11  Resolved: 20/Mar/11

Status: Closed
Project: QuickFIX/J
Component/s: Engine
Affects Version/s: 1.4.0
Fix Version/s: None

Type: Other Priority: Default
Reporter: Raman Assignee: Unassigned
Resolution: Fixed Votes: 1
Labels: None
Environment:

java 1.6.0._07
windows
quickfixj 1.4.0


Attachments: Text File diff2.txt    

 Description   

Greetings!

My configuration is as follows:
[DEFAULT]
UseDataDictionary=N
AllowUnknownMsgFields=Y
ValidateFieldsOutOfOrder=N
ValidateFieldsHaveValues=N
ValidateUserDefinedFields=N
and others
[SESSION1]
#nothing out of the ordinary as below
[SESSION2]
BeginString=FIX.4.2
SenderCompID=RBDC
TargetCompID=IRDC
SocketConnectHost=192.168.42.80
SocketConnectPort=15000

And yet, all incoming 35=8 messages are being rejected with this error msg
Rejected: Tag not defined for this message type.

What am I doing wrong?
Can we request a simple configuration setting to suppress msgtypes?

Thank you
Raman



 Comments   
Comment by Raman [ 27/Sep/09 ]

I have solved this by modifying Session.java and placing the .class ahead of quickfix.jar.
rk2153 at gmail

Comment by Rhys Yarranton [ 10/May/10 ]

Discovered the following:

  • If unknown field is defined in the data dictionary, but not on the message type in question, then AllowUnknownMsgFields = true will have an effect.
  • If the unknown fields is not in the data dictionary at all, AllowUnknownMsgFields = true will have no effect.

The problem appears to be in the order of steps in the DataDictionary.iterate() method.

  • shouldCheckTag(field) only checks against user-defined fields (>= 5000) so it returns true.
  • dd.checkValidTagNumber(field) checks against the whole dictionary's field list
  • checkIsInMessage(field, msgType) is where AllowUnknownMsgFields is consulted. But this is too late if the field wasn't in the data dictionary at all.

Also note that the documentation for AllowUnknownMsgFields is misleading. The 1.4.0 implementation can have an effect regardless of the tag number.

Attached a patch which modifies iterate to skip dd.checkValidateTagNumber(field) and checkIsInMessage(field, msgType) if AllowUnknownMsgFields is true. I left dd.checkGroupCount(...) in place.

There may be some more fishiness in this area. For example, if you set ValidateUserDefinedFields to false, dd.checkGroupCount(...) will be skipped even if the field is in the data dictionary for the message. Is that right or wrong? It is not clear what the expected behaviour should be, especially given the inaccuracies in the documentation.

Please change this from "Other" to "Bug". We have customers who do weird things in production, such as sending us "mystery tags", and much as we might like them to adhere strictly to the spec, it isn't going to happen. So it is imperative that we are able to relax validation sufficiently to handle their behaviour.

Generated at Sat Nov 23 11:48:04 UTC 2024 using JIRA 7.5.2#75007-sha1:9f5725bb824792b3230a5d8716f0c13e296a3cae.