PHPackages                             bmatovu/multi-auth - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Authentication &amp; Authorization](/categories/authentication)
4. /
5. bmatovu/multi-auth

ActiveLibrary[Authentication &amp; Authorization](/categories/authentication)

bmatovu/multi-auth
==================

Laravel Multi Authentication

v12.1.0(2y ago)18325.1k25[4 issues](https://github.com/mtvbrianking/multi-auth/issues)[1 PRs](https://github.com/mtvbrianking/multi-auth/pulls)MITPHPPHP ^8.1

Since Sep 22Pushed 2y ago9 watchersCompare

[ Source](https://github.com/mtvbrianking/multi-auth)[ Packagist](https://packagist.org/packages/bmatovu/multi-auth)[ RSS](/packages/bmatovu-multi-auth/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (10)Dependencies (8)Versions (49)Used By (0)

Laravel Multi-Authentication Package
====================================

[](#laravel-multi-authentication-package)

[![Total Downloads](https://camo.githubusercontent.com/70972ff70799f0813ed453c6d0d3ed070403f09437265eaa6cec0d4ac45f9f54/68747470733a2f2f706f7365722e707567782e6f72672f626d61746f76752f6d756c74692d617574682f646f776e6c6f616473)](https://packagist.org/packages/bmatovu/multi-auth)[![Latest Stable Version](https://camo.githubusercontent.com/5157ba19c4f2254ac19406e8580678ca01caa3f5bf3138afb2b0fdb91497e0c8/68747470733a2f2f706f7365722e707567782e6f72672f626d61746f76752f6d756c74692d617574682f762f737461626c65)](https://packagist.org/packages/bmatovu/multi-auth)[![Quality](https://camo.githubusercontent.com/47cfd883231ced4b1c2aef5e706871ffb4a5a6a31f6f6a0259214c1d0c298493/68747470733a2f2f7363727574696e697a65722d63692e636f6d2f672f6d7476627269616e6b696e672f6d756c74692d617574682f6261646765732f7175616c6974792d73636f72652e706e673f623d6d6173746572)](https://scrutinizer-ci.com/g/mtvbrianking/multi-auth/?branch=master)[![Coverage](https://camo.githubusercontent.com/cd1f67121b0d62ce3f4308300f1eaee0c35eaecf53b5806a6f72292ca41e9a5a/68747470733a2f2f7363727574696e697a65722d63692e636f6d2f672f6d7476627269616e6b696e672f6d756c74692d617574682f6261646765732f636f7665726167652e706e673f623d6d6173746572)](https://scrutinizer-ci.com/g/mtvbrianking/multi-auth/?branch=master)[![Unit Tests](https://github.com/mtvbrianking/multi-auth/workflows/run-tests/badge.svg)](https://github.com/mtvbrianking/multi-auth/actions?query=workflow:run-tests)

This package gives you the ability to separate user areas in your application.

E.g, an ecommerce application with customers, sellers, and administrators user areas using [auth guards](https://laravel.com/docs/master/authentication#adding-custom-guards)

Prerequisite
------------

[](#prerequisite)

This package only extends the official [`laravel/breeze`](https://github.com/laravel/breeze) starter kit, it doesn't regenerate the frontend assets \[js, css - tailwind, vite, ...\]

Therefore, you need to use it after scaffolding basic auth using Breeze.

**Breaking Changes**

For old versions (Laravel v9 and below) refer to [v11](https://github.com/mtvbrianking/multi-auth/tree/11.x)

Installation
------------

[](#installation)

```
composer require bmatovu/multi-auth --dev
```

Scaffolding
-----------

[](#scaffolding)

```
php artisan multi-auth:install admin
```

Register service provider
-------------------------

[](#register-service-provider)

> config/app.php

```
  'providers' => [
      /*
      * Package Service Providers...
      */
+     App\Modules\Admins\AdminServiceProvider::class,
  ],
```

Register JS entry point in Vite (Inertia - Vue, React)
------------------------------------------------------

[](#register-js-entry-point-in-vite-inertia---vue-react)

> vite.config.js

```
  export default defineConfig({
      plugins: [
          laravel({
-             input: 'resources/js/app.js',
+             input: [
+                 'resources/js/app.js',
+                 'resources/js/Admins/app.js',
+             ],
-             ssr: 'resources/js/ssr.js',
+             ssr: [
+                 'resources/js/ssr.js',
+                 'resources/js/Admins/ssr.js',
+             ],
              refresh: true,
          }),
          ...
      ],
  });
```

Read more about [Inertia Server Side Rendering](https://inertiajs.com/server-side-rendering)

Recompile frontend assets
-------------------------

[](#recompile-frontend-assets)

```
npm run build
```

Run Database Migrations
-----------------------

[](#run-database-migrations)

```
php artisan migrate
```

Possible approaches for separating user areas
---------------------------------------------

[](#possible-approaches-for-separating-user-areas)

### Using sub-domains

[](#using-sub-domains)

Separate user areas by sub-domains.

*I would use separate repos for each sub-domain*

URIUser Grouplarastore.comcustomersseller.larastore.comsellersadmin.larastore.comadministrators### Using URLs\*

[](#using-urls)

*Separate user areas based on URLs. Restricted with auth guards*

\* What this package offers

URIUser Grouplarastore.comcustomerslarastore.com/sellersellerslarastore.com/adminadministrators### Using roles

[](#using-roles)

Restrict access based on the user's roles and permissions

*I'd stay away from this approach as it'd more complex to maintain for large projects*

URIUser Grouplarastore.comcustomers, sellers, administrators

###  Health Score

46

—

FairBetter than 93% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity42

Moderate usage in the ecosystem

Community18

Small or concentrated contributor base

Maturity85

Battle-tested with a long release history

 Bus Factor1

Top contributor holds 98.6% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~52 days

Recently: every ~301 days

Total

47

Last Release

755d ago

Major Versions

7.x-dev → v8.0.02019-09-06

8.x-dev → v9.0.02020-03-24

9.x-dev → v10.0.02020-09-12

v10.4.0 → v11.0.02022-05-15

11.x-dev → v12.0.02023-03-08

PHP version history (9 changes)v1.0.0PHP &gt;=5.6.4

4.x-devPHP &gt;=7.0.0

v5.0.0PHP ^7.1.3

v8.0.0PHP &gt;=7.2

v9.0.0PHP ^7.2.5

v10.0.0PHP ^7.3

10.x-devPHP ^7.3|^8.0

v11.0.0PHP ^8.0.2

v12.0.0PHP ^8.1

### Community

Maintainers

![](https://www.gravatar.com/avatar/0cc99b58d12a288f0fd19099cc3c724ff4df84d978df0e7451b650e8182bc919?d=identicon)[bmatovu](/maintainers/bmatovu)

---

Top Contributors

[![mtvbrianking](https://avatars.githubusercontent.com/u/5412360?v=4)](https://github.com/mtvbrianking "mtvbrianking (144 commits)")[![ankurk91](https://avatars.githubusercontent.com/u/6111524?v=4)](https://github.com/ankurk91 "ankurk91 (1 commits)")[![mkarnicki](https://avatars.githubusercontent.com/u/2966794?v=4)](https://github.com/mkarnicki "mkarnicki (1 commits)")

---

Tags

authenticationguardlaravellaravel-multi-authenticationscaffoldlaravelauthmulti

###  Code Quality

TestsPHPUnit

Code StylePHP CS Fixer

### Embed Badge

![Health badge](/badges/bmatovu-multi-auth/health.svg)

```
[![Health](https://phpackages.com/badges/bmatovu-multi-auth/health.svg)](https://phpackages.com/packages/bmatovu-multi-auth)
```

###  Alternatives

[tymon/jwt-auth

JSON Web Token Authentication for Laravel and Lumen

11.5k49.1M350](/packages/tymon-jwt-auth)[laravel/cashier

Laravel Cashier provides an expressive, fluent interface to Stripe's subscription billing services.

2.5k25.9M107](/packages/laravel-cashier)[php-open-source-saver/jwt-auth

JSON Web Token Authentication for Laravel and Lumen

8359.8M53](/packages/php-open-source-saver-jwt-auth)[laravel/pulse

Laravel Pulse is a real-time application performance monitoring tool and dashboard for your Laravel application.

1.7k12.1M99](/packages/laravel-pulse)[laravel-doctrine/orm

An integration library for Laravel and Doctrine ORM

8425.3M87](/packages/laravel-doctrine-orm)[ollieread/multiauth

Alternative auth system for Laravel

443135.6k1](/packages/ollieread-multiauth)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
