mirror of
				https://github.com/slawkens/myaac.git
				synced 2025-10-26 14:04:17 +01:00 
			
		
		
		
	 3f6ff3a332
			
		
	
	3f6ff3a332
	
	
	
		
			
			* Migrations up down * Add forum model * Syntactic sugar for db structure changes * Refactor migrations with $up & $down * Fix migrations upgrade and downgrade + Add option to disable auto migrate * Add migrate:to command Usage: php aac migrate:to x (x - database version) * Show error when mail is not enabled * Fixes regarding to init.php * Add migrate command to manually upgrade db, incase auto migrate is disabled * Fixed rest of the migrations * Limit max version of database * Don't allow minus number * Option to clear specified plugin settings by name * Version is required * Fix PHPStan errors * Unset $up after migration, to prevent executing same migration twice * Add database version to output * This is not needed * Update 5.php * Set database_auto_migrate on install * Set blank & color only if current db version supports it * Fix duplicate function declaration
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * @var OTS_DB_MySQL $db
 | |
|  */
 | |
| 
 | |
| use MyAAC\Models\Spell;
 | |
| 
 | |
| $up = function () use ($db) {
 | |
| 	// add new item_id field for runes
 | |
| 	if (!$db->hasColumn(TABLE_PREFIX . 'spells', 'item_id')) {
 | |
| 		$db->addColumn(TABLE_PREFIX . 'spells', 'item_id', 'INT(11) NOT NULL DEFAULT 0 AFTER `conjure_count`');
 | |
| 	}
 | |
| 
 | |
| 	// change unique index from spell to name
 | |
| 	$db->query("ALTER TABLE `" . TABLE_PREFIX . "spells` DROP INDEX `spell`;");
 | |
| 	$db->query("ALTER TABLE `" . TABLE_PREFIX . "spells` ADD UNIQUE INDEX (`name`);");
 | |
| 
 | |
| 	// change comment of spells.type
 | |
| 	$db->modifyColumn(TABLE_PREFIX . 'spells', 'type', "TINYINT(1) NOT NULL DEFAULT 0 COMMENT '1 - instant, 2 - conjure, 3 - rune'");
 | |
| 
 | |
| 	// new items table
 | |
| 	if (!$db->hasTable(TABLE_PREFIX . 'items')) {
 | |
| 		$db->query(file_get_contents(__DIR__ . '/12-items.sql'));
 | |
| 	}
 | |
| 
 | |
| 	// new weapons table
 | |
| 	if (!$db->hasTable(TABLE_PREFIX . 'weapons')) {
 | |
| 		$db->query(file_get_contents(__DIR__ . '/12-weapons.sql'));
 | |
| 	}
 | |
| 
 | |
| 	// modify vocations to support json data
 | |
| 	$db->modifyColumn(TABLE_PREFIX . 'spells', 'vocations', "VARCHAR(100) NOT NULL DEFAULT ''");
 | |
| 
 | |
| 	$spells = Spell::select('id', 'vocations')->get();
 | |
| 	foreach ($spells as $spell) {
 | |
| 		$tmp = explode(',', $spell->vocations);
 | |
| 		foreach ($tmp as &$v) {
 | |
| 			$v = (int)$v;
 | |
| 		}
 | |
| 
 | |
| 		Spell::where('id', $spell->id)->update(['vocations' => json_encode($tmp)]);
 | |
| 	}
 | |
| };
 | |
| 
 | |
| $down = function () use ($db) {
 | |
| 	// remove item_id field for runes
 | |
| 	if ($db->hasColumn(TABLE_PREFIX . 'spells', 'item_id')) {
 | |
| 		$db->dropColumn(TABLE_PREFIX . 'spells', 'item_id');
 | |
| 	}
 | |
| 
 | |
| 	// change unique index from spell to name
 | |
| 	$db->query("ALTER TABLE `" . TABLE_PREFIX . "spells` DROP INDEX `name`;");
 | |
| 	$db->query("ALTER TABLE `" . TABLE_PREFIX . "spells` ADD INDEX (`spell`);");
 | |
| 
 | |
| 	$db->dropTable(TABLE_PREFIX . 'items');
 | |
| 	$db->dropTable(TABLE_PREFIX . 'weapons');
 | |
| 
 | |
| 	$spells = Spell::select('id', 'vocations')->get();
 | |
| 	// modify vocations to use vocation separated by comma
 | |
| 	foreach ($spells as $spell) {
 | |
| 		$vocations = empty($spell->vocations) ? [] : json_decode($spell->vocations);
 | |
| 
 | |
| 		Spell::where('id', $spell->id)->update(['vocations' => implode(',', $vocations)]);
 | |
| 	}
 | |
| };
 |