. */ use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration; use Poniverse\Ponyfm\Console\Commands\RebuildSearchIndex; use Poniverse\Ponyfm\Models\Track; class SetupElasticsearch extends Migration { /** * Run the migrations. * * @return void */ public function up() { $elasticsearch = Elasticsearch::connection(); $elasticsearch->indices()->create([ 'index' => 'ponyfm', 'body' => [ 'mappings' => [ 'track' => [ '_source' => ['enabled' => true], 'dynamic' => 'strict', 'properties' => [ 'title' => ['type' => 'string'], 'artist' => ['type' => 'string'], 'published_at' => ['type' => 'date'], 'genre' => ['type' => 'string', 'index' => 'not_analyzed'], 'track_type' => ['type' => 'string', 'index' => 'not_analyzed'], // This field is intended to be used as an array. // Note that all Elasticsearch fields can technically be used as arrays. // See: https://www.elastic.co/guide/en/elasticsearch/reference/current/array.html 'show_songs' => ['type' => 'string', 'index' => 'not_analyzed'], ] ], 'album' => [ '_source' => ['enabled' => true], 'dynamic' => 'strict', 'properties' => [ 'title' => ['type' => 'string'], 'artist' => ['type' => 'string'], // This field is intended to be used as an array. // Note that all Elasticsearch fields can technically be used as arrays. // See: https://www.elastic.co/guide/en/elasticsearch/reference/current/array.html 'tracks' => ['type' => 'string'] ] ] ] ] ]); Artisan::call('rebuild:search'); } /** * Reverse the migrations. * * @return void */ public function down() { $elasticsearch = Elasticsearch::connection(); $elasticsearch->indices()->delete(['index' => 'ponyfm']); } }