Download the PHP package leemason/tenantable without Composer
On this page you can find all versions of the php package leemason/tenantable. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package tenantable
Tenantable
The Laravel Tenantable package is designed to enable multi-tenancy based database connections on the fly without having to access the database in every database call.
Installation
Just place require new package for your laravel installation via composer.json
Then hit composer dump-autoload
After updating composer, add the ServiceProvider to the providers array in config/app.php. You should ideally have this inserted into the array just after the to ensure its boot methods is called after the database is available but before any other Service Providers are booted.
Laravel 5.1:
Run the migrations
Then in your workflow create tenants the Eloquent way:
And that's it! Whenever your app is visited via http://domain.com the default database connection will be set with the above details.
Compatibility
The Tenantable package has been developed with Laravel 5.1, i see no reason why it wouldn't work with 5.0 but it is only tested for 5.1 and above.
Introduction
The package simply resolves the correct connection details via the domain accessed via connection details saved in the database.
Once resolved it sets the default database connection with the saved values.
This prevents the need to keep switching, or programatically accessing the right connection depending on the tenant being accessed.
This means all of your routes, models, etc will run on the active tenant database (unless explicitly stated via )
Lifecycle
This is how things work during a HTTP request:
- Tenantable copies the name of the default database connection into the config area.
- Tenantable gets the host string via the method.
- Tenantable looks for a tenant in the database that match this host.
- If one isn't found, Tenantable looks in the Domains table to find a match (and if found uses eloquent relationships to return the Tenant model.
- When a match is found, the match is saved as the active tenant, and the database details for the tenant are placed in the config.
- Then the default database connection is changed to 'tenant' and the connection purged (disconnected/reconnected).
- The config is set the tenants domain.
- If a match isn't found in either tables a TenantNotResolved event is fired and no config changes happen.
This is how it works during an artisan console request:
- Tenantable copies the name of the default database connection into the config area.
- Tenantable registers a console option of where you can supply the id,uuid,domain or *,all to run for all tenants.
- Tenantable checks to see if the tenant option is provided, if it isn't no tenant is resolved. The command runs normally.
- If a match is found it resolves the tenant (settings the tenant connection details) before excecuting the command.
- If you provide with either a or the string Tenantable will run the command foreach tenant found in the database, setting the active tenant before running each time.
The Resolver Class
The class responsible for resolving and managing the active tenant during http and console access.
The registers this class as a singleton for use anywhere in your app via method injection, or by using the helper function.
This class provides you with methods to access or alter the active tenant:
The Tenant Model
The class is a very simple Eloquent model with some database connection attributes, and a meta attribute which is cast to a when accessed.
Each attribute (except id,uuid,domain,driver,prefix,meta, and timestamps) are encrypted for security and are decrypted on access, encrypted on save automatically.
Each model instance is assigned a upon creation, this attribute cannot be set/changed as its a unique id generated for this tenant.
The reason for the uuid is to allow you to use an identifyer for the tenant elsewhere without exposing the tenants id or domain (for example in the filesystem, where you may store tenant specific files in sub folders).
The model can be used in any way other Eloquent models are to create/read/update/delete:
Events
The Tenantable packages produces a few events which can be consumed in your application
This event is fired when a tenant is set as the active tenant and has a public property containing the instance.
Note this may not be as a result of the resolver but is also fired when a tenant is set to active programatically.
This event is fired when a tenant is resolved by the resolver and has a public property containing the instance.
Note this is only fired once per request as the resolver is responsible for this event.
This event is fired when by the resolver when it cannot resolve a tenant and has a public property containing the instance.
Note this is only fired once per request as the resolver is responsible for this event.
Notes on using Artisan::call();
Using the Facade to run a command provides no access to alter the applications active tenant before running (unlike console artisan access).
Because of this the currently active tenant will be used.
To run the command foreach tenant you will need to fetch all tenants using and run the method inside a foreach after setting the active tenant like so:
If you need to run the Artisan facade on the original default connection (ie not the tenant connection) simply call the function first:
The Future
- Add tests
- Add meta items to laravel config