mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-09-18 07:15:52 +00:00
64 lines
2.0 KiB
PHP
64 lines
2.0 KiB
PHP
<?php
|
|
|
|
use Illuminate\Support\Facades\Schema;
|
|
use Illuminate\Database\Schema\Blueprint;
|
|
use Illuminate\Database\Migrations\Migration;
|
|
|
|
class CreateSearchIndexTable extends Migration
|
|
{
|
|
/**
|
|
* Run the migrations.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function up()
|
|
{
|
|
Schema::create('search_terms', function (Blueprint $table) {
|
|
$table->increments('id');
|
|
$table->string('term', 200);
|
|
$table->string('entity_type', 100);
|
|
$table->integer('entity_id');
|
|
$table->integer('score');
|
|
|
|
$table->index('term');
|
|
$table->index('entity_type');
|
|
$table->index(['entity_type', 'entity_id']);
|
|
$table->index('score');
|
|
});
|
|
|
|
// Drop search indexes
|
|
Schema::table('pages', function(Blueprint $table) {
|
|
$table->dropIndex('search');
|
|
$table->dropIndex('name_search');
|
|
});
|
|
Schema::table('books', function(Blueprint $table) {
|
|
$table->dropIndex('search');
|
|
$table->dropIndex('name_search');
|
|
});
|
|
Schema::table('chapters', function(Blueprint $table) {
|
|
$table->dropIndex('search');
|
|
$table->dropIndex('name_search');
|
|
});
|
|
|
|
app(\BookStack\Services\SearchService::class)->indexAllEntities();
|
|
}
|
|
|
|
/**
|
|
* Reverse the migrations.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function down()
|
|
{
|
|
$prefix = DB::getTablePrefix();
|
|
DB::statement("ALTER TABLE {$prefix}pages ADD FULLTEXT search(name, text)");
|
|
DB::statement("ALTER TABLE {$prefix}books ADD FULLTEXT search(name, description)");
|
|
DB::statement("ALTER TABLE {$prefix}chapters ADD FULLTEXT search(name, description)");
|
|
DB::statement("ALTER TABLE {$prefix}pages ADD FULLTEXT name_search(name)");
|
|
DB::statement("ALTER TABLE {$prefix}books ADD FULLTEXT name_search(name)");
|
|
DB::statement("ALTER TABLE {$prefix}chapters ADD FULLTEXT name_search(name)");
|
|
|
|
Schema::dropIfExists('search_terms');
|
|
}
|
|
}
|