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

Order::before()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 1
dl 0
loc 3
rs 10
c 0
b 0
f 0
cc 1
nc 1
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 Order extends Base
13
{
14
	public function before() : array
15
	{
16
		return ['Locale'];
17
	}
18
19
20
	public function up()
21
	{
22
		$this->info( 'Creating order schema', 'vv' );
23
		$db = $this->db( 'db-order' );
24
25
		foreach( $this->paths( 'default/schema/order.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_order_product_attr', 'idx_msordprat_si_cd_va' ) )
39
		{
40
			$db->for( 'mysql', 'CREATE INDEX `idx_msordprat_si_cd_va` ON `mshop_order_product_attr` (`siteid`, `code`, `value`(16))' );
41
			$db->for( 'postgresql', 'CREATE INDEX "idx_msordprat_si_cd_va" ON "mshop_order_product_attr" ("siteid", "code", left("value", 16))' );
42
			$db->for( 'mssql', 'CREATE INDEX "idx_msordprat_si_cd_va" ON "mshop_order_product_attr" ("siteid", "code")' );
43
		}
44
45
		if( !$db->hasIndex( 'mshop_order_service_attr', 'idx_msordseat_si_cd_va' ) )
46
		{
47
			$db->for( 'mysql', 'CREATE INDEX `idx_msordseat_si_cd_va` ON `mshop_order_service_attr` (`siteid`, `code`, `value`(16))' );
48
			$db->for( 'postgresql', 'CREATE INDEX "idx_msordseat_si_cd_va" ON "mshop_order_service_attr" ("siteid", "code", left("value", 16))' );
49
			$db->for( 'mssql', 'CREATE INDEX "idx_msordseat_si_cd_va" ON "mshop_order_service_attr" ("siteid", "code")' );
50
		}
51
	}
52
}
53