Merge pull request #2929 from EnesSacid-Buker/trait-updates

Updates trait, migration option
This commit is contained in:
Cüneyt Şentürk 2023-03-10 11:25:10 +03:00 committed by GitHub
commit 77fb8df96b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -2,20 +2,27 @@
namespace App\Traits;
use Illuminate\Support\Facades\Artisan;
use Illuminate\Support\Facades\File;
trait Updates
{
/**
* get the alias.
*/
public function getAlias(): string
{
$const = static::class . '::ALIAS';
return defined($const) ? constant($const) : 'core';
}
/**
* get the path by alias.
*/
public function getPathByAlias(string $alias = ''): string
{
if (empty($alias)) {
$const = static::class . '::ALIAS';
$alias = defined($const) ? constant($const) : 'core';
}
$alias = empty($alias) ? $this->getAlias() : $alias;
return $alias === 'core' ? base_path() : module_path($alias);
}
@ -43,4 +50,34 @@ trait Updates
File::deleteDirectory($path . '/' . $folder);
}
}
/**
* Run single migration.
*/
public function runMigration(string $file_name, $alias = ''): void
{
$path = $this->getPathByAlias($alias);
$semi_path = str($path)->contains('modules') ? '/Database/Migrations/' : '/database/migrations/';
$migration_file = $path . $semi_path . $file_name . '.php';
if (File::missing($migration_file)) {
return;
}
$migration_file = str($migration_file)->replace(base_path(), '');
Artisan::call('migrate', ['--force' => true, '--path' => $migration_file]);
}
/**
* Run multiple migrations.
*/
public function runMigrations(array $file_names, $alias = ''): void
{
foreach ($file_names as $file_name) {
$this->runMigration($file_name, $alias);
}
}
}