373 Zeilen
Kein EOL
11 KiB
PHP
373 Zeilen
Kein EOL
11 KiB
PHP
<?php
|
|
/**
|
|
* Project:
|
|
* Contenido Content Management System
|
|
*
|
|
* Description:
|
|
* Frontend user list
|
|
*
|
|
* Requirements:
|
|
* @con_php_req 5.0
|
|
*
|
|
*
|
|
* @package Contenido Backend includes
|
|
* @version 1.1.9
|
|
* @author unknown
|
|
* @copyright four for business AG <www.4fb.de>
|
|
* @license http://www.contenido.org/license/LIZENZ.txt
|
|
* @link http://www.4fb.de
|
|
* @link http://www.contenido.org
|
|
* @since file available since contenido release <= 4.6
|
|
*
|
|
* {@internal
|
|
* created unknown
|
|
* modified 2008-06-27, Frederic Schneider, add security fix
|
|
*
|
|
* $Id$:
|
|
* }}
|
|
*
|
|
*/
|
|
|
|
if(!defined('CON_FRAMEWORK')) {
|
|
die('Illegal call');
|
|
}
|
|
|
|
|
|
$oPage = new cPage;
|
|
//
|
|
///* Set default values */
|
|
$oUser = new cApiUser($auth->auth["uid"]);
|
|
if (!isset($_REQUEST["elemperpage"]) || !is_numeric($_REQUEST['elemperpage']) || $_REQUEST['elemperpage'] <= 0) {
|
|
$_REQUEST["elemperpage"] = $oUser->getProperty("itemsperpage", $area);
|
|
}
|
|
if (!is_numeric($_REQUEST['elemperpage'])) {
|
|
$_REQUEST['elemperpage'] = 25;
|
|
}
|
|
$oUser->setProperty("itemsperpage", $area, $_REQUEST["elemperpage"]);
|
|
unset ($oUser);
|
|
|
|
if (!isset($_REQUEST["page"]) || !is_numeric($_REQUEST['page']) || $_REQUEST['page'] <= 0 || $_REQUEST["elemperpage"] == 0) {
|
|
$_REQUEST["page"] = 1;
|
|
}
|
|
|
|
$aFieldsToSearch = array("--all--" => i18n("-- All fields --"), "username" => i18n("Username"));
|
|
$aFieldsToSort = array("username" => i18n("Username"));
|
|
|
|
$aFieldSources = array();
|
|
$aFieldSources["username"] = "base";
|
|
|
|
$bUsePlugins = getEffectiveSetting("frontendusers", "pluginsearch", "true");
|
|
|
|
if ($bUsePlugins == "false")
|
|
{
|
|
$bUsePlugins = false;
|
|
} else {
|
|
$bUsePlugins = true;
|
|
}
|
|
|
|
if (is_array($cfg['plugins']['frontendusers']))
|
|
{
|
|
foreach ($cfg['plugins']['frontendusers'] as $plugin)
|
|
{
|
|
plugin_include("frontendusers", $plugin."/".$plugin.".php");
|
|
}
|
|
}
|
|
|
|
if ($bUsePlugins == true)
|
|
{
|
|
if (is_array($cfg['plugins']['frontendusers']))
|
|
{
|
|
$_sValidPlugins = getEffectiveSetting("frontendusers", "pluginsearch_valid_plugins", '');
|
|
$_aValidPlugins = array();
|
|
if (strlen($_sValidPlugins)>0) {
|
|
$_aValidPlugins = explode(',', $_sValidPlugins);
|
|
}
|
|
$_iCountValidPlugins = sizeof($_aValidPlugins);
|
|
foreach ($cfg['plugins']['frontendusers'] as $plugin)
|
|
{
|
|
if ($_iCountValidPlugins == 0 || in_array($plugin, $_aValidPlugins)) {
|
|
if (function_exists("frontendusers_".$plugin."_wantedVariables") && function_exists("frontendusers_".$plugin."_canonicalVariables"))
|
|
{
|
|
$aVariableNames = call_user_func("frontendusers_".$plugin."_canonicalVariables");
|
|
|
|
if (is_array($aVariableNames))
|
|
{
|
|
$aTmp = array_merge($aFieldsToSearch, $aVariableNames);
|
|
$aFieldsToSearch = $aTmp;
|
|
|
|
$aTmp2 = array_merge($aFieldsToSort, $aVariableNames);
|
|
$aFieldsToSort = $aTmp2;
|
|
|
|
foreach ($aVariableNames as $sVariableName => $name)
|
|
{
|
|
$aFieldSources[$sVariableName] = $plugin;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$aSortOrderOptions = array ("asc" => i18n("Ascending"), "desc" => i18n("Descending"));
|
|
|
|
$oListOptionRow = new cFoldingRow("f081b6ab-370d-4fd8-984f-6b38590fe48b", i18n("List options"));
|
|
|
|
$oSelectItemsPerPage = new cHTMLSelectElement("elemperpage");
|
|
$oSelectItemsPerPage->autoFill(array(25 => 25, 50 => 50, 75 => 75, 100 => 100));
|
|
$oSelectItemsPerPage->setDefault($_REQUEST["elemperpage"]);
|
|
|
|
asort($aFieldsToSort);
|
|
asort($aFieldsToSearch);
|
|
|
|
$oSelectSortBy = new cHTMLSelectElement("sortby");
|
|
$oSelectSortBy->autoFill($aFieldsToSort);
|
|
$oSelectSortBy->setDefault($_REQUEST["sortby"]);
|
|
|
|
$oSelectSortOrder = new cHTMLSelectElement("sortorder");
|
|
$oSelectSortOrder->autoFill($aSortOrderOptions);
|
|
$oSelectSortOrder->setDefault($_REQUEST["sortorder"]);
|
|
|
|
$oSelectSearchIn = new cHTMLSelectElement("searchin");
|
|
$oSelectSearchIn->autoFill($aFieldsToSearch);
|
|
$oSelectSearchIn->setDefault($_REQUEST["searchin"]);
|
|
|
|
$fegroups = new FrontendGroupCollection;
|
|
$fegroups->setWhere("idclient", $client);
|
|
$fegroups->query();
|
|
|
|
$aFEGroups = array("--all--" => i18n("-- All Groups --"));
|
|
|
|
while ($fegroup = $fegroups->next())
|
|
{
|
|
$aFEGroups[$fegroup->get("idfrontendgroup")] = $fegroup->get("groupname");
|
|
}
|
|
|
|
$oSelectRestrictGroup = new cHTMLSelectElement("restrictgroup");
|
|
$oSelectRestrictGroup->autoFill($aFEGroups);
|
|
$oSelectRestrictGroup->setDefault($_REQUEST["restrictgroup"]);
|
|
|
|
$oTextboxFilter = new cHTMLTextbox("filter", $_REQUEST["filter"], 20);
|
|
|
|
$oFEUsers = new FrontendUserCollection;
|
|
$oFEUsers->setWhere("FrontendUserCollection.idclient", $client);
|
|
|
|
if (strlen($_REQUEST["filter"]) > 0 && $bUsePlugins == false)
|
|
{
|
|
$oFEUsers->setWhere("FrontendUsercollection.username", $_REQUEST["filter"], "diacritics");
|
|
}
|
|
|
|
if ($_REQUEST["restrictgroup"] != "" && $_REQUEST["restrictgroup"] != "--all--")
|
|
{
|
|
$oFEUsers->link("FrontendGroupMemberCollection");
|
|
$oFEUsers->setWhere("FrontendGroupMemberCollection.idfrontendgroup", $_REQUEST["restrictgroup"]);
|
|
}
|
|
|
|
$mPage = $_REQUEST["page"];
|
|
$elemperpage = $_REQUEST["elemperpage"];
|
|
|
|
$iFullTableCount = 0;
|
|
if ($bUsePlugins == false)
|
|
{
|
|
$oFEUsers->query();
|
|
|
|
$iFullTableCount = $oFEUsers->count();
|
|
|
|
$oFEUsers->setOrder(implode(" ", array($oSelectSortBy->getDefault(), $oSelectSortOrder->getDefault())));
|
|
$oFEUsers->setLimit($elemperpage * ($mPage - 1), $elemperpage);
|
|
} else {
|
|
$oFEUsers->query();
|
|
$iFullTableCount = $oFEUsers->count();
|
|
}
|
|
|
|
if ($_REQUEST["elemperpage"]*($_REQUEST["page"]) >= $iFullTableCount+$_REQUEST["elemperpage"] && $_REQUEST["page"] != 1) {
|
|
$_REQUEST["page"]--;
|
|
$mPage--;
|
|
}
|
|
|
|
$oFEUsers->query();
|
|
|
|
$aUserTable = array();
|
|
|
|
while ($feuser = $oFEUsers->next())
|
|
{
|
|
foreach ($aFieldSources as $key => $field)
|
|
{
|
|
$idfrontenduser = $feuser->get("idfrontenduser");
|
|
|
|
$aUserTable[$idfrontenduser]["idfrontenduser"] = $idfrontenduser;
|
|
|
|
switch ($field)
|
|
{
|
|
case "base":
|
|
$aUserTable[$idfrontenduser][$key] = $feuser->get("username");
|
|
break;
|
|
default:
|
|
if ($_REQUEST["filter"] != "")
|
|
{
|
|
$aUserTable[$idfrontenduser][$key] = call_user_func("frontendusers_".$field."_getvalue", $key);
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
if ($_REQUEST["filter"] != "")
|
|
{
|
|
if ($_REQUEST["searchin"] == "--all--" || $_REQUEST["searchin"] == "")
|
|
{
|
|
$found = false;
|
|
|
|
foreach ($aUserTable[$idfrontenduser] as $key => $value)
|
|
{
|
|
if (stripos($value, $_REQUEST["filter"]) !== false)
|
|
{
|
|
$found = true;
|
|
}
|
|
}
|
|
|
|
if ($found == false)
|
|
{
|
|
unset($aUserTable[$idfrontenduser]);
|
|
}
|
|
|
|
} else {
|
|
if (stripos($aUserTable[$idfrontenduser][$_REQUEST["searchin"]], $_REQUEST["filter"]) === false)
|
|
{
|
|
unset($aUserTable[$idfrontenduser]);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($_REQUEST["sortorder"] == "desc")
|
|
{
|
|
$sortorder = SORT_DESC;
|
|
} else {
|
|
$sortorder = SORT_ASC;
|
|
}
|
|
|
|
if ($_REQUEST["sortby"])
|
|
{
|
|
$aUserTable = array_csort($aUserTable, $_REQUEST["sortby"], $sortorder);
|
|
} else {
|
|
$aUserTable = array_csort($aUserTable, "username", $sortorder);
|
|
}
|
|
|
|
$mlist = new UI_Menu;
|
|
$iMenu = 0;
|
|
$iItemCount = 0;
|
|
|
|
foreach ($aUserTable as $mkey => $params)
|
|
{
|
|
$idfrontenduser = $params["idfrontenduser"];
|
|
$link = new cHTMLLink;
|
|
$link->setMultiLink($area, "", $area, "");
|
|
$link->setCustom("idfrontenduser", $idfrontenduser);
|
|
|
|
$iItemCount++;
|
|
|
|
if (($iItemCount > ($elemperpage * ($mPage - 1)) && $iItemCount < (($elemperpage * $mPage) + 1)) || $bUsePlugins == false)
|
|
{
|
|
$iMenu++;
|
|
|
|
$message = sprintf(i18n("Do you really want to delete the user %s?"), clHtmlSpecialChars($params["username"]));
|
|
|
|
$delTitle = i18n("Delete user");
|
|
$deletebutton = '<a title="'.$delTitle.'" href="javascript://" onclick="box.confirm(\''.$delTitle.'\', \''.$message.'\', \'deleteFrontenduser('.$idfrontenduser.')\')"><img src="'.$cfg['path']['images'].'delete.gif" border="0" title="'.$delTitle.'" alt="'.$delTitle.'"></a>';
|
|
|
|
$mlist->setTitle($iMenu, $params["username"]);
|
|
$mlist->setLink($iMenu, $link);
|
|
$mlist->setActions($iMenu, "delete", $deletebutton);
|
|
$mlist->setImage($iMenu, "");
|
|
|
|
if ($_GET['frontenduser'] == $idfrontenduser) {
|
|
$mlist->setExtra($iMenu, 'id="marked" ');
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($bUsePlugins == false)
|
|
{
|
|
$iItemCount = $iFullTableCount;
|
|
}
|
|
|
|
$deleteScript = '<script>
|
|
var sid = "'.$sess->id.'";
|
|
var box = new messageBox("", "", "", 0, 0);
|
|
|
|
function deleteFrontenduser(idfrontenduser)
|
|
{
|
|
form = parent.left_top.document.getElementById("filter");
|
|
url = \'main.php?area=frontend\';
|
|
url += \'&action=frontend_delete\';
|
|
url += \'&frame=4\';
|
|
url += \'&idfrontenduser=\' + idfrontenduser;
|
|
url += \'&contenido=\' + sid;
|
|
url += get_registered_parameters();
|
|
url += \'&sortby=\' +form.sortby.value;
|
|
url += \'&sortorder=\' +form.sortorder.value;
|
|
url += \'&filter=\' +form.filter.value;
|
|
url += \'&searchin=\' +form.searchin.value;
|
|
url += \'&elemperpage=\' +form.elemperpage.value;
|
|
url += \'&restrictgroup=\' +form.restrictgroup.value;
|
|
url += \'&page=\' +\''.$mPage.'\';
|
|
parent.parent.right.right_bottom.location.href = url;
|
|
}
|
|
</script>';
|
|
|
|
$sInitRowMark = "<script type=\"text/javascript\">
|
|
if (document.getElementById('marked')) {
|
|
row.markedRow = document.getElementById('marked');
|
|
}
|
|
</script>";
|
|
|
|
$oPage->setMargin(0);
|
|
$oPage->addScript('messagebox', '<script type="text/javascript" src="scripts/messageBox.js.php?contenido='.$sess->id.'"></script>');
|
|
$oPage->addScript('delete', $deleteScript);
|
|
//$oPage->addScript('cfoldingrow.js', '<script language="JavaScript" src="scripts/cfoldingrow.js"></script>');
|
|
$oPage->addScript('parameterCollector.js', '<script language="JavaScript" src="scripts/parameterCollector.js"></script>');
|
|
|
|
//generate current content for Object Pager
|
|
$oPagerLink = new cHTMLLink;
|
|
$oPagerLink->setTargetFrame('left_bottom');
|
|
$oPagerLink->setLink("main.php");
|
|
$oPagerLink->setCustom("elemperpage", $elemperpage);
|
|
$oPagerLink->setCustom("filter", $_REQUEST["filter"]);
|
|
$oPagerLink->setCustom("sortby", $_REQUEST["sortby"]);
|
|
$oPagerLink->setCustom("sortorder", $_REQUEST["sortorder"]);
|
|
$oPagerLink->setCustom("searchin", $_REQUEST["searchin"]);
|
|
$oPagerLink->setCustom("restrictgroup", $_REQUEST["restrictgroup"]);
|
|
$oPagerLink->setCustom("frame", $frame);
|
|
$oPagerLink->setCustom("area", $area);
|
|
$oPagerLink->enableAutomaticParameterAppend();
|
|
$oPagerLink->setCustom("contenido", $sess->id);
|
|
|
|
$oPager = new cObjectPager("25c6a67d-a3f1-4ea4-8391-446c131952c9", $iItemCount, $_REQUEST['elemperpage'], $mPage, $oPagerLink, "page", $pagingLink);
|
|
|
|
//add slashes, to insert in javascript
|
|
$sPagerContent = $oPager->render(1);
|
|
$sPagerContent = str_replace('\\', '\\\\', $sPagerContent);
|
|
$sPagerContent = str_replace('\'', '\\\'', $sPagerContent);
|
|
|
|
//send new object pager to left_top
|
|
$sRefreshPager = '
|
|
<script type="text/javascript">
|
|
var sNavigation = \''.$sPagerContent.'\';
|
|
var left_top = parent.left_top;
|
|
if (left_top.document) {
|
|
var oPager = left_top.document.getElementById(\'25c6a67d-a3f1-4ea4-8391-446c131952c9\');
|
|
|
|
if (oPager) {
|
|
oInsert = oPager.firstChild;
|
|
oInsert.innerHTML = sNavigation;
|
|
left_top.iPage = '.$_REQUEST["page"].';
|
|
left_top.toggle_pager(\'25c6a67d-a3f1-4ea4-8391-446c131952c9\');
|
|
}
|
|
}
|
|
</script>';
|
|
|
|
$oPage->addScript('refreshpager', $sRefreshPager);
|
|
$oPage->setContent($mlist->render(false).$sInitRowMark);
|
|
$oPage->render();
|
|
|
|
?>
|