Package Data | |
---|---|
Maintainer Username: | gecche |
Maintainer Contact: | giacomo.terreni@gmail.com (Giacomo Terreni) |
Package Create Date: | 2016-02-06 |
Package Last Update: | 2024-05-30 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-15 03:03:21 |
Package Statistics | |
---|---|
Total Downloads: | 161,468 |
Monthly Downloads: | 3,182 |
Daily Downloads: | 117 |
Total Stars: | 874 |
Total Watchers: | 28 |
Total Forks: | 106 |
Total Open Issues: | 11 |
An extension for using Laravel in a multi domain setting
This package allows a single Laravel installation to work with multiple HTTP domains.
There are many cases in which different customers use the same application in terms of code but not in terms of database, storage and configuration.
This package gives a very simple way to get a specific env file, a specific storage path and a specific database for each such customer.
Laravel | Multidomain :---------|:---------- 5.5.x | 1.1.x 5.6.x | 1.2.x 5.7.x | 1.3.x 5.8.x | 1.4.x 6.x | 2.x
Releases v1.1.x:
To date, releases v1.1.6+, v1.2.x, v1.3.x, v1.4.x and v2.x are functionally equivalent. Releases have been separated in order to run integration tests with the corresponding version of the Laravel framework.
v1.0 requires Laravel 5.1, 5.2, 5.3 and 5.4 (no longer maintained and not tested versus laravel 5.4, however the usage of the package is the same as for 1.1)
Add gecche/laravel-multidomain as a requirement to composer.json:
{
"require": {
"gecche/laravel-multidomain": "2.*"
}
}
Update your packages with composer update or install with composer install.
You can also add the package using composer require gecche/laravel-multidomain
and later
specify the version you want (for now, dev-v1.1.* is your best bet).
This package needs to override the detection of the HTTP domain in a minimal set of Laravel core functions at the very start of the bootstrap process in order to get the specific environment file. So this package needs a few more configuration steps than most Laravel packages.
Installation steps:
bootstrap/app.php
file.//$app = new Illuminate\Foundation\Application(
$app = new Gecche\Multidomain\Foundation\Application(
$_ENV['APP_BASE_PATH'] ?? dirname(__DIR__)
);
At the very top of the app/Http/Kernel.php
file , do the following change:
//use Illuminate\Foundation\Http\Kernel as HttpKernel;
use Gecche\Multidomain\Foundation\Http\Kernel as HttpKernel;
Similarly in the ``app/Console/Kernel.php` file:
//use Illuminate\Foundation\Console\Kernel as ConsoleKernel;
use Gecche\Multidomain\Foundation\Console\Kernel as ConsoleKernel;
QueueServiceProvider
with the extended
one in the $providers
array in the config/app.php
file: //Illuminate\Queue\QueueServiceProvider::class,
Gecche\Multidomain\Queue\QueueServiceProvider::class,
php artisan vendor:publish
(This package makes use of the discovery feature.)
Following the above steps, your application will be aware of the HTTP domain in which is running, both for HTTP and CLI requests, including queue support.
This package adds three commands to manage your application HTTP domains:
domain.add
artisan commandThe main command is the domain:add
command which takes as argument the name of the
HTTP domain to add to the application. Let us suppose we have two domains, site1.com
and site2.com
, sharing the same code.
We simply do:
php artisan domain:add site1.com
and
php artisan domain:add site2.com
These commands create two new environment files, .env.site1.com
and .env.site2.com
,
in which you can put the specific configuration for each site (e.g. databases configuration,
cache configuration and other configurations, as usually found in an environment file).
The command also adds an entry in the domains
key in config/domains.php
file.
In addition, two new folders are created, storage/site1_com/
and storage/site2_com/
.
They have the same folder structure as the main storage.
Customisations to this storage
substructure must be matched by values in the config/domain.php
file.
domain.remove
artisan commandThe domain:remove
command removes the specified HTTP domain from the
application by deleting its environment file. E.g.:
php artisan domain:remove site2.com
Adding the force
option will delete the domain storage folder.
The command also removes the appropriate entry from, the domains
key in config/domains.php
file.
domain.update_env
artisan commandThe domain:update_env
command passes a json encoded array of data to update one or all of the environment files.
These values will be added at the end of the appropriate .env.
Update a single domain environment file by adding the domain
option.
When the domain
option is absent, the command updates all the environment files, including the standard .env
one.
The list of domains to be updated is maintained in the domain.php
config file.
E.g.:
php artisan domain:update_env --domain_values='{"TOM_DRIVER":"TOMMY"}'
will add the line TOM_DRIVER=TOMMY
to all the domain environment files.
domain.list
artisan commandThe domain:list
command lists the currently installed domains, with their .env file and storage path dir.
The list is maintained in the domains
key of the config/domain.php
config file.
This list is automatically updated at every domain:add
and domain:remove
commands run.
config:cache
artisan commandThe config:cache artisan command can be used with this package in the same way as any other artisan command.
Note that this command will generate a file config.php file for each domain under which the command has been executed. I.e. the command
php artisan config:cache --domain=site2.com
will generate the file
config-site2_com.php
At run-time, the current HTTP domain is maintained in the laravel container
and can be accessed by its domain()
method added by this package.
A domainList()
method is available. It returns an associative array
containing the installed domains info, similar to the domain.list
command above.
E.g.
[
site1.com => [
'storage_path' => <LARAVEL-STORAGE-PATH>/site1_com,
'env' => '.env.site1.com'
]
]
For each HTTP request received by the application, the specific environment file is loaded and the specific storage folder is used.
If no specific environment file and/or storage folder is found, the standard one is used.
The detection of the right HTTP domain is done by using the $_SERVER['SERVER_NAME']
PHP variable.
In order to distinguishing between domains, each artisan command accepts a new option: domain
. E.g.:
php artisan list --domain=site1.com
The command will use the corresponding domain settings.
The artisan commands queue:work
and queue:listen
commands have been updated
to accept a new domain
option.
php artisan queue:work --domain=site1.com
As usual, the above command will use the corresponding domain settings.
Keep in mind that if, for example, you are using the database
driver and you have two domains sharing the same db,
you should use two distinct queues if you want to manage the jobs of each domain separately.
For example, you could:
QUEUE_DEFAULT=default1
for site1.com and QUEUE_DEFAULT=default2
for site2.comqueue.php
config file by changing the default queue accordingly:'database' => [
'driver' => 'database',
'table' => 'jobs',
'queue' => env('QUEUE_DEFAULT','default'),
'retry_after' => 90,
],
php artisan queue:work --domain=site1.com --queue=default1
and
php artisan queue:work --domain=site1.com --queue=default2
Obviously, the same can be done for each other queue driver, apart from the sync
driver.