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-2011 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']);
54 $createDbCheckbox = '';
55 $createDb = (isset($_SESSION['setup_db_create_database']) && !empty($_SESSION['setup_db_create_database'])) ? 'checked="checked"' : '';
56 $dropCreate = (isset($_SESSION['setup_db_drop_tables']) && !empty($_SESSION['setup_db_drop_tables'])) ? 'checked="checked"' : '';
58 if (isset($_SESSION['setup_db_host_instance']) && !empty($_SESSION['setup_db_host_instance'])){
59 $instanceName = $_SESSION['setup_db_host_instance'];
62 if($_SESSION['setup_db_type'] == 'oci8') {
65 $host_lbl = $mod_strings['LBL_DBCONF_HOST_NAME'];
66 if($_SESSION['setup_db_type'] == 'mssql') {
67 $host_lbl = $mod_strings['LBL_DBCONF_HOST_NAME_MSSQL'];
70 $dbSplit1 = '<tr><td colspan="3" align="left">'.$mod_strings['LBL_DBCONFIG_MSG2'].' </td></tr>
72 <td><span class="required">*</span></td>
73 <td nowrap><b>'.$host_lbl.'</b></td>
75 <input type="text" name="setup_db_host_name" id="setup_db_host_name" value="'.$_SESSION['setup_db_host_name'].'" />';
76 if (isset($_SESSION['setup_db_type']) && $_SESSION['setup_db_type'] =='mssql'){
77 $dbSplit1 .= ' \ <input type="text" name="setup_db_host_instance" id="setup_db_host_instance" value="'.$instanceName.'" />';
88 ///////////////////////////////////////////////////////////////////////////////
89 //// BEGIN PAGE OUTPUT
92 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
95 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
96 <meta http-equiv="Content-Script-Type" content="text/javascript">
97 <meta http-equiv="Content-Style-Type" content="text/css">
98 <title>{$mod_strings['LBL_WIZARD_TITLE']} {$mod_strings['LBL_DBCONF_TITLE']}</title>
99 <link rel="stylesheet" href="install/install.css" type="text/css" />
100 <script type="text/javascript" src="install/installCommon.js"></script>
101 <script type="text/javascript" src="install/dbConfig.js"></script>
102 <link REL="SHORTCUT ICON" HREF="include/images/sugar_icon.ico">
103 <script src="include/javascript/sugar_grp1_yui.js?s={$sugar_version}&c={$js_custom_version}"></script>
104 <script type="text/javascript">
110 <link rel='stylesheet' type='text/css' href='include/javascript/yui/build/container/assets/container.css' />
114 $out .= '<body onload="document.getElementById(\'button_next2\').focus();">';
117 <form action="install.php" method="post" name="setConfig" id="form">
118 <input type='hidden' name='setup_db_drop_tables' id='setup_db_drop_tables' value='false'>
119 <input type="hidden" id="hidden_goto" name="goto" value="{$mod_strings['LBL_BACK']}" />
120 <table cellspacing="0" cellpadding="0" border="0" align="center" class="shell">
122 <tr><td colspan="2" id="help"><a href="{$help_url}" target='_blank'>{$mod_strings['LBL_HELP']} </a></td></tr>
126 <img src="{$sugar_md}" alt="SugarCRM" border="0">
128 {$mod_strings['LBL_DBCONF_TITLE']}
130 <th width="200" height="30" style="text-align: right;"><a href="http://www.sugarcrm.com" target="_blank">
131 <IMG src="include/images/sugarcrm_login.png" width="145" height="30" alt="SugarCRM" border="0"></a>
136 <div id="errorMsgs" style="display:none"></div>
137 <div class="required">{$mod_strings['LBL_REQUIRED']}</div>
138 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
139 <tr><th colspan="3" align="left" >{$mod_strings['LBL_DBCONF_TITLE_NAME']} </td></tr>
141 <tr><td colspan="3" align="left"> {$mod_strings['LBL_DBCONFIG_MSG3']}</td></tr>
142 <tr><td width='1%'><span class="required">*</span></td>
143 <td width='60%' nowrap><b>{$mod_strings['LBL_DBCONF_DB_NAME']} {$oci8sid}</b></td>
144 <td width='35%' nowrap align="left">
145 <input type="text" name="setup_db_database_name" value="{$_SESSION['setup_db_database_name']}"><br>
154 <tr><th colspan="3" align="left">{$mod_strings['LBL_DBCONF_TITLE_USER_INFO']} </td></tr>
155 <tr><td colspan="3" align="left">{$mod_strings['LBL_DBCONFIG_B_MSG1']}</td></tr>
157 <td><span class="required">*</span></td>
158 <td nowrap><b>{$mod_strings['LBL_DBCONF_DB_ADMIN_USER']}</b></td>
159 <td nowrap align="left">
160 <input type="text" name="setup_db_admin_user_name" maxlength="30" value="{$_SESSION['setup_db_admin_user_name']}" autocomplete="off"/>
165 <td nowrap><b>{$mod_strings['LBL_DBCONF_DB_ADMIN_PASSWORD']}</b></td>
166 <td nowrap align="left"><input type="password" name="setup_db_admin_password" value="{$_SESSION['setup_db_admin_password']}" autocomplete="off" /></td></tr>
170 //if we are installing in custom mode, include the following html
171 if($_SESSION['setup_db_type'] != 'oci8' ){
173 // create / set db user dropdown
174 $auto_select = '';$provide_select ='';$create_select = '';$same_select = '';
175 if(isset($_SESSION['dbUSRData'])){
176 // if($_SESSION['dbUSRData']=='auto') {$auto_select ='selected';}
177 if($_SESSION['dbUSRData']=='provide') {$provide_select ='selected';}
178 if(isset($_SESSION['install_type']) && !empty($_SESSION['install_type']) && strtolower($_SESSION['install_type'])=='custom'){
179 if($_SESSION['dbUSRData']=='create') {$create_select ='selected';}
181 if($_SESSION['dbUSRData']=='same') {$same_select ='selected';}
183 $same_select ='selected';
185 $dbUSRDD = "<select name='dbUSRData' id='dbUSRData' onchange='toggleDBUser();'>";
186 $dbUSRDD .= "<option value='provide' $provide_select>".$mod_strings['LBL_DBCONFIG_PROVIDE_DD']."</option>";
187 $dbUSRDD .= "<option value='create' $create_select>".$mod_strings['LBL_DBCONFIG_CREATE_DD']."</option>";
188 $dbUSRDD .= "<option value='same' $same_select>".$mod_strings['LBL_DBCONFIG_SAME_DD']."</option>";
189 $dbUSRDD .= "</select><br> ";
196 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
197 <tr><td colspan="3" align="left"><br>{$mod_strings['LBL_DBCONFIG_SECURITY']}</td></tr>
198 <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>
201 <span id='connection_user_div' style="display:none">
202 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
204 <td width='1%'><span class="required">*</span></td>
205 <td nowrap width='60%'><b>{$mod_strings['LBL_DBCONF_SUGAR_DB_USER']}</b></td>
206 <td width='35%'nowrap align="left">
207 <input type="text" name="setup_db_sugarsales_user" maxlength="16" value="{$_SESSION['setup_db_sugarsales_user']}" />
212 <td nowrap><b>{$mod_strings['LBL_DBCONF_DB_PASSWORD']}</b></td>
213 <td nowrap align="left"><input type="password" name="setup_db_sugarsales_password" value="{$_SESSION['setup_db_sugarsales_password']}" /></td>
217 <td nowrap><b>{$mod_strings['LBL_DBCONF_DB_PASSWORD2']}</b></td>
218 <td nowrap align="left"><input type="password" name="setup_db_sugarsales_password_retype" value="{$_SESSION['setup_db_sugarsales_password_retype']}" /></td>
226 //$supported_demodata = array(
227 // 'en_us' => 'English (US)',
228 // 'zh_cn' => '简体ä¸æ–‡',
229 // 'ja_jp' => 'Japanese - 日本語',
231 $demoDD = "<select name='demoData' id='demoData'><option value='no' >".$mod_strings['LBL_NO']."</option><option value='yes'>".$mod_strings['LBL_YES']."</option>";
232 //foreach($supported_demodata as $key => $v){
233 // // mssql is broken for mbcs
234 // if( ($_SESSION['setup_db_type'] == 'mssql') && ($key != 'en_us'))
237 // if($_SESSION['demoData'] == $key)
238 // $selected = "selected";
239 // $demoDD .="<option value='$key' $selected>".$v."</option>";
241 $demoDD .= "</select><br> ";
245 <table width="100%" cellpadding="0" cellpadding="0" border="0" class="StyleDottedHr">
246 <tr><th colspan="3" align="left">{$mod_strings['LBL_DBCONF_DEMO_DATA_TITLE']}</th></tr>
248 <td width='1%'> </td>
249 <td width='60%'nowrap><b>{$mod_strings['LBL_DBCONF_DEMO_DATA']}</b></td>
250 <td width='35%'nowrap align="left">
262 <td align="right" colspan="2">
264 <input type="hidden" name="current_step" value="{$next_step}">
265 <table cellspacing="0" cellpadding="0" border="0" class="stdTable">
268 <input class="button" type="button" name="goto" value="{$mod_strings['LBL_BACK']}" id="button_back_dbConfig" onclick="document.getElementById('form').submit();" />
271 <input class="button" type="button" name="goto" id="button_next2" value="{$mod_strings['LBL_NEXT']}" onClick="callDBCheck();"/>
282 function toggleDBUser(){
283 if(typeof(document.getElementById('dbUSRData')) !='undefined'
284 && document.getElementById('dbUSRData') != null){
286 ouv = document.getElementById('dbUSRData').value;
287 if(ouv == 'provide' || ouv == 'create'){
288 document.getElementById('connection_user_div').style.display = '';
289 document.getElementById('sugarDBUser').style.display = 'none';
291 document.getElementById('connection_user_div').style.display = 'none';
292 document.getElementById('sugarDBUser').style.display = '';
299 function callDBCheck(){
301 //begin main function that will be called
302 ajaxCall = function(msg_panel){
303 //create success function for callback
305 getPanel = function() {
306 var args = { width:"300px",
309 constraintoviewport: false,
314 effect:{effect:YAHOO.widget.ContainerEffect.FADE, duration:.5}
316 msg_panel = new YAHOO.widget.Panel('p_msg', args);
318 msg_panel.setHeader("{$mod_strings['LBL_LICENSE_CHKDB_HEADER']}");
319 msg_panel.setBody(document.getElementById("checkingDiv").innerHTML);
320 msg_panel.render(document.body);
321 msgPanel = msg_panel;
325 passed = function(url){
326 document.setConfig.goto.value="{$mod_strings['LBL_NEXT']}";
327 document.getElementById('hidden_goto').value="{$mod_strings['LBL_NEXT']}";
328 document.setConfig.current_step.value="{$next_step}";
329 document.setConfig.submit();
331 success = function(o) {
333 //condition for just the preexisting database
334 if (o.responseText.indexOf('preexeest')>=0){
336 // throw confirmation message
337 msg_panel.setBody(document.getElementById("sysCheckMsg").innerHTML);
338 msg_panel.render(document.body);
339 msgPanel = msg_panel;
340 document.getElementById('accept_btn').focus();
341 //condition for no errors
342 }else if (o.responseText.indexOf('dbCheckPassed')>=0){
344 passed("install.php?goto={$mod_strings['LBL_NEXT']}");
346 //condition for other errors
348 //turn off loading message
350 document.getElementById("errorMsgs").innerHTML = o.responseText;
351 document.getElementById("errorMsgs").style.display = '';
358 //set loading message and create url
360 postData = "checkDBSettings=true&to_pdf=1&sugar_body_only=1";
361 postData += "&setup_db_database_name="+document.setConfig.setup_db_database_name.value;
362 if(typeof(document.setConfig.setup_db_host_instance) != 'undefined'){
363 postData += "&setup_db_host_instance="+document.setConfig.setup_db_host_instance.value;
365 postData += "&setup_db_host_name="+document.setConfig.setup_db_host_name.value;
366 postData += "&setup_db_admin_user_name="+document.setConfig.setup_db_admin_user_name.value;
367 postData += "&setup_db_admin_password="+document.setConfig.setup_db_admin_password.value;
368 if(typeof(document.setConfig.setup_db_sugarsales_user) != 'undefined'){
369 postData += "&setup_db_sugarsales_user="+document.setConfig.setup_db_sugarsales_user.value;
371 if(typeof(document.setConfig.setup_db_sugarsales_password) != 'undefined'){
372 postData += "&setup_db_sugarsales_password="+document.setConfig.setup_db_sugarsales_password.value;
374 if(typeof(document.setConfig.setup_db_sugarsales_password_retype) != 'undefined'){
375 postData += "&setup_db_sugarsales_password_retype="+document.setConfig.setup_db_sugarsales_password_retype.value;
377 if(typeof(document.setConfig.dbUSRData) != 'undefined'){
378 postData += "&dbUSRData="+document.getElementById('dbUSRData').value;
383 $out_dd = 'postData += "&demoData="+document.setConfig.demoData.value;';
385 postData += "&to_pdf=1&sugar_body_only=1";
387 //if this is a call already in progress, then just return
388 if(typeof ajxProgress != 'undefined'){
394 var ajxProgress = YAHOO.util.Connect.asyncRequest('POST','install.php', {success: success, failure: success}, postData);
397 };//end ajaxCall method
402 function confirm_drop_tables(yes_no){
405 document.getElementById('setup_db_drop_tables').value = true;
407 document.setConfig.goto.value="{$mod_strings['LBL_NEXT']}";
408 document.getElementById('hidden_goto').value="{$mod_strings['LBL_NEXT']}";
409 document.setConfig.current_step.value="{$next_step}";
410 document.setConfig.submit();
412 //set drop tables to false
413 document.getElementById('setup_db_drop_tables').value = false;
422 <div id="checkingDiv" style="display:none">
423 <table cellspacing="0" cellpadding="0" border="0">
425 <p><img src='install/processing.gif'> <br>{$mod_strings['LBL_LICENSE_CHKDB_HEADER']}</p>
430 <div id='sysCheckMsg' style="display:none">
431 <table cellspacing="0" cellpadding="0" border="0" >
433 <p>{$mod_strings['LBL_DROP_DB_CONFIRM']}</p>
435 <tr><td align='center'>
436 <input id='accept_btn' type='button' class='button' onclick='confirm_drop_tables(true)' value="{$mod_strings['LBL_ACCEPT']}">
437 <input type='button' class='button' onclick='confirm_drop_tables(false)' id="button_cancel_dbConfig" value="{$mod_strings['LBL_CANCEL']}">
455 ///////////////////////////////////////////////////////////////////////////////