. * * You can contact KnowledgeTree Inc., PO Box 7775 #87847, San Francisco, * California 94120-7775, or email info@knowledgetree.com. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU General Public License version 3. * * In accordance with Section 7(b) of the GNU General Public License version 3, * these Appropriate Legal Notices must retain the display of the "Powered by * KnowledgeTree" logo and retain the original copyright notice. If the display of the * logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices * must display the words "Powered by KnowledgeTree" and retain the original * copyright notice. * * @copyright 2008-2009, KnowledgeTree Inc. * @license GNU General Public License version 3 * @author KnowledgeTree Team * @package Migrater * @version Version 0.1 */ class migrateDatabase extends Step { /** * Reference to Database object * * @author KnowledgeTree Team * @access public * @var object */ public $_dbhandler = null; /** * Reference to Database object * * @author KnowledgeTree Team * @access public * @var object */ public $_util = null; /** * List of errors encountered * * @author KnowledgeTree Team * @access public * @var array */ public $error = array(); /** * Flag to store class information in session * * @author KnowledgeTree Team * @access public * @var array */ public $storeInSession = true; /** * Flag if step needs to be migrated * * @author KnowledgeTree Team * @access public * @var array */ protected $runMigrate = true; /** * Flag if step needs to run silently * * @author KnowledgeTree Team * @access public * @var array */ protected $silent = true; /** * List of errors used in template * * @author KnowledgeTree Team * @access public * @var array */ public $templateErrors = array('dmspassword', 'dmsuserpassword', 'con', 'dname', 'dtype', 'duname', 'dpassword'); /** * Constructs database object * * @author KnowledgeTree Team * @access public * @param none */ public function __construct() { $this->temp_variables = array("step_name"=>"database", "silent"=>$this->silent); $this->util = new MigrateUtil(); if(WINDOWS_OS) $this->mysqlDir = MYSQL_BIN; $this->wizardLocation = '../wizard'; } /** * Main control of database setup * * @author KnowledgeTree Team * @param none * @access public * @return string */ public function doStep() { $this->initErrors(); // Load template errors $this->setDetails(); // Set any posted variables if(!$this->inStep("database")) { return 'landing'; } if($this->next()) { if($this->exportDatabase()) { return 'next'; } } else if($this->previous()) { return 'previous'; } return 'landing'; } public function exportDatabase() { if(WINDOWS_OS) { } else { $tmpFolder = "/tmp/knowledgtree"; } @mkdir($tmpFolder); $installation = $this->getDataFromSession("installation"); // Get installation directory $dbSettings = $installation['dbSettings']; $uname = $this->temp_variables['duname']; $pwrd = $this->temp_variables['dpassword']; $sqlFile = $tmpFolder."dms.sql"; $dbName = $dbSettings['dbName']; $cmd = "mysqldump -u{$uname} -p{$pwrd} {$dbName} > ".$sqlFile; $response = $this->util->pexec($cmd); if(file_exists($sqlFile)) { return true; } else { return false; } } /** * Store options * * @author KnowledgeTree Team * @params object SimpleXmlObject * @access private * @return void */ private function setDetails() { $this->temp_variables['duname'] = $this->getPostSafe('duname'); $this->temp_variables['dpassword'] = $this->getPostSafe('dpassword'); // create lock file to indicate migration mode $this->createMigrateFile(); } /** * Creates migration lock file so that system knows it is supposed to run an upgrade installation * * @author KnowledgeTree Team * @access private * @return void */ private function createMigrateFile() { @touch($this->wizardLocation . DIRECTORY_SEPARATOR . "migrate.lock"); } /** * Safer way to return post data * * @author KnowledgeTree Team * @params SimpleXmlObject $simplexml * @access public * @return void */ public function getPostSafe($key) { return isset($_POST[$key]) ? $_POST[$key] : ""; } /** * Stores varibles used by template * * @author KnowledgeTree Team * @params none * @access public * @return array */ public function getStepVars() { return $this->temp_variables; } /** * Returns database errors * * @author KnowledgeTree Team * @access public * @params none * @return array */ public function getErrors() { return $this->error; } /** * Initialize errors to false * * @author KnowledgeTree Team * @param none * @access private * @return boolean */ private function initErrors() { foreach ($this->templateErrors as $e) { $this->error[$e] = false; } } } ?>