\n";
}
foreach ($this->header as $header) {
$result.= $header;
@@ -309,7 +324,7 @@ class listing {
// Render multi select if needed
if ($this->multiSelect) {
- $result.="
";
+ $result.="
";
}
// Render defined department columns, fill the rest with some stuff
@@ -383,18 +398,18 @@ class listing {
if ($i != $this->numColumns-1) {
$result.= "
";
} else {
- $result.= "
";
+ $result.= "
";
}
}
$result.= "
";
}
// Close list body
- $result.= "
";
+ $result.= "
";
// Add the footer if requested
if ($this->showFooter) {
- $result.= "
";
+ $result.= "
";
foreach ($this->objectTypes as $objectType) {
if (isset($this->objectTypeCount[$objectType['label']])) {
@@ -403,11 +418,17 @@ class listing {
}
}
- $result.= "
";
+ $result.= "";
}
// Close list
- $result.= "
";
+ $result.= $switch?"":"";
+
+ // Add scroll positioner
+ $result.= '';
$smarty= get_smarty();
$smarty->assign("usePrototype", "true");
@@ -431,7 +452,15 @@ class listing {
// Assign summary
$smarty->assign("HEADLINE", $this->headline);
- return ($smarty->fetch(get_template_path($this->xmlData['definition']['template'], true)));
+ // Try to load template from plugin the folder first...
+ $file = get_template_path($this->xmlData['definition']['template'], true);
+
+ // ... if this fails, try to load the file from the theme folder.
+ if(!file_exists($file)){
+ $file = get_template_path($this->xmlData['definition']['template']);
+ }
+
+ return ($smarty->fetch($file));
}
@@ -440,92 +469,110 @@ class listing {
global $config;
$ui= get_userinfo();
+ // Take care of base selector
+ if ($this->baseMode) {
+ $this->baseSelector->update();
+ }
+
+ // Save base
+ $refresh= false;
+ if ($this->baseMode) {
+ $this->base= $this->baseSelector->getBase();
+ session::global_set("CurrentMainBase", $this->base);
+ $refresh= true;
+ }
+
+
// Reset object counter / DN mapping
$this->objectTypeCount= array();
$this->objectDnMapping= array();
// Do not do anything if this is not our PID
- if(isset($_REQUEST['PID']) && $_REQUEST['PID'] != $this->pid) {
- return;
- }
+ if($refresh || !(isset($_REQUEST['PID']) && $_REQUEST['PID'] != $this->pid)) {
- // Save base
- if (isset($_POST['BASE']) && $this->baseMode) {
- $base= get_post('BASE');
- if (isset($this->bases[$base])) {
- $this->base= $base;
- session::global_set("CurrentMainBase", $this->base);
+ // Save position if set
+ if (isset($_POST['position_'.$this->pid]) && is_numeric($_POST['position_'.$this->pid])) {
+ $this->scrollPosition= $_POST['position_'.$this->pid];
}
- }
- // Override the base if we got a message from the browser navigation
- if ($this->departmentBrowser && isset($_GET['act'])) {
- if (preg_match('/^department_([0-9]+)$/', validate($_GET['act']), $match)){
- if (isset($this->departments[$match[1]])){
- $this->base= $this->departments[$match[1]]['dn'];
- session::global_set("CurrentMainBase", $this->base);
+ // Override the base if we got a message from the browser navigation
+ if ($this->departmentBrowser && isset($_GET['act'])) {
+ if (preg_match('/^department_([0-9]+)$/', validate($_GET['act']), $match)){
+ if (isset($this->departments[$match[1]])){
+ $this->base= $this->departments[$match[1]]['dn'];
+ if ($this->baseMode) {
+ $this->baseSelector->setBase($this->base);
+ }
+ session::global_set("CurrentMainBase", $this->base);
+ }
}
}
- }
- // Filter POST with "act" attributes -> posted from action menu
- if (isset($_POST['exec_act']) && $_POST['act'] != '') {
- if (preg_match('/^export.*$/', $_POST['act']) && isset($this->exporter[$_POST['act']])) {
- $exporter= $this->exporter[$_POST['act']];
- $userinfo= ", "._("created by")." ".$ui->cn." - ".strftime('%A, %d. %B %Y, %H:%M:%S');
- $entryIterator= new listingSortIterator($this->entries, $this->sortDirection[$this->sortColumn], "_sort".$this->sortColumn, $this->sortType);
- $sortedEntries= array();
- foreach ($entryIterator as $entry){
- $sortedEntries[]= $entry;
+ // Filter POST with "act" attributes -> posted from action menu
+ if (isset($_POST['exec_act']) && $_POST['act'] != '') {
+ if (preg_match('/^export.*$/', $_POST['act']) && isset($this->exporter[$_POST['act']])) {
+ $exporter= $this->exporter[$_POST['act']];
+ $userinfo= ", "._("created by")." ".$ui->cn." - ".strftime('%A, %d. %B %Y, %H:%M:%S');
+ $entryIterator= new listingSortIterator($this->entries, $this->sortDirection[$this->sortColumn], "_sort".$this->sortColumn, $this->sortType);
+ $sortedEntries= array();
+ foreach ($entryIterator as $entry){
+ $sortedEntries[]= $entry;
+ }
+ $instance= new $exporter['class']($this->headline.$userinfo, $this->plainHeader, $sortedEntries, $this->exportColumns);
+ $type= call_user_func(array($exporter['class'], "getInfo"));
+ $type= $type[$_POST['act']];
+ send_binary_content($instance->query(), $type['filename'], $type= $type['mime']);
}
- $instance= new $exporter['class']($this->headline.$userinfo, $this->plainHeader, $sortedEntries, $this->exportColumns);
- $type= call_user_func(array($exporter['class'], "getInfo"));
- $type= $type[$_POST['act']];
- send_binary_content($instance->query(), $type['filename'], $type= $type['mime']);
}
- }
- // Filter GET with "act" attributes
- if (isset($_GET['act'])) {
- $key= validate($_GET['act']);
- if (preg_match('/^SORT_([0-9]+)$/', $key, $match)) {
- // Switch to new column or invert search order?
- $column= $match[1];
- if ($this->sortColumn != $column) {
- $this->sortColumn= $column;
- } else {
- $this->sortDirection[$column]= !$this->sortDirection[$column];
- }
+ // Filter GET with "act" attributes
+ if (isset($_GET['act'])) {
+ $key= validate($_GET['act']);
+ if (preg_match('/^SORT_([0-9]+)$/', $key, $match)) {
+ // Switch to new column or invert search order?
+ $column= $match[1];
+ if ($this->sortColumn != $column) {
+ $this->sortColumn= $column;
+ } else {
+ $this->sortDirection[$column]= !$this->sortDirection[$column];
+ }
- // Allow header to update itself according to the new sort settings
- $this->renderHeader();
+ // Allow header to update itself according to the new sort settings
+ $this->renderHeader();
+ }
}
- }
- // Override base if we got signals from the navigation elements
- $action= "";
- foreach ($_POST as $key => $value) {
- if (preg_match('/^(ROOT|BACK|HOME)_x$/', $key, $match)) {
- $action= $match[1];
- break;
+ // Override base if we got signals from the navigation elements
+ $action= "";
+ foreach ($_POST as $key => $value) {
+ if (preg_match('/^(ROOT|BACK|HOME)_x$/', $key, $match)) {
+ $action= $match[1];
+ break;
+ }
}
- }
- // Navigation handling
- if ($action == 'ROOT') {
- $deps= $ui->get_module_departments($this->module);
- $this->base= $deps[0];
- }
- if ($action == 'BACK') {
- $deps= $ui->get_module_departments($this->module);
- $base= preg_replace("/^[^,]+,/", "", $this->base);
- if(in_array_ics($base, $deps)){
- $this->base= $base;
+ // Navigation handling
+ if ($action == 'ROOT') {
+ $deps= $ui->get_module_departments($this->categories);
+ $this->base= $deps[0];
+ $this->baseSelector->setBase($this->base);
+ session::global_set("CurrentMainBase", $this->base);
+ }
+ if ($action == 'BACK') {
+ $deps= $ui->get_module_departments($this->categories);
+ $base= preg_replace("/^[^,]+,/", "", $this->base);
+ if(in_array_ics($base, $deps)){
+ $this->base= $base;
+ $this->baseSelector->setBase($this->base);
+ session::global_set("CurrentMainBase", $this->base);
+ }
+ }
+ if ($action == 'HOME') {
+ $ui= get_userinfo();
+ $this->base= get_base_from_people($ui->dn);
+ $this->baseSelector->setBase($this->base);
+ session::global_set("CurrentMainBase", $this->base);
}
- }
- if ($action == 'HOME') {
- $ui= get_userinfo();
- $this->base= $this->filter->getObjectBase($ui->dn);
}
// Reload departments
@@ -536,12 +583,20 @@ class listing {
// Update filter and refresh entries
$this->filter->setBase($this->base);
$this->entries= $this->filter->query();
+
+ // Fix filter if querie returns NULL
+ if ($this->entries == null) {
+ $this->entries= array();
+ }
}
function setBase($base)
{
$this->base= $base;
+ if ($this->baseMode) {
+ $this->baseSelector->setBase($this->base);
+ }
}
@@ -556,12 +611,12 @@ class listing {
$result= array();
$layout= preg_replace("/^\|/", "", $layout);
$layout= preg_replace("/\|$/", "", $layout);
- $cols= split("\|", $layout);
+ $cols= explode("|", $layout);
foreach ($cols as $index => $config) {
if ($config != "") {
$res= "";
- $components= split(';', $config);
+ $components= explode(';', $config);
foreach ($components as $part) {
if (preg_match("/^r$/", $part)) {
$res.= "text-align:right;";
@@ -586,15 +641,18 @@ class listing {
$res.= "min-width:200px;";
}
- $result[$index]= " style='$res' ";
+ $result[$index]= " style='$res'";
} else {
- $result[$index]= " style='min-width:100px'";
+ $result[$index]= " style='min-width:100px;'";
}
}
// Save number of columns for later use
$this->numColumns= count($cols);
+ // Add no border to the last column
+ $result[$this->numColumns-1]= preg_replace("/'$/", "border-right:0;'", $result[$this->numColumns-1]);
+
return $result;
}
@@ -630,35 +688,7 @@ class listing {
return;
}
- $result= "";
-
- // Reset the currently used base to the first DN we found if there
- // was no match.
- if(!$found){
- $this->base = $firstDN;
- }
-
- return $result;
+ return $this->baseSelector->render();
}
@@ -688,21 +718,31 @@ class listing {
// Row is replaced by the row number
if ($param == "row") {
$params[]= $row;
+ continue;
}
// pid is replaced by the current PID
if ($param == "pid") {
$params[]= $this->pid;
+ continue;
}
// base is replaced by the current base
if ($param == "base") {
$params[]= $this->getBase();
+ continue;
}
// Fixie with "" is passed directly
if (preg_match('/^".*"$/', $param)){
$params[]= preg_replace('/"/', '', $param);
+ continue;
+ }
+
+ // Move dn if needed
+ if ($param == "dn") {
+ $params[]= LDAP::fix($config["dn"]);
+ continue;
}
// LDAP variables get replaced by their objects
@@ -713,13 +753,9 @@ class listing {
unset($values['count']);
}
$params[]= $values;
+ break;
}
}
-
- // Move dn if needed
- if ($param == "dn") {
- $params[]= LDAP::fix($config["dn"]);
- }
}
// Replace information
@@ -799,14 +835,14 @@ class listing {
$actions= $this->xmlData['actiontriggers']['action'];
foreach($actions as $action) {
// Skip the entry completely if there's no permission to execute it
- if (!$this->hasActionPermission($action, $dn)) {
+ if (!$this->hasActionPermission($action, $dn, $classes)) {
$result.= "";
continue;
}
// Skip entry if the pseudo filter does not fit
if (isset($action['filter']) && preg_match('/^[a-z0-9_]+!?=[a-z0-9_]+$/i', $action['filter'])) {
- list($fa, $fv)= split('=', $action['filter']);
+ list($fa, $fv)= explode('=', $action['filter']);
if (preg_match('/^(.*)!$/', $fa, $m)){
$fa= $m[1];
if (isset($this->entries[$row][$fa]) && $this->entries[$row][$fa][0] == $fv) {
@@ -832,11 +868,16 @@ class listing {
$result.= "";
continue;
}
- } else {
+ } elseif (is_string($objectclass)) {
if(!in_array($objectclass, $classes)) {
$result.= "";
continue;
}
+ } elseif (is_array($objectclass)) {
+ if(count(array_intersect($objectclass, $classes)) != count($objectclass)){
+ $result.= "";
+ continue;
+ }
}
}
@@ -859,7 +900,9 @@ class listing {
}
if ($action['type'] == "copypaste") {
- $result.= $this->renderCopyPasteActions($row, $this->entries[$row]['dn'], $category, $class);
+ $copy = !isset($action['copy']) || $action['copy'] == "true";
+ $cut = !isset($action['cut']) || $action['cut'] == "true";
+ $result.= $this->renderCopyPasteActions($row, $this->entries[$row]['dn'], $category, $class,$copy,$cut);
} else {
$result.= $this->renderSnapshotActions($row, $this->entries[$row]['dn'], $category, $class);
}
@@ -921,7 +964,7 @@ class listing {
$ui = get_userinfo();
/* Check if base = first available base */
- $deps = $ui->get_module_departments($this->module);
+ $deps = $ui->get_module_departments($this->categories);
if(!count($deps) || $deps[0] == $this->filter->base){
$enableBack = false;
@@ -931,7 +974,7 @@ class listing {
$listhead ="";
/* Check if we are in users home department */
- if(!count($deps) || $this->filter->base == $this->filter->getObjectBase($ui->dn)){
+ if(!count($deps) || $this->filter->base == get_base_from_people($ui->dn)){
$enableHome = false;
}
@@ -974,6 +1017,11 @@ class listing {
return;
}
+ // Save position if set
+ if (isset($_POST['position_'.$this->pid]) && is_numeric($_POST['position_'.$this->pid])) {
+ $this->scrollPosition= $_POST['position_'.$this->pid];
+ }
+
$result= array("targets" => array(), "action" => "");
// Filter GET with "act" attributes
@@ -1122,7 +1170,9 @@ class listing {
// Check for special types
switch ($action['type']) {
case 'copypaste':
- $result.= $this->renderCopyPasteMenu($separator);
+ $cut = !isset($action['cut']) || $action['cut'] != "false";
+ $copy = !isset($action['copy']) || $action['copy'] != "false";
+ $result.= $this->renderCopyPasteMenu($separator, $copy , $cut);
break;
case 'snapshot':
@@ -1146,7 +1196,7 @@ class listing {
}
- function hasActionPermission($action, $dn)
+ function hasActionPermission($action, $dn, $classes= null)
{
$ui= get_userinfo();
@@ -1158,9 +1208,15 @@ class listing {
// Every ACL has to pass
foreach ($acls as $acl) {
- $module= $this->module;
+ $module= $this->categories;
$aclList= array();
+ // Replace %acl if available
+ if ($classes) {
+ $otype= $this->getObjectType($this->objectTypes, $classes);
+ $acl= str_replace('%acl', $otype['category']."/".$otype['class'], $acl);
+ }
+
// Split for category and plugins if needed
// match for "[rw]" style entries
if (preg_match('/^\[([rwcdm]+)\]$/', $acl, $match)){
@@ -1182,7 +1238,7 @@ class listing {
// match "users/user[userPassword:rw(,...)*]" style entries
if (preg_match('/^([a-zA-Z0-9]+\/[a-zA-Z0-9]+)\[([a-zA-Z0-9]+:[rwcdm]+(,[a-zA-Z0-9]+:[rwcdm]+)*)\]$/', $acl, $match)){
$module= $match[1];
- $aclList= split(',', $match[2]);
+ $aclList= explode(',', $match[2]);
}
// Walk thru prepared ACL by using $module
@@ -1225,7 +1281,7 @@ class listing {
// Do some array munching to get it user friendly
$ids= $config->idepartments;
- $d= $ui->get_module_departments($this->module);
+ $d= $ui->get_module_departments($this->categories);
$k_ids= array_keys($ids);
$deps= array_intersect($d,$k_ids);
@@ -1234,6 +1290,11 @@ class listing {
foreach($k_ids as $department){
$this->bases[$department] = $ids[$department];
}
+
+ // Populate base selector if already present
+ if ($this->baseSelector && $this->baseMode) {
+ $this->baseSelector->setBases($this->bases);
+ }
}
@@ -1246,7 +1307,7 @@ class listing {
$types = departmentManagement::get_support_departments();
// Load departments allowed by ACL
- $validDepartments = $ui->get_module_departments($this->module);
+ $validDepartments = $ui->get_module_departments($this->categories);
// Build filter and look in the LDAP for possible sub departments
// of current base
@@ -1257,7 +1318,7 @@ class listing {
$attrs[]= $data['ATTR'];
}
$filter.= "))";
- $res= get_list($filter, $this->module, $this->base, $attrs, GL_NONE);
+ $res= get_list($filter, $this->categories, $this->base, $attrs, GL_NONE);
// Analyze list of departments
foreach ($res as $department) {
@@ -1380,7 +1441,7 @@ class listing {
$result = "";
$ui = get_userinfo();
- if($this->snapshotHandler->enabled() && $ui->allow_snapshot_restore($this->base, $this->module)){
+ if($this->snapshotHandler->enabled() && $ui->allow_snapshot_restore($this->base, $this->categories)){
// Check if there is something to restore
$restore= false;
@@ -1481,6 +1542,23 @@ class listing {
}
+ function getEntry($dn)
+ {
+ foreach ($this->entries as $entry) {
+ if (isset($entry['dn']) && strcasecmp($dn, $entry['dn']) == 0){
+ return $entry;
+ }
+ }
+ return null;
+ }
+
+
+ function getEntries()
+ {
+ return $this->entries;
+ }
+
+
function getType($dn)
{
if (isset($this->objectDnMapping[$dn])) {