mirror of
https://github.com/archtechx/tenancy.git
synced 2025-12-12 07:04:03 +00:00
[1.7.0] Add the option to set values & db name during tenant creation (#86)
* Add the option to set values & db name during tenant creation * Apply fixes from StyleCI * Add tests * Apply fixes from StyleCI * Rewrite conditional for clarity
This commit is contained in:
parent
769ec16f89
commit
d7358c588c
5 changed files with 113 additions and 1 deletions
26
README.md
26
README.md
|
|
@ -217,6 +217,32 @@ You can use the `tenancy()` and `tenant()` helpers to resolve `Stancl\Tenancy\Te
|
|||
]
|
||||
```
|
||||
|
||||
You can also put data into the storage during the tenant creation process:
|
||||
|
||||
```php
|
||||
>>> tenant()->create('dev.localhost', [
|
||||
'plan' => 'basic'
|
||||
])
|
||||
=> [
|
||||
"uuid" => "49670df0-1a87-11e9-b7ba-cf5353777957",
|
||||
"domain" => "dev.localhost",
|
||||
"plan" => "basic",
|
||||
]
|
||||
```
|
||||
|
||||
If you want to specify the tenant's database name, set the `tenancy.database_name_key` configuration key to the name of the key that is used to specify the database name in the tenant storage. You must use a name that you won't use for storing other data, so it's recommended to avoid names like `database` and use names like `_stancl_tenancy_database_name` instead. Then just give the key a value during the tenant creation process:
|
||||
|
||||
```php
|
||||
>>> tenant()->create('example.com', [
|
||||
'_stancl_tenancy_database_name' => 'example_com'
|
||||
])
|
||||
=> [
|
||||
"uuid" => "49670df0-1a87-11e9-b7ba-cf5353777957",
|
||||
"domain" => "example.com",
|
||||
"_stancl_tenancy_database_name" => "example_com",
|
||||
]
|
||||
```
|
||||
|
||||
When you create a new tenant, you can [migrate](#tenant-migrations) their database like this:
|
||||
|
||||
```php
|
||||
|
|
|
|||
8
src/Exceptions/CannotChangeUuidOrDomainException.php
Normal file
8
src/Exceptions/CannotChangeUuidOrDomainException.php
Normal file
|
|
@ -0,0 +1,8 @@
|
|||
<?php
|
||||
|
||||
namespace Stancl\Tenancy\Exceptions;
|
||||
|
||||
class CannotChangeUuidOrDomainException extends \Exception
|
||||
{
|
||||
protected $message = 'Uuid and domain cannot be changed.';
|
||||
}
|
||||
|
|
@ -5,6 +5,7 @@ namespace Stancl\Tenancy;
|
|||
use Stancl\Tenancy\Interfaces\StorageDriver;
|
||||
use Stancl\Tenancy\Traits\BootstrapsTenancy;
|
||||
use Illuminate\Contracts\Foundation\Application;
|
||||
use Stancl\Tenancy\Exceptions\CannotChangeUuidOrDomainException;
|
||||
|
||||
class TenantManager
|
||||
{
|
||||
|
|
@ -70,7 +71,14 @@ class TenantManager
|
|||
return $tenant;
|
||||
}
|
||||
|
||||
public function create(string $domain = null): array
|
||||
/**
|
||||
* Create a tenant.
|
||||
*
|
||||
* @param string $domain
|
||||
* @param array $data
|
||||
* @return array
|
||||
*/
|
||||
public function create(string $domain = null, array $data = []): array
|
||||
{
|
||||
$domain = $domain ?: $this->currentDomain();
|
||||
|
||||
|
|
@ -79,6 +87,13 @@ class TenantManager
|
|||
}
|
||||
|
||||
$tenant = $this->jsonDecodeArrayValues($this->storage->createTenant($domain, (string) \Webpatser\Uuid\Uuid::generate(1, $domain)));
|
||||
|
||||
if ($data) {
|
||||
$this->put($data, null, $tenant['uuid']);
|
||||
|
||||
$tenant = array_merge($tenant, $data);
|
||||
}
|
||||
|
||||
$this->database->create($this->getDatabaseName($tenant));
|
||||
|
||||
return $tenant;
|
||||
|
|
@ -168,6 +183,12 @@ class TenantManager
|
|||
{
|
||||
$tenant = $tenant ?: $this->tenant;
|
||||
|
||||
if ($key = $this->app['config']['tenancy.database_name_key']) {
|
||||
if (isset($tenant[$key])) {
|
||||
return $tenant[$key];
|
||||
}
|
||||
}
|
||||
|
||||
return $this->app['config']['tenancy.database.prefix'] . $tenant['uuid'] . $this->app['config']['tenancy.database.suffix'];
|
||||
}
|
||||
|
||||
|
|
@ -254,6 +275,15 @@ class TenantManager
|
|||
*/
|
||||
public function put($key, $value = null, string $uuid = null)
|
||||
{
|
||||
if (in_array($key, ['uuid', 'domain'], true) || (
|
||||
is_array($key) && (
|
||||
in_array('uuid', array_keys($key), true) ||
|
||||
in_array('domain', array_keys($key), true)
|
||||
)
|
||||
)) {
|
||||
throw new CannotChangeUuidOrDomainException;
|
||||
}
|
||||
|
||||
if (\is_null($uuid)) {
|
||||
if (! isset($this->tenant['uuid'])) {
|
||||
throw new \Exception('No UUID supplied (and no tenant is currently identified).');
|
||||
|
|
|
|||
|
|
@ -43,4 +43,5 @@ return [
|
|||
],
|
||||
'queue_database_creation' => false,
|
||||
'queue_database_deletion' => false,
|
||||
'database_name_key' => null,
|
||||
];
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@ namespace Stancl\Tenancy\Tests;
|
|||
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Illuminate\Support\Facades\Storage;
|
||||
use Stancl\Tenancy\Exceptions\CannotChangeUuidOrDomainException;
|
||||
|
||||
class TenantManagerTest extends TestCase
|
||||
{
|
||||
|
|
@ -194,4 +195,50 @@ class TenantManagerTest extends TestCase
|
|||
$tenant2 = tenant()->create('bar.localhost');
|
||||
$this->assertEqualsCanonicalizing([$tenant1, $tenant2], tenant()->all()->toArray());
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function properites_can_be_passed_in_the_create_method()
|
||||
{
|
||||
$data = ['plan' => 'free', 'subscribed_until' => '2020-01-01'];
|
||||
$tenant = tenant()->create('foo.localhost', $data);
|
||||
|
||||
$tenant_data = $tenant;
|
||||
unset($tenant_data['uuid']);
|
||||
unset($tenant_data['domain']);
|
||||
|
||||
$this->assertSame($data, $tenant_data);
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function database_name_can_be_passed_in_the_create_method()
|
||||
{
|
||||
$database = 'abc';
|
||||
config(['tenancy.database_name_key' => '_stancl_tenancy_database_name']);
|
||||
|
||||
$tenant = tenant()->create('foo.localhost', [
|
||||
'_stancl_tenancy_database_name' => $database,
|
||||
]);
|
||||
|
||||
$this->assertSame($database, tenant()->getDatabaseName($tenant));
|
||||
}
|
||||
|
||||
/** @test */
|
||||
public function uuid_and_domain_cannot_be_changed()
|
||||
{
|
||||
$tenant = tenant()->create('foo.localhost');
|
||||
|
||||
$this->expectException(CannotChangeUuidOrDomainException::class);
|
||||
tenant()->put('uuid', 'foo', $tenant['uuid']);
|
||||
|
||||
$this->expectException(CannotChangeUuidOrDomainException::class);
|
||||
tenant()->put(['uuid' => 'foo'], null, $tenant['uuid']);
|
||||
|
||||
tenancy()->init('foo.localhost');
|
||||
|
||||
$this->expectException(CannotChangeUuidOrDomainException::class);
|
||||
tenant()->put('uuid', 'foo');
|
||||
|
||||
$this->expectException(CannotChangeUuidOrDomainException::class);
|
||||
tenant()->put(['uuid' => 'foo']);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue