| Conditions | 5 |
| Paths | 7 |
| Total Lines | 23 |
| Code Lines | 12 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
| 1 | <?php |
||
| 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 | } |
||
| 46 |