Passed
Push — master ( de4224...45eff3 )
by Aimeos
05:03
created

Index::up()   A

Complexity

Conditions 5
Paths 7

Size

Total Lines 22
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 11
nc 7
nop 0
dl 0
loc 22
c 1
b 0
f 0
cc 5
rs 9.6111
1
<?php
2
3
/**
4
 * @license LGPLv3, https://opensource.org/licenses/LGPL-3.0
5
 * @copyright Aimeos (aimeos.org), 2021
6
 */
7
8
9
namespace Aimeos\Upscheme\Task;
10
11
12
class Index extends Base
13
{
14
	public function after() : array
15
	{
16
		return ['Product'];
17
	}
18
19
20
	public function up()
21
	{
22
		$this->info( 'Creating index schema', 'v' );
23
		$db = $this->db( 'db-product' );
24
25
		foreach( $this->paths( 'default/schema/index.php' ) as $filepath )
26
		{
27
			if( ( $list = include( $filepath ) ) === false ) {
28
				throw new \RuntimeException( sprintf( 'Unable to get schema from file "%1$s"', $filepath ) );
29
			}
30
31
			foreach( $list['table'] ?? [] as $name => $fcn ) {
32
				$db->table( $name, $fcn );
33
			}
34
		}
35
36
		$db->up();
37
38
		if( !$db->hasIndex( 'mshop_index_text', 'idx_msindte_content' ) )
39
		{
40
			$db->for( 'mysql', 'CREATE FULLTEXT INDEX `idx_msindte_content` ON `mshop_index_text` (`content`)' );
41
			$db->for( 'postgresql', 'CREATE INDEX "idx_msindte_content" ON "mshop_index_text" USING GIN (to_tsvector(\'english\', "content"))' );
42
		}
43
	}
44
}