Passed
Push — master ( f68345...02e211 )
by Aimeos
04:32
created

Text::up()   A

Complexity

Conditions 5
Paths 7

Size

Total Lines 23
Code Lines 12

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 12
c 0
b 0
f 0
dl 0
loc 23
rs 9.5555
cc 5
nc 7
nop 0
1
<?php
2
3
/**
4
 * @license LGPLv3, https://opensource.org/licenses/LGPL-3.0
5
 * @copyright Aimeos (aimeos.org), 2021-2024
6
 */
7
8
9
namespace Aimeos\Upscheme\Task;
10
11
12
class Text extends Base
13
{
14
	public function before() : array
15
	{
16
		return ['Locale'];
17
	}
18
19
20
	public function up()
21
	{
22
		$this->info( 'Creating text schema', 'vv' );
23
		$db = $this->db( 'db-text' );
24
25
		foreach( $this->paths( 'default/schema/text.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_text', 'idx_mstex_sid_dom_cont' ) )
39
		{
40
			$db->for( 'mysql', 'CREATE INDEX `idx_mstex_sid_dom_cont` ON `mshop_text` (`siteid`, `domain`, `content`(255))' );
41
			$db->for( 'postgresql', 'CREATE INDEX "idx_mstex_sid_dom_cont" ON "mshop_text" ("siteid", "domain", left("content", 255) )' );
42
			$db->for( 'mssql', 'CREATE INDEX "idx_mstex_sid_dom_cont" ON "mshop_text" ("siteid", "domain")' );
43
		}
44
	}
45
}
46