mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 21:16:47 +00:00 
			
		
		
		
	Catch errors in database table create statements.
This commit is contained in:
		| @@ -23,6 +23,7 @@ | ||||
| declare(strict_types=1); | ||||
|  | ||||
| use Illuminate\Database\Migrations\Migration; | ||||
| use Illuminate\Database\QueryException; | ||||
| use Illuminate\Database\Schema\Blueprint; | ||||
| use Illuminate\Support\Facades\Schema; | ||||
|  | ||||
| @@ -53,7 +54,7 @@ class UserGroups extends Migration | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function down() | ||||
|     public function down(): void | ||||
|     { | ||||
|         // remove columns from tables | ||||
|         /** @var string $tableName */ | ||||
| @@ -89,52 +90,66 @@ class UserGroups extends Migration | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function up() | ||||
|     public function up(): void | ||||
|     { | ||||
|         /* | ||||
|          * user is a member of a user_group through a user_group_role | ||||
|          * may have multiple roles in a group | ||||
|          */ | ||||
|         Schema::create( | ||||
|             'user_groups', | ||||
|             static function (Blueprint $table) { | ||||
|                 $table->bigIncrements('id'); | ||||
|                 $table->timestamps(); | ||||
|                 $table->softDeletes(); | ||||
|         try { | ||||
|             Schema::create( | ||||
|                 'user_groups', | ||||
|                 static function (Blueprint $table) { | ||||
|                     $table->bigIncrements('id'); | ||||
|                     $table->timestamps(); | ||||
|                     $table->softDeletes(); | ||||
|  | ||||
|                 $table->string('title', 255); | ||||
|                 $table->unique('title'); | ||||
|             } | ||||
|         ); | ||||
|                     $table->string('title', 255); | ||||
|                     $table->unique('title'); | ||||
|                 } | ||||
|             ); | ||||
|         } catch (QueryException $e) { | ||||
|             Log::error(sprintf('Could not create table "user_groups": %s', $e->getMessage())); | ||||
|             Log::error('If this table exists already (see the error message), this is not a problem. Other errors? Please open a discussion on GitHub.'); | ||||
|         } | ||||
|         try { | ||||
|             Schema::create( | ||||
|                 'user_roles', | ||||
|                 static function (Blueprint $table) { | ||||
|                     $table->bigIncrements('id'); | ||||
|                     $table->timestamps(); | ||||
|                     $table->softDeletes(); | ||||
|  | ||||
|         Schema::create( | ||||
|             'user_roles', | ||||
|             static function (Blueprint $table) { | ||||
|                 $table->bigIncrements('id'); | ||||
|                 $table->timestamps(); | ||||
|                 $table->softDeletes(); | ||||
|                     $table->string('title', 255); | ||||
|                     $table->unique('title'); | ||||
|                 } | ||||
|             ); | ||||
|         } catch (QueryException $e) { | ||||
|             Log::error(sprintf('Could not create table "user_roles": %s', $e->getMessage())); | ||||
|             Log::error('If this table exists already (see the error message), this is not a problem. Other errors? Please open a discussion on GitHub.'); | ||||
|         } | ||||
|  | ||||
|                 $table->string('title', 255); | ||||
|                 $table->unique('title'); | ||||
|             } | ||||
|         ); | ||||
|         try { | ||||
|             Schema::create( | ||||
|                 'group_memberships', | ||||
|                 static function (Blueprint $table) { | ||||
|                     $table->bigIncrements('id'); | ||||
|                     $table->timestamps(); | ||||
|                     $table->softDeletes(); | ||||
|                     $table->integer('user_id', false, true); | ||||
|                     $table->bigInteger('user_group_id', false, true); | ||||
|                     $table->bigInteger('user_role_id', false, true); | ||||
|  | ||||
|         Schema::create( | ||||
|             'group_memberships', | ||||
|             static function (Blueprint $table) { | ||||
|                 $table->bigIncrements('id'); | ||||
|                 $table->timestamps(); | ||||
|                 $table->softDeletes(); | ||||
|                 $table->integer('user_id', false, true); | ||||
|                 $table->bigInteger('user_group_id', false, true); | ||||
|                 $table->bigInteger('user_role_id', false, true); | ||||
|  | ||||
|                 $table->foreign('user_id')->references('id')->on('users')->onUpdate('cascade')->onDelete('cascade'); | ||||
|                 $table->foreign('user_group_id')->references('id')->on('user_groups')->onUpdate('cascade')->onDelete('cascade'); | ||||
|                 $table->foreign('user_role_id')->references('id')->on('user_roles')->onUpdate('cascade')->onDelete('cascade'); | ||||
|                 $table->unique(['user_id', 'user_group_id', 'user_role_id']); | ||||
|             } | ||||
|         ); | ||||
|                     $table->foreign('user_id')->references('id')->on('users')->onUpdate('cascade')->onDelete('cascade'); | ||||
|                     $table->foreign('user_group_id')->references('id')->on('user_groups')->onUpdate('cascade')->onDelete('cascade'); | ||||
|                     $table->foreign('user_role_id')->references('id')->on('user_roles')->onUpdate('cascade')->onDelete('cascade'); | ||||
|                     $table->unique(['user_id', 'user_group_id', 'user_role_id']); | ||||
|                 } | ||||
|             ); | ||||
|         } catch (QueryException $e) { | ||||
|             Log::error(sprintf('Could not create table "group_memberships": %s', $e->getMessage())); | ||||
|             Log::error('If this table exists already (see the error message), this is not a problem. Other errors? Please open a discussion on GitHub.'); | ||||
|         } | ||||
|         Schema::table( | ||||
|             'users', | ||||
|             function (Blueprint $table) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user