mirror of
https://github.com/optim-enterprises-bv/Mailu.git
synced 2025-11-02 19:18:07 +00:00
Make roundcube use internal auth
This commit is contained in:
@@ -46,6 +46,7 @@ RUN apt-get update && apt-get install -y \
|
|||||||
|
|
||||||
COPY php.ini /php.ini
|
COPY php.ini /php.ini
|
||||||
COPY config.inc.php /var/www/html/config/
|
COPY config.inc.php /var/www/html/config/
|
||||||
|
COPY mailu.php /var/www/html/plugins/mailu/mailu.php
|
||||||
COPY start.py /start.py
|
COPY start.py /start.py
|
||||||
|
|
||||||
EXPOSE 80/tcp
|
EXPOSE 80/tcp
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ $config['plugins'] = array(
|
|||||||
'markasjunk',
|
'markasjunk',
|
||||||
'managesieve',
|
'managesieve',
|
||||||
'enigma',
|
'enigma',
|
||||||
'carddav'
|
'carddav',
|
||||||
|
'mailu'
|
||||||
);
|
);
|
||||||
|
|
||||||
$front = getenv('FRONT_ADDRESS') ? getenv('FRONT_ADDRESS') : 'front';
|
$front = getenv('FRONT_ADDRESS') ? getenv('FRONT_ADDRESS') : 'front';
|
||||||
@@ -37,6 +38,7 @@ $config['managesieve_usetls'] = false;
|
|||||||
|
|
||||||
// Customization settings
|
// Customization settings
|
||||||
$config['support_url'] = getenv('WEB_ADMIN') ? '../..' . getenv('WEB_ADMIN') : '';
|
$config['support_url'] = getenv('WEB_ADMIN') ? '../..' . getenv('WEB_ADMIN') : '';
|
||||||
|
$config['sso_logout_url'] = getenv('WEB_ADMIN').'/ui/logout';
|
||||||
$config['product_name'] = 'Mailu Webmail';
|
$config['product_name'] = 'Mailu Webmail';
|
||||||
|
|
||||||
// We access the IMAP and SMTP servers locally with internal names, SSL
|
// We access the IMAP and SMTP servers locally with internal names, SSL
|
||||||
|
|||||||
59
webmails/roundcube/mailu.php
Normal file
59
webmails/roundcube/mailu.php
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class mailu extends rcube_plugin
|
||||||
|
{
|
||||||
|
|
||||||
|
function init()
|
||||||
|
{
|
||||||
|
$this->add_hook('startup', array($this, 'startup'));
|
||||||
|
$this->add_hook('authenticate', array($this, 'authenticate'));
|
||||||
|
$this->add_hook('login_after', array($this, 'login'));
|
||||||
|
$this->add_hook('login_failed', array($this, 'login_failed'));
|
||||||
|
$this->add_hook('logout_after', array($this, 'logout'));
|
||||||
|
}
|
||||||
|
|
||||||
|
function startup($args)
|
||||||
|
{
|
||||||
|
if (empty($_SESSION['user_id'])) {
|
||||||
|
$args['action'] = 'login';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $args;
|
||||||
|
}
|
||||||
|
|
||||||
|
function authenticate($args)
|
||||||
|
{
|
||||||
|
if (!in_array('HTTP_X_REMOTE_USER', $_SERVER) || !in_array('HTTP_X_REMOTE_USER_TOKEN', $_SERVER)) {
|
||||||
|
header('HTTP/1.0 403 Forbidden');
|
||||||
|
die();
|
||||||
|
}
|
||||||
|
$args['user'] = $_SERVER['HTTP_X_REMOTE_USER'];
|
||||||
|
$args['pass'] = $_SERVER['HTTP_X_REMOTE_USER_TOKEN'];
|
||||||
|
|
||||||
|
$args['cookiecheck'] = false;
|
||||||
|
$args['valid'] = true;
|
||||||
|
|
||||||
|
return $args;
|
||||||
|
}
|
||||||
|
|
||||||
|
function logout($args) {
|
||||||
|
// Redirect to global SSO logout path.
|
||||||
|
$this->load_config();
|
||||||
|
|
||||||
|
$sso_logout_url = rcmail::get_instance()->config->get('sso_logout_url');
|
||||||
|
header("Location: " . $sso_logout_url, true);
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
function login($args)
|
||||||
|
{
|
||||||
|
header('Location: index.php');
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
function login_failed($args)
|
||||||
|
{
|
||||||
|
header('Location: sso.php');
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -39,6 +39,8 @@ conf.jinja("/php.ini", os.environ, "/usr/local/etc/php/conf.d/roundcube.ini")
|
|||||||
os.system("mkdir -p /data/gpg /var/www/html/logs")
|
os.system("mkdir -p /data/gpg /var/www/html/logs")
|
||||||
os.system("touch /var/www/html/logs/errors.log")
|
os.system("touch /var/www/html/logs/errors.log")
|
||||||
os.system("chown -R www-data:www-data /var/www/html/logs")
|
os.system("chown -R www-data:www-data /var/www/html/logs")
|
||||||
|
os.system("chmod -R a+rX /var/www/html/")
|
||||||
|
os.system("ln -s /var/www/html/index.php /var/www/html/sso.php")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
print("Initializing database")
|
print("Initializing database")
|
||||||
|
|||||||
Reference in New Issue
Block a user