Package Data | |
---|---|
Maintainer Username: | marciojcoelho |
Maintainer Contact: | jason.koolman@hotmail.com (Jason Koolman) |
Package Create Date: | 2016-10-27 |
Package Last Update: | 2017-02-16 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-12-15 15:17:15 |
Package Statistics | |
---|---|
Total Downloads: | 108 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 0 |
Total Watchers: | 2 |
Total Forks: | 0 |
Total Open Issues: | 0 |
A simple and lightweight package to craft multi-tenant applications with Laravel.
This package relies on composer as dependency manger. Run the composer require marciojcoelho/multi-tenant
to install this package. Next add the service provider within config/app.php
: Mjc\MultiTenant\MultiTenantServiceProvider::class
in order to be bootstrapped.
Tenants are defined in config/tenant.php
. Make sure to run the php artisan vendor:publish
command to have this file created. By default, the tenant directories are located at storage/tenants/{tenantID}
. If you want to use a different base path, override the path
array key.
return [
'path' => storage_path('tenants'),
'hosts' => [
'mysite.com' => [
'id' => 'mysite',
'name' => 'MySite',
'https' => true,
],
'anothersite.com' => [
'id' => 'anothersite',
'name' => 'AnotherSite',
'https' => false,
'foo' => 'bar',
]
]
]
In some cases you might want to add custom tenant-specific parameters, like an API key, for instance. Simply use the helper function to retrieve a tenant-specific key value: tenant('foo')
.
In order for your models to deal with multiple connections, simply extend the TenantModel
class or implement the HasTenancy
trait. Both classes do exactly the same. Choose the approach you prefer.
Each tenant has it's own database, which you will want to migrate and seed every once in a while. Define your tenant connections within config/database.php
and simply add the --database
parameter to tell artisan which database to choose, for example:
php artisan migrate:refresh --database {tenantConnection} --seed
Each tenant has it's own assets which are, by default, stored at storage/tenants/{tenantID}/assets
. Use the helper function tasset('foo.svg')
to retrieve a tenant asset. This function will use the route asset/{path}
to retrieve assets outside the public directory.