mirror of
https://github.com/e107inc/e107.git
synced 2025-01-18 05:09:05 +01:00
254 lines
5.8 KiB
PHP
Executable File
254 lines
5.8 KiB
PHP
Executable File
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2011 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
* Alt_auth plugin - general configuration
|
|
*
|
|
* $URL$
|
|
* $Id$
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* e107 Alternate authorisation plugin
|
|
*
|
|
* @package e107_plugins
|
|
* @subpackage alt_auth
|
|
* @version $Id$;
|
|
*/
|
|
|
|
|
|
/*
|
|
@todo:
|
|
1. Change prefs handling
|
|
2. Change admin log references
|
|
*/
|
|
$eplug_admin = true;
|
|
require_once(__DIR__.'/../../class2.php');
|
|
if(!getperms('P') || !e107::isInstalled('alt_auth'))
|
|
{
|
|
e107::redirect('admin');
|
|
exit();
|
|
}
|
|
require_once(e_HANDLER.'form_handler.php');
|
|
$frm = e107::getForm();
|
|
require_once(e_ADMIN.'auth.php');
|
|
e107::includeLan(e_PLUGIN.'alt_auth/languages/'.e_LANGUAGE.'/admin_alt_auth.php');
|
|
define('ALT_AUTH_ACTION', 'main');
|
|
require_once(e_PLUGIN.'alt_auth/alt_auth_adminmenu.php');
|
|
require_once(e_HANDLER.'user_extended_class.php');
|
|
$euf = new e107_user_extended;
|
|
|
|
|
|
$pref = e107::pref('core');
|
|
|
|
if(isset($_POST['updateprefs']))
|
|
{
|
|
unset($temp);
|
|
$temp['auth_method'] = $tp->toDB($_POST['auth_method']);
|
|
$temp['auth_noconn'] = intval($_POST['auth_noconn']);
|
|
$temp['auth_method2'] = $tp->toDB($_POST['auth_method2']);
|
|
$temp['auth_badpassword'] = intval($_POST['auth_badpassword']);
|
|
if ($admin_log->logArrayDiffs($temp, $pref, 'AUTH_01'))
|
|
{
|
|
e107::getConfig('core')->setPref($temp)->save(false);
|
|
header('location:'.e_SELF);
|
|
exit;
|
|
}
|
|
}
|
|
|
|
|
|
if(isset($_POST['updateeufs']))
|
|
{
|
|
$authExtended = array();
|
|
foreach ($_POST['auth_euf_include'] as $au)
|
|
{
|
|
$authExtended[] = trim($tp->toDB($au));
|
|
}
|
|
$au = implode(',',$authExtended);
|
|
if ($au != $pref['auth_extended'])
|
|
{
|
|
|
|
e107::getConfig()->set('auth_extended', $au)->save(true,true,true);
|
|
e107::getLog()->add('AUTH_02',$au,'');
|
|
}
|
|
}
|
|
|
|
// Avoid need for lots of checks later
|
|
if (!isset($pref['auth_badpassword'])) $pref['auth_badpassword'] = 0;
|
|
if (!isset($pref['auth_noconn'])) $pref['auth_noconn'] = 0;
|
|
|
|
// Convert prefs
|
|
if (isset($pref['auth_nouser']))
|
|
{
|
|
$cfg = e107::getConfig();
|
|
$cfg->set('auth_method2', 'none');
|
|
|
|
if($pref['auth_nouser'])
|
|
{
|
|
$cfg->set('auth_method2', 'e107');
|
|
}
|
|
|
|
$cfg->remove('auth_nouser');
|
|
|
|
if (!isset($pref['auth_badpassword']))
|
|
{
|
|
$cfg->set('auth_badpassword', 0);
|
|
}
|
|
|
|
$cfg->save(false, true, true);
|
|
|
|
}
|
|
|
|
|
|
$authlist = alt_auth_admin::alt_auth_get_authlist();
|
|
if (isset($pref['auth_extended']))
|
|
{
|
|
$authExtended = explode(',',$pref['auth_extended']);
|
|
}
|
|
else
|
|
{
|
|
$pref['auth_extended'] = '';
|
|
$authExtended = array();
|
|
}
|
|
|
|
if(e107::getDb()->getPDO() === false)
|
|
{
|
|
$mess = "PDO is required to use alt-auth. To enable add: <code>define('e_PDO', true);</code> to e107_config.php.<br />
|
|
<small>Warning: If PDO is not correctly configured on your server then your site may fail to connect with the database.</small>";
|
|
echo e107::getMessage()->addInfo($mess)->render();
|
|
}
|
|
|
|
if(!empty($message))
|
|
{
|
|
echo e107::getMessage()->addSuccess($message)->render();
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$altAuthAdmin = new alt_auth_admin();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$text = "
|
|
<div>
|
|
<form method='post' action='".e_SELF."'>
|
|
<table class='table adminform'>
|
|
<colgroup span='2'>
|
|
<col class='col-label' />
|
|
<col class='col-control' />
|
|
</colgroup>
|
|
<tr>
|
|
<td>".LAN_ALT_1.": </td>
|
|
<td>".
|
|
$altAuthAdmin->alt_auth_get_dropdown('auth_method', $pref['auth_method'], 'e107')."
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_ALT_78.":<br /></td>
|
|
<td>
|
|
<select class='tbox' name='auth_badpassword'>";
|
|
$sel = (!$pref['auth_badpassword'] ? "" : " selected = 'selected' ");
|
|
$text .= "<option value='0' {$sel} >".LAN_ALT_FAIL."</option>";
|
|
$sel = ($pref['auth_badpassword'] ? " selected = 'selected' " : "");
|
|
$text .= "<option value='1' {$sel} >".LAN_ALT_FALLBACK."</option>
|
|
</select><div class='smalltext field-help'>".LAN_ALT_79."</div>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_ALT_6.":<br /></td>
|
|
<td>
|
|
<select class='tbox' name='auth_noconn'>";
|
|
$sel = (!$pref['auth_noconn'] ? '' : " selected = 'selected' ");
|
|
$text .= "<option value='0' {$sel} >".LAN_ALT_FAIL."</option>";
|
|
$sel = ($pref['auth_noconn'] ? " selected = 'selected' " : '');
|
|
$text .= "<option value='1' {$sel} >".LAN_ALT_FALLBACK."</option>
|
|
</select><div class='smalltext field-help'>".LAN_ALT_7."</div>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td>".LAN_ALT_8.":<br />
|
|
|
|
</td>
|
|
<td>".$altAuthAdmin->alt_auth_get_dropdown('auth_method2', varset($pref['auth_method2']), 'none')."
|
|
<div class='smalltext field-help'>".LAN_ALT_9."</div>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<div class='buttons-bar center'>".
|
|
$frm->admin_button('updateprefs',LAN_UPDATE,'update')."
|
|
</div>
|
|
</form>
|
|
</div>";
|
|
$ns = e107::getRender();
|
|
|
|
$ns->tablerender(LAN_ALT_3, $text);
|
|
|
|
|
|
if ($euf->userCount)
|
|
{
|
|
e107::includeLan(e_LANGUAGEDIR.e_LANGUAGE.'/lan_user_extended.php');
|
|
$fl = &$euf->fieldDefinitions;
|
|
$text = "<div>
|
|
<form method='post' action='".e_SELF."'>
|
|
<table class='table adminlist'>
|
|
<colgroup>
|
|
<col style='width:10%' />
|
|
<col style='width:30%' />
|
|
<col style='width:40%' />
|
|
<col style='width:20%' />
|
|
</colgroup>\n";
|
|
|
|
$text .= "<thead><tr>
|
|
<th class='center'>".LAN_ALT_61."</th>
|
|
<th>".LAN_ALT_62."</th>
|
|
<th>".LAN_ALT_63."</th>
|
|
<th>".LAN_ALT_64."</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>";
|
|
foreach ($fl as $f)
|
|
{
|
|
$checked = (in_array($f['user_extended_struct_name'], $authExtended) ? " checked='checked'" : '');
|
|
$text .= "<tr>
|
|
<td class='center'><input type='checkbox' name='auth_euf_include[]' value='{$f['user_extended_struct_name']}'{$checked} /></td>
|
|
<td>{$f['user_extended_struct_name']}</td>
|
|
<td>".$tp->toHTML($f['user_extended_struct_text'],FALSE,'TITLE')."</td>
|
|
<td>". varset($euf->user_extended_types[$f['user_extended_struct_type']])."</td></tr>\n";
|
|
}
|
|
$text .= "</tbody>
|
|
</table><div class='buttons-bar center'>
|
|
".$frm->admin_button('updateeufs',LAN_UPDATE,'update')."
|
|
|
|
</div>
|
|
|
|
</form>
|
|
</div>";
|
|
e107::getRender()->tablerender(LAN_ALT_60, $text);
|
|
|
|
|
|
}
|
|
|
|
|
|
require_once(e_ADMIN.'footer.php');
|
|
|
|
function alt_auth_conf_adminmenu()
|
|
{
|
|
alt_auth_adminmenu();
|
|
}
|
|
|
|
|