Skip to content

Commit

Permalink
- Option 'force_https' replaced by 'force_https' plugin
Browse files Browse the repository at this point in the history
- added option 'force_https_port' in 'force_https' plugin (#1486091)
  • Loading branch information
alecpl committed Oct 13, 2009
1 parent f281242 commit 65c0a0e
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 13 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
CHANGELOG RoundCube Webmail
===========================

- added option 'force_https_port' in 'force_https' plugin (#1486091)
- Option 'force_https' replaced by 'force_https' plugin
- Fix IE issue with non-UTF-8 characters in AJAX response (#1486159)
- Partially fixed "empty body" issue by showing raw body of malformed message (#1486166)
- Fix importing/sending to email address with whitespace (#1486214)
Expand Down
4 changes: 0 additions & 4 deletions config/main.inc.php.dist
Original file line number Diff line number Diff line change
Expand Up @@ -49,10 +49,6 @@ $rcmail_config['enable_caching'] = FALSE;
// possible units: s, m, h, d, w
$rcmail_config['message_cache_lifetime'] = '10d';

// enforce connections over https
// with this option enabled, all non-secure connections will be redirected
$rcmail_config['force_https'] = FALSE;

// automatically create a new RoundCube user when log-in the first time.
// a new user will be created once the IMAP login succeeds.
// set to false if only registered users can use this service
Expand Down
9 changes: 0 additions & 9 deletions index.php
Original file line number Diff line number Diff line change
Expand Up @@ -63,19 +63,11 @@
raise_error(array('code' => hexdec($_GET['_code'])), FALSE, TRUE);
}

// check if https is required (for login) and redirect if necessary
if ($RCMAIL->config->get('force_https', false) && empty($_SESSION['user_id'])
&& !(isset($_SERVER['HTTPS']) || $_SERVER['SERVER_PORT'] == 443 || $RCMAIL->config->get('use_https'))) {
header('Location: https://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']);
exit;
}

// trigger startup plugin hook
$startup = $RCMAIL->plugins->exec_hook('startup', array('task' => $RCMAIL->task, 'action' => $RCMAIL->action));
$RCMAIL->set_task($startup['task']);
$RCMAIL->action = $startup['action'];


// try to log in
if ($RCMAIL->action=='login' && $RCMAIL->task=='mail') {
// purge the session in case of new login when a session already exists
Expand Down Expand Up @@ -161,7 +153,6 @@
$OUTPUT->send($RCMAIL->task);
}


// not logged in -> show login page
if (empty($RCMAIL->user->ID)) {

Expand Down
38 changes: 38 additions & 0 deletions plugins/force_https/force_https.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
<?php

/**
* Enforce secure HTTPs connection for login
*
* Configuration:
* // Port for https connection
* $rcmail_config['force_https_port'] = 443;
*
* @version 1.0
* @author Aleksander 'A.L.E.C' Machniak <alec@alec.pl>
*/
class force_https extends rcube_plugin
{
function init()
{
$this->add_hook('startup', array($this, 'redirect'));
}

function redirect($args)
{
$config = rcmail::get_instance()->config;

$port = (int) $config->get('force_https_port', 443);

// check if https is required (for login) and redirect if necessary
if (empty($_SESSION['user_id']) && !$config->get('use_https')
&& (!isset($_SERVER['HTTPS']) || $_SERVER['SERVER_PORT'] != $port))
{
header('Location: https://' . $_SERVER['HTTP_HOST'] . ($port != 443 ? ":$port" : '') . $_SERVER['REQUEST_URI']);
exit;
}

return $args;
}
}

?>

0 comments on commit 65c0a0e

Please sign in to comment.