mirror of
				https://github.com/BookStackApp/BookStack.git
				synced 2025-11-03 02:13:16 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace BookStack\Console\Commands;
 | 
						|
 | 
						|
use Illuminate\Console\Command;
 | 
						|
use Illuminate\Support\Facades\DB;
 | 
						|
 | 
						|
class UpgradeDatabaseEncoding extends Command
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * The name and signature of the console command.
 | 
						|
     *
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    protected $signature = 'bookstack:db-utf8mb4 {--database= : The database connection to use.}';
 | 
						|
 | 
						|
    /**
 | 
						|
     * The console command description.
 | 
						|
     *
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    protected $description = 'Generate SQL commands to upgrade the database to UTF8mb4';
 | 
						|
 | 
						|
    /**
 | 
						|
     * Create a new command instance.
 | 
						|
     */
 | 
						|
    public function __construct()
 | 
						|
    {
 | 
						|
        parent::__construct();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Execute the console command.
 | 
						|
     *
 | 
						|
     * @return mixed
 | 
						|
     */
 | 
						|
    public function handle()
 | 
						|
    {
 | 
						|
        $connection = DB::getDefaultConnection();
 | 
						|
        if ($this->option('database') !== null) {
 | 
						|
            DB::setDefaultConnection($this->option('database'));
 | 
						|
        }
 | 
						|
 | 
						|
        $database = DB::getDatabaseName();
 | 
						|
        $tables = DB::select('SHOW TABLES');
 | 
						|
        $this->line('ALTER DATABASE `' . $database . '` CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;');
 | 
						|
        $this->line('USE `' . $database . '`;');
 | 
						|
        $key = 'Tables_in_' . $database;
 | 
						|
        foreach ($tables as $table) {
 | 
						|
            $tableName = $table->$key;
 | 
						|
            $this->line('ALTER TABLE `' . $tableName . '` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;');
 | 
						|
        }
 | 
						|
 | 
						|
        DB::setDefaultConnection($connection);
 | 
						|
    }
 | 
						|
}
 |