2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4 * SugarCRM Community Edition is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
7 * This program is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU Affero General Public License version 3 as published by the
9 * Free Software Foundation with the addition of the following permission added
10 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
14 * This program is distributed in the hope that it will be useful, but WITHOUT
15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
19 * You should have received a copy of the GNU Affero General Public License along with
20 * this program; if not, see http://www.gnu.org/licenses or write to the Free
21 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
24 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
27 * The interactive user interfaces in modified source and object code versions
28 * of this program must display Appropriate Legal Notices, as required under
29 * Section 5 of the GNU Affero General Public License version 3.
31 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32 * these Appropriate Legal Notices must retain the display of the "Powered by
33 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34 * technical reasons, the Appropriate Legal Notices must display the words
35 * "Powered by SugarCRM".
36 ********************************************************************************/
40 global $sugar_version, $js_custom_version;
43 if(empty($_SESSION['setup_db_host_name'])){
44 $_SESSION['setup_db_host_name'] = (isset($sugar_config['db_host_name'])) ? $sugar_config['db_host_name'] : $_SERVER['SERVER_NAME'];
47 if( !isset( $install_script ) || !$install_script ){
48 die($mod_strings['ERR_NO_DIRECT_SCRIPT']);
53 $createDbCheckbox = '';
54 $createDb = (!empty($_SESSION['setup_db_create_database'])) ? 'checked="checked"' : '';
55 $dropCreate = (!empty($_SESSION['setup_db_drop_tables'])) ? 'checked="checked"' : '';
57 if (isset($_SESSION['setup_db_host_instance']) && !empty($_SESSION['setup_db_host_instance'])){
58 $instanceName = $_SESSION['setup_db_host_instance'];
62 if (isset($_SESSION['setup_db_port_num']) && !empty($_SESSION['setup_db_port_num'])){
63 $setupDbPortNum = $_SESSION['setup_db_port_num'];
66 $db = getInstallDbInstance();
68 ///////////////////////////////////////////////////////////////////////////////
69 //// BEGIN PAGE OUTPUT
71 $langHeader = get_language_header();
74 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
77 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
78 <meta http-equiv="Content-Script-Type" content="text/javascript">
79 <meta http-equiv="Content-Style-Type" content="text/css">
80 <title>{$mod_strings['LBL_WIZARD_TITLE']} {$mod_strings['LBL_DBCONF_TITLE']}</title>
81 <link rel="stylesheet" href="install/install.css" type="text/css" />
82 <script type="text/javascript" src="install/installCommon.js"></script>
83 <script type="text/javascript" src="install/dbConfig.js"></script>
84 <link REL="SHORTCUT ICON" HREF="include/images/sugar_icon.ico">
85 <script src="cache/include/javascript/sugar_grp1_yui.js?s={$sugar_version}&c={$js_custom_version}"></script>
86 <script type="text/javascript">
92 <link rel='stylesheet' type='text/css' href='include/javascript/yui/build/container/assets/container.css' />
96 $out .= '<body onload="document.getElementById(\'button_next2\').focus();">';
99 <form action="install.php" method="post" name="setConfig" id="form">
100 <input type='hidden' name='setup_db_drop_tables' id='setup_db_drop_tables' value=''>
101 <input type="hidden" id="hidden_goto" name="goto" value="{$mod_strings['LBL_BACK']}" />
102 <table cellspacing="0" cellpadding="0" border="0" align="center" class="shell">
104 <tr><td colspan="2" id="help"><a href="{$help_url}" target='_blank'>{$mod_strings['LBL_HELP']} </a></td></tr>
108 <img src="{$sugar_md}" alt="SugarCRM" border="0">
110 {$mod_strings['LBL_DBCONF_TITLE']}
112 <th width="200" height="30" style="text-align: right;"><a href="http://www.sugarcrm.com" target="_blank">
113 <IMG src="include/images/sugarcrm_login.png" width="145" height="30" alt="SugarCRM" border="0"></a>
118 <div id="errorMsgs" style="display:none"></div>
119 <div class="required">{$mod_strings['LBL_REQUIRED']}</div>
120 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
121 <tr><th colspan="3" align="left" >{$mod_strings['LBL_DBCONF_TITLE_NAME']} </td></tr>
125 $config_params = $db->installConfig();
127 foreach($config_params as $group => $gdata) {
128 $form .= "<tr><td colspan=\"3\" align=\"left\">{$mod_strings[$group]}</td></tr>\n";
129 foreach($gdata as $name => $value) {
132 if(!empty($value['required'])) {
133 $form .= "<td><span class=\"required\">*</span></td>\n";
135 $form .= "<td> </td>\n";
137 if(!empty($_SESSION[$name])) {
138 $sessval = $_SESSION[$name];
142 if(!empty($value["type"])) {
143 $type = $value["type"];
149 <td nowrap><b>{$mod_strings[$value["label"]]}</b></td>
152 //if the type is password, set a hidden field to capture the value. This is so that we can properly encode special characters, which is a limitation with password fields
153 if($type=='password'){
154 $form .= "<input type='$type' name='{$name}_entry' id='{$name}_entry' value='".urldecode($sessval)."'><input type='hidden' name='$name' id='$name' value='".urldecode($sessval)."'>";
156 $form .= "<input type='$type' name='$name' id='$name' value='$sessval'>";
166 $form .= "<input name=\"$name\" id=\"$name\" value=\"\" type=\"hidden\">\n";
173 //if we are installing in custom mode, include the following html
174 if($db->supports("create_user")){
175 // create / set db user dropdown
176 $auto_select = '';$provide_select ='';$create_select = '';$same_select = '';
177 if(isset($_SESSION['dbUSRData'])){
178 // if($_SESSION['dbUSRData']=='auto') {$auto_select ='selected';}
179 if($_SESSION['dbUSRData']=='provide') {$provide_select ='selected';}
180 if(isset($_SESSION['install_type']) && !empty($_SESSION['install_type']) && strtolower($_SESSION['install_type'])=='custom'){
181 if($_SESSION['dbUSRData']=='create') {$create_select ='selected';}
183 if($_SESSION['dbUSRData']=='same') {$same_select ='selected';}
185 $same_select ='selected';
187 $dbUSRDD = "<select name='dbUSRData' id='dbUSRData' onchange='toggleDBUser();'>";
188 $dbUSRDD .= "<option value='provide' $provide_select>".$mod_strings['LBL_DBCONFIG_PROVIDE_DD']."</option>";
189 $dbUSRDD .= "<option value='create' $create_select>".$mod_strings['LBL_DBCONFIG_CREATE_DD']."</option>";
190 $dbUSRDD .= "<option value='same' $same_select>".$mod_strings['LBL_DBCONFIG_SAME_DD']."</option>";
191 $dbUSRDD .= "</select><br> ";
195 $setup_db_sugarsales_password = urldecode($_SESSION['setup_db_sugarsales_password']);
196 $setup_db_sugarsales_user = urldecode($_SESSION['setup_db_sugarsales_user']);
197 $setup_db_sugarsales_password_retype = urldecode($_SESSION['setup_db_sugarsales_password_retype']);
201 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
202 <tr><td colspan="3" align="left"><br>{$mod_strings['LBL_DBCONFIG_SECURITY']}</td></tr>
203 <tr><td width='1%'> </td><td width='60%'><div id='sugarDBUser'><b>{$mod_strings['LBL_DBCONF_SUGAR_DB_USER']}</b></div> </td><td width='35%'>$dbUSRDD</td></tr>
206 <span id='connection_user_div' style="display:none">
207 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
209 <td width='1%'><span class="required">*</span></td>
210 <td nowrap width='60%'><b>{$mod_strings['LBL_DBCONF_SUGAR_DB_USER']}</b></td>
211 <td width='35%'nowrap align="left">
212 <input type="text" name="setup_db_sugarsales_user" maxlength="16" value="{$_SESSION['setup_db_sugarsales_user']}" />
217 <td nowrap><b>{$mod_strings['LBL_DBCONF_DB_PASSWORD']}</b></td>
218 <td nowrap align="left"><input type="password" name="setup_db_sugarsales_password_entry" value="{$setup_db_sugarsales_password}" /><input type="hidden" name="setup_db_sugarsales_password" value="{$setup_db_sugarsales_password}" /></td>
219 <input type="hidden" name="setup_db_sugarsales_password" value="{$_SESSION['setup_db_sugarsales_password']}" /></td>
223 <td nowrap><b>{$mod_strings['LBL_DBCONF_DB_PASSWORD2']}</b></td>
224 <td nowrap align="left"><input type="password" name="setup_db_sugarsales_password_retype_entry" value="{$setup_db_sugarsales_password_retype}" /><input type="hidden" name="setup_db_sugarsales_password_retype" value="{$setup_db_sugarsales_password_retype}" /></td>
232 //$supported_demodata = array(
233 // 'en_us' => 'English (US)',
234 // 'zh_cn' => '简体ä¸æ–‡',
235 // 'ja_jp' => 'Japanese - 日本語',
237 $demoDD = "<select name='demoData' id='demoData'><option value='no' >".$mod_strings['LBL_NO']."</option><option value='yes'>".$mod_strings['LBL_YES']."</option>";
238 $demoDD .= "</select><br> ";
242 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
243 <tr><th colspan="3" align="left">{$mod_strings['LBL_DBCONF_DEMO_DATA_TITLE']}</th></tr>
245 <td width='1%'> </td>
246 <td width='60%'nowrap><b>{$mod_strings['LBL_DBCONF_DEMO_DATA']}</b></td>
247 <td width='35%'nowrap align="left">
259 <td align="right" colspan="2">
261 <input type="hidden" name="current_step" value="{$next_step}">
262 <table cellspacing="0" cellpadding="0" border="0" class="stdTable">
265 <input class="button" type="button" name="goto" value="{$mod_strings['LBL_BACK']}" id="button_back_dbConfig" onclick="document.getElementById('form').submit();" />
268 <input class="button" type="button" name="goto" id="button_next2" value="{$mod_strings['LBL_NEXT']}" onClick="callDBCheck();"/>
279 function toggleDBUser(){
280 if(typeof(document.getElementById('dbUSRData')) !='undefined'
281 && document.getElementById('dbUSRData') != null){
283 ouv = document.getElementById('dbUSRData').value;
284 if(ouv == 'provide' || ouv == 'create'){
285 document.getElementById('connection_user_div').style.display = '';
286 document.getElementById('sugarDBUser').style.display = 'none';
288 document.getElementById('connection_user_div').style.display = 'none';
289 document.getElementById('sugarDBUser').style.display = '';
296 function callDBCheck(){
298 //begin main function that will be called
299 ajaxCall = function(msg_panel){
300 //create success function for callback
302 getPanel = function() {
303 var args = { width:"300px",
306 constraintoviewport: false,
311 effect:{effect:YAHOO.widget.ContainerEffect.FADE, duration:.5}
313 msg_panel = new YAHOO.widget.Panel('p_msg', args);
315 msg_panel.setHeader("{$mod_strings['LBL_LICENSE_CHKDB_HEADER']}");
316 msg_panel.setBody(document.getElementById("checkingDiv").innerHTML);
317 msg_panel.render(document.body);
318 msgPanel = msg_panel;
322 passed = function(url){
323 document.setConfig.goto.value="{$mod_strings['LBL_NEXT']}";
324 document.getElementById('hidden_goto').value="{$mod_strings['LBL_NEXT']}";
325 document.setConfig.current_step.value="{$next_step}";
326 document.setConfig.submit();
328 success = function(o) {
330 //condition for just the preexisting database
331 if (o.responseText.indexOf('preexeest')>=0){
333 // throw confirmation message
334 msg_panel.setBody(document.getElementById("sysCheckMsg").innerHTML);
335 msg_panel.render(document.body);
336 msgPanel = msg_panel;
337 document.getElementById('accept_btn').focus();
338 //condition for no errors
339 }else if (o.responseText.indexOf('dbCheckPassed')>=0){
341 passed("install.php?goto={$mod_strings['LBL_NEXT']}");
343 //condition for other errors
345 //turn off loading message
347 document.getElementById("errorMsgs").innerHTML = o.responseText;
348 document.getElementById("errorMsgs").style.display = '';
356 //copy the db values over to the hidden field counterparts
357 document.setConfig.setup_db_admin_password.value = document.setConfig.setup_db_admin_password_entry.value;
361 //set loading message and create url
362 postData = "checkDBSettings=true&to_pdf=1&sugar_body_only=1";
363 postData += "&setup_db_database_name="+document.setConfig.setup_db_database_name.value;
364 if(typeof(document.setConfig.setup_db_host_instance) != 'undefined'){
365 postData += "&setup_db_host_instance="+document.setConfig.setup_db_host_instance.value;
367 if(typeof(document.setConfig.setup_db_port_num) != 'undefined'){
368 postData += "&setup_db_port_num="+document.setConfig.setup_db_port_num.value;
370 postData += "&setup_db_host_name="+document.setConfig.setup_db_host_name.value;
371 postData += "&setup_db_admin_user_name="+document.setConfig.setup_db_admin_user_name.value;
372 postData += "&setup_db_admin_password="+encodeURIComponent(document.setConfig.setup_db_admin_password.value);
373 if(typeof(document.setConfig.setup_db_sugarsales_user) != 'undefined'){
374 postData += "&setup_db_sugarsales_user="+document.setConfig.setup_db_sugarsales_user.value;
376 if(typeof(document.setConfig.setup_db_sugarsales_password) != 'undefined'){
377 document.setConfig.setup_db_sugarsales_password.value = document.setConfig.setup_db_sugarsales_password_entry.value;
378 postData += "&setup_db_sugarsales_password="+encodeURIComponent(document.setConfig.setup_db_sugarsales_password.value);
380 if(typeof(document.setConfig.setup_db_sugarsales_password_retype) != 'undefined'){
381 document.setConfig.setup_db_sugarsales_password_retype.value = document.setConfig.setup_db_sugarsales_password_retype_entry.value;
382 postData += "&setup_db_sugarsales_password_retype="+encodeURIComponent(document.setConfig.setup_db_sugarsales_password_retype.value);
384 if(typeof(document.setConfig.dbUSRData) != 'undefined'){
385 postData += "&dbUSRData="+document.getElementById('dbUSRData').value;
390 $out_dd = 'postData += "&demoData="+document.setConfig.demoData.value;';
392 postData += "&to_pdf=1&sugar_body_only=1";
394 //if this is a call already in progress, then just return
395 if(typeof ajxProgress != 'undefined'){
401 var ajxProgress = YAHOO.util.Connect.asyncRequest('POST','install.php', {success: success, failure: success}, postData);
404 };//end ajaxCall method
409 function confirm_drop_tables(yes_no){
412 document.getElementById('setup_db_drop_tables').value = true;
414 document.setConfig.goto.value="{$mod_strings['LBL_NEXT']}";
415 document.getElementById('hidden_goto').value="{$mod_strings['LBL_NEXT']}";
416 document.setConfig.current_step.value="{$next_step}";
417 document.setConfig.submit();
419 //set drop tables to false
420 document.getElementById('setup_db_drop_tables').value = false;
429 <div id="checkingDiv" style="display:none">
430 <table cellspacing="0" cellpadding="0" border="0">
432 <p><img alt="{$mod_strings['LBL_LICENSE_CHKDB_HEADER']}" src='install/processing.gif'> <br>{$mod_strings['LBL_LICENSE_CHKDB_HEADER']}</p>
437 <div id='sysCheckMsg' style="display:none">
438 <table cellspacing="0" cellpadding="0" border="0" >
440 <p>{$mod_strings['LBL_DROP_DB_CONFIRM']}</p>
442 <tr><td align='center'>
443 <input id='accept_btn' type='button' class='button' onclick='confirm_drop_tables(true)' value="{$mod_strings['LBL_ACCEPT']}">
444 <input type='button' class='button' onclick='confirm_drop_tables(false)' id="button_cancel_dbConfig" value="{$mod_strings['LBL_CANCEL']}">
462 ///////////////////////////////////////////////////////////////////////////////