• Stars
    star
    232
  • Rank 172,847 (Top 4 %)
  • Language
    PHP
  • Created over 3 years ago
  • Updated 4 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Filament plugin that makes it easy to impersonate your users

Filament Impersonate

Latest Version on Packagist Software License

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:

composer require stechstudio/filament-impersonate

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:

namespace App\Filament\Resources;

use Filament\Resources\Resource;
use STS\FilamentImpersonate\Tables\Actions\Impersonate;

class UserResource extends Resource {
    public static function table(Table $table)
    {
        return $table
            ->columns([
                // ...
            ])
            ->actions([
                Impersonate::make(), // <--- 
            ]);
    }

You can also define a guard and redirectTo for the action:

Impersonate::make('impersonate')
    ->guard('another-guard')
    ->redirectTo(route('some.other.route'));

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.

<?php
namespace App\Filament\Resources\UserResource\Pages;

use App\Filament\Resources\UserResource;
use Filament\Resources\Pages\EditRecord;
use STS\FilamentImpersonate\Pages\Actions\Impersonate;

class EditUser extends EditRecord
{
    protected static string $resource = UserResource::class;

    protected function getActions(): array
    {
        return [
            Impersonate::make()->record($this->getRecord()) // <--
        ];
    }
}

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:

CleanShot 2022-01-03 at 14 10 36@2x

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:

banner

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:

class User implements FilamentUser {
    
    public function canImpersonate()
    {
        return true;
    }
    
}

You can also control which targets can be impersonated. Just add a canBeImpersonated method to the user class with whatever logic you need:

class User {

    public function canBeImpersonated()
    {
        // Let's prevent impersonating other users at our own company
        return !Str::endsWith($this->email, '@mycorp.com');
    }
    
}

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.

<x-impersonate::banner style='light'/>

Display name

The banner will show the name of the impersonated user, assuming there is a name attribute. You can customize this if needed:

<x-impersonate::banner :display='auth()->user()->email'/>

More Repositories

1

laravel-zipstream

Easily create Zip files on-the-fly and provide a streaming download
PHP
381
star
2

laravel-ssh-tunnel

Easy creation & maintenance of an SSH Tunnel for Laravel/Lumen
PHP
191
star
3

backoff

PHP library providing retry functionality with multiple backoff strategies and jitter support
PHP
187
star
4

Laravel-PHP-CS-Fixer

Artisan Command for FriendsOfPHP/PHP-CS_Fixer
PHP
146
star
5

laravel-jwt

Helper package that makes it easy to generate, consume, and protect routes with JWT tokens in Laravel
PHP
121
star
6

laravel-env-security

Securely manage Laravel .env files for different deployment environments
PHP
75
star
7

laravel-bref-bridge

Bref, the Laravel way.
PHP
71
star
8

laravel-metrics

Easily track metrics from Laravel events and ship to InfluxDB, Prometheus, CloudWatch, or PostHog.
PHP
46
star
9

libvips-lambda

libvips Executable for AWS Lambda
Shell
46
star
10

aws-lambda-build

Docker Image for building AWS Lambda executables.
Dockerfile
40
star
11

laravel-aws-lambda

⛔️ DEPRECATED: Running Laravel on AWS Lambda
PHP
33
star
12

laravel-visual-testing

Visual UI screenshot testing with Laravel Dusk using percy.io
PHP
32
star
13

php-lambda

Build PHP executables for AWS Lambda
Dockerfile
24
star
14

laravel-record

What if Laravel's Collection and Model classes had a baby?
PHP
22
star
15

laravel-raw-sessions

Laravel session driver to establish bridge with raw PHP $_SESSION
PHP
18
star
16

laravel-hubspot

PHP
17
star
17

bref-extensions

Build tools for compiling binaries and extensions against the bref layer.
Dockerfile
14
star
18

codeception-laravel-unittest

PHP
11
star
19

laravel-vfs-adapter

Virtual Filesystem Storage Adapter for Laravel
PHP
10
star
20

filament-opcache

Manage OPcache from your Filament admin panel.
PHP
7
star
21

laravel-socialite-auth

PHP
6
star
22

filament-phpinfo

View phpinfo from your Filament admin panel.
Blade
4
star
23

phpinfo

Easily interact with your PHP configuration
PHP
4
star
24

laravel-upload-server

PHP
3
star
25

chalice_helpers

Some utilities for AWS Chalice
Python
3
star
26

aws-events

Library to help manage the plethora of event configurations in AWS Lambda
PHP
3
star
27

bai2

PHP library for parsing BAI2 files
PHP
2
star
28

laravel-storage-connect

Laravel package to easily connect to cloud storage accounts and upload files
PHP
2
star
29

insult-service

Random Insults from Martin Luther
JavaScript
1
star
30

laravatar

Minimalist Blade component for displaying a Gravatar, or falling back to initials.
PHP
1
star
31

laravel-locking-migrations

PHP
1
star
32

laravel-email-events

Laravel package to normalize webhooks from email providers like SendGrid or Postmark
PHP
1
star
33

lbb-core

Laravel Vapor Core Lambda Bootstrap for your own Lambda Layer, like bref!
PHP
1
star
34

slack-laravel-api

Laravelized Slack PHP Api
PHP
1
star