-
Notifications
You must be signed in to change notification settings - Fork 387
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
[#5112] feat(core): support pre event for event listener systems #5110
Conversation
9740528
to
269e7c6
Compare
* | ||
* <p>This method provides a hook for pre-operation event processing, any changes you make to the | ||
* resources during the event will be reflected in the operations that follow. You must set mode | ||
* to SYNC to process pre events. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do we need to set SYNC to support pre events?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
removed
@@ -35,25 +37,45 @@ public class EventBus { | |||
// which are meant for synchronous event listening, or AsyncQueueListener, designed for | |||
// asynchronous event processing. | |||
private final List<EventListenerPlugin> postEventListeners; | |||
// Only contain sync EventListenerPlugins. | |||
private final List<EventListenerPlugin> preEventListeners; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do we need to have 2 listeners for pre and post event separately?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
removed
@jerryshao please help to review again |
*/ | ||
void onPostEvent(Event event) throws RuntimeException; | ||
default void onPostEvent(Event postEvent) throws RuntimeException {} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do we change to default
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
after supporting pre event, the user who only interest on pre event, could only implement onPreEvent interface, no need to implement onPostEvent interface
* Handles events generated after the completion of an operation. Implementers are responsible for | ||
* processing these events, which may involve additional logic to respond to the operation | ||
* outcomes. | ||
* Handles events generated after the completion of an operation. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"Handle post-events..."
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
updated
default void onPostEvent(Event postEvent) throws RuntimeException {} | ||
|
||
/** | ||
* Handles pre events generated before the operation. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"Handle pre-events..."
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
updated
private void dispatchPostEvent(Event postEvent) { | ||
eventListeners.forEach(postEventListener -> postEventListener.onPostEvent(postEvent)); | ||
} | ||
|
||
private void dispatchPreEvent(PreEvent preEvent) throws ForbiddenException { | ||
eventListeners.forEach(preEventListener -> preEventListener.onPreEvent(preEvent)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually, we don't differentiate pre or post event listeners, the code here is a little confusing. We can change to:
private void dispatchPostEvent(Event postEvent) {
eventListeners.forEach(listener -> listener.onPostEvent(postEvent));
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ok
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
LOG.warn( | ||
"Event listener {} process pre event {} failed, will skip the operation.", | ||
listenerName, | ||
preEvent.getClass().getSimpleName(), | ||
e); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think you can extract the common part here to simplify the code.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
* Handles pre events generated before the operation. | ||
* | ||
* <p>This method handles pre-operation events in SYNC or ASYNC mode, any changes to resources in | ||
* the event will inflect the subsequent operations. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"will affect..."
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
* @throws ForbiddenException The operation will be skipped if and only if throwing {@code | ||
* org.apache.gravitino.exceptions.ForbiddenException} and the event listener is SYNC mode, | ||
* the exception will be ignored in other conditions. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you please explain about the exception here, how you handle this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
updated
What changes were proposed in this pull request?
support pre event for event listener systems
PreEvent
to represent Pre event and onlySYNC
event listeners could processPreEvent
Event
as post event to keep compatibility.EventBus
dispatch event to corresponding event listeners.Why are the changes needed?
Fix: #5112
Does this PR introduce any user-facing change?
no
How was this patch tested?
add UT