summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 0f77152)
raw | patch | inline | side by side (parent: 0f77152)
author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 5 Nov 2009 14:12:30 +0000 (14:12 +0000) | ||
committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 5 Nov 2009 14:12:30 +0000 (14:12 +0000) |
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@14765 594d385d-05f5-0310-b6e9-bd551577e9d8
gosa-core/plugins/admin/ogroups/class_ogroupManagement.inc | patch | blob | history | |
gosa-core/plugins/admin/ogroups/ogroup-list.xml | patch | blob | history |
diff --git a/gosa-core/plugins/admin/ogroups/class_ogroupManagement.inc b/gosa-core/plugins/admin/ogroups/class_ogroupManagement.inc
index 8d329da116fcb03dbc9924b5a8d83bf04fc01679..2debc7f88792e5a417c690422b93325c904b21f2 100644 (file)
$this->registerAction("edit_phonequeue","editEntry");
$this->registerAction("edit_workstartup","editEntry");
$this->registerAction("edit_termgroup","editEntry");
+
+ $this->registerAction("sendMessage", "sendMessage");
+ $this->registerAction("saveEventDialog", "saveEventDialog");
+ $this->registerAction("abortEventDialog", "closeDialogs");
}
+
+ // Inject user actions
+ function detectPostActions()
+ {
+ $action = management::detectPostActions();
+
+ if(isset($_POST['save_event_dialog'])) $action['action'] = "saveEventDialog";
+ if(isset($_POST['abort_event_dialog'])) $action['action'] = "abortEventDialog";
+ return($action);
+ }
+
+
function editEntry($action="",$target=array(),$all=array(), $altTabClass ="", $altTabType = "", $altAclCategory="")
{
management::editEntry($action,$target);
}
}
+
+ /*! \brief Sends a message to a set of users using gosa-si events.
+ */
+ function saveEventDialog()
+ {
+ $this->dialogObject->save_object();
+ $msgs = $this->dialogObject->check();
+ if(count($msgs)){
+ msg_dialog::displayChecks($msgs);
+ }else{
+ $o_queue = new gosaSupportDaemon();
+ $o_queue->append($this->dialogObject);
+ if($o_queue->is_error()){
+ msg_dialog::display(_("Infrastructure error"), msgPool::siError($o_queue->get_error()),ERROR_DIALOG);
+ }
+ $this->closeDialogs();
+ }
+ }
+
+
+ /*! \brief Sends a message to a set of users using gosa-si events.
+ */
+ function sendMessage($action="",$target=array(),$all=array())
+ {
+
+ if(class_available("DaemonEvent_notify")){
+
+ // Resolv targets
+ $targets = array();
+ $m_list = array();
+ $ldap = $this->config->get_ldap_link();
+
+ // Collect selected ogroups
+ foreach($target as $dn){
+ $ldap->cat($dn, array('member'));
+ while ($entry = $ldap->fetch()) {
+ $m_list[] = $entry;
+ }
+ }
+
+ // Collect object group member dns
+ foreach($m_list as $entry){
+ $members = $entry['member'];
+ for($i=0;$i<$members['count'];$i++) {
+
+ // Fetch member object
+ $ldap->cat($members[$i], array('uid','cn','objectClass'));
+ if ($ldap->count() > 0) {
+
+ // Determine which type the object has
+ $attrs = $ldap->fetch();
+ if (array_search('gosaAccount', $attrs['objectClass'])) {
+ $uid = $attrs['uid'][0];
+ $targets['USERS'][] = $uid;
+ }elseif (array_search('posixGroup', $attrs['objectClass'])) {
+ $group = $attrs['cn'][0];
+ $targets['GROUPS'][] = $group;
+ }
+ }
+ }
+ }
+
+ // We've at least one recipient
+ if(count($targets)){
+ $events = DaemonEvent::get_event_types(USER_EVENT);
+ if(isset($events['BY_CLASS']['DaemonEvent_notify'])){
+ $type = $events['BY_CLASS']['DaemonEvent_notify'];
+ $this->dialogObject = new $type['CLASS_NAME']($this->config);
+ $this->dialogObject->add_targets($targets);
+ $this->dialogObject->set_type(TRIGGERED_EVENT);
+ }
+ }
+
+ }
+ }
+
static function filterProperties($row, $gosaGroupObjects)
{
diff --git a/gosa-core/plugins/admin/ogroups/ogroup-list.xml b/gosa-core/plugins/admin/ogroups/ogroup-list.xml
index 27e0432cb94e1fc357a65aa822444729c7f5ce37..2722b29b0cbc3ab36719b14820875bffd89014b0 100644 (file)
<label>Remove</label>
</action>
+ <action>
+ <name>sendMessage</name>
+ <type>entry</type>
+ <depends>DaemonEvent_notify</depends>
+ <image>plugins/goto/images/notify.png</image>
+ <label>Send message</label>
+ </action>
+
+ <action>
+ <type>separator</type>
+ </action>
+
<action>
<type>exporter</type>
</action>