summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 37a863a)
raw | patch | inline | side by side (parent: 37a863a)
author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 21 Jan 2010 14:58:48 +0000 (14:58 +0000) | ||
committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 21 Jan 2010 14:58:48 +0000 (14:58 +0000) |
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@15237 594d385d-05f5-0310-b6e9-bd551577e9d8
gosa-plugins/goto/addons/goto/events/class_DaemonEvent.inc | patch | blob | history | |
gosa-plugins/goto/addons/goto/events/class_EventTargetAddList.inc | patch | blob | history | |
gosa-plugins/goto/addons/goto/events/eventTargetSystems-filter.tpl | [new file with mode: 0644] | patch | blob |
gosa-plugins/goto/addons/goto/events/eventTargetSystems-filter.xml | [new file with mode: 0644] | patch | blob |
gosa-plugins/goto/addons/goto/events/eventTargetSystems-list.tpl | [new file with mode: 0644] | patch | blob |
gosa-plugins/goto/addons/goto/events/eventTargetSystems-list.xml | [new file with mode: 0644] | patch | blob |
diff --git a/gosa-plugins/goto/addons/goto/events/class_DaemonEvent.inc b/gosa-plugins/goto/addons/goto/events/class_DaemonEvent.inc
index ba24adf9d42a45c60433370e100ca05e00263cc6..e0c0b30bdddc6413bf678409d90e32dec7705312 100644 (file)
if($this->target_divlist == NULL){
$this->target_divlist = new EventTargetAddList($this->config,$this);
}
- $this->target_divlist->execute();
$smarty = get_smarty();
- $smarty->assign("divlist",$this->target_divlist->Draw());
+ $smarty->assign("divlist",$this->target_divlist->execute());
return($smarty->fetch(get_template_path('target_list.tpl', TRUE, dirname(__FILE__))));
}
diff --git a/gosa-plugins/goto/addons/goto/events/class_EventTargetAddList.inc b/gosa-plugins/goto/addons/goto/events/class_EventTargetAddList.inc
index fbc32992a6d6002d76e247c681697b9f469da445..e0f8e6db060b88f3c1872be145cc44a8168ed5b4 100644 (file)
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-class EventTargetAddList extends MultiSelectWindow
+class EventTargetAddList extends management
{
- public $display_server = TRUE;
- public $display_workstation = TRUE;
- public $display_ogroup = TRUE;
- public $filter_iprange = FALSE;
+ // Tab definition
+ protected $skipFooter = TRUE;
+ protected $skipHeader = TRUE;
- public $regex = "*";
- public $ipfrom = "0.0.0.0";
- public $ipto = "*";
- public $_target_list = array();
-
- public $workstation_list = array();
- public $server_list = array();
-
-
- function __construct(&$config,$parent)
+ function __construct($config,$ui)
{
- MultiSelectWindow::MultiSelectWindow($config, "EventTargetAddList",
- array("server",
- "workstation",
- "ogroups"));
-
- $this->parent = $parent;
- $this->ui = get_userinfo();
-
-
- $this->target_divlist = new MultiSelectWindow($this->config,"EventAddTargedtList","gotomasses");
- $this->SetSummary(_("Targets"));
- $this->EnableCloseButton(FALSE);
- $this->EnableSaveButton(FALSE);
-
- $this->SetInformation(_("This dialog shows all available targets for the event. Check the targets you want to add and use the 'Apply' button."));
-
- /* Toggle all selected / deselected */
- $chk = "<input type='checkbox' id='select_all' name='select_all'
- onClick='toggle_all_(\"^item_selected_[0-9]*$\",\"select_all\");' >";
-
- $this->EnableAplhabet(TRUE);
-
- /* set Page header */
- $this->AddHeader(array("string"=> $chk, "attach"=>"style='width:20px;'"));
- $this->AddHeader(array("string"=>" ","attach"=>"style='width:20px;'"));
- $this->AddHeader(array("string"=>_("System / Department")));
-
- //$name,$string,$value,$conn,$image="images/lists/search.png")
- $this->AddRegex("regex" ,"regex" ,"*" , TRUE);
- $this->AddRegex("ipfrom","ipfrom" ,"0.0.0.0" , FALSE);
- $this->AddRegex("ipto" ,"ipto" ,"255.255.255.255" , FALSE);
-
- $this->AddCheckBox("display_server","1" ,_("Display server"),TRUE);
- $this->AddCheckBox("display_workstation","1",_("Display workstation"),TRUE);
- $this->AddCheckBox("display_ogroup","1" ,_("Display object groups"),TRUE);
- $this->AddCheckBox("filter_iprange","1" ,_("Filter by IP range"),FALSE);
-
-
-
- /* Create a list of servers
- */
- $tmp = get_sub_list("(&(macAddress=*)(objectClass=goServer))",
- "server",get_ou("serverRDN"),$config->current['BASE'],
- array("cn","objectClass","description","ipHostNumber","macAddress"),GL_SUBSEARCH);
- foreach($tmp as $server){
- $this->server_list[$server['dn']] = $server;
- }
-
- /* Create a list of workstations
- */
- $tmp = get_sub_list("(&(macAddress=*)(objectClass=gotoWorkstation))",
- "server",get_ou("workstationRDN"),$config->current['BASE'],
- array("cn","objectClass","description","ipHostNumber","macAddress"),GL_SUBSEARCH);
- foreach($tmp as $server){
- $this->workstation_list[$server['dn']] = $server;
- }
-
- }
-
-
- function execute()
- {
- $this->ClearElementsList();
- $this->AddDepartments($this->selectedBase,2,1);
- $this->setEntries();
- $this->GenHeader();
- }
-
-
- function GenHeader()
- {
- $modules = array("server","workstation");
-
- /* Add base */
- $tmp = array();
- $base = $this->config->current['BASE'];
- $tmp[] = array("dn"=>$this->config->current['BASE']);
- $tmp= array_merge($tmp,get_list("(&(|(ou=*)(description=*))(objectClass=gosaDepartment))", $modules, $base,
- array("ou", "description"), GL_SIZELIMIT | GL_SUBSEARCH));
-
- $deps = array();
- foreach($tmp as $tm){
- $deps[$tm['dn']] = $tm['dn'];
- }
-
- $department = $departments = array();
- $ui= get_userinfo();
- $d = $ui->get_module_departments($modules);
- foreach($d as $department){
- $departments[$department] = $department;
- }
-
- /* Load possible departments */
- $ids = $this->config->idepartments;
- $first = "";
- $found = FALSE;
- $options = array();
- foreach($ids as $dep => $name){
- if(isset($deps[$dep]) && in_array_ics($dep, $departments)){
-
- /* Keep first base dn in mind, we could need this
- * info if no valid base was found
- */
- if(empty($first)) {
- $first = $dep['dn'];
- }
-
- $value = $ids[$dep];
- if ($this->selectedBase == $dep){
- $found = TRUE;
- $options.= "<option selected='selected' value='".$dep."'>$value</option>";
- } else {
- $options.= "<option value='".$dep."'>$value</option>";
- }
- }
- }
-
- $listhead = $this->get_default_header();
-
- /* Add base selection */
- $listhead .= _("Base")." <select name='CurrentMainBase' onChange='mainform.submit()' class='center'>$options</select>".
- " <input class='center' type='image' src='images/lists/submit.png' align='middle'
- title='"._("Submit department")."' name='submit_department' alt='". _("Submit")."'> ";
-
- $this->SetListHeader($listhead);
-
+ $this->config = $config;
+ $this->ui = $ui;
+ $this->storagePoints = array(
+ get_ou("serverRDN"),
+ get_ou("workstationRDN"),
+ get_ou('terminalRDN'));
+
+# // Build filter
+# if (session::global_is_set(get_class($this)."_filter")){
+# $filter= session::global_get(get_class($this)."_filter");
+# } else {
+ $filter = new filter(get_template_path("../../addons/goto/events/eventTargetSystems-filter.xml", TRUE));
+ $filter->setObjectStorage($this->storagePoints);
+# }
+ $this->setFilter($filter);
+
+ // Build headpage
+ $headpage = new listing(get_template_path("../../addons/goto/events/eventTargetSystems-list.xml", TRUE));
+ $headpage->setFilter($filter);
+ parent::__construct($config, $ui, "object", $headpage);
}
-
- function get_selected_targets()
- {
- $a_targets = array();
- foreach($this->list_get_selected_items() as $id){
- if(in_array("gosaGroupOfNames",$this->_target_list[$id]['objectClass'])){
- foreach($this->_target_list[$id]['member'] as $mem_dn){
- if(isset($this->workstation_list[$mem_dn])){
- $a_targets[] = $this->workstation_list[$mem_dn]['macAddress'][0];
- }
- if(isset($this->server_list[$mem_dn])){
- $a_targets[] = $this->server_list[$mem_dn]['macAddress'][0];
- }
- }
- }else{
- if(isset($this->_target_list[$id]['macAddress'][0])){
- $a_targets[] = $this->_target_list[$id]['macAddress'][0];
- }
- }
- }
- return($a_targets);
+ function save_object() {}
+ function Draw(){
+
}
-
- function setEntries()
+ function execute()
{
- $_target_list = array();
- if($this->display_server){
- $_target_list = array_merge($_target_list,
- get_list("(&(cn=".$this->regex.")(objectClass=goServer))",
- "server",get_ou("serverRDN").$this->selectedBase,
- array("cn","objectClass","description","ipHostNumber","macAddress"),GL_NONE));
- }
- if($this->display_workstation){
- $_target_list = array_merge($_target_list,
- get_list("(&(cn=".$this->regex.")(objectClass=gotoWorkstation))",
- "workstation",get_ou("workstationRDN").$this->selectedBase,
- array("cn","objectClass","description","ipHostNumber","macAddress"),GL_NONE));
- }
- if($this->display_ogroup){
- $_target_list = array_merge($_target_list,
- get_list("(&(cn=".$this->regex.")(member=*)(objectClass=gosaGroupOfNames))",
- "ogroups",get_ou("ogroupRDN").$this->selectedBase,
- array("cn","objectClass","description","member"),GL_NONE));
- }
- $this->_target_list = $_target_list;
-
- $tmp = array();
- foreach($this->_target_list as $key => $object){
- $tmp[$key] = $object['cn'][0];
- }
- natcasesort($tmp);
-
- foreach($tmp as $key => $obj){
-
- $obj = $this->_target_list[$key];
- $name = $obj['cn'][0];
- if(isset($obj['description'])){
- $name .= " [".$obj['description'][0]."]";
- }
- if(isset($obj['macAddress'])){
- $name .= " - ".$obj['macAddress'][0]."";
- }
- if(isset($obj['ipHostNumber'])){
- $name .= " - ".$obj['ipHostNumber'][0]."";
- }
-
- $img ="";
- if(in_array("goServer",$obj['objectClass'])){
- $img = '<img class="center" src="plugins/systems/images/select_server.png" alt="S" title="'._("Server").'">';
-
- if($this->filter_iprange){
- if(!isset($obj['ipHostNumber']) || !tests::is_in_ip_range($this->ipfrom,$this->ipto, $obj['ipHostNumber'][0])) {
- continue;
- }
- }
- if(!isset($this->server_list[$obj['dn']])){
- continue;
- }
- }elseif(in_array("gotoWorkstation",$obj['objectClass'])){
- $img = '<img class="center" src="plugins/systems/images/select_workstation.png" alt="W" title="'._("Workstation").'">';
- if($this->filter_iprange){
- if(!isset($obj['ipHostNumber']) || !tests::is_in_ip_range($this->ipfrom,$this->ipto,$obj['ipHostNumber'][0])) {
- continue;
- }
- }
- if(!isset($this->workstation_list[$obj['dn']])){
- continue;
- }
- }elseif(in_array("gosaGroupOfNames",$obj['objectClass'])){
- $img = '<img class="center" src="plugins/ogroups/images/select_ogroup.png" alt="O" title="'._("Object group").'">';
- }
-
- $field1 = array("string" => "<input type='checkbox' id='item_selected_".$key."' name='item_selected_".$key."'>",
- "attach" => "style='width:20px;'");
- $field2 = array("string" => $img,
- "attach" => "style='width:20px;'");
- $field3 = array("string" => $name , "attach" => "title='".$obj['dn']."'");
- $this->AddElement(array($field1,$field2,$field3));
- }
+ $str = management::execute();
+ $str.= "<p class='separator'> </p>
+ <p style=\"text-align:right\">
+ <input type=submit name=\"SaveMultiSelectWindow\" value=\"".msgPool::okButton()."\">
+
+ <input type=submit name=\"CloseMultiSelectWindow\" value=\"".msgPool::cancelButton()."\">
+ </p>";
+ return($str);
}
-
- /*! \brief Returns a set of elements selected in a MultiSelectWindow
- @return Array[integer]=integer
- */
- protected function list_get_selected_items()
+ function save()
{
- $ids = array();
- foreach($_POST as $name => $value){
- if(preg_match("/^item_selected_[0-9]*$/",$name)){
- $id = preg_replace("/^item_selected_/","",$name);
- $ids[$id] = $id;
- }
+ $act = $this->detectPostActions();
+ $headpage = $this->getHeadpage();
+ if(!isset($act['targets'])) return(array());
+ $ret = array();
+ foreach($act['targets'] as $dn){
+ $ret[] = $headpage->getEntry($dn);
}
- return($ids);
+ return($ret);
}
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
diff --git a/gosa-plugins/goto/addons/goto/events/eventTargetSystems-filter.tpl b/gosa-plugins/goto/addons/goto/events/eventTargetSystems-filter.tpl
--- /dev/null
@@ -0,0 +1,38 @@
+<div class="contentboxh">
+ <p class="contentboxh">
+ <img src="images/launch.png" align="right" alt="[F]">{t}Filter{/t}
+ </p>
+</div>
+
+<div class="contentboxb">
+
+<div style="border-top:1px solid #AAAAAA"></div>
+
+ {$SERVER} <LABEL for='SERVER'>{t}Show servers{/t}</LABEL><br>
+ {$WORKSTATION} <LABEL for='WORKSTATION'>{t}Show workstations{/t}</LABEL><br>
+ {$TERMINAL} <LABEL for='TERMINAL'>{t}Show terminals{/t}</LABEL><br>
+
+ <div style="border-top:1px solid #AAAAAA"></div>
+ {$SCOPE}
+
+ <table summary="" style="width:100%;border-top:1px solid #B0B0B0;">
+ <tr>
+ <td>
+ <label for="NAME">
+ <img src="images/lists/search.png" align=middle> Name
+ </label>
+ </td>
+ <td>
+ {$NAME}
+ </td>
+ </tr>
+ </table>
+
+ <table summary="" width="100%" style="background:#EEEEEE;border-top:1px solid #B0B0B0;">
+ <tr>
+ <td width="100%" align="right">
+ {$APPLY}
+ </td>
+ </tr>
+ </table>
+</div>
diff --git a/gosa-plugins/goto/addons/goto/events/eventTargetSystems-filter.xml b/gosa-plugins/goto/addons/goto/events/eventTargetSystems-filter.xml
--- /dev/null
@@ -0,0 +1,64 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<filterdef>
+ <definition>
+ <category>server</category>
+ <template>../../addons/goto/events/eventTargetSystems-filter.tpl</template>
+ <initial>true</initial>
+ </definition>
+
+ <search>
+ <query>
+ <backend>LDAP</backend>
+ <filter>(&(|$SERVER $WORKSTATION $TERMINAL ) $NAME)</filter>
+ <attribute>dn</attribute>
+ <attribute>objectClass</attribute>
+ <attribute>cn</attribute>
+ <attribute>description</attribute>
+ </query>
+ <scope>auto</scope>
+ </search>
+
+ <element>
+ <type>textfield</type>
+ <tag>NAME</tag>
+ <size>20</size>
+ <maxlength>60</maxlength>
+ <default></default>
+ <unset></unset>
+ <set>(cn=*$*)</set>
+ <alphabet>true</alphabet>
+ <autocomplete>
+ <backend>LDAP</backend>
+ <filter>(cn=*$NAME*)</filter>
+ <attribute>cn</attribute>
+ <frequency>0.5</frequency>
+ <characters>3</characters>
+ </autocomplete>
+ </element>
+
+ <element>
+ <type>checkbox</type>
+ <tag>SERVER</tag>
+ <default>true</default>
+ <set>(objectClass=goServer)</set>
+ <unset></unset>
+ </element>
+
+ <element>
+ <type>checkbox</type>
+ <tag>WORKSTATION</tag>
+ <default>true</default>
+ <unset></unset>
+ <set>(objectClass=gotoWorkstation)</set>
+ </element>
+
+ <element>
+ <type>checkbox</type>
+ <tag>TERMINAL</tag>
+ <default>true</default>
+ <unset></unset>
+ <set>(objectClass=gotoTerminal)</set>
+ </element>
+
+</filterdef>
diff --git a/gosa-plugins/goto/addons/goto/events/eventTargetSystems-list.tpl b/gosa-plugins/goto/addons/goto/events/eventTargetSystems-list.tpl
--- /dev/null
@@ -0,0 +1,31 @@
+<input type='image' src='images/empty.png' name='no_action_posted' value='do_nothing' alt='' style='width:2px;height:2px;'>
+
+<table summary="" style="width:100%; vertical-align:top; text-align:left;" cellpadding=2>
+ <tr>
+ <td style="vertical-align:top; width:50%;">
+ <div class="contentboxh">
+ <p class="contentboxh"> {$HEADLINE} {$SIZELIMIT}</p>
+ </div>
+
+ <div class="contentboxb">
+ <div style='background:white;padding:0px;padding:3px;'>
+ <table><tr>
+ <td>{$ROOT} </td><td>{$BACK} </td><td>{$HOME} </td><td>{$RELOAD} </td><td>{$SEPARATOR} </td><td>{t}Base{/t} {$BASE} <input class='center' type='image' src='images/lists/submit.png' align='middle' title='{t}Update{/t}' name='submit_department' alt='{t}Submit{/t}'> </td><td>{$SEPARATOR} </td><td><img src='images/rocket.png' alt='' class='center'></td><td> {$ACTIONS}</td>
+ </tr></table>
+ </div>
+ </div>
+
+ <div style='height:4px;'>
+ </div>
+
+ <input type="hidden" id="d_save" value="450">
+ <input type="hidden" id="d_space" value="760">
+ {$LIST}
+ </td>
+ <td style='vertical-align:top'>
+ {$FILTER}
+ </td>
+ </tr>
+</table>
+
+<input type="hidden" name="ignore">
diff --git a/gosa-plugins/goto/addons/goto/events/eventTargetSystems-list.xml b/gosa-plugins/goto/addons/goto/events/eventTargetSystems-list.xml
--- /dev/null
@@ -0,0 +1,79 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<list>
+ <definition>
+ <departmentBrowser>true</departmentBrowser>
+ <departmentRootVisible>false</departmentRootVisible>
+ <baseMode>true</baseMode>
+ <multiSelect>true</multiSelect>
+ <template>../../addons/goto/events/eventTargetSystems-list.tpl</template>
+ <module>server</module>
+ <label>List of systems</label>
+ <defaultSortColumn>1</defaultSortColumn>
+
+ <objectType>
+ <label>Server</label>
+ <objectClass>goServer</objectClass>
+ <category>server</category>
+ <class>servgeneric</class>
+ <image>plugins/systems/images/select_server.png</image>
+ </objectType>
+
+ <objectType>
+ <label>Workstation</label>
+ <objectClass>gotoWorkstation</objectClass>
+ <category>workstation</category>
+ <class>workgeneric</class>
+ <image>plugins/systems/images/select_workstation.png</image>
+ </objectType>
+
+ <objectType>
+ <label>Terminal</label>
+ <objectClass>gotoTerminal</objectClass>
+ <category>terminal</category>
+ <class>termgeneric</class>
+ <image>plugins/systems/images/select_terminal.png</image>
+ </objectType>
+
+ </definition>
+
+ <table>
+ <layout>|20px;c|220px||</layout>
+
+ <department>
+ <value>%{filter:objectType(dn,objectClass)}</value>
+ </department>
+
+ <department>
+ <value>%{filter:departmentLink(row,dn,description)}</value>
+ <span>1</span>
+ </department>
+
+ <column>
+ <value>%{filter:objectType(dn,objectClass)}</value>
+ </column>
+
+ <column>
+ <label>Name</label>
+ <sortAttribute>cn</sortAttribute>
+ <sortType>string</sortType>
+ <value>%{cn}</value>
+ <export>true</export>
+ </column>
+
+ <column>
+ <label>Description name</label>
+ <sortAttribute>description</sortAttribute>
+ <sortType>string</sortType>
+ <value>%{description}</value>
+ <export>true</export>
+ </column>
+
+ </table>
+
+ <actionmenu>
+ </actionmenu>
+
+ <actiontriggers snapshot="false" copypaste="false">
+ </actiontriggers>
+</list>