-
Notifications
You must be signed in to change notification settings - Fork 11.3k
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
Registering observers with the ObservedBy attribute is not tracked by event:list command #53616
Comments
Thank you for reporting this issue! As Laravel is an open source project, we rely on the community to help us diagnose and fix issues as it is not possible to research and fix every issue reported to us via GitHub. If possible, please make a pull request fixing the issue you have described, along with corresponding tests. All pull requests are promptly reviewed by the Laravel team. Thank you! |
The issue occurs because PHP attributes like ObservedBy are inspected at runtime. Observers registered using attributes are resolved only when the corresponding model is bootstrapped. However, the php artisan event:list command does not bootstrap models, so their observers are not resolved, and related events do not appear in the list. To include these in php artisan event:list, a mechanism is needed to discover and bootstrap all models in the application. This could be achieved by:
|
I also noticed in this discuss #53607 another behavior that differs. |
Yeah. Same issue. Adding new trait in a model wont make any effect until the model is bootstrapped. |
It's true, but seems hard to fix the issue ... |
Right, I suggested two solutions, but fixing it might feel like more hassle than it’s worth—still, if someone needs it to work, they could give them a shot. |
The second option here sounds like it would be annoying and laborious for developers using Laravel, and an auto-discovery convention similar to the one employed with event listeners would be far preferable. So as not to negatively affect performance though, implementing that would also necessitate implementing a caching mechanism (again, as is the case with event listeners) so that It looks like it would be fairly straightforward to implement both of those features though, with some modifications to I'd be interested in working on this if it sounds like something the Laravel team would be happy to merge. |
imho it would be important to take into account and try to align also the different behaviors of #53607 |
Laravel Version
11.33.2
PHP Version
8.2.24
Database Driver & Version
No response
Description
Hi, I noticed that when I register an observers with the
ObservedBy
attribute is not tracked byevent:list
command while via observe method in an AppServiceProvider this is appropriately tracked.Steps To Reproduce
php artisan event:list
commandThe text was updated successfully, but these errors were encountered: