Skip to content

Commit

Permalink
Fix bug upgrading from 2.x and add utf8 for mysql connection for upgrade
Browse files Browse the repository at this point in the history
  • Loading branch information
xcompass committed Aug 19, 2014
1 parent fef1138 commit a4ba3bd
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 7 deletions.
2 changes: 1 addition & 1 deletion app/controllers/upgrade_controller.php
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ function index()
$dbv = $this->SysParameter->get('database.version');
// workaround for a mistake in a sql templates in v3.0.x where
// we forgot to add the system.version entry into sys_parameters
if (empty($sysv) && $dbv == 4) {
if (empty($sysv) && $dbv == 4 && $this->SysParameter->get('display.vocabulary.department')) {
// upgrading from iPeer v3.0
$sysv = '3.0.x';
$dbv = 5;
Expand Down
12 changes: 6 additions & 6 deletions app/libs/upgrade_scripts/upgrade_300.php
Original file line number Diff line number Diff line change
Expand Up @@ -36,12 +36,12 @@ public function isUpgradable()
$dbv = $sysparameter->get('database.version');
$sysv = $sysparameter->get('system.version');

// If system.version doesn't exist, but we get a database version of 4,
// then that means we're upgrading from a prior iPeer v3 installation
// If system.version doesn't exist, but we get a database version of 4,
// then that means we're upgrading from a prior iPeer v3 installation
// and don't need to run this upgrader.
if (empty($sysv) && $dbv == 4) {
return false;
}
# if (empty($sysv) && $dbv == 4) {
# return false;
# }

return parent::isUpgradable();
}
Expand Down Expand Up @@ -69,7 +69,7 @@ public function up()
// when upgrading from v2, will run through all the delta_*.sql files
// up to $this->dbVersion because the database version wasn't stored in
// the database, so PHP get a null value back, which is then treated
// as if we're starting from version 0
// as if we're starting from version 0
$sysparameter = ClassRegistry::init('SysParameter');
$dbv = $sysparameter->getDatabaseVersion();
$ret = $this->patchDb($dbv, $this->dbVersion);
Expand Down
11 changes: 11 additions & 0 deletions app/libs/upgrade_scripts/upgrade_base.php
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,15 @@
* @license PHP Version 3.0 {@link http://www.php.net/license/3_0.txt}
* @version Release: 3.0
*/

// mysql_set_charset is only available PHP 5 >= 5.2.3
if (!function_exists('mysql_set_charset')) {
function mysql_set_charset($charset,$dbh)
{
return mysql_query("set names $charset",$dbh);
}
}

class UpgradeBase
{
public $errors = array();
Expand Down Expand Up @@ -136,6 +145,8 @@ protected function connectDb()
return 'Could not connect to database!';
}

mysql_set_charset('utf8', $mysql);

//Open the database
$mysqldb = mysql_select_db($dbConfig['database']);
if (!$mysqldb) {
Expand Down

0 comments on commit a4ba3bd

Please sign in to comment.