-
Notifications
You must be signed in to change notification settings - Fork 66
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
How to handle malformed JSON on message payload? #77
Comments
Since servicebus-retry is a middleware, it doesn't yet have access to the message content at this point, because it hasn't been parsed and turned into json. I think, long term, the way to fix this is to no longer have formatters. You would just have middleware, and everyone would likely just use a What you might be able do to alleviate this is 1) set your formatter (used here servicebus/bus/rabbitmq/queue.js Line 93 in 670ebfc
content in both scenarios. 2) create a json middleware that does stringify on outboundMessage and parse on inboundMessage.
It's possible, however that you may need two middleware's however - one at the top of your stack for sending and one at the bottom of your stack for inbound. |
Hi @keizohirata. I've created a PR at #91. Can you test and see if this gives you the behavior you'd prefer? |
Can you not just make it a "string" and let the consumer handle the format as needed? |
The problem is the rippling effect up the middleware chain it would require to get the retry behavior expected. upstream middleware, including servicebus-retry, expect the incoming message to be an object, in order to append functions on it which it then uses to ack or reject. You could change the formatter to be a middleware, but it would need to be higher in the stack than retry. There are some options for doing this refactoring (allow middleware to pass errors forward to the end of the pipeline, make retry a sort of plugin instead of middleware) but all would introduce a breaking change. |
@mateodelnorte , there are any reason why #91 isn't merged yet? |
yeah, @alexkazantsev, it doesn't really handle the issue correctly. What you really want is to catch the json parse error in the middle of the middleware chain, after retry() has seen the message, so you can call reject() on it and have it try again. As it stands, the parsing is before the middleware pipeline (because all the middleware rely on the message being an object). so, it would really take a larger re-architecting of the middleware pipeline and probably a reworking of the retry middleware. happy to do it, but it's going to be a larger effort and other things currently have priority. if it's something you'd like to take a swack at, I'd be happy to talk all about it and lead you through on nycnode.com/slack or on here. |
I was running some tests sending the messages directly from RabbitMQ Manager. Then I sent a malformed JSON and my application stopped with the following exception:
I thought that this kind of issue should be solved by the servicebus-retry package. So after N attempts to process the message, I thought that the message could be put on the '.error' queue. But I was wrong and the application just stopped.
Am I doing something wrong on how to handle this situation?
The text was updated successfully, but these errors were encountered: