| | |
| | | <?php |
| | | |
| | | if (!class_exists('rcube_install') || !is_object($RCI)) { |
| | | if (!class_exists('rcmail_install', false) || !is_object($RCI)) { |
| | | die("Not allowed! Please open installer/index.php instead."); |
| | | } |
| | | |
| | | ?> |
| | | <form action="index.php" method="post"> |
| | | <input type="hidden" name="_step" value="2" /> |
| | | <?php |
| | | |
| | | // also load the default config to fill in the fields |
| | | $RCI->load_defaults(); |
| | | |
| | | // register these boolean fields |
| | | $RCI->bool_config_props = array( |
| | | 'ip_check' => 1, |
| | | 'enable_caching' => 1, |
| | | 'enable_spellcheck' => 1, |
| | | 'auto_create_user' => 1, |
| | | 'smtp_log' => 1, |
| | |
| | | $_SESSION['allowinstaller'] = true; |
| | | |
| | | if (!empty($_POST['submit'])) { |
| | | |
| | | echo '<p class="notice">Copy or download the following configurations and save them in two files'; |
| | | echo ' (names above the text box) within the <tt>'.RCMAIL_CONFIG_DIR.'</tt> directory of your Roundcube installation.<br/>'; |
| | | echo ' Make sure that there are no characters outside the <tt><?php ?></tt> brackets when saving the files.</p>'; |
| | | |
| | | $textbox = new html_textarea(array('rows' => 16, 'cols' => 60, 'class' => "configfile")); |
| | | |
| | | echo '<div><em>main.inc.php (<a href="index.php?_getfile=main">download</a>)</em></div>'; |
| | | echo $textbox->show(($_SESSION['main.inc.php'] = $RCI->create_config('main'))); |
| | | |
| | | echo '<div style="margin-top:1em"><em>db.inc.php (<a href="index.php?_getfile=db">download</a>)</em></div>'; |
| | | echo $textbox->show($_SESSION['db.inc.php'] = $RCI->create_config('db')); |
| | | $_SESSION['config'] = $RCI->create_config(); |
| | | |
| | | if ($RCI->save_configfile($_SESSION['config'])) { |
| | | echo '<p class="notice">The config file was saved successfully into <tt>'.RCMAIL_CONFIG_DIR.'</tt> directory of your Roundcube installation.'; |
| | | |
| | | if ($RCI->legacy_config) { |
| | | echo '<br/><br/>Afterwards, please <b>remove</b> the old configuration files <tt>main.inc.php</tt> and <tt>db.inc.php</tt> from the config directory.'; |
| | | } |
| | | |
| | | echo '</p>'; |
| | | } |
| | | else { |
| | | if (($dir = sys_get_temp_dir()) && @is_writable($dir)) { |
| | | echo '<iframe name="getconfig" style="display:none"></iframe>'; |
| | | echo '<form id="getconfig_form" action="index.php" method="get" target="getconfig" style="display:none">'; |
| | | echo '<input name="_getconfig" value="2" /></form>'; |
| | | |
| | | $button_txt = html::quote('Save in ' . $dir); |
| | | $save_button = ' <input type="button" onclick="document.getElementById(\'getconfig_form\').submit()" value="' . $button_txt . '" />'; |
| | | } |
| | | |
| | | echo '<p class="notice">Copy or download the following configuration and save it'; |
| | | echo ' as <tt><b>config.inc.php</b></tt> within the <tt>'.RCUBE_CONFIG_DIR.'</tt> directory of your Roundcube installation.<br/>'; |
| | | echo ' Make sure that there are no characters outside the <tt><?php ?></tt> brackets when saving the file.'; |
| | | echo ' <input type="button" onclick="location.href=\'index.php?_getconfig=1\'" value="Download" />'; |
| | | echo $save_button; |
| | | |
| | | if ($RCI->legacy_config) { |
| | | echo '<br/><br/>Afterwards, please <b>remove</b> the old configuration files <tt>main.inc.php</tt> and <tt>db.inc.php</tt> from the config directory.'; |
| | | } |
| | | |
| | | echo '</p>'; |
| | | |
| | | $textbox = new html_textarea(array('rows' => 16, 'cols' => 60, 'class' => "configfile")); |
| | | echo $textbox->show(($_SESSION['config'])); |
| | | } |
| | | |
| | | echo '<p class="hint">Of course there are more options to configure. |
| | | Have a look at the config files or visit <a href="http://trac.roundcube.net/wiki/Howto_Config">Howto_Config</a> to find out.</p>'; |
| | | Have a look at the defaults.inc.php file or visit <a href="http://trac.roundcube.net/wiki/Howto_Config" target="_blank">Howto_Config</a> to find out.</p>'; |
| | | |
| | | echo '<p><input type="button" onclick="location.href=\'./index.php?_step=3\'" value="CONTINUE" /></p>'; |
| | | |
| | | |
| | | // echo '<style type="text/css"> .configblock { display:none } </style>'; |
| | | echo "\n<hr style='margin-bottom:1.6em' />\n"; |
| | | } |
| | | |
| | | ?> |
| | | <form action="index.php" method="post"> |
| | | <input type="hidden" name="_step" value="2" /> |
| | | |
| | | <fieldset> |
| | | <legend>General configuration</legend> |
| | | <dl class="configblock"> |
| | |
| | | |
| | | ?> |
| | | <div>Provide an URL where a user can get support for this Roundcube installation.<br/>PLEASE DO NOT LINK TO THE ROUNDCUBE.NET WEBSITE HERE!</div> |
| | | <p class="hint">Enter an absolute URL (inculding http://) to a support page/form or a mailto: link.</p> |
| | | <p class="hint">Enter an absolute URL (including http://) to a support page/form or a mailto: link.</p> |
| | | </dd> |
| | | |
| | | <dt class="propname">skin_logo</dt> |
| | |
| | | |
| | | ?> |
| | | <div>This key is used to encrypt the users imap password before storing in the session record</div> |
| | | <p class="hint">It's a random generated string to ensure that every installation has its own key. |
| | | If you enter it manually please provide a string of exactly 24 chars.</p> |
| | | <p class="hint">It's a random generated string to ensure that every installation has its own key.</p> |
| | | </dd> |
| | | |
| | | <dt class="propname">ip_check</dt> |
| | |
| | | <p class="hint">This increases security but can cause sudden logouts when someone uses a proxy with changing IPs.</p> |
| | | </dd> |
| | | |
| | | <dt class="propname">enable_caching</dt> |
| | | <dd> |
| | | <?php |
| | | |
| | | $check_caching = new html_checkbox(array('name' => '_enable_caching', 'id' => "cfgcache")); |
| | | echo $check_caching->show(intval($RCI->getprop('enable_caching')), array('value' => 1)); |
| | | |
| | | ?> |
| | | <label for="cfgcache">Cache messages in local database</label><br /> |
| | | </dd> |
| | | |
| | | <dt class="propname">enable_spellcheck</dt> |
| | | <dd> |
| | |
| | | <?php |
| | | $select_spell = new html_select(array('name' => '_spellcheck_engine', 'id' => "cfgspellcheckengine")); |
| | | if (extension_loaded('pspell')) |
| | | $select_spell->add('pspell', 'pspell'); |
| | | $select_spell->add('Pspell', 'pspell'); |
| | | if (extension_loaded('enchant')) |
| | | $select_spell->add('Enchant', 'enchant'); |
| | | $select_spell->add('Googie', 'googie'); |
| | | $select_spell->add('ATD', 'atd'); |
| | | |
| | | echo $select_spell->show($RCI->is_post ? $_POST['_spellcheck_engine'] : 'pspell'); |
| | | |
| | | ?> |
| | | <label for="cfgspellcheckengine">Which spell checker to use</label><br /> |
| | | |
| | | <p class="hint">GoogieSpell implies that the message content will be sent to Google in order to check the spelling.</p> |
| | | <p class="hint">Googie implies that the message content will be sent to external server to check the spelling.</p> |
| | | </dd> |
| | | |
| | | <dt class="propname">identities_level</dt> |
| | |
| | | $input_ilevel->add('many identities with possibility to edit all params but not email address', 1); |
| | | $input_ilevel->add('one identity with possibility to edit all params', 2); |
| | | $input_ilevel->add('one identity with possibility to edit all params but not email address', 3); |
| | | $input_ilevel->add('one identity with possibility to edit only signature', 4); |
| | | echo $input_ilevel->show($RCI->getprop('identities_level'), 0); |
| | | |
| | | ?> |
| | |
| | | |
| | | echo $check_debug->show(($value & 4) ? 4 : 0, array('value' => 4, 'id' => 'cfgdebug4')); |
| | | echo '<label for="cfgdebug4">Print errors (to the browser)</label><br />'; |
| | | |
| | | echo $check_debug->show(($value & 8) ? 8 : 0, array('value' => 8, 'id' => 'cfgdebug8')); |
| | | echo '<label for="cfgdebug8">Verbose display (enables debug console)</label><br />'; |
| | | |
| | | ?> |
| | | </dd> |
| | |
| | | $input_dbhost = new html_inputfield(array('name' => '_dbhost', 'size' => 20, 'id' => "cfgdbhost")); |
| | | $input_dbname = new html_inputfield(array('name' => '_dbname', 'size' => 20, 'id' => "cfgdbname")); |
| | | $input_dbuser = new html_inputfield(array('name' => '_dbuser', 'size' => 20, 'id' => "cfgdbuser")); |
| | | $input_dbpass = new html_passwordfield(array('name' => '_dbpass', 'size' => 20, 'id' => "cfgdbpass")); |
| | | $input_dbpass = new html_inputfield(array('name' => '_dbpass', 'size' => 20, 'id' => "cfgdbpass")); |
| | | |
| | | $dsnw = rcube_db::parse_dsn($RCI->getprop('db_dsnw')); |
| | | |
| | |
| | | |
| | | ?> |
| | | </dd> |
| | | |
| | | <dt class="propname">db_prefix</dt> |
| | | <dd> |
| | | <?php |
| | | |
| | | $input_prefix = new html_inputfield(array('name' => '_db_prefix', 'size' => 20, 'id' => "cfgdbprefix")); |
| | | echo $input_prefix->show($RCI->getprop('db_prefix')); |
| | | |
| | | ?> |
| | | <div>Optional prefix that will be added to database object names (tables and sequences).</div> |
| | | </dd> |
| | | |
| | | </dl> |
| | | </fieldset> |
| | | |
| | |
| | | <?php |
| | | |
| | | $text_smtpuser = new html_inputfield(array('name' => '_smtp_user', 'size' => 20, 'id' => "cfgsmtpuser")); |
| | | $text_smtppass = new html_passwordfield(array('name' => '_smtp_pass', 'size' => 20, 'id' => "cfgsmtppass")); |
| | | $text_smtppass = new html_inputfield(array('name' => '_smtp_pass', 'size' => 20, 'id' => "cfgsmtppass")); |
| | | echo $text_smtpuser->show($RCI->getprop('smtp_user')); |
| | | echo $text_smtppass->show($RCI->getprop('smtp_pass')); |
| | | |
| | |
| | | $select_param_folding->add('RFC 2047/2231 (MS Outlook, OE)', '1'); |
| | | $select_param_folding->add('Full RFC 2047 (deprecated)', '2'); |
| | | |
| | | echo $select_param_folding->show(intval($RCI->getprop('mime_param_folding'))); |
| | | echo $select_param_folding->show(strval($RCI->getprop('mime_param_folding'))); |
| | | |
| | | ?> |
| | | <div>How to encode attachment long/non-ascii names</div> |
| | |
| | | <p class="hint"><span class="userconf">*</span> These settings are defaults for the user preferences</p> |
| | | </fieldset> |
| | | |
| | | |
| | | <fieldset> |
| | | <legend>Plugins</legend> |
| | | <dl class="configblock" id="cgfblockdisplay"> |
| | | |
| | | <?php |
| | | $plugins = $RCI->list_plugins(); |
| | | foreach($plugins as $p) |
| | | { |
| | | $p_check = new html_checkbox(array('name' => '_plugins_'.$p['name'], 'id' => 'cfgplugin_'.$p['name'], 'value' => $p['name'])); |
| | | echo '<dt class="propname"><label>'; |
| | | echo $p_check->show($p['enabled'] ? $p['name'] : 0); |
| | | echo ' ' . $p['name'] . '</label></dt><dd>'; |
| | | echo '<label for="cfgplugin_'.$p['name'].'" class="hint">' . $p['desc'] . '</label><br/></dd>'; |
| | | } |
| | | |
| | | ?> |
| | | </dl> |
| | | |
| | | <p class="hint">Please consider checking dependencies of enabled plugins</p> |
| | | </fieldset> |
| | | |
| | | <?php |
| | | |
| | | echo '<p><input type="submit" name="submit" value="' . ($RCI->configured ? 'UPDATE' : 'CREATE') . ' CONFIG" ' . ($RCI->failures ? 'disabled' : '') . ' /></p>'; |