Skip to content

waldemarnt/cake-multi-tenant

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Multi tenant CakePHP (2.x) Plugin

The Multi Tenant plugin allows an application to be separated in several applications having own routes, sharing the same code and different databases (or the same).

##Installing Via composer:

    composer require waldemarnt/cake-multi-tenant

Or just download the repository here

##Configuration

###bootstrap.php configuration

Just call the plugin below the Dispatch configuration in your boostrap, enable routes and boostrap.

    CakePlugin::load('CakeMultiTenant', array('routes' => true, 'bootstrap' => true));

###core.php configuration In the core file you will need add the several properties. Current tenant (or default).

    Configure::write('Config.current_tenant', 'example');

Note: current tenant will be the active tenant, you can use this information to know which tenant is active.

Tenant configuration will be an array using the tenant name as a index and connection_name will be the name of database connection that the tenant will use.

    Configure::write('Config.multi_tenant_config', [
            'example' => [
                'name' => 'Example Tenant',
                'connection_name' => 'my_custom_db_connection'
            ],
            'waldemar' => [
                'name' => 'Waldemar',
                'connection_name' => 'my_other_db_connection'
            ]
        ]
    );

###database.php configuration In the database file you just need add the configuration for each tenant like this:

	public $my_custom_db_connection = array(
		'datasource' => 'Database/Mysql',
		'persistent' => false,
		'host' => '172.17.0.3',
		'login' => 'root',
		'password' => 'root',
		'database' => 'db_one',
		'prefix' => '',
		//'encoding' => 'utf8',
	);

	public $my_other_db_connection = array(
		'datasource' => 'Database/Mysql',
		'persistent' => false,
		'host' => '172.17.0.3',
		'login' => 'root',
		'password' => 'root',
		'database' => 'db_two',
		'prefix' => '',
		//'encoding' => 'utf8',
	);

AppModel.php configuration

Just extend your AppModel from MultiTenantAppModel, the MultiTenantAppModel that handles the database switch when the model will be created.

    App::uses('MultiTenantAppModel', 'CakeMultiTenant.Model');

    class AppModel extends MultiTenantAppModel {
    
    }

###AppController.php In the AppController you will need configure two stuffs, Html Helper and AuthComponent (if you need auth :D). Html helper configuration:

    
    public $helpers = array(
        'Html' => array('className' => 'CakeMultiTenant.MultiTenantHtml'),
    );

AuthComponent configuration:

    public $components = array(
        'Auth' => [
			'className' => 'CakeMultiTenant.MultiTenantAuth'
    );

Note: you can add loginAction and LoginRedirect configurations in the Auth component there's no change in the original behavior of the component.

Version

0.*

About

Plugin that allows CakePHP(2.x) applications have multi tenants with multiples databases and own routes.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages