function db_open($db) { $con = mysqli_connect("localhost", "plamencurso", "", $db); if ($con === false) { return db_connect_error(); } return $con; }
function db_and_errors_init($servers) { global $mysqli; foreach ($servers as $id => $server) { list($dbhost, $dbuser, $dbpass, $dbname, $debug, $onair) = $server; $mysqli = @new mysqli($dbhost, $dbuser, $dbpass, $dbname); if (!mysqli_connect_error()) { define("ON_AIR", $onair); define("DB_HOST", $dbhost); define("DB_USER", $dbuser); define("DB_PASS", $dbpass); define("DB_NAME", $dbname); break; } } if ($mysqli->connect_errno) { die('I cannot connect to the database because: ' . db_connect_error()); } $mysqli->set_charset("utf8"); define("DEBUGMODE", $debug); if ($debug) { error_reporting(E_ALL | E_STRICT); function query($sql) { global $mysqli, $queries_end; $time = microtime(true); $result = $mysqli->query($sql); $queries_end++; $delta = round((microtime(true) - $time) * 1000); if ($delta > 1) { //echo "\n<!--\n$sql\n$delta ms\n-->\n"; } if ($mysqli->errno) { throw new Exception('Query ' . $sql . ' failed because: ' . db_error()); } return $result; } } else { error_reporting(0); function query($sql) { global $mysqli; return $mysqli->query($sql); } } }
$t = 0; while (!@socket_connect($s, $vars['dbhost'], 3306) && $t < CONNECTION_TIMEOUT_SEC) { $t++; if ($t % 15 == 0) { echo "Waited for {$t} seconds...\n"; } sleep(1); } if ($t >= CONNECTION_TIMEOUT_SEC) { err("Timed out waiting for database TCP connection"); } //Check database installation status $db_installed = false; echo "Connecting to database mysql://{$vars['dbuser']}@{$vars['dbhost']}/{$vars['dbname']}\n"; if (!db_connect($vars['dbhost'], $vars['dbuser'], $vars['dbpass'])) { err(sprintf(__('Unable to connect to MySQL server: %s'), db_connect_error())); } elseif (explode('.', db_version()) < explode('.', $installer->getMySQLVersion())) { err(sprintf(__('osTicket requires MySQL %s or later!'), $installer->getMySQLVersion())); } elseif (!db_select_database($vars['dbname']) && !db_create_database($vars['dbname'])) { err("Database doesn't exist"); } elseif (!db_select_database($vars['dbname'])) { err('Unable to select the database'); } else { $sql = 'SELECT * FROM `' . $vars['prefix'] . 'config` LIMIT 1'; if (db_query($sql, false)) { $db_installed = true; echo "Database already installed\n"; } } //Create secret if not set by env var and not previously stored DEFINE('SECRET_FILE', '/data/secret.txt');
define('SLA_TABLE', TABLE_PREFIX . 'sla'); define('API_KEY_TABLE', TABLE_PREFIX . 'api_key'); define('TIMEZONE_TABLE', TABLE_PREFIX . 'timezone'); #Global override if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) { // Take the left-most item for X-Forwarded-For $_SERVER['REMOTE_ADDR'] = array_pop(explode(',', trim($_SERVER['HTTP_X_FORWARDED_FOR']))); } #Connect to the DB && get configuration from database $ferror = null; $options = array(); if (defined('DBSSLCA')) { $options['ssl'] = array('ca' => DBSSLCA, 'cert' => DBSSLCERT, 'key' => DBSSLKEY); } if (!db_connect(DBHOST, DBUSER, DBPASS, $options)) { $ferror = 'Unable to connect to the database -' . db_connect_error(); } elseif (!db_select_database(DBNAME)) { $ferror = 'Unknown or invalid database ' . DBNAME; } elseif (!($ost = osTicket::start()) || !($cfg = $ost->getConfig())) { $ferror = 'Unable to load config info from DB. Get tech support.'; } if ($ferror) { //Fatal error //try alerting admin using email in config file $msg = $ferror . "\n\n" . THISPAGE; Mailer::sendmail(ADMIN_EMAIL, 'osTicket Fatal Error', $msg, sprintf('"osTicket Alerts"<%s>', ADMIN_EMAIL)); //Display generic error to the user Http::response(500, "<b>Fatal Error:</b> Contact system administrator."); } //Init $session = $ost->getSession();
function install($vars) { $this->errors=$f=array(); $f['name'] = array('type'=>'string', 'required'=>1, 'error'=>__('Name required')); $f['email'] = array('type'=>'email', 'required'=>1, 'error'=>__('Valid email required')); $f['fname'] = array('type'=>'string', 'required'=>1, 'error'=>__('First name required')); $f['lname'] = array('type'=>'string', 'required'=>1, 'error'=>__('Last name required')); $f['admin_email'] = array('type'=>'email', 'required'=>1, 'error'=>__('Valid email required')); $f['username'] = array('type'=>'username', 'required'=>1, 'error'=>__('Username required')); $f['passwd'] = array('type'=>'password', 'required'=>1, 'error'=>__('Password required')); $f['passwd2'] = array('type'=>'password', 'required'=>1, 'error'=>__('Confirm Password')); $f['prefix'] = array('type'=>'string', 'required'=>1, 'error'=>__('Table prefix required')); $f['dbhost'] = array('type'=>'string', 'required'=>1, 'error'=>__('Host name required')); $f['dbname'] = array('type'=>'string', 'required'=>1, 'error'=>__('Database name required')); $f['dbuser'] = array('type'=>'string', 'required'=>1, 'error'=>__('Username required')); $f['dbpass'] = array('type'=>'string', 'required'=>1, 'error'=>__('Password required')); $vars = array_map('trim', $vars); if(!Validator::process($f,$vars,$this->errors) && !$this->errors['err']) $this->errors['err']=__('Missing or invalid data - correct the errors and try again.'); //Staff's email can't be same as system emails. if($vars['admin_email'] && $vars['email'] && !strcasecmp($vars['admin_email'],$vars['email'])) $this->errors['admin_email']=__('Conflicts with system email above'); //Admin's pass confirmation. if(!$this->errors && strcasecmp($vars['passwd'],$vars['passwd2'])) $this->errors['passwd2']=__('Password(s) do not match'); //Check table prefix underscore required at the end! if($vars['prefix'] && substr($vars['prefix'], -1)!='_') $this->errors['prefix']=__('Bad prefix. Must have underscore (_) at the end. e.g \'ost_\''); //Make sure admin username is not very predictable. XXX: feels dirty but necessary if(!$this->errors['username'] && in_array(strtolower($vars['username']),array('admin','admins','username','osticket'))) $this->errors['username']=__('Bad username'); // Support port number specified in the hostname with a colon (:) list($host, $port) = explode(':', $vars['dbhost']); if ($port && is_numeric($port) && ($port < 1 || $port > 65535)) $this->errors['db'] = __('Invalid database port number'); //MYSQL: Connect to the DB and check the version & database (create database if it doesn't exist!) if(!$this->errors) { if(!db_connect($vars['dbhost'],$vars['dbuser'],$vars['dbpass'])) $this->errors['db']=sprintf(__('Unable to connect to MySQL server: %s'), db_connect_error()); elseif(explode('.', db_version()) < explode('.', $this->getMySQLVersion())) $this->errors['db']=sprintf(__('osTicket requires MySQL %s or later!'),$this->getMySQLVersion()); elseif(!db_select_database($vars['dbname']) && !db_create_database($vars['dbname'])) { $this->errors['dbname']=__("Database doesn't exist"); $this->errors['db']=__('Unable to create the database.'); } elseif(!db_select_database($vars['dbname'])) { $this->errors['dbname']=__('Unable to select the database'); } else { //Abort if we have another installation (or table) with same prefix. $sql = 'SELECT * FROM `'.$vars['prefix'].'config` LIMIT 1'; if(db_query($sql, false)) { $this->errors['err'] = __('We have a problem - another installation with same table prefix exists!'); $this->errors['prefix'] = __('Prefix already in-use'); } else { //Try changing charset and collation of the DB - no bigie if we fail. db_query('ALTER DATABASE '.$vars['dbname'].' DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci', false); } } } //bailout on errors. if($this->errors) return false; /*************** We're ready to install ************************/ define('ADMIN_EMAIL',$vars['admin_email']); //Needed to report SQL errors during install. define('TABLE_PREFIX',$vars['prefix']); //Table prefix Bootstrap::defineTables(TABLE_PREFIX); Bootstrap::loadCode(); $debug = true; // Change it to false to squelch SQL errors. //Last minute checks. if(!file_exists($this->getConfigFile()) || !($configFile=file_get_contents($this->getConfigFile()))) $this->errors['err']=__('Unable to read config file. Permission denied! (#2)'); elseif(!($fp = @fopen($this->getConfigFile(),'r+'))) $this->errors['err']=__('Unable to open config file for writing. Permission denied! (#3)'); else { $streams = DatabaseMigrater::getUpgradeStreams(INCLUDE_DIR.'upgrader/streams/'); foreach ($streams as $stream=>$signature) { $schemaFile = INC_DIR."streams/$stream/install-mysql.sql"; if (!file_exists($schemaFile) || !($fp2 = fopen($schemaFile, 'rb'))) $this->errors['err'] = sprintf( __('%s: Internal Error - please make sure your download is the latest (#1)'), $stream); elseif ( // TODO: Make the hash algo configurable in the streams // configuration ( core : md5 ) !($hash = md5(fread($fp2, filesize($schemaFile)))) || strcasecmp($signature, $hash)) $this->errors['err'] = sprintf( __('%s: Unknown or invalid schema signature (%s .. %s)'), $stream, $signature, $hash); elseif (!$this->load_sql_file($schemaFile, $vars['prefix'], true, $debug)) $this->errors['err'] = sprintf( __('%s: Error parsing SQL schema! Get help from developers (#4)'), $stream); } } if(!$this->errors) { // TODO: Use language selected from install worksheet $i18n = new Internationalization($vars['lang_id']); $i18n->loadDefaultData(); Signal::send('system.install', $this); $sql='SELECT `id` FROM '.TABLE_PREFIX.'sla ORDER BY `id` LIMIT 1'; $sla_id_1 = db_result(db_query($sql, false)); $sql='SELECT `dept_id` FROM '.TABLE_PREFIX.'department ORDER BY `dept_id` LIMIT 1'; $dept_id_1 = db_result(db_query($sql, false)); $sql='SELECT `tpl_id` FROM '.TABLE_PREFIX.'email_template_group ORDER BY `tpl_id` LIMIT 1'; $template_id_1 = db_result(db_query($sql, false)); $sql='SELECT `group_id` FROM '.TABLE_PREFIX.'groups ORDER BY `group_id` LIMIT 1'; $group_id_1 = db_result(db_query($sql, false)); $sql='SELECT `value` FROM '.TABLE_PREFIX.'config WHERE namespace=\'core\' and `key`=\'default_timezone_id\' LIMIT 1'; $default_timezone = db_result(db_query($sql, false)); //Create admin user. $sql='INSERT INTO '.TABLE_PREFIX.'staff SET created=NOW() ' .", isactive=1, isadmin=1, group_id='$group_id_1', dept_id='$dept_id_1'" .", timezone_id='$default_timezone', max_page_size=25" .', email='.db_input($vars['admin_email']) .', firstname='.db_input($vars['fname']) .', lastname='.db_input($vars['lname']) .', username='******'username']) .', passwd='.db_input(Passwd::hash($vars['passwd'])); if(!db_query($sql, false) || !($uid=db_insert_id())) $this->errors['err']=__('Unable to create admin user (#6)'); } if(!$this->errors) { //Create default emails! $email = $vars['email']; list(,$domain)=explode('@',$vars['email']); $sql='INSERT INTO '.TABLE_PREFIX.'email (`name`,`email`,`created`,`updated`) VALUES ' ." ('Support','$email',NOW(),NOW())" .",('osTicket Alerts','alerts@$domain',NOW(),NOW())" .",('','noreply@$domain',NOW(),NOW())"; $support_email_id = db_query($sql, false) ? db_insert_id() : 0; $sql='SELECT `email_id` FROM '.TABLE_PREFIX."email WHERE `email`='alerts@$domain' LIMIT 1"; $alert_email_id = db_result(db_query($sql, false)); //Create config settings---default settings! $defaults = array( 'default_email_id'=>$support_email_id, 'alert_email_id'=>$alert_email_id, 'default_dept_id'=>$dept_id_1, 'default_sla_id'=>$sla_id_1, 'default_template_id'=>$template_id_1, 'admin_email'=>$vars['admin_email'], 'schema_signature'=>$streams['core'], 'helpdesk_url'=>URL, 'helpdesk_title'=>$vars['name']); $config = new Config('core'); if (!$config->updateAll($defaults)) $this->errors['err']=__('Unable to create config settings').' (#7)'; // Set company name require_once(INCLUDE_DIR.'class.company.php'); $company = new Company(); $company->getForm()->setAnswer('name', $vars['name']); $company->getForm()->save(); foreach ($streams as $stream=>$signature) { if ($stream != 'core') { $config = new Config($stream); if (!$config->update('schema_signature', $signature)) $this->errors['err']=__('Unable to create config settings').' (#8)'; } } } if($this->errors) return false; //Abort on internal errors. //Rewrite the config file - MUST be done last to allow for installer recovery. $configFile= str_replace("define('OSTINSTALLED',FALSE);","define('OSTINSTALLED',TRUE);",$configFile); $configFile= str_replace('%ADMIN-EMAIL',$vars['admin_email'],$configFile); $configFile= str_replace('%CONFIG-DBHOST',$vars['dbhost'],$configFile); $configFile= str_replace('%CONFIG-DBNAME',$vars['dbname'],$configFile); $configFile= str_replace('%CONFIG-DBUSER',$vars['dbuser'],$configFile); $configFile= str_replace('%CONFIG-DBPASS',$vars['dbpass'],$configFile); $configFile= str_replace('%CONFIG-PREFIX',$vars['prefix'],$configFile); $configFile= str_replace('%CONFIG-SIRI',Misc::randCode(32),$configFile); if(!$fp || !ftruncate($fp,0) || !fwrite($fp,$configFile)) { $this->errors['err']=__('Unable to write to config file. Permission denied! (#5)'); return false; } @fclose($fp); /************* Make the system happy ***********************/ $sql='UPDATE '.TABLE_PREFIX."email SET dept_id=$dept_id_1"; db_query($sql, false); global $cfg; $cfg = new OsticketConfig(); //Create a ticket to make the system warm and happy. $errors = array(); $ticket_vars = $i18n->getTemplate('templates/ticket/installed.yaml') ->getData(); $ticket = Ticket::create($ticket_vars, $errors, 'api', false, false); if ($ticket && ($org = Organization::objects()->order_by('id')->one())) { $user=User::lookup($ticket->getOwnerId()); $user->setOrganization($org); } //TODO: create another personalized ticket and assign to admin?? //Log a message. $msg=__("Congratulations osTicket basic installation completed!\n\nThank you for choosing osTicket!"); $sql='INSERT INTO '.TABLE_PREFIX.'syslog SET created=NOW(), updated=NOW(), log_type="Debug" ' .', title="osTicket installed!"' .', log='.db_input($msg) .', ip_address='.db_input($_SERVER['REMOTE_ADDR']); db_query($sql, false); return true; }
function connect() { #Connect to the DB && get configuration from database $ferror = null; $options = array(); if (defined('DBSSLCA')) { $options['ssl'] = array('ca' => DBSSLCA, 'cert' => DBSSLCERT, 'key' => DBSSLKEY); } if (!db_connect(DBHOST, DBUSER, DBPASS, $options)) { $ferror = sprintf('Unable to connect to the database — %s', db_connect_error()); } elseif (!db_select_database(DBNAME)) { $ferror = sprintf('Unknown or invalid database: %s', DBNAME); } if ($ferror) { //Fatal error self::croak($ferror); } }
function install($vars) { $this->errors = $f = array(); $f['name'] = array('type' => 'string', 'required' => 1, 'error' => 'Name required'); $f['email'] = array('type' => 'email', 'required' => 1, 'error' => 'Valid email required'); $f['fname'] = array('type' => 'string', 'required' => 1, 'error' => 'First name required'); $f['lname'] = array('type' => 'string', 'required' => 1, 'error' => 'Last name required'); $f['admin_email'] = array('type' => 'email', 'required' => 1, 'error' => 'Valid email required'); $f['username'] = array('type' => 'username', 'required' => 1, 'error' => 'Username required'); $f['passwd'] = array('type' => 'password', 'required' => 1, 'error' => 'Password required'); $f['passwd2'] = array('type' => 'string', 'required' => 1, 'error' => 'Confirm password'); $f['prefix'] = array('type' => 'string', 'required' => 1, 'error' => 'Table prefix required'); $f['dbhost'] = array('type' => 'string', 'required' => 1, 'error' => 'Hostname required'); $f['dbname'] = array('type' => 'string', 'required' => 1, 'error' => 'Database name required'); $f['dbuser'] = array('type' => 'string', 'required' => 1, 'error' => 'Username required'); $f['dbpass'] = array('type' => 'string', 'required' => 1, 'error' => 'password required'); if (!Validator::process($f, $vars, $this->errors) && !$this->errors['err']) { $this->errors['err'] = 'Missing or invalid data - correct the errors and try again.'; } //Staff's email can't be same as system emails. if ($vars['admin_email'] && $vars['email'] && !strcasecmp($vars['admin_email'], $vars['email'])) { $this->errors['admin_email'] = 'Conflicts with system email above'; } //Admin's pass confirmation. if (!$this->errors && strcasecmp($vars['passwd'], $vars['passwd2'])) { $this->errors['passwd2'] = 'passwords to not match!'; } //Check table prefix underscore required at the end! if ($vars['prefix'] && substr($vars['prefix'], -1) != '_') { $this->errors['prefix'] = 'Bad prefix. Must have underscore (_) at the end. e.g \'ost_\''; } //Make sure admin username is not very predictable. XXX: feels dirty but necessary if (!$this->errors['username'] && in_array(strtolower($vars['username']), array('admin', 'admins', 'username', 'osticket'))) { $this->errors['username'] = '******'; } // Support port number specified in the hostname with a colon (:) list($host, $port) = explode(':', $vars['dbhost']); if ($port && is_numeric($port) && ($port < 1 || $port > 65535)) { $this->errors['db'] = 'Invalid database port number'; } //MYSQL: Connect to the DB and check the version & database (create database if it doesn't exist!) if (!$this->errors) { if (!db_connect($vars['dbhost'], $vars['dbuser'], $vars['dbpass'])) { $this->errors['db'] = 'Unable to connect to MySQL server. ' . db_connect_error(); } elseif (explode('.', db_version()) < explode('.', $this->getMySQLVersion())) { $this->errors['db'] = sprintf('osTicket requires MySQL %s or better!', $this->getMySQLVersion()); } elseif (!db_select_database($vars['dbname']) && !db_create_database($vars['dbname'])) { $this->errors['dbname'] = 'Database doesn\'t exist'; $this->errors['db'] = 'Unable to create the database.'; } elseif (!db_select_database($vars['dbname'])) { $this->errors['dbname'] = 'Unable to select the database'; } else { //Abort if we have another installation (or table) with same prefix. $sql = 'SELECT * FROM `' . $vars['prefix'] . 'config` LIMIT 1'; if (db_query($sql, false)) { $this->errors['err'] = 'We have a problem - another installation with same table prefix exists!'; $this->errors['prefix'] = 'Prefix already in-use'; } else { //Try changing charset and collation of the DB - no bigie if we fail. db_query('ALTER DATABASE ' . $vars['dbname'] . ' DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci', false); } } } //bailout on errors. if ($this->errors) { return false; } /*************** We're ready to install ************************/ define('ADMIN_EMAIL', $vars['admin_email']); //Needed to report SQL errors during install. define('PREFIX', $vars['prefix']); //Table prefix $debug = true; // Change it to false to squelch SQL errors. //Last minute checks. if (!file_exists($this->getConfigFile()) || !($configFile = file_get_contents($this->getConfigFile()))) { $this->errors['err'] = 'Unable to read config file. Permission denied! (#2)'; } elseif (!($fp = @fopen($this->getConfigFile(), 'r+'))) { $this->errors['err'] = 'Unable to open config file for writing. Permission denied! (#3)'; } else { $streams = DatabaseMigrater::getUpgradeStreams(INCLUDE_DIR . 'upgrader/streams/'); foreach ($streams as $stream => $signature) { $schemaFile = INC_DIR . "streams/{$stream}/install-mysql.sql"; if (!file_exists($schemaFile) || !($fp2 = fopen($schemaFile, 'rb'))) { $this->errors['err'] = $stream . ': Internal Error - please make sure your download is the latest (#1)'; } elseif (!($hash = md5(fread($fp2, filesize($schemaFile)))) || strcasecmp($signature, $hash)) { $this->errors['err'] = $stream . ': Unknown or invalid schema signature (' . $signature . ' .. ' . $hash . ')'; } elseif (!$this->load_sql_file($schemaFile, $vars['prefix'], true, $debug)) { $this->errors['err'] = $stream . ': Error parsing SQL schema! Get help from developers (#4)'; } } } $sql = 'SELECT `id` FROM ' . PREFIX . 'sla ORDER BY `id` LIMIT 1'; $sla_id_1 = db_result(db_query($sql, false), 0); $sql = 'SELECT `dept_id` FROM ' . PREFIX . 'department ORDER BY `dept_id` LIMIT 1'; $dept_id_1 = db_result(db_query($sql, false), 0); $sql = 'SELECT `tpl_id` FROM ' . PREFIX . 'email_template_group ORDER BY `tpl_id` LIMIT 1'; $template_id_1 = db_result(db_query($sql, false), 0); $sql = 'SELECT `group_id` FROM ' . PREFIX . 'groups ORDER BY `group_id` LIMIT 1'; $group_id_1 = db_result(db_query($sql, false), 0); $sql = 'SELECT `id` FROM ' . PREFIX . 'timezone WHERE offset=-5.0 LIMIT 1'; $eastern_timezone = db_result(db_query($sql, false), 0); if (!$this->errors) { //Create admin user. $sql = 'INSERT INTO ' . PREFIX . 'staff SET created=NOW() ' . ", isactive=1, isadmin=1, group_id={$group_id_1}, dept_id={$dept_id_1}" . ", timezone_id={$eastern_timezone}, max_page_size=25" . ', email=' . db_input($vars['admin_email']) . ', firstname=' . db_input($vars['fname']) . ', lastname=' . db_input($vars['lname']) . ', username='******'username']) . ', passwd=' . db_input(Passwd::hash($vars['passwd'])); if (!db_query($sql, false) || !($uid = db_insert_id())) { $this->errors['err'] = 'Unable to create admin user (#6)'; } } if (!$this->errors) { //Create default emails! $email = $vars['email']; list(, $domain) = explode('@', $vars['email']); $sql = 'INSERT INTO ' . PREFIX . 'email (`name`,`email`,`created`,`updated`) VALUES ' . " ('Support','{$email}',NOW(),NOW())" . ",('osTicket Alerts','alerts@{$domain}',NOW(),NOW())" . ",('','noreply@{$domain}',NOW(),NOW())"; $support_email_id = db_query($sql, false) ? db_insert_id() : 0; $sql = 'SELECT `email_id` FROM ' . PREFIX . "email WHERE `email`='alerts@{$domain}' LIMIT 1"; $alert_email_id = db_result(db_query($sql, false), 0); //Create config settings---default settings! //XXX: rename ostversion helpdesk_* ?? // XXX: Some of this can go to the core install file $defaults = array('isonline' => '0', 'default_email_id' => $support_email_id, 'alert_email_id' => $alert_email_id, 'default_dept_id' => $dept_id_1, 'default_sla_id' => $sla_id_1, 'default_timezone_id' => $eastern_timezone, 'default_template_id' => $template_id_1, 'admin_email' => db_input($vars['admin_email']), 'schema_signature' => db_input($streams['core']), 'helpdesk_url' => db_input(URL), 'helpdesk_title' => db_input($vars['name'])); foreach ($defaults as $key => $value) { $sql = 'UPDATE ' . PREFIX . 'config SET updated=NOW(), value=' . $value . ' WHERE namespace="core" AND `key`=' . db_input($key); if (!db_query($sql, false)) { $this->errors['err'] = 'Unable to create config settings (#7)'; } } foreach ($streams as $stream => $signature) { if ($stream != 'core') { $sql = 'INSERT INTO ' . PREFIX . 'config (`namespace`, `key`, `value`, `updated`) ' . 'VALUES (' . db_input($stream) . ', ' . db_input('schema_signature') . ', ' . db_input($signature) . ', NOW())'; if (!db_query($sql, false)) { $this->errors['err'] = 'Unable to create config settings (#7)'; } } } } if ($this->errors) { return false; } //Abort on internal errors. //Rewrite the config file - MUST be done last to allow for installer recovery. $configFile = str_replace("define('OSTINSTALLED',FALSE);", "define('OSTINSTALLED',TRUE);", $configFile); $configFile = str_replace('%ADMIN-EMAIL', $vars['admin_email'], $configFile); $configFile = str_replace('%CONFIG-DBHOST', $vars['dbhost'], $configFile); $configFile = str_replace('%CONFIG-DBNAME', $vars['dbname'], $configFile); $configFile = str_replace('%CONFIG-DBUSER', $vars['dbuser'], $configFile); $configFile = str_replace('%CONFIG-DBPASS', $vars['dbpass'], $configFile); $configFile = str_replace('%CONFIG-PREFIX', $vars['prefix'], $configFile); $configFile = str_replace('%CONFIG-SIRI', Misc::randCode(32), $configFile); if (!$fp || !ftruncate($fp, 0) || !fwrite($fp, $configFile)) { $this->errors['err'] = 'Unable to write to config file. Permission denied! (#5)'; return false; } @fclose($fp); /************* Make the system happy ***********************/ $sql = 'UPDATE ' . PREFIX . "email SET dept_id={$dept_id_1}"; db_query($sql, false); $sql = 'UPDATE ' . PREFIX . "department SET email_id={$support_email_id}" . ", autoresp_email_id={$support_email_id}"; db_query($sql, false); //Create a ticket to make the system warm and happy. $sql = 'INSERT INTO ' . PREFIX . 'ticket SET created=NOW(), status="open", source="Web" ' . " ,priority_id=0, dept_id={$dept_id_1}, topic_id=0 " . ' ,ticketID=' . db_input(Misc::randNumber(6)) . ' ,email="*****@*****.**" ' . ' ,name="osTicket Support" ' . ' ,subject="osTicket Installed!"'; if (db_query($sql, false) && ($tid = db_insert_id())) { if (!($msg = file_get_contents(INC_DIR . 'msg/installed.txt'))) { $msg = 'Congratulations and Thank you for choosing osTicket!'; } $sql = 'INSERT INTO ' . PREFIX . 'ticket_thread SET created=NOW()' . ', source="Web" ' . ', thread_type="M" ' . ', ticket_id=' . db_input($tid) . ', title=' . db_input('osTicket Installed') . ', body=' . db_input($msg); db_query($sql, false); } //TODO: create another personalized ticket and assign to admin?? //Log a message. $msg = "Congratulations osTicket basic installation completed!\n\nThank you for choosing osTicket!"; $sql = 'INSERT INTO ' . PREFIX . 'syslog SET created=NOW(), updated=NOW(), log_type="Debug" ' . ', title="osTicket installed!"' . ', log=' . db_input($msg) . ', ip_address=' . db_input($_SERVER['REMOTE_ADDR']); db_query($sql, false); return true; }