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

Make exceptions that prevent transitions available #970

Open
wants to merge 8 commits into
base: main
Choose a base branch
from

Conversation

egreijus
Copy link
Contributor

Sometimes it's desirable to know what caused the denial of a state transition. For instance, a user might want to trigger a state transition by submitting an event coupled with data.
In this case the transition might fail because of:

  1. An invalid state transition. The source state of the machine does not match any of the valid transitions configured.
  2. Insufficient (or unauthenticated) access rights. The state transition requires a role the user does not have.
  3. Exception thrown by an action that is run for the state transition.

In each of these cases the user can be made aware of the outcome (transition/no transition) but it's quite complicated to find out the reason to why a transition would be denied.
Getting hold of the exception that prevented the transition would make this a lot easier.

This problem has been mentioned in issues: #548, #553 and #340 and this proposed change provides a way to get hold of this piece of information.

(A CLA has been completed)

@jvalkeal
Copy link
Contributor

jvalkeal commented Jun 26, 2021

I think we should expose error in a different way as setting it on a machine itself is wrong. You would never really know from where that throwable was set and it'd stay there forever. Maybe we could enhance StateMachineEventResult or something around it to expose what you need?

@egreijus
Copy link
Contributor Author

Good point. It's been refactored now.

@davidjohansson
Copy link

Any progress on this issue? We are facing the same problem and need to find a way to get the exception that was thrown inside of an action.

@tarockx
Copy link

tarockx commented Feb 1, 2023

Was this ever addressed? I'm facing the same issue, is this PR currently the best solution?

@giovanni-mazzucco-e-projectsrl

Catching exceptions and being able to log them is crucial. For me it is a necessary change as soon as possible

@Zhoth
Copy link

Zhoth commented Feb 17, 2023

Please accept this pull request because it's a crucial feature for my project.

@Ma55imo
Copy link

Ma55imo commented Feb 17, 2023

Please pull

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants