\n";
// Save rendered entry
$this->entries[$row]['_rendered']= $trow;
-
- $alt++;
}
// Complete list by sorting entries for _sort$index and appending them to the output
$entryIterator= new listingSortIterator($this->entries, $this->sortDirection[$this->sortColumn], "_sort".$this->sortColumn, $this->sortType);
foreach ($entryIterator as $row => $entry){
+ $alt++;
+ $result.="
\n";
$result.= $entry['_rendered'];
+ $result.="
\n";
}
// Need to fill the list if it's not full (nobody knows why this is 22 ;-))
@@ -413,6 +442,18 @@ class listing {
}
}
+ // 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');
+ $instance= new $exporter['class']($this->headline.$userinfo, $this->plainHeader, $this->entries, $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']);
@@ -467,6 +508,18 @@ class listing {
}
+ function setBase($base)
+ {
+ $this->base= $base;
+ }
+
+
+ function getBase()
+ {
+ return $this->base;
+ }
+
+
function parseLayout($layout)
{
$result= array();
@@ -894,7 +947,9 @@ class listing {
// Filter POST with "act" attributes -> posted from action menu
if (isset($_POST['act']) && $_POST['act'] != '') {
- $result['action']= validate($_POST['act']);
+ if (!preg_match('/^export.*$/', $_POST['act'])){
+ $result['action']= validate($_POST['act']);
+ }
}
// Drop targets if empty
@@ -914,7 +969,7 @@ class listing {
// Load shortcut
$actions= &$this->xmlData['actionmenu']['action'];
- $result= "".
+ $result= "".
"
Aktionen ";
@@ -976,6 +1031,10 @@ class listing {
$result.= $this->renderSnapshotMenu($separator);
break;
+ case 'exporter':
+ $result.= $this->renderExporterMenu($separator);
+ break;
+
case 'daemon':
$result.= $this->renderDaemonMenu($separator);
break;
@@ -1151,13 +1210,13 @@ class listing {
// Copy entry
if($copy){
- $result.= "
";
+
+ return($result);
+ }
+
+
function renderSnapshotActions($row, $dn, $category, $class, $copy= true, $cut= true)
{
// We can only provide information if we've got a snapshot handler
@@ -1294,7 +1373,7 @@ class listing {
$events= DaemonEvent::get_event_types_by_category($this->categories);
if(isset($events['BY_CLASS']) && count($events['BY_CLASS'])){
foreach($events['BY_CLASS'] as $name => $event){
- $result.= "