-
-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
4 events for adding and removing roles or permissions #2742
base: main
Are you sure you want to change the base?
Conversation
…d` and `RoleDetached`
…d` and `RoleDetached`
…d` and `RoleDetached`
@parallels999 You're absolutely right. I added it. |
This will work only when giving programaticly roles/permissions, but when used in tool like Laravel Nova or some other tool where a record is added to the pivot table, events will not be fired. I used a approach of PivotTable model and emit event against its created & deleted hooks, which doesnt care how you add or sync the permissions, its looks the pivot events and then fires evets. I'm writing this so others can try it if they need it: Overide the permisison relation on the public function permissions(): BelongsToMany
{
// ...
return $relation = $this->morphToMany(
config('permission.models.permission'),
'model',
config('permission.table_names.model_has_permissions'),
config('permission.column_names.model_morph_key'),
PermissionRegistrar::$pivotPermission
)->using(\App\Models\Pivots\ModelHasPermissions::class); // Use custom pivot class here
}
use Illuminate\Database\Eloquent\Relations\MorphPivot;
class ModelHasPermissions extends MorphPivot
{
// ..
} And create observer class ModelHasPermissionsObserver
{
public function created(ModelHasPermissions $pivot)
{
event(new PermissionAttached($pivot->model, $pivot->permission));
}
public function deleted(ModelHasPermissions $pivot)
{
event(new PermissionRemoved($model, $pivot->permission));
}
} Observe for changes in AppServiceProvider: ModelHasPermissions::observe(ModelHasPermissionsObserver::class); You can do the same for the roles. |
Wouldn't |
Looking further, The downside to specifying a pivot model is that it introduces an extra db query. But the upside is that you can register observers to it. |
@votkapower Sure I can override the method, but I would prefer if the package provides this configuration or the event itself :) @drbyte This is also a very good idea and would be easy to implement. I would like both. Which idea do we want to give a chance? :) |
First of all: This is my first pull request. If everything is not correct, please give me feedback!
Why I created this pull request
In my company we have an API and a UI. If changes have been made to permissions or roles (e.g. because an additional service has been booked), the UI wants to be informed about this. In my opinion, events are perfect for this!
Unfortunately, this package does not currently offer such events, as the
HasRoles::roles()
andHasPermissions::permissions()
methods do not fire any. There is also no observer, as there is noModel
class for the pivot table.This pull request adds 4 events
PermissionAttached
,PermissionDetached
,RoleAttached
andRoleDetached
for adding and removing roles or permission.You can then have a listener listen to these in the main instance or work directly with sockets.