Download the PHP package stechstudio/filament-impersonate without Composer
On this page you can find all versions of the php package stechstudio/filament-impersonate. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download stechstudio/filament-impersonate
More information about stechstudio/filament-impersonate
Files in stechstudio/filament-impersonate
Package filament-impersonate
Short Description A Filament package to impersonate your users.
License MIT
Informations about the package filament-impersonate
Filament Impersonate
This is a plugin for Filament that makes it easy to impersonate your users.
Credit
This package uses https://github.com/404labfr/laravel-impersonate under the hood, and borrows heavily from https://github.com/KABBOUCHI/nova-impersonate.
Installation
You know the drill:
Quickstart
1. Add table action
First open the resource where you want the impersonate action to appear. This is generally going to be your UserResource
class.
Go down to the table
method. After defining the table columns, you want to add Impersonate
as a new action for the table via actions
method. Your class should look like this:
You can also define a guard
and redirectTo
for the action:
2. Add the page action
Now open the page where you would want the button to appear, this will commonly be EditUser
;
Go to the getActions
method and add the Impersonate
page action here.
Note: you must pass the record in as seen in this example!
3. Add the banner to your blade layout
The only other step is to display a notice in your app whenever you are impersonating another user. Open up your master layout file and add <x-impersonate::banner/>
before the closing </body>
tag.
4. Profit!
That's it. You should now see an action icon next to each user in your Filament UserResource
list:
When you click on the impersonate icon you will be logged in as that user, and redirected to your main app. You will see the impersonation banner at the top of the page, with a button to leave and return to Filament:
Configuration
All configuration can be managed with ENV variables, no need to publish and edit the config directly. Just check out the config file.
Authorization
By default, only Filament admins can impersonate other users. You can control this by adding a canImpersonate
method to your FilamentUser
class:
You can also control which targets can be impersonated. Just add a canBeImpersonated
method to the user class with whatever logic you need:
Customizing the banner
The blade component has a few options you can customize.
Style
The banner is dark by default, you can set this to light, or auto.
Display name
The banner will show the name of the impersonated user, assuming there is a name
attribute. You can customize this if needed: