2016-09-12 14:24:01 +02:00
< ? php
2022-12-29 19:43:43 +01:00
2017-12-10 09:02:26 +01:00
/**
* 2016_09_12_121359_ fix_nullables . php
2020-03-17 16:06:30 +00:00
* Copyright ( c ) 2019 james @ firefly - iii . org .
2017-12-10 09:02:26 +01:00
*
2019-10-02 06:38:38 +02:00
* This file is part of Firefly III ( https :// github . com / firefly - iii ) .
2017-12-10 09:02:26 +01:00
*
2019-10-02 06:38:38 +02:00
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation , either version 3 of the
* License , or ( at your option ) any later version .
2017-12-10 09:02:26 +01:00
*
2019-10-02 06:38:38 +02:00
* This program is distributed in the hope that it will be useful ,
2017-12-10 09:02:26 +01:00
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
2019-10-02 06:38:38 +02:00
* GNU Affero General Public License for more details .
2017-12-10 09:02:26 +01:00
*
2019-10-02 06:38:38 +02:00
* You should have received a copy of the GNU Affero General Public License
* along with this program . If not , see < https :// www . gnu . org / licenses />.
2017-12-10 09:02:26 +01:00
*/
2017-03-25 13:41:17 +01:00
declare ( strict_types = 1 );
2016-09-12 14:24:01 +02:00
use Illuminate\Database\Migrations\Migration ;
2023-04-07 19:33:19 +02:00
use Illuminate\Database\QueryException ;
2016-09-13 19:20:09 +02:00
use Illuminate\Database\Schema\Blueprint ;
/**
2020-03-17 16:06:30 +00:00
* Class FixNullables .
2021-03-12 06:17:50 +01:00
*
2020-10-27 06:53:47 +01:00
* @ codeCoverageIgnore
2016-09-13 19:20:09 +02:00
*/
class FixNullables extends Migration
{
2023-05-30 20:15:07 +02:00
private const COLUMN_ALREADY_EXISTS = 'If this table exists already (see the error message), this is not a problem. Other errors? Please open a discussion on GitHub.' ;
private const TABLE_UPDATE_ERROR = 'Could not update table "%s": %s' ;
2016-09-13 19:20:09 +02:00
/**
* Reverse the migrations .
*/
2023-11-30 17:28:44 +01:00
public function down () : void {}
2016-09-12 14:24:01 +02:00
/**
* Run the migrations .
*
2023-12-20 19:41:37 +01:00
* @ SuppressWarnings ( PHPMD . ShortMethodName )
2016-09-12 14:24:01 +02:00
*/
2019-03-02 15:54:24 +01:00
public function up () : void
2016-09-12 14:24:01 +02:00
{
2023-04-10 08:29:27 +02:00
if ( ! Schema :: hasColumn ( 'rule_groups' , 'description' )) {
try {
Schema :: table (
'rule_groups' ,
2023-12-21 05:06:17 +01:00
static function ( Blueprint $table ) : void {
2023-04-10 08:29:27 +02:00
$table -> text ( 'description' ) -> nullable () -> change ();
}
);
} catch ( QueryException $e ) {
2023-08-11 19:37:52 +02:00
app ( 'log' ) -> error ( sprintf ( self :: TABLE_UPDATE_ERROR , 'rule_groups' , $e -> getMessage ()));
app ( 'log' ) -> error ( self :: COLUMN_ALREADY_EXISTS );
2023-04-10 08:29:27 +02:00
}
2023-04-07 19:33:19 +02:00
}
2016-09-12 14:24:01 +02:00
2023-04-10 08:29:27 +02:00
if ( ! Schema :: hasColumn ( 'rules' , 'description' )) {
try {
Schema :: table (
'rules' ,
2023-12-21 05:06:17 +01:00
static function ( Blueprint $table ) : void {
2023-04-10 08:29:27 +02:00
$table -> text ( 'description' ) -> nullable () -> change ();
}
);
} catch ( QueryException $e ) {
2023-08-11 19:37:52 +02:00
app ( 'log' ) -> error ( sprintf ( self :: TABLE_UPDATE_ERROR , 'rules' , $e -> getMessage ()));
app ( 'log' ) -> error ( self :: COLUMN_ALREADY_EXISTS );
2023-04-10 08:29:27 +02:00
}
2023-04-07 19:33:19 +02:00
}
2016-09-12 14:24:01 +02:00
}
}