 7e7f0be7df
			
		
	
	
		7e7f0be7df
		
			
		
	
	
	
	
		
			
			* WIP * Update laravel and migrations * WIP * fix tests * Update composer * Fix transformer * Fix filament pages * WIP * Update DatabaseHostTransformer * fix: tests * pint this files pls * resolve merge better * Update migration * Update Migration, Again * Update down migration --------- Co-authored-by: Vehikl <go@vehikl.com>
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| use Illuminate\Database\Migrations\Migration;
 | |
| use Illuminate\Database\Schema\Blueprint;
 | |
| use Illuminate\Support\Facades\Artisan;
 | |
| use Illuminate\Support\Facades\DB;
 | |
| use Illuminate\Support\Facades\Schema;
 | |
| 
 | |
| return new class extends Migration
 | |
| {
 | |
|     public function up(): void
 | |
|     {
 | |
|         Schema::table('eggs', function (Blueprint $table) {
 | |
|             $table->text('tags');
 | |
|         });
 | |
| 
 | |
|         DB::table('eggs')->update(['tags' => '[]']);
 | |
| 
 | |
|         $eggsWithNests = DB::table('eggs')
 | |
|             ->select(['eggs.id', 'nests.name'])
 | |
|             ->join('nests', 'nests.id', '=', 'eggs.nest_id')
 | |
|             ->get();
 | |
| 
 | |
|         foreach ($eggsWithNests as $egg) {
 | |
|             DB::table('eggs')
 | |
|                 ->where('id', $egg->id)
 | |
|                 ->update(['tags' => "[\"$egg->name\"]"]);
 | |
|         }
 | |
| 
 | |
|         Schema::table('eggs', function (Blueprint $table) {
 | |
|             if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|                 $table->dropForeign('service_options_nest_id_foreign');
 | |
|             } else {
 | |
|                 $table->dropForeign(['nest_id']);
 | |
|             }
 | |
| 
 | |
|             $table->dropColumn('nest_id');
 | |
|         });
 | |
| 
 | |
|         Schema::table('servers', function (Blueprint $table) {
 | |
|             $table->dropForeign(['nest_id']);
 | |
|             $table->dropColumn('nest_id');
 | |
|         });
 | |
| 
 | |
|         Schema::drop('nests');
 | |
| 
 | |
|         Schema::table('api_keys', function (Blueprint $table) {
 | |
|             $table->dropColumn('r_nests');
 | |
|         });
 | |
|     }
 | |
| 
 | |
|     // Not really reversible, but...
 | |
|     public function down(): void
 | |
|     {
 | |
|         Schema::table('api_keys', function (Blueprint $table) {
 | |
|             $table->unsignedTinyInteger('r_nests')->default(0);
 | |
|         });
 | |
| 
 | |
|         Schema::create('nests', function (Blueprint $table) {
 | |
|             $table->increments('id');
 | |
|             $table->char('uuid', 36)->unique();
 | |
|             $table->string('author');
 | |
|             $table->string('name');
 | |
|             $table->text('description')->nullable();
 | |
|             $table->timestamps();
 | |
|         });
 | |
| 
 | |
|         Schema::table('eggs', function (Blueprint $table) {
 | |
|             $table->dropColumn('tags');
 | |
|             $table->mediumInteger('nest_id')->unsigned();
 | |
|             $table->foreign(['nest_id'], 'service_options_nest_id_foreign');
 | |
|         });
 | |
| 
 | |
|         Schema::table('servers', function (Blueprint $table) {
 | |
|             $table->mediumInteger('nest_id')->unsigned();
 | |
|             $table->foreign(['nest_id'], 'servers_nest_id_foreign');
 | |
|         });
 | |
| 
 | |
|         if (class_exists('Database\Seeders\NestSeeder')) {
 | |
|             Artisan::call('db:seed', [
 | |
|                 '--class' => 'NestSeeder',
 | |
|             ]);
 | |
|         }
 | |
|     }
 | |
| };
 |