Skip to content
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

DIDComm message handler breaks out of message handler flow #944

Closed
rkreutzer opened this issue Jun 17, 2022 · 3 comments · Fixed by #1064
Closed

DIDComm message handler breaks out of message handler flow #944

rkreutzer opened this issue Jun 17, 2022 · 3 comments · Fixed by #1064
Labels
bug Something isn't working pinned don't close this just for being stale

Comments

@rkreutzer
Copy link
Contributor

Once a DIDComm v2 message is unpacked, no further messageHandlers are executed. Maybe this is intended behavior, but I was expecting to use subsequent message handlers to perform more processing on the message.

The fix would be easy, changing line 124 of the DidComm message-handler.ts from "return message" to "return super.handle(message, context)".

@rkreutzer rkreutzer added the bug Something isn't working label Jun 17, 2022
@mirceanis
Copy link
Member

We found that our original message chaining design was confusing for a lot of folks and that's why we decided to try to change it.

We didn't actually get to change the behavior of the other message handlers, leading to this bug.

I think the fix you propose should be good to align the behavior of the handlers, but I'd still like to come up with a better solution for all.


One of the ideas was to split message handlers into parsers and handlers

Parsers can be chained, just like the the handlers of today, and they should return a message as soon as a message type is decoded.

Then the message with a type can be broadcast to all the handlers, which can do further processing and rebroadcast a message with a different type, if for example there's a different layer that can be decoded.

This seemingly more complicated design should accommodate handlers that can handle multiple messages (like a message forwarding handler) and messages that can be interpreted by multiple handlers ( a jwt string can be both a final message as well as an envelope for another protocol)

Another reason for a redesign is the fact that our chaining logic today doesn't differentiate between an invalid signature and an exceptional failure (like failing to resolve a DID while trying to verify a signature) leading to very unhelpful "Unsupported message type“ errors.

Any feedback here is very welcome!

@rkreutzer
Copy link
Contributor Author

I submitted a PR for this fix.

Maybe I've just gotten used to the current method of chaining, but I think that any confusion can be dealt with in more documentation and some more examples. Some apps may only need a few handlers, if they are working with a limited scope of messages, while other apps may need more handlers to process a wider variety of messages.

The broadcast/rebroadcast idea may add more complexity than is needed. I'd rather see a move to a single package for message handling, with the various handlers being within that, so each new handler doesn't require a unique package/plugin.

@stale
Copy link

stale bot commented Sep 21, 2022

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions.

@stale stale bot added the wontfix This will not be worked on label Sep 21, 2022
@mirceanis mirceanis added the pinned don't close this just for being stale label Sep 21, 2022
@stale stale bot removed the wontfix This will not be worked on label Sep 21, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working pinned don't close this just for being stale
Projects
None yet
2 participants