index c92488c37ef562d8ff9a0eff2968c8ca13ec7f92..a8bd21d8106a3447c4654cf41f917ebb8b79b63c 100644 (file)
public $config = null;
public $ui = null;
- public $plIcon = "";
- public $plDescription = "";
- public $plHeadline = "";
+ // The plugin description
+ public $plugname = "unconfigured";
+ public $plIcon = "unconfigured";
+ public $plDescription = "unconfigured";
+ public $plHeadline = "unconfigured";
- // Protected
+ // The currently used object(s) (e.g. in edit, removal)
protected $dn = "";
protected $dns = array();
- protected $storagePoints = array();
-
+ // The last used object(s).
protected $last_dn = "";
protected $last_dns = array();
- protected $tabClass = "";
- protected $tabType = "";
- protected $aclCategory = "";
- protected $objectName = "";
+ // The common places the displayed objects are stored in. (e.g. array("ou=groups,",".."))
+ protected $storagePoints = array();
+
+ // The tab definitions to use for the current object.
+ protected $tabClass = ""; // e.g. usertabs
+ protected $tabType = ""; // e.g. USERTABS
+ protected $aclCategory = ""; // e.g. users
+ protected $objectName = ""; // e.g. users
+
+ // The opened object.
protected $tabObject = null;
protected $dialogObject = null;
+ // The last opened object.
protected $last_tabObject = null;
protected $last_dialogObject = null;
+ // Whether to display the apply button or not
protected $displayApplyBtn = "";
+
+ // Copy&Paste handler
protected $cpHandler = null;
+
+ // Indicates that we want to paste objects right now.
protected $cpPastingStarted = FALSE;
-
+
+ // The Snapshot handler class.
protected $snapHandler = null;
- // Private
- protected $plugname = "";
+ // The listing handlers
protected $headpage = null;
protected $filter = null;
+
+ // A list of configured actions/events
protected $actions = array();
-
+
function __construct($config,$ui,$plugname, $headpage)
{
$this->plugname = $plugname;
$this->registerAction("apply", "applyChanges");
$this->registerAction("save", "saveChanges");
$this->registerAction("cancel", "cancelEdit");
+ $this->registerAction("cancelDelete", "cancelEdit");
$this->registerAction("remove", "removeEntryRequested");
$this->registerAction("removeConfirmed", "removeEntryConfirmed");
$this->registerAction("saveSnapshot","saveSnapshot");
$this->registerAction("restoreSnapshot","restoreSnapshot");
$this->registerAction("cancelSnapshot","closeDialogs");
-
}
+ /*! \brief Execute this plugin
+ * Handle actions/events, locking, snapshots, dialogs, tabs,...
+ */
function execute()
{
// Ensure that html posts and gets are kept even if we see a 'Entry islocked' dialog.
}
$this->snapHandler->setSnapshotBases($bases);
}
-
+
$this->headpage->update();
$display = $this->headpage->render();
return($this->getHeader().$display);
}
+
+
+ /*! \brief Generates the plugin header which is displayed whenever a tab object is
+ * opened.
+ */
protected function getHeader()
{
if (get_object_info() != ""){
$display= print_header(get_template_path($this->plIcon),_($this->plDescription),
- "<img alt=\"\" class=\"center\" src=\"".get_template_path('images/lists/locked.png')."\">".
- LDAP::fix(get_object_info()));
+ "<img alt=\"\" class=\"center\" src=\"".get_template_path('images/lists/locked.png')."\">".
+ LDAP::fix(get_object_info()));
} else {
$display= print_header(get_template_path($this->plIcon),_($this->plDescription));
}
}
+ /*! \brief Generates the footer which is used whenever a tab object is
+ * displayed.
+ */
protected function _getTabFooter()
- {
+ {
+ // Do not display tab footer for non tab objects
if(!($this->tabObject instanceOf tabs || $this->tabObject instanceOf multi_plug)){
return("");
}
-
+
+ // Check if there is a dialog opened - We don't need any buttons in this case.
if($this->tabObject->by_object[$this->tabObject->current]){
$current = $this->tabObject->by_object[$this->tabObject->current];
if(is_object($current->dialog)){
}
}
+ // In case an of locked entry, we may have opened a read-only tab.
$str = "";
if(isset($this->tabObject->read_only) && $this->tabObject->read_only == TRUE){
$str.= "<p style=\"text-align:right\">
</p>";
return($str);
}else{
+
+ // Display ok, (apply) and cancel buttons
$str.= "<p style=\"text-align:right\">\n";
$str.= "<input type=submit name=\"edit_finish\" style=\"width:80px\" value=\"".msgPool::okButton()."\">\n";
$str.= " \n";
}
- protected function removeEntryRequested($action,$entry,$all)
+ /*! \brief Initiates the removal for the given entries
+ * and displays a confirmation dialog.
+ *
+ * @param String 'action' The name of the action which was the used as trigger.
+ * @param Array 'target' A list of object dns, which should be affected by this method.
+ * @param Array 'all' A combination of both 'action' and 'target'.
+ */
+ protected function removeEntryRequested($action="",$target=array(),$all=array())
{
$disallowed = array();
$this->dns = array();
- foreach($entry as $dn){
+
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$target,"Entry removel requested!");
+
+ // Check permissons for each target
+ foreach($target as $dn){
$acl = $this->ui->get_permissions($dn, $this->aclCategory."/".$this->aclPlugin);
if(preg_match("/d/",$acl)){
$this->dns[] = $dn;
$disallowed[] = $dn;
}
}
-
if(count($disallowed)){
msg_dialog::display(_("Permission"),msgPool::permDelete($disallowed),INFO_DIALOG);
}
+ // We've at least one entry to delete.
if(count($this->dns)){
- /* Check locks */
+ // check locks
if ($user= get_multiple_locks($this->dns)){
return(gen_locked_message($user,$this->dns));
}
+ // Add locks
$dns_names = array();
foreach($this->dns as $dn){
$dns_names[] =LDAP::fix($dn);
}
add_lock ($this->dns, $this->ui->dn);
- /* Lock the current entry, so nobody will edit it during deletion */
+ // Display confirmation dialog.
$smarty = get_smarty();
$smarty->assign("info", msgPool::deleteInfo($dns_names,_($this->objectName)));
$smarty->assign("multiple", true);
}
- protected function removeEntryConfirmed()
+ /*! \brief Object removal was confirmed, now remove the requested entries.
+ *
+ * @param String 'action' The name of the action which was the used as trigger.
+ * @param Array 'target' A list of object dns, which should be affected by this method.
+ * @param Array 'all' A combination of both 'action' and 'target'.
+ */
+ function removeEntryConfirmed($action="",$target=array(),$all=array(),
+ $altTabClass="",$altTabType="",$altAclCategory="")
{
+ $tabType = $this->tabType;
+ $tabClass = $this->tabClass;
+ $aclCategory = $this->aclCategory;
+ if(!empty($altTabClass)) $tabClass = $altTabClass;
+ if(!empty($altTabType)) $tabType = $altTabType;
+ if(!empty($altAclCategory)) $aclCategory = $altAclCategory;
+
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$target,"Entry removel confirmed!");
+
foreach($this->dns as $key => $dn){
- /* Load permissions for selected 'dn' and check if
- we're allowed to remove this 'dn' */
+ // Check permissions, are we allowed to remove this object?
$acl = $this->ui->get_permissions($dn, $this->aclCategory."/".$this->aclPlugin);
if(preg_match("/d/",$acl)){
- /* Delete request is permitted, perform LDAP action */
+ // Delete the object
$this->dn = $dn;
- $tab = $this->tabClass;
- $this->tabObject= new $tab($this->config,$this->config->data['TABS'][$this->tabType], $this->dn, $this->aclCategory);
+ $this->tabObject= new $tabClass($this->config,$this->config->data['TABS'][$tabType], $this->dn, $aclCategory);
$this->tabObject->set_acl_base($this->dn);
$this->tabObject->delete ();
+
+ // Remove the lock for the current object.
del_lock($this->dn);
} else {
-
- /* Normally this shouldn't be reached, send some extra
- logs to notify the administrator */
msg_dialog::display(_("Permission error"), msgPool::permDelete(), ERROR_DIALOG);
new log("security","groups/".get_class($this),$dn,array(),"Tried to trick deletion.");
}
}
+ // Cleanup
$this->remove_lock();
$this->closeDialogs();
}
+ /*! \brief Detects actions/events send by the ui
+ * and the corresponding targets.
+ */
function detectPostActions()
{
$action= $this->headpage->getAction();
-
if(isset($_POST['edit_apply'])) $action['action'] = "apply";
if(isset($_POST['edit_finish'])) $action['action'] = "save";
if(isset($_POST['edit_cancel'])) $action['action'] = "cancel";
if(isset($_POST['delete_confirmed'])) $action['action'] = "removeConfirmed";
+ if(isset($_POST['delete_cancel'])) $action['action'] = "cancelDelete";
// Detect Snapshot actions
if(isset($_POST['CreateSnapshot'])) $action['action'] = "saveSnapshot";
return($action);
}
+
+ /*! \brief Calls the registered method for a given action/event.
+ */
function handleActions($action)
{
// Start action
}
}
+
+ /*! \brief Opens the snapshot creation dialog for the given target.
+ *
+ * @param String 'action' The name of the action which was the used as trigger.
+ * @param Array 'target' A list of object dns, which should be affected by this method.
+ * @param Array 'all' A combination of both 'action' and 'target'.
+ */
function createSnapshotDialog($action="",$target=array(),$all=array())
{
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$target,"Snaptshot creation initiated!");
+
foreach($target as $entry){
if(!empty($entry) && $this->ui->allow_snapshot_create($entry,$this->aclCategory)){
$this->dialogObject = new SnapShotDialog($this->config,$entry,$this);
$this->dialogObject->aclCategories = array($this->aclCategory);
-
+
}else{
msg_dialog::display(_("Permission"),sprintf(_("You are not allowed to create a snapshot for %s."),$entry),
ERROR_DIALOG);
* @param Array 'target' A list of object dns, which should be affected by this method.
* @param Array 'all' A combination of both 'action' and 'target'.
*/
- function saveSnapsho($action="",$target=array(),$all=array())
+ function saveSnapshot($action="",$target=array(),$all=array())
{
$this->dialogObject->save_object();
$msgs = $this->dialogObject->check();
}else{
$this->dn = $this->dialogObject->dn;
$this->snapHandler->create_snapshot( $this->dn,$this->dialogObject->CurrentDescription);
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$this->dn,"Snaptshot created!");
$this->closeDialogs();
}
}
$entry = array_pop($target);
if(!empty($entry) && $this->ui->allow_snapshot_restore($entry,$this->aclCategory)){
$this->snapHandler->restore_snapshot($entry);
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$this->dn,"Snaptshot restored!");
$this->closeDialogs();
}else{
msg_dialog::display(_("Permission"),sprintf(_("You are not allowed to restore a snapshot for %s."),$entry),
if(!count($target)){
$entry = $this->headpage->getBase();
if(!empty($entry) && $this->ui->allow_snapshot_restore($entry,$this->aclCategory)){
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$entry,"Snaptshot restoring initiated!");
$this->dialogObject = new SnapShotDialog($this->config,$entry,$this);
$this->dialogObject->set_snapshot_bases($bases);
$this->dialogObject->display_all_removed_objects = true;
// Display the restore points for a given object.
$entry = array_pop($target);
if(!empty($entry) && $this->ui->allow_snapshot_restore($entry,$this->aclCategory)){
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$entry,"Snaptshot restoring initiated!");
$this->dialogObject = new SnapShotDialog($this->config,$entry,$this);
$this->dialogObject->set_snapshot_bases($bases);
$this->dialogObject->display_restore_dialog = true;
* @param Array 'target' A list of object dns, which should be affected by this method.
* @param Array 'all' A combination of both 'action' and 'target'.
*/
- function newEntry($action="",$target=array(),$all=array(), $altTabClass ="", $altTabType = "", $altAclCategory)
+ function newEntry($action="",$target=array(),$all=array(), $altTabClass ="", $altTabType = "", $altAclCategory="")
{
/* To handle mutliple object types overload this method.
* ...
if(!empty($altTabClass)) $tabClass = $altTabClass;
if(!empty($altTabType)) $tabType = $altTabType;
if(!empty($altAclCategory)) $aclCategory = $altAclCategory;
- {
+
// Check locking & lock entry if required
$this->displayApplyBtn = FALSE;
$this->dn = "new";
}else{
$this->tabObject= new $tabClass($this->config,$this->config->data['TABS'][$tabType], $this->dn, $aclCategory);
$this->tabObject->set_acl_base($this->headpage->getBase());
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$this->dn,"Create new entry initiated!");
}
}
* @param Array 'target' A list of object dns, which should be affected by this method.
* @param Array 'all' A combination of both 'action' and 'target'.
*/
- function editEntry($action="",$target=array(),$all=array(), $altTabClass ="", $altTabType = "", $altAclCategory)
+ function editEntry($action="",$target=array(),$all=array(), $altTabClass ="", $altTabType = "", $altAclCategory="")
{
/* To handle mutliple object types overload this method.
* ...
}else{
$tab = $tabClass;
$this->tabObject= new $tab($this->config,$this->config->data['TABS'][$tabType], $this->dn,$aclCategory);
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$this->dn,"Edit entry initiated!");
$this->tabObject->set_acl_base($this->dn);
}
}else{
if ($tmp->entries_locked()){
return($tmp->display_lock_message());
}
-
+
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$this->dns,"Edit entry initiated!");
+
// Now lock entries.
$tmp->lock_entries($this->ui->dn);
if($tmp->multiple_available()){
return("");
}else{
$this->tabObject->save();
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$this->dns,"Entry saved!");
$this->remove_lock();
$this->closeDialogs();
}
*/
protected function applyChanges()
{
- if($this->tabObject instanceOf tabs || $this->tabObject instanceOf multi_plug){
- $this->tabObject->save_object();
+ if($this->tabObject instanceOf tabs || $this->tabObject instanceOf multi_plug){
+ $this->tabObject->save_object();
$msgs = $this->tabObject->check();
if(count($msgs)){
msg_dialog::displayChecks($msgs);
return("");
}else{
$this->tabObject->save();
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$this->dns,"Modifications applied!");
$this->tabObject->re_init();
}
}
}
-
+
/*! \brief This method closes dialogs
* and cleans up the cached object info and the ui.
*/
$this->closeDialogs();
}
-
+
/*! \brief Every click in the list user interface sends an event
* here can we connect those events to a method.
* eg. ::registerEvent('new','createUser')
$this->actions[$action] = $target;
}
-
+
/*! \brief Removes ldap object locks created by this class.
* Whenever an object is edited, we create locks to avoid
* concurrent modifications.
* @param Array 'target' A list of object dns, which should be affected by this method.
* @param Array 'all' A combination of both 'action' and 'target'.
*/
- function copyPasteHandler($action="",$target=array(),$all=array())
+ function copyPasteHandler($action="",$target=array(),$all=array(),
+ $altTabClass ="", $altTabType = "", $altAclCategory="",$altAclPlugin="")
{
// Return without any actions while copy&paste handler is disabled.
if(!is_object($this->cpHandler)) return("");
+ $tabType = $this->tabType;
+ $tabClass = $this->tabClass;
+ $aclCategory = $this->aclCategory;
+ $aclPlugin = $this->aclPlugin;
+ if(!empty($altTabClass)) $tabClass = $altTabClass;
+ if(!empty($altTabType)) $tabType = $altTabType;
+ if(!empty($altAclCategory)) $aclCategory = $altAclCategory;
+ if(!empty($altAclPlugin)) $aclPlugin = $altAclPlugin;
+
// Save user input
$this->cpHandler->save_object();
// Add entries to queue
- if($s_action == "copy" || $s_action == "cut"){
+ if($action == "copy" || $action == "cut"){
$this->cpHandler->cleanup_queue();
- foreach($s_entry as $dn){
- if($s_action == "copy" && $this->ui->is_copyable($dn,$this->aclCategory,$this->aclPlugin)){
- $this->cpHandler->add_to_queue($dn,"copy",$this->tabClass,$this->tabType,$this->aclCategory);
+ foreach($target as $dn){
+ if($action == "copy" && $this->ui->is_copyable($dn,$aclCategory,$aclPlugin)){
+ $this->cpHandler->add_to_queue($dn,"copy",$tabClass,$tabType,$aclCategory);
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$dn,"Entry copied!");
}
- if($s_action == "cut" && $this->ui->is_cutable($dn,$this->aclCategory,$this->aclPlugin)){
- $this->cpHandler->add_to_queue($dn,"cut",$this->tabClass,$this->tabType,$this->aclCategory);
+ if($action == "cut" && $this->ui->is_cutable($dn,$aclCategory,$aclPlugin)){
+ $this->cpHandler->add_to_queue($dn,"cut",$tabClass,$tabType,$aclCategory);
+ @DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,$dn,"Entry cutted!");
}
}
}
// Initiate pasting
- if($s_action == "paste"){
+ if($action == "paste"){
$this->cpPastingStarted = TRUE;
}
}
+ function setFilter($str) {
+ $this->filter = $str;
+ }
+
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: