2018-10-18 16:04:36 +11:00
|
|
|
<?php
|
2019-05-11 13:32:07 +10:00
|
|
|
/**
|
|
|
|
|
* Invoice Ninja (https://invoiceninja.com)
|
|
|
|
|
*
|
|
|
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
|
|
|
*
|
|
|
|
|
* @copyright Copyright (c) 2019. Invoice Ninja LLC (https://invoiceninja.com)
|
|
|
|
|
*
|
|
|
|
|
* @license https://opensource.org/licenses/AAL
|
|
|
|
|
*/
|
2018-10-18 16:04:36 +11:00
|
|
|
|
|
|
|
|
namespace App\Libraries;
|
|
|
|
|
|
2019-07-08 10:08:57 +10:00
|
|
|
use App\Models\ClientContact;
|
2019-07-12 15:03:30 +10:00
|
|
|
use App\Models\Company;
|
2019-03-28 09:21:28 +11:00
|
|
|
use App\Models\CompanyToken;
|
2018-10-18 16:04:36 +11:00
|
|
|
use App\Models\User;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Class MultiDB
|
|
|
|
|
* @package App\Libraries
|
|
|
|
|
*/
|
|
|
|
|
class MultiDB
|
|
|
|
|
{
|
2018-10-24 21:24:09 +11:00
|
|
|
const DB_PREFIX = 'db-ninja-';
|
2018-10-18 16:04:36 +11:00
|
|
|
|
2018-10-24 21:24:09 +11:00
|
|
|
public static $dbs = ['db-ninja-01', 'db-ninja-02'];
|
2018-10-21 09:26:21 +11:00
|
|
|
|
2018-10-18 16:04:36 +11:00
|
|
|
/**
|
|
|
|
|
* @param $email
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2018-10-21 09:26:21 +11:00
|
|
|
|
2018-11-27 18:24:26 +11:00
|
|
|
public static function getDbs() : array
|
2018-10-21 09:26:21 +11:00
|
|
|
{
|
|
|
|
|
|
|
|
|
|
return self::$dbs;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2019-07-12 15:03:30 +10:00
|
|
|
public static function checkDomainAvailable($domain) : bool
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if (! config('ninja.db.multi_db_enabled'))
|
|
|
|
|
{
|
|
|
|
|
return Company::whereDomain($domain)->get()->count() == 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//multi-db active
|
|
|
|
|
foreach (self::$dbs as $db)
|
|
|
|
|
{
|
|
|
|
|
if(Company::whereDomain($domain)->get()->count() >=1)
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-18 16:04:36 +11:00
|
|
|
public static function checkUserEmailExists($email) : bool
|
|
|
|
|
{
|
2018-12-02 21:42:06 +11:00
|
|
|
|
2018-10-21 09:26:21 +11:00
|
|
|
if (! config('ninja.db.multi_db_enabled'))
|
2018-10-18 16:04:36 +11:00
|
|
|
{
|
|
|
|
|
return User::where(['email' => $email])->get()->count() >= 1 ?? false; // true >= 1 emails found / false -> == emails found
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//multi-db active
|
2018-10-21 09:26:21 +11:00
|
|
|
foreach (self::$dbs as $db)
|
2018-10-18 16:04:36 +11:00
|
|
|
{
|
|
|
|
|
if(User::on($db)->where(['email' => $email])->get()->count() >=1) // if user already exists, validation will fail
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param array $data
|
2018-12-02 21:42:06 +11:00
|
|
|
* @return App\Models\User | bool
|
2018-10-18 16:04:36 +11:00
|
|
|
*/
|
2018-11-27 18:24:26 +11:00
|
|
|
public static function hasUser(array $data) : ?User
|
2018-10-18 16:04:36 +11:00
|
|
|
{
|
2018-12-02 21:42:06 +11:00
|
|
|
|
2018-10-21 09:26:21 +11:00
|
|
|
if (! config('ninja.db.multi_db_enabled'))
|
2018-10-18 16:04:36 +11:00
|
|
|
{
|
|
|
|
|
return User::where($data)->first();
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-21 09:26:21 +11:00
|
|
|
foreach (self::$dbs as $db)
|
2018-10-18 16:04:36 +11:00
|
|
|
{
|
|
|
|
|
self::setDB($db);
|
|
|
|
|
|
|
|
|
|
$user = User::where($data)->first();
|
|
|
|
|
|
2018-10-21 09:26:21 +11:00
|
|
|
if($user) {
|
|
|
|
|
|
2018-10-18 16:04:36 +11:00
|
|
|
return $user;
|
2018-10-21 09:26:21 +11:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-18 16:04:36 +11:00
|
|
|
}
|
|
|
|
|
|
2019-05-22 10:56:47 +10:00
|
|
|
return null;
|
2018-10-18 16:04:36 +11:00
|
|
|
}
|
|
|
|
|
|
2019-07-08 10:08:57 +10:00
|
|
|
public static function contactFindAndSetDb($token) :bool
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
foreach (self::$dbs as $db)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if($ct = ClientContact::on($db)->whereRaw("BINARY `token`= ?", [$token])->first())
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
self::setDb($ct->company->db);
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-28 09:21:28 +11:00
|
|
|
public static function findAndSetDb($token) :bool
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
foreach (self::$dbs as $db)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if($ct = CompanyToken::on($db)->whereRaw("BINARY `token`= ?", [$token])->first())
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
self::setDb($ct->company->db);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
}
|
2018-10-18 16:04:36 +11:00
|
|
|
|
2019-07-14 19:34:49 +10:00
|
|
|
public static function findAndSetDbByDomain($domain) :bool
|
2019-07-12 15:03:30 +10:00
|
|
|
{
|
|
|
|
|
|
|
|
|
|
foreach (self::$dbs as $db)
|
|
|
|
|
{
|
|
|
|
|
|
2019-07-14 19:34:49 +10:00
|
|
|
if($company = Company::on($db)->whereDomain($domain)->first())
|
2019-07-12 15:03:30 +10:00
|
|
|
{
|
|
|
|
|
|
|
|
|
|
self::setDb($company->db);
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-18 16:04:36 +11:00
|
|
|
/**
|
|
|
|
|
* @param $database
|
|
|
|
|
*/
|
2018-12-02 21:42:06 +11:00
|
|
|
public static function setDB(string $database) : void
|
2018-10-18 16:04:36 +11:00
|
|
|
{
|
2018-10-19 14:45:55 +11:00
|
|
|
/* This will set the database connection for the request */
|
2018-10-18 16:04:36 +11:00
|
|
|
config(['database.default' => $database]);
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-02 21:42:06 +11:00
|
|
|
|
2018-10-18 16:04:36 +11:00
|
|
|
}
|