mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 10:16:52 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			112 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| use Illuminate\Support\Facades\Schema;
 | |
| use Illuminate\Database\Schema\Blueprint;
 | |
| use Illuminate\Database\Migrations\Migration;
 | |
| 
 | |
| return new class extends Migration
 | |
| {
 | |
|     /**
 | |
|      * Run the migrations.
 | |
|      */
 | |
|     public function up(): void
 | |
|     {
 | |
|         Schema::disableForeignKeyConstraints();
 | |
| 
 | |
|         if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|             Schema::table('service_options', function (Blueprint $table) {
 | |
|                 $table->dropForeign(['config_from']);
 | |
|                 $table->dropForeign(['copy_script_from']);
 | |
|             });
 | |
|         }
 | |
| 
 | |
|         Schema::rename('service_options', 'eggs');
 | |
| 
 | |
|         Schema::table('packs', function (Blueprint $table) {
 | |
|             if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|                 $table->dropForeign(['option_id']);
 | |
|             }
 | |
| 
 | |
|             $table->renameColumn('option_id', 'egg_id');
 | |
|             $table->foreign('egg_id')->references('id')->on('eggs')->onDelete('CASCADE');
 | |
|         });
 | |
| 
 | |
|         Schema::table('servers', function (Blueprint $table) {
 | |
|             if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|                 $table->dropForeign(['option_id']);
 | |
|             }
 | |
| 
 | |
|             $table->renameColumn('option_id', 'egg_id');
 | |
|             $table->foreign('egg_id')->references('id')->on('eggs');
 | |
|         });
 | |
| 
 | |
|         Schema::table('eggs', function (Blueprint $table) {
 | |
|             $table->foreign('config_from')->references('id')->on('eggs')->onDelete('SET NULL');
 | |
|             $table->foreign('copy_script_from')->references('id')->on('eggs')->onDelete('SET NULL');
 | |
|         });
 | |
| 
 | |
|         Schema::table('service_variables', function (Blueprint $table) {
 | |
|             if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|                 $table->dropForeign(['option_id']);
 | |
|             }
 | |
| 
 | |
|             $table->renameColumn('option_id', 'egg_id');
 | |
| 
 | |
|             $table->foreign('egg_id')->references('id')->on('eggs')->onDelete('CASCADE');
 | |
|         });
 | |
| 
 | |
|         Schema::enableForeignKeyConstraints();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Reverse the migrations.
 | |
|      */
 | |
|     public function down(): void
 | |
|     {
 | |
|         Schema::disableForeignKeyConstraints();
 | |
| 
 | |
|         if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|             Schema::table('eggs', function (Blueprint $table) {
 | |
|                 $table->dropForeign(['config_from']);
 | |
|                 $table->dropForeign(['copy_script_from']);
 | |
|             });
 | |
|         }
 | |
| 
 | |
|         Schema::rename('eggs', 'service_options');
 | |
| 
 | |
|         Schema::table('packs', function (Blueprint $table) {
 | |
|             if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|                 $table->dropForeign(['egg_id']);
 | |
|             }
 | |
| 
 | |
|             $table->renameColumn('egg_id', 'option_id');
 | |
|             $table->foreign('option_id')->references('id')->on('service_options')->onDelete('CASCADE');
 | |
|         });
 | |
| 
 | |
|         Schema::table('servers', function (Blueprint $table) {
 | |
|             if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|                 $table->dropForeign(['egg_id']);
 | |
|             }
 | |
| 
 | |
|             $table->renameColumn('egg_id', 'option_id');
 | |
|             $table->foreign('option_id')->references('id')->on('service_options');
 | |
|         });
 | |
| 
 | |
|         Schema::table('service_options', function (Blueprint $table) {
 | |
|             $table->foreign('config_from')->references('id')->on('service_options')->onDelete('SET NULL');
 | |
|             $table->foreign('copy_script_from')->references('id')->on('service_options')->onDelete('SET NULL');
 | |
|         });
 | |
| 
 | |
|         Schema::table('service_variables', function (Blueprint $table) {
 | |
|             if (Schema::getConnection()->getDriverName() !== 'sqlite') {
 | |
|                 $table->dropForeign(['egg_id']);
 | |
|             }
 | |
| 
 | |
|             $table->renameColumn('egg_id', 'option_id');
 | |
|             $table->foreign('option_id')->references('id')->on('options')->onDelete('CASCADE');
 | |
|         });
 | |
| 
 | |
|         Schema::enableForeignKeyConstraints();
 | |
|     }
 | |
| };
 | 
