summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 7caa1a5)
raw | patch | inline | side by side (parent: 7caa1a5)
author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Wed, 28 Oct 2009 13:10:05 +0000 (13:10 +0000) | ||
committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Wed, 28 Oct 2009 13:10:05 +0000 (13:10 +0000) |
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@14669 594d385d-05f5-0310-b6e9-bd551577e9d8
gosa-core/include/class_management.inc | patch | blob | history | |
gosa-core/plugins/admin/users/class_userManagement.inc | patch | blob | history |
index c92488c37ef562d8ff9a0eff2968c8ca13ec7f92..6eababcf81ca6ed95ca0ed05d169e90fe236af0e 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;
}
+ /*! \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,$all)
{
$disallowed = array();
$this->dns = array();
- foreach($entry as $dn){
+
+ // 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())
{
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->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";
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())
{
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 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";
* @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.
* ...
if ($tmp->entries_locked()){
return($tmp->display_lock_message());
}
-
+
// Now lock entries.
$tmp->lock_entries($this->ui->dn);
if($tmp->multiple_available()){
*/
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);
}
}
-
+
/*! \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);
}
- 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);
}
}
}
// 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:
diff --git a/gosa-core/plugins/admin/users/class_userManagement.inc b/gosa-core/plugins/admin/users/class_userManagement.inc
index 9a10adf8a2551327afd5d8154f93a87bd7a58eb0..f5f6408b8f58f2f46b62092224728e35354f9966 100644 (file)
* if he wants to use one.
* -> See 'templateContinue' for further handling.
*/
- function newEntry($action="",$target=array(),$all=array())
+ function newEntry($action="",$target=array(),$all=array(), $altTabClass ="", $altTabType = "", $altAclCategory="")
{
// Call parent method, it manages everything, locking, object creation...
}
- function copyPasteHandler($s_action,$s_entry)
+ function copyPasteHandler($action="",$target=array(),$all=array(),
+ $altTabClass ="", $altTabType = "", $altAclCategory="",$altAclPlugin="")
{
$this->cpHandler->lastdn = "";
- $str = management::copyPasteHandler($s_action,$s_entry);
-
+ $str = management::copyPasteHandler($action,$target,$all);
if($this->cpHandler->lastdn != "" && isset($_POST['passwordTodo']) && $_POST['passwordTodo'] == "new"){
$this->pwd_change_queue[] = $this->cpHandler->lastdn;
return($this->handlePasswordQueue());