. * * 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 Installer * @version Version 0.1 */ if(isset($_GET['action'])) { $func = $_GET['action']; if($func != '') { require_once("../ini.php"); require_once("../step.php"); require_once("../path.php"); require_once("../dbUtil.php"); require_once("../installUtil.php"); } } class configuration extends Step { /** * Database object * * @author KnowledgeTree Team * @access private * @var object */ private $_dbhandler = null; /** * Database host * * @author KnowledgeTree Team * @access private * @var string */ private $host; /** * Database port * * @author KnowledgeTree Team * @access private * @var string */ private $port; /** * Relative path to knowledge tree directory * * @author KnowledgeTree Team * @access private * @var string */ private $root_url; /** * Absolute path to knowledge tree directory * * @author KnowledgeTree Team * @access private * @var string */ private $file_system_root; /** * Whether or not ssl is enabled * * @author KnowledgeTree Team * @access private * @var string */ private $ssl_enabled; /** * Whether or not the step is complete * * @author KnowledgeTree Team * @access private * @var string */ private $done; /** * Flag to display confirmation page first * * @author KnowledgeTree Team * @access public * @var array */ public $displayFirst = true; /** * Flag to store class information in session * * @author KnowledgeTree Team * @access public * @var array */ protected $storeInSession = true; /** * Flag if step needs to be installed * * @author KnowledgeTree Team * @access public * @var array */ protected $runInstall = true; /** * Flag if step needs to run silently * * @author KnowledgeTree Team * @access public * @var array */ protected $silent = false; /** * Flag if step needs to run silently * * @author KnowledgeTree Team * @access public * @var array */ protected $error = array(); /** * List of paths * * @author KnowledgeTree Team * @access public * @var array */ protected $paths = array(); /** * Reference to utility object * * @author KnowledgeTree Team * @access protected * @var object */ protected $util = null; protected $confpaths = array(); /** * Class constructor * * @author KnowledgeTree Team * @access public */ public function __construct() { $this->temp_variables = array("step_name"=>"configuration", "silent"=>$this->silent); $this->_dbhandler = new dbUtil(); $this->util = new InstallUtil(); $this->done = true; } /** * Control function for position within the step * * @author KnowledgeTree Team * @access public * @return string The position in the step */ public function doStep() { if(!$this->inStep("configuration")) { $this->setDetails(); $this->doRun(); return 'landing'; } $this->loadTemplateDefaults(); if($this->next()) { if($this->doRun()) { return 'confirm'; } return 'error'; } else if($this->previous()) { return 'previous'; } else if($this->confirm()) { $this->setDetails(); if($this->doRun()) { return 'next'; } return 'error'; } else if($this->edit()) { $this->setDetails(); if($this->doRun(true)) { return 'landing'; } else { return 'error'; } } $this->doRun(); return 'landing'; } /** * Set the variables from those stored in the session. * Used for stepping back to the step from a future step. * * @author KnowledgeTree Team * @access private * @param none * @return void */ private function setDetails() { $conf = $this->getDataFromSession("configuration"); if($conf) { $this->temp_variables['server'] = $conf['server']; $this->temp_variables['paths'] = $conf['paths']; } } /** * Default Template settings * * @author KnowledgeTree Team * @access public * @param none * @return void */ public function loadTemplateDefaults() { $this->temp_variables['paths_perms'] = 'tick'; } /** * Execute the step * * @author KnowledgeTree Team * @access public * @return boolean True to continue | False if errors occurred */ public function doRun($edit = false) { $server = $this->getServerInfo(); if(!$edit) $this->temp_variables['server'] = $server; $paths = $this->getPathInfo($server['file_system_root']['value']); if(!$edit) $this->temp_variables['paths'] = $paths; // Running user // Logging return $this->done; } /** * Get the database configuration settings * * @author KnowledgeTree Team * @access public * @param array $server * @param array $dbconf * @return array */ public function registerDBConfig($server, $dbconf) { // Adjust server variables $server['dbName'] = array('where'=>'file', 'name'=>ucwords($dbconf['dname']), 'section'=>'db', 'value'=>$dbconf['dname'], 'setting'=>'dbName'); $server['dbUser'] = array('where'=>'file', 'name'=>ucwords($dbconf['duname']), 'section'=>'db', 'value'=>$dbconf['duname'], 'setting'=>'dbUser'); $server['dbPass'] = array('where'=>'file', 'name'=>ucwords($dbconf['dpassword']), 'section'=>'db', 'value'=>$dbconf['dpassword'], 'setting'=>'dbPass'); $server['dbPort'] = array('where'=>'file', 'name'=>ucwords($dbconf['dport']), 'section'=>'db', 'value'=>$dbconf['dport'], 'setting'=>'dbPort'); $server['dbAdminUser'] = array('where'=>'file', 'name'=>ucwords($dbconf['dmsname']), 'section'=>'db', 'value'=>$dbconf['dmsname'], 'setting'=>'dbAdminUser'); $server['dbAdminPass'] = array('where'=>'file', 'name'=>ucwords($dbconf['dmspassword']), 'section'=>'db', 'value'=>$dbconf['dmspassword'], 'setting'=>'dbAdminPass'); return $server; } private function registerDirs() { // Adjust directories variables $this->readConfigPath(); $dirs = $this->getFromConfigPath(); $dbconf = $this->getDataFromSession("database"); // retrieve database information from session $this->_dbhandler->load($dbconf['dhost'], $dbconf['duname'], $dbconf['dpassword'], $dbconf['dname']); // initialise the db connection //$this->_dbhandler->getDatabaseLink() $directories['varDirectory'] = array('section'=>'urls', 'value'=>addslashes($dirs['varDirectory']['path']), 'setting'=>'varDirectory'); $directories['logDirectory'] = array('section'=>'urls', 'value'=>addslashes($dirs['logDirectory']['path']), 'setting'=>'logDirectory'); $directories['documentRoot'] = array('section'=>'urls', 'value'=>addslashes($dirs['documentRoot']['path']), 'setting'=>'documentRoot'); $directories['uiDirectory'] = array('section'=>'urls', 'value'=>'${fileSystemRoot}/presentation/lookAndFeel/knowledgeTree', 'setting'=>'uiDirectory'); $directories['tmpDirectory'] = array('section'=>'urls', 'value'=>addslashes($dirs['tmpDirectory']['path']), 'setting'=>'tmpDirectory'); return $directories; } /** * Perform the installation associated with the step. * Variables required by the installation are stored within the session. * * @author KnowledgeTree Team * @access public */ public function installStep() { $conf = $this->getDataFromSession("configuration"); // get data from the server $server = $conf['server']; $paths = $conf['paths']; $this->readConfigPath(); // initialise writing to config.ini $dirs = $this->getFromConfigPath(); if(isset($this->confpaths['configIni'])) { // Check if theres a config path $configPath = realpath("../../{$this->confpaths['configIni']}"); // Relative to Config Path File if($configPath == '') { // Absolute path probably entered $configPath = realpath("{$this->confpaths['configIni']}"); // Get relative path } } else { $configPath = realpath('../../config/config.ini'); } $ini = false; if(file_exists($configPath)) { $ini = new Ini($configPath); } $this->writeUrlSection($ini); $this->writeDBSection($ini, $server); $this->writeDBPathSection($ini, $paths); if(!$ini === false){ // write out the config.ini file $ini->write(); } $this->_dbhandler->close(); // close the database connection $this->writeCachePath(); // Write cache path file $this->writeConfigPath(); // Write config file } private function writeUrlSection($ini) { $directories = $this->registerDirs(); foreach($directories as $item) { // write server settings to config_settings table and config.ini if(!$ini === false) { $ini->updateItem($item['section'], $item['setting'], $item['value']); } } } private function writeDBPathSection($ini, $paths) { $table = 'config_settings'; if(is_array($paths)) { // write the paths to the config_settings table foreach ($paths as $item){ if(empty($item['setting'])){ continue; } $value = mysql_real_escape_string($item['path']); $setting = mysql_real_escape_string($item['setting']); $sql = "UPDATE {$table} SET value = '{$value}' WHERE item = '{$setting}'"; $this->_dbhandler->query($sql); } } } private function writeDBSection($ini, $server) { $dbconf = $this->getDataFromSession("database"); // retrieve database information from session $this->_dbhandler->load($dbconf['dhost'], $dbconf['duname'], $dbconf['dpassword'], $dbconf['dname']); // initialise the db connection $server = $this->registerDBConfig($server, $dbconf); // add db config to server variables $table = 'config_settings'; foreach($server as $item) { // write server settings to config_settings table and config.ini switch($item['where']) { case 'file': $value = $item['value']; if($value == 'yes') { $value = 'true'; } if($value == 'no'){ $value = 'false'; } if(!$ini === false){ $ini->updateItem($item['section'], $item['setting'], $value); } break; case 'db': $value = mysql_real_escape_string($item['value']); $setting = mysql_real_escape_string($item['setting']); $sql = "UPDATE {$table} SET value = '{$value}' WHERE item = '{$setting}'"; $this->_dbhandler->query($sql); break; } } } /** * Get the server settings information * * @author KnowledgeTree Team * @access private * @return array Server settings */ private function getServerInfo() { $script = $_SERVER['SCRIPT_NAME']; $file_system_root = $_SERVER['DOCUMENT_ROOT']; $host = $_SERVER['SERVER_NAME']; $port = $_SERVER['SERVER_PORT']; $ssl_enabled = isset($_SERVER['HTTPS']) ? (strtolower($_SERVER['HTTPS']) === 'on' ? 'yes' : 'no') : 'no'; $pos = strpos($script, '/setup/wizard/'); $root_url = substr($script, 0, $pos); $root_url = (isset($_POST['root_url'])) ? $_POST['root_url'] : $root_url; $file_system_root = (isset($_POST['file_system_root'])) ? $_POST['file_system_root'] : $file_system_root.$root_url; $host = (isset($_POST['host'])) ? $_POST['host'] : $host; $port = (isset($_POST['port'])) ? $_POST['port'] : $port; $ssl_enabled = (isset($_POST['ssl_enabled'])) ? $_POST['ssl_enabled'] : $ssl_enabled; $server = array(); $server['root_url'] = array('name' => 'Root Url', 'setting' => 'rootUrl', 'where' => 'db', 'value' => $root_url); $server['file_system_root'] = array('name' => 'File System Root', 'section' => 'KnowledgeTree', 'setting' => 'fileSystemRoot', 'where' => 'file', 'value' => $file_system_root); $server['host'] = array('name' => 'Host', 'setting' => 'server_name', 'where' => 'db', 'value' => $host); $server['port'] = array('name' => 'Port', 'setting' => 'server_port', 'where' => 'db', 'value' => $port); $server['ssl_enabled'] = array('name' => 'SSL Enabled', 'section' => 'KnowledgeTree', 'setting' => 'sslEnabled', 'where' => 'file', 'value' => $ssl_enabled); if(empty($server['host']['value'])) $this->error[] = 'Please enter the server\'s host name'; if(empty($server['port']['value'])) $this->error[] = 'Please enter the server\'s port'; if(empty($server['file_system_root']['value'])) $this->error[] = 'Please enter the file system root'; return $server; } /** * Get the path information for directories. Check permissions and existence of each. * Expands any ${fileSystemRoot} and ${varDirectory} variables contained in the path. * * @author KnowledgeTree Team * @access private * @param string $fileSystemRoot The file system root of the installation * @return array The path information */ private function getPathInfo($fileSystemRoot) { if(isset($this->temp_variables['paths'])) { $dirs = $this->temp_variables['paths']; // Pull from temp } else { $this->readConfigPath(); $dirs = $this->getFromConfigPath(); } $varDirectory = $fileSystemRoot . DS . 'var'; foreach ($dirs as $key => $dir){ $path = (isset($_POST[$dir['setting']])) ? $_POST[$dir['setting']] : $dir['path']; while(preg_match('/\$\{([^}]+)\}/', $path, $matches)){ $path = str_replace($matches[0], $$matches[1], $path); } if(WINDOWS_OS) $path = preg_replace('/\//', '\\',$path); $dirs[$key]['path'] = $path; if(isset($dir['file'])) $class = $this->util->checkPermission($path, $dir['create'], true); else $class = $this->util->checkPermission($path, $dir['create']); if($class['class'] != 'tick') { $this->temp_variables['paths_perms'] = $class['class']; $this->done = false; $this->error[] = "Path error"; } if(isset($class['msg'])) { $this->done = false; $this->error[] = $class['msg']; } $dirs[$key] = array_merge($dirs[$key], $class); } return $dirs; } /** * Get the list of directories that need to be checked * * @author KnowledgeTree Team * @access private * @return array The directory list */ private function getDirectories() { return array( array('name' => 'Var Directory', 'setting' => 'varDirectory', 'path' => '${varDirectory}', 'create' => false), array('name' => 'Document Directory', 'setting' => 'documentRoot', 'path' => '${varDirectory}/Documents', 'create' => true), array('name' => 'Log Directory', 'setting' => 'logDirectory', 'path' => '${varDirectory}/log', 'create' => true), array('name' => 'Temporary Directory', 'setting' => 'tmpDirectory', 'path' => '${varDirectory}/tmp', 'create' => true), array('name' => 'Cache Directory', 'setting' => 'cacheDirectory', 'path' => '${varDirectory}/cache', 'create' => true), array('name' => 'Uploads Directory', 'setting' => 'uploadDirectory', 'path' => '${varDirectory}/uploads', 'create' => true), array('name' => 'Configuration File', 'setting' => 'configFile', 'path' => '${fileSystemRoot}/config/config.ini', 'create' => false), ); } /** * Store contents of edited settings * * @author KnowledgeTree Team * @access private * @param none * @return array The path information */ private function setFromPost() { $this->paths = array( array('name' => 'Var Directory', 'setting' => 'varDirectory', 'path' => $_POST['varDirectory'], 'create' => false), array('name' => 'Document Directory', 'setting' => 'documentRoot', 'path' => $_POST['documentRoot'], 'create' => true), array('name' => 'Log Directory', 'setting' => 'logDirectory', 'path' => $_POST['logDirectory'], 'create' => true), array('name' => 'Temporary Directory', 'setting' => 'tmpDirectory', 'path' => $_POST['tmpDirectory'], 'create' => true), array('name' => 'Cache Directory', 'setting' => 'cacheDirectory', 'path' => $_POST['cacheDirectory'], 'create' => true), array('name' => 'Uploads Directory', 'setting' => 'uploadDirectory', 'path' => $_POST['uploadDirectory'], 'create' => true), array('name' => 'Configuration File', 'setting' => 'configFile', 'path' => $_POST['configFile'], 'create' => false, 'file'=>true), ); } /** * Store contents of edited settings * * @author KnowledgeTree Team * @access private * @param none * @return array The path information */ private function getFromConfigPath() { $configs = array(); if(isset($this->confpaths['configIni'])) { // Simple check to see if any paths were written $configPath = $this->confpaths['configIni']; // Get absolute path } else { $configPath = '${fileSystemRoot}/config/config.ini'; } $configs['configFile'] = array('name' => 'Configuration File', 'setting' => 'configFile', 'path' => $configPath, 'create' => false, 'file'=>true); if(isset($this->confpaths['Documents'])) { $docsPath = $this->confpaths['Documents']; } else { $docsPath = '${varDirectory}/Documents'; } $configs['documentRoot'] = array('name' => 'Document Directory', 'setting' => 'documentRoot', 'path' => $docsPath, 'create' => true); if(isset($this->confpaths['log'])) { $logPath = $this->confpaths['log']; } else { $logPath = '${varDirectory}/log'; } $configs['logDirectory'] = array('name' => 'Log Directory', 'setting' => 'logDirectory', 'path' => $logPath, 'create' => true); if(isset($this->confpaths['tmp'])) { $tmpPath = $this->confpaths['tmp']; } else { $tmpPath = '${varDirectory}/tmp'; } $configs['tmpDirectory'] = array('name' => 'Temporary Directory', 'setting' => 'tmpDirectory', 'path' => $tmpPath, 'create' => true); if(isset($this->confpaths['cache'])) { $cachePath = $this->confpaths['cache']; } else { $cachePath = '${varDirectory}/cache'; } $configs['cacheDirectory'] = array('name' => 'Cache Directory', 'setting' => 'cacheDirectory', 'path' => $cachePath, 'create' => true); if(isset($this->confpaths['uploads'])) { $uploadsPath = $this->confpaths['uploads']; } else { $uploadsPath = '${varDirectory}/uploads'; } $configs['uploadDirectory'] = array('name' => 'Uploads Directory', 'setting' => 'uploadDirectory', 'path' => $uploadsPath, 'create' => true); if(isset($this->confpaths['var'])) { $varPath = $this->confpaths['var']; } else { $varPath = '${fileSystemRoot}/var'; } $configs['varDirectory'] = array('name' => 'Var Directory', 'setting' => 'varDirectory', 'path' => $varPath, 'create' => false); return $configs; } /** * Path information * * @author KnowledgeTree Team * @access public * @param string $fileSystemRoot The file system root of the installation * @return array The path information */ public function getFromPost() { return $this->paths; } /** * Read contents of config path file * * @author KnowledgeTree Team * @access private * @param none * @return array The path information */ private function readConfigPath() { $configPath = $this->getContentPath(); if(!$configPath) return false; $ini = new Ini($configPath); $data = $ini->getFileByLine(); $firstline = true; foreach ($data as $k=>$v) { if($firstline) { // First line holds the var directory $firstline = false; if(!preg_match('/config.ini/', $k)) { // Make sure it is not the old config.ini $this->confpaths['var'] = $k; // Store var directory } } if(preg_match('/config.ini/', $k)) { // Find config.ini $this->confpaths['configIni'] = $k; } elseif (preg_match('/Documents/', $k)) { // Find documents directory $this->confpaths['Documents'] = $k; } elseif (preg_match('/cache/', $k)) { $this->confpaths['cache'] = $k; } elseif (preg_match('/indexes/', $k)) { $this->confpaths['indexes'] = $k; } elseif (preg_match('/log/', $k)) { $this->confpaths['log'] = $k; } elseif (preg_match('/proxies/', $k)) { $this->confpaths['proxies'] = $k; } elseif (preg_match('/tmp/', $k)) { $this->confpaths['tmp'] = $k; } elseif (preg_match('/uploads/', $k)) { $this->confpaths['uploads'] = $k; } } return true; } /** * Read contents of config path file * * @author KnowledgeTree Team * @access private * @param none * @return boolean */ private function writeConfigPath() { $configPath = $this->getContentPath(); if(!$configPath) return false; $ini = new Ini($configPath); $data = $ini->getFileByLine(); $configContent = ''; foreach ($data as $k=>$v) { if(preg_match('/config.ini/', $k)) { $configContent = $k; break; } } $fp = fopen($configPath, 'w'); if(fwrite($fp, $configContent)) return true; return false; } private function writeCachePath() { $cachePath = $this->getCachePath(); if(!$cachePath) return false; $configPath = $this->getContentPath(); if(!$configPath) return false; $ini = new Ini($configPath); $data = $ini->getFileByLine(); $cacheContent = ''; foreach ($data as $k=>$v) { if(preg_match('/cache/', $k)) { $cacheContent = $k; break; } } $fp = fopen($cachePath, 'w'); if($cacheContent != '') { if(fwrite($fp, $cacheContent)) return true; } return false; } /** * Attempt to locate config-path file in system * * @author KnowledgeTree Team * @access private * @param none * @return mixed */ public function getContentPath() { $configPath = realpath('../../../config/config-path'); if($configPath == '') $configPath = realpath('../../config/config-path'); if(!$configPath) return false; return $configPath; } public function getCachePath() { $cachePath = realpath('../../../config/cache-path'); if($cachePath == '') $cachePath = realpath('../../config/cache-path'); if(!$cachePath) return false; return $cachePath; } public function doReadConfig() { } } if(isset($_GET['action'])) { $func = $_GET['action']; if($func != '') { $serv = new configuration(); $func_call = strtoupper(substr($func,0,1)).substr($func,1); $method = "do$func_call"; $serv->$method(); } } ?>