Download the PHP package henryavila/laravel-nova-multitenancy without Composer
On this page you can find all versions of the php package henryavila/laravel-nova-multitenancy. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download henryavila/laravel-nova-multitenancy
More information about henryavila/laravel-nova-multitenancy
Files in henryavila/laravel-nova-multitenancy
Package laravel-nova-multitenancy
Short Description Integrate the multi tenancy single database in Laravel Nova.
License proprietary
Homepage https://github.com/henryavila/laravel-nova-multitenancy
Informations about the package laravel-nova-multitenancy
Integrate the multitenancy single database in Laravel Nova.
Integrate the multitenancy single database in Laravel Nova.
This package is based on https://spatie.be/docs/laravel-multitenancy. So logic and config of spatie/laravel-multitenancy still aplies
Installation
You can install the package via composer:
You can publish the config, view, migrations and translation with:
The views file will be published, personalize it at your will.
Don't forget to run npm run build
You can run the migration with (To create the Tenant table)
Edit the app\Http\Kernel.php
file adding an entry in web group and creating the tenant group
If you activated (User Impersonation)[https://nova.laravel.com/docs/4.0/customization/impersonation.html] on Laravel Nova, you must set up this event Listeners.
Edit the file App\Providers\EventServiceProvider
and add:
Make your User
model extends \HenryAvila\LaravelNovaMultitenancy\Models\User
If you want to customize the Tenant model, change it in config file
Add the trait \HenryAvila\LaravelNovaMultitenancy\Traits\ModelWithTenant
to all models that are tenant aware
Add to your database
file a tenant_connection
entry with the tenant db connection. See:
This is the relation between the connections and the database
Name | Database |
---|---|
default | Landlord database |
tenant_connection | Tenant database |
PS.: Don't forget to create this connections in database.connections
config file.
Usage
To protect a specific route, just add the 'tenant' middleware to route
If you receive an error: Route [login] not defined.
.
Remember to change the route from login
to nova.login
in your App\Http\Middleware\Authenticate
file
Another option to don't define the tenant to an route is set the following default
data to route declaration
If the Tenant
has domains
relationship, allow to define the current tenant based on current domain.
The domains
relation model, must contain an fqdn
attribute with the fqdn domain
Testing
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
- Henry Ávila
- All Contributors
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-nova-multitenancy with dependencies
illuminate/contracts Version ^9.0|^10.0|^11.0
spatie/laravel-multitenancy Version ^3.0.2
spatie/laravel-package-tools Version ^1.14.0