1
0
Fork 0
mirror of https://github.com/archtechx/tenancy.git synced 2026-02-05 06:04:03 +00:00

Use seeder params in tenants:seed instead of just the automatic seeder

This commit is contained in:
Samuel Štancl 2020-03-14 19:58:19 +01:00
parent c7c6a7fec8
commit e886c2bae5
4 changed files with 9 additions and 9 deletions

View file

@ -104,7 +104,7 @@ return [
],
'seed_after_migration' => false, // should the seeder run after automatic migration
'seeder_parameters' => [
'--class' => 'DatabaseSeeder', // root seeder class to run after automatic migrations, e.g.: 'DatabaseSeeder'
'--class' => 'DatabaseSeeder', // root seeder class, e.g.: 'DatabaseSeeder'
// '--force' => true, // force database seeder
],
'queue_database_deletion' => false,

View file

@ -52,6 +52,10 @@ class Seed extends SeedCommand
$this->input->setOption('database', $tenant->getConnectionName());
foreach (config('tenancy.seeder_parameters') as $parameter => $value) {
$this->input->setOption($parameter, $value);
}
$tenant->run(function () {
// Seed
parent::handle();

View file

@ -19,13 +19,9 @@ class QueuedTenantDatabaseSeeder implements ShouldQueue
/** @var string */
protected $tenantId;
/** @var array */
protected $seederParameters = [];
public function __construct(Tenant $tenant, $seederParameters = [])
public function __construct(Tenant $tenant)
{
$this->tenantId = $tenant->id;
$this->seederParameters = $seederParameters;
}
/**
@ -37,6 +33,6 @@ class QueuedTenantDatabaseSeeder implements ShouldQueue
{
Artisan::call('tenants:seed', [
'--tenants' => [$this->tenantId],
] + $this->seederParameters);
]);
}
}

View file

@ -86,11 +86,11 @@ class TenantManager
if ($this->shouldSeedAfterMigration()) {
$afterCreating[] = $this->databaseCreationQueued()
? new QueuedTenantDatabaseSeeder($tenant, $this->getSeederParameters())
? new QueuedTenantDatabaseSeeder($tenant)
: function () use ($tenant) {
$this->artisan->call('tenants:seed', [
'--tenants' => [$tenant['id']],
] + $this->getSeederParameters());
]);
};
}