ILIAS  Release_4_4_x_branch Revision 61816
 All Data Structures Namespaces Files Functions Variables Groups Pages
ilObjRoleFolderGUI Class Reference

Class ilObjRoleFolderGUI. More...

+ Inheritance diagram for ilObjRoleFolderGUI:
+ Collaboration diagram for ilObjRoleFolderGUI:

Public Member Functions

 ilObjRoleFolderGUI ($a_data, $a_id, $a_call_by_reference)
 Constructor public.
 executeCommand ()
 execute command
 viewObject ()
 ilErrorHandler $ilErr ilRbacSystem $rbacsystem ilToolbarGUI $ilToolbar
 resetFilterObject ()
 Reset role filter.
 createObject ()
 role folders are created automatically DEPRECATED !!! public
 deleteObject ()
 display deletion confirmation screen DEPRECATED !!! public
 adoptPermSaveObject ()
 ??? TODO: what is the purpose of this function? public
 showPossibleSubObjects ($a_tpl)
 show possible subobjects (pulldown menu) overwritten to prevent displaying of role templates in local role folders
 saveObject ()
 save object public
 getAdminTabs (&$tabs_gui)
 Add role folder tabs ilTree $tree ilLanguage $lng.
 editSettingsObject (ilPropertyFormGUI $a_form=null)
 saveSettingsObject ()
 addToExternalSettingsForm ($a_form_id)
- Public Member Functions inherited from ilObjectGUI
 ilObjectGUI ($a_data, $a_id=0, $a_call_by_reference=true, $a_prepare_output=true)
 Constructor public.
 withReferences ()
 determines wether objects are referenced or not (got ref ids or not)
 setCreationMode ($a_mode=true)
 if true, a creation screen is displayed the current $_GET[ref_id] don't belong to the current class! the mode is determined in ilrepositorygui
 getCreationMode ()
 get creation mode
 getHTML ()
 confirmedDeleteObject ()
 confirmed deletion of object -> objects are moved to trash or deleted immediately, if trash is disabled
 cancelDeleteObject ()
 cancel deletion of object
 cancelObject ($in_rep=false)
 cancel action and go back to previous page public
 cancelCreation ()
 cancel create action and go back to repository parent
 editObject ()
 edit object
 updateObject ()
 updates object entry in object_data
 getFormAction ($a_cmd, $a_formaction="")
 get form action for command (command is method name without "Object", e.g.
 isVisible ($a_ref_id, $a_type)
 deleteObject ($a_error=false)
 Display deletion confirmation screen.
 cloneAllObject ()
 Clone single (not container object) Method is overwritten in ilContainerGUI.

Data Fields

 $type
- Data Fields inherited from ilObjectGUI
const COPY_WIZARD_NEEDS_PAGE = 1
 $ilias
 $objDefinition
 $tpl
 $tree
 $lng
 $data
 $object
 $ref_id
 $obj_id
 $maxcount
 $formaction
 $return_location
 $target_frame
 $tab_target_script
 $actions
 $sub_objects
 $omit_locator = false
const CFORM_NEW = 1
const CFORM_IMPORT = 2
const CFORM_CLONE = 3

Protected Member Functions

 roleSearchObject ()
 Search target roles.
 initRoleSearchForm ()
 Init role search form.
 roleSearchFormObject ()
 Parse search query type $ilCtrl.
 roleSearchListObject ()
 List roles.
 chooseCopyBehaviourObject ()
 Chosse change existing objects,...
 initCopyBehaviourForm ()
 Show copy behaviour form.
 copyRoleObject ()
 Copy role.
 addRolePermissionsObject ()
 Add role permissions.
 doAddRolePermissions ($source, $target, $change_existing)
 do add role permission
 removeRolePermissionsObject ()
 Remove role permissions.
 doRemoveRolePermissions ($source, $target, $change_existing)
 do add role permission
 doCopyRole ($source, $target, $change_existing)
 Perform copy of role ilTree $tree <type> $rbacadmin <type> $rbacreview.
 applyFilterObject ()
 Apply role filter.
 confirmDeleteObject ()
 Confirm deletion of roles.
 deleteRoleObject ()
 Delete roles.
 initSettingsForm ()
- Protected Member Functions inherited from ilObjectGUI
 assignObject ()
 prepareOutput ()
 prepare output
 setTitleAndDescription ()
 called by prepare output
 initHeaderAction ($a_sub_type=null, $a_sub_id=null)
 Add header action menu.
 insertHeaderAction ($a_list_gui)
 Insert header action into main template.
 addHeaderAction ()
 Add header action menu.
 redrawHeaderActionObject ()
 Ajax call: redraw action header only.
 showMountWebfolderIcon ()
 setTabs ()
 set admin tabs public
 setAdminTabs ()
 set admin tabs public
 setLocator ()
 set Locator
 addLocatorItems ()
 should be overwritten to add object specific items (repository items are preloaded)
 omitLocator ($a_omit=true)
 addAdminLocatorItems ($a_do_not_add_object=false)
 should be overwritten to add object specific items (repository items are preloaded)
 initCreationForms ($a_new_type)
 Init creation froms.
 getCreationFormsHTML (array $a_forms)
 Get HTML for creation forms (accordion)
 initCreateForm ($a_new_type)
 Init object creation form.
 initDidacticTemplate (ilPropertyFormGUI $form)
 Show didactic template types.
 addDidacticTemplateOptions (array &$a_options)
 Add custom templates.
 getDidacticTemplateVar ($a_type)
 Get didactic template setting from creation screen.
 putObjectInTree (ilObject $a_obj, $a_parent_node_id=null)
 Add object to tree at given position.
 afterSave (ilObject $a_new_object)
 Post (successful) object creation hook.
 initEditForm ()
 Init object edit form.
 initEditCustomForm (ilPropertyFormGUI $a_form)
 Add custom fields to update form.
 getEditFormValues ()
 Get values for edit form.
 getEditFormCustomValues (array &$a_values)
 Add values to custom edit fields.
 updateCustom (ilPropertyFormGUI $a_form)
 Insert custom update form values into object.
 afterUpdate ()
 Post (successful) object update hook.
 initImportForm ($a_new_type)
 Init object import form.
 importFileObject ($parent_id=null)
 Import.
 afterImport (ilObject $a_new_object)
 Post (successful) object import hook.
 setFormAction ($a_cmd, $a_formaction)
 set specific form action for command
 getReturnLocation ($a_cmd, $a_location="")
 get return location for command (command is method name without "Object", e.g.
 setReturnLocation ($a_cmd, $a_location)
 set specific return location for command
 getTargetFrame ($a_cmd, $a_target_frame="")
 get target frame for command (command is method name without "Object", e.g.
 setTargetFrame ($a_cmd, $a_target_frame)
 set specific target frame for command
 showPossibleSubObjects ()
 show possible subobjects (pulldown menu)
 getTemplateFile ($a_cmd, $a_type="")
 get a template blockfile format: tpl.
 getTitlesByRefId ($a_ref_ids)
 get Titles of objects this method is used for error messages in methods cut/copy/paste
 getTabs (&$tabs_gui)
 get tabs abstract method.
 __showButton ($a_cmd, $a_text, $a_target= '')
 hitsperpageObject ()
__initTableGUI ()
 __setTableGUIBasicData (&$tbl, &$result_set, $a_from="")
 standard implementation for tables use 'from' variable use different initial setting of table
 redirectToRefId ($a_ref_id, $a_cmd="")
 redirects to (repository) view per ref id usually to a container and usually used at the end of a save/import method where the object gui type (of the new object) doesn't match with the type of the current $_GET["ref_id"] value
 fillCloneTemplate ($a_tpl_varname, $a_type)
 Fill object clone template This method can be called from any object GUI class that wants to offer object cloning.
 getCenterColumnHTML ()
 Get center column.
 getRightColumnHTML ()
 Display right column.
 setColumnSettings ($column_gui)
 May be overwritten in subclasses.
 checkPermission ($a_perm, $a_cmd="", $a_type="", $a_ref_id=null)
 Check permission and redirect on error.
 checkPermissionBool ($a_perm, $a_cmd="", $a_type="", $a_ref_id=null)
 Check permission.
 enableDragDropFileUpload ()
 Enables the file upload into this object by dropping files.
 handleAutoRating (ilObject $a_new_obj)
 Activate rating automatically if parent container setting.

Additional Inherited Members

- Static Public Member Functions inherited from ilObjectGUI
static _gotoRepositoryRoot ($a_raise_error=false)
 Goto repository root.
static _gotoRepositoryNode ($a_ref_id, $a_cmd="frameset")
 Goto repository root.

Detailed Description

Member Function Documentation

ilObjRoleFolderGUI::addRolePermissionsObject ( )
protected

Add role permissions.

Definition at line 332 of file class.ilObjRoleFolderGUI.php.

References $_POST, $_REQUEST, $ilCtrl, doAddRolePermissions(), initCopyBehaviourForm(), and ilUtil\sendSuccess().

{
global $ilCtrl;
// Finally copy role/rolt
$roles = explode(',',$_POST['roles']);
$source = (int) $_REQUEST['copy_source'];
$form = $this->initCopyBehaviourForm();
if($form->checkInput())
{
foreach((array) $roles as $role_id)
{
if($role_id != $source)
{
$this->doAddRolePermissions($source,$role_id,$form->getInput('change_existing'));
}
}
ilUtil::sendSuccess($this->lng->txt('rbac_copy_finished'),true);
$ilCtrl->redirect($this,'view');
}
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::addToExternalSettingsForm (   $a_form_id)

Definition at line 817 of file class.ilObjRoleFolderGUI.php.

References ilPrivacySettings\_getInstance(), ilSecuritySettings\_getInstance(), ilAdministrationSettingsFormHandler\FORM_PRIVACY, ilAdministrationSettingsFormHandler\FORM_SECURITY, and ilAdministrationSettingsFormHandler\VALUE_BOOL.

{
switch($a_form_id)
{
include_once('./Services/PrivacySecurity/classes/class.ilSecuritySettings.php');
$fields = array('adm_adm_role_protect' => array($security->isAdminRoleProtected(), ilAdministrationSettingsFormHandler::VALUE_BOOL));
return array(array("editSettings", $fields));
include_once('./Services/PrivacySecurity/classes/class.ilPrivacySettings.php');
$subitems = null;
if((bool)$privacy->enabledRbacLog())
{
$subitems = array('rbac_log_age' => $privacy->getRbacLogAge());
}
$fields = array('rbac_log' => array($privacy->enabledRbacLog(), ilAdministrationSettingsFormHandler::VALUE_BOOL, $subitems));
return array(array("editSettings", $fields));
}
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::adoptPermSaveObject ( )

??? TODO: what is the purpose of this function? public

Definition at line 603 of file class.ilObjRoleFolderGUI.php.

References ilUtil\sendSuccess().

{
ilUtil::sendSuccess($this->lng->txt("saved_successfully"),true);
$this->ctrl->redirect($this, "view");
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::applyFilterObject ( )
protected

Apply role filter.

Definition at line 472 of file class.ilObjRoleFolderGUI.php.

References viewObject().

{
include_once './Services/AccessControl/classes/class.ilRoleTableGUI.php';
$table = new ilRoleTableGUI($this,'view');
$table->init();
$table->resetOffset();
$table->writeFilterToSession();
$this->viewObject();
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::chooseCopyBehaviourObject ( )
protected

Chosse change existing objects,...

Definition at line 241 of file class.ilObjRoleFolderGUI.php.

References $_REQUEST, $GLOBALS, $ilCtrl, and initCopyBehaviourForm().

{
global $ilCtrl, $ilTabs;
$ilTabs->clearTargets();
$ilTabs->setBackTarget(
$this->lng->txt('rbac_back_to_overview'),
$this->ctrl->getLinkTarget($this,'roleSearchList')
);
$GLOBALS['ilLog']->write(__METHOD__.': '.$_REQUEST['copy_source']);
$ilCtrl->setParameter($this,'copy_source',(int) $_REQUEST['copy_source']);
$form = $this->initCopyBehaviourForm();
$this->tpl->setContent($form->getHTML());
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::confirmDeleteObject ( )
protected

Confirm deletion of roles.

Definition at line 500 of file class.ilObjRoleFolderGUI.php.

References $_POST, $ilCtrl, ilObjRole\_getTranslation(), ilObject\_lookupTitle(), and ilUtil\sendFailure().

{
global $ilCtrl;
if(!count($_POST['roles']))
{
ilUtil::sendFailure($this->lng->txt('select_one'),true);
$ilCtrl->redirect($this,'view');
}
$question = $this->lng->txt('rbac_role_delete_qst');
include_once './Services/Utilities/classes/class.ilConfirmationGUI.php';
$confirm = new ilConfirmationGUI();
$confirm->setHeaderText($question);
$confirm->setFormAction($ilCtrl->getFormAction($this));
$confirm->setHeaderText($this->lng->txt("info_delete_sure"));
$confirm->setConfirm($this->lng->txt('delete'), 'deleteRole');
$confirm->setCancel($this->lng->txt('cancel'), 'cancel');
include_once './Services/AccessControl/classes/class.ilObjRole.php';
foreach($_POST['roles'] as $role_id)
{
$confirm->addItem(
'roles[]',
$role_id,
);
}
$this->tpl->setContent($confirm->getHTML());
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::copyRoleObject ( )
protected

Copy role.

Definition at line 305 of file class.ilObjRoleFolderGUI.php.

References $_POST, $_REQUEST, $ilCtrl, doCopyRole(), initCopyBehaviourForm(), and ilUtil\sendSuccess().

{
global $ilCtrl;
// Finally copy role/rolt
$roles = explode(',',$_POST['roles']);
$source = (int) $_REQUEST['copy_source'];
$form = $this->initCopyBehaviourForm();
if($form->checkInput())
{
foreach((array) $roles as $role_id)
{
if($role_id != $source)
{
$this->doCopyRole($source,$role_id,$form->getInput('change_existing'));
}
}
ilUtil::sendSuccess($this->lng->txt('rbac_copy_finished'),true);
$ilCtrl->redirect($this,'view');
}
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::createObject ( )

role folders are created automatically DEPRECATED !!! public

Reimplemented from ilObjectGUI.

Definition at line 576 of file class.ilObjRoleFolderGUI.php.

{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
/*
$this->object->setTitle($this->lng->txt("obj_".$this->object->getType()."_local"));
$this->object->setDescription("obj_".$this->object->getType()."_local_desc");
$this->saveObject();
*/
}
ilObjRoleFolderGUI::deleteObject ( )

display deletion confirmation screen DEPRECATED !!! public

Definition at line 593 of file class.ilObjRoleFolderGUI.php.

{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
ilObjRoleFolderGUI::deleteRoleObject ( )
protected

Delete roles.

Definition at line 536 of file class.ilObjRoleFolderGUI.php.

References $_POST, $ilCtrl, $ilErr, ilObjectFactory\getInstanceByObjId(), and ilUtil\sendSuccess().

{
global $rbacsystem,$ilErr,$rbacreview,$ilCtrl;
if(!$rbacsystem->checkAccess('delete',$this->object->getRefId()))
{
$ilErr->raiseError(
$this->lng->txt('msg_no_perm_delete'),
$ilErr->MESSAGE
);
}
foreach((array) $_POST['roles'] as $id)
{
// instatiate correct object class (role or rolt)
if ($obj->getType() == "role")
{
$rolf_arr = $rbacreview->getFoldersAssignedToRole($obj->getId(),true);
$obj->setParent($rolf_arr[0]);
}
$obj->delete();
}
// set correct return location if rolefolder is removed
ilUtil::sendSuccess($this->lng->txt("msg_deleted_roles_rolts"),true);
$ilCtrl->redirect($this,'view');
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::doAddRolePermissions (   $source,
  $target,
  $change_existing 
)
protected

do add role permission

Definition at line 359 of file class.ilObjRoleFolderGUI.php.

Referenced by addRolePermissionsObject().

{
global $rbacadmin, $rbacreview;
$rbacadmin->copyRolePermissionUnion(
$source,
$this->object->getRefId(),
$target,
$rbacreview->getRoleFolderOfRole($target),
$target,
$rbacreview->getRoleFolderOfRole($target)
);
}

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::doCopyRole (   $source,
  $target,
  $change_existing 
)
protected

Perform copy of role ilTree $tree <type> $rbacadmin <type> $rbacreview.

Parameters
<type>$source
<type>$target
<type>$change_existing
Returns
<type>

Definition at line 427 of file class.ilObjRoleFolderGUI.php.

References ilObjectGUI\$tree, ilObjRole\MODE_PROTECTED_DELETE_LOCAL_POLICIES, and ilObjRole\MODE_UNPROTECTED_DELETE_LOCAL_POLICIES.

Referenced by copyRoleObject().

{
global $tree, $rbacadmin, $rbacreview;
$target_rolf = $rbacreview->getRoleFolderOfRole($target);
// Copy role template permissions
$rbacadmin->copyRoleTemplatePermissions(
$source,
$this->object->getRefId(),
$target_rolf,
$target
);
if(!$change_existing || !$target_rolf)
{
return true;
}
$start = $tree->getParentId($target_rolf);
include_once './Services/AccessControl/classes/class.ilObjRole.php';
if($rbacreview->isProtected($this->object->getRefId(),$source))
{
}
else
{
}
if($start)
{
$role = new ilObjRole($target);
$role->changeExistingObjects(
$start,
$mode,
array('all')
);
}
}

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::doRemoveRolePermissions (   $source,
  $target,
  $change_existing 
)
protected

do add role permission

Definition at line 403 of file class.ilObjRoleFolderGUI.php.

Referenced by removeRolePermissionsObject().

{
global $rbacadmin, $rbacreview;
$rbacadmin->copyRolePermissionSubtract(
$source,
$this->object->getRefId(),
$target,
$rbacreview->getRoleFolderOfRole($target)
);
}

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::editSettingsObject ( ilPropertyFormGUI  $a_form = null)

Definition at line 730 of file class.ilObjRoleFolderGUI.php.

References initSettingsForm().

Referenced by saveSettingsObject().

{
if(!$a_form)
{
$a_form = $this->initSettingsForm();
}
$this->tpl->setContent($a_form->getHTML());
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::executeCommand ( )

execute command

Reimplemented from ilObjectGUI.

Definition at line 60 of file class.ilObjRoleFolderGUI.php.

References $cmd, $ret, and ilObjectGUI\prepareOutput().

{
global $ilTabs;
$next_class = $this->ctrl->getNextClass($this);
$cmd = $this->ctrl->getCmd();
$this->prepareOutput();
switch($next_class)
{
case 'ilpermissiongui':
include_once("Services/AccessControl/classes/class.ilPermissionGUI.php");
$perm_gui =& new ilPermissionGUI($this);
$ret =& $this->ctrl->forwardCommand($perm_gui);
break;
default:
if(!$cmd)
{
$cmd = "view";
}
$cmd .= "Object";
$this->$cmd();
break;
}
return true;
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::getAdminTabs ( $tabs_gui)

Add role folder tabs ilTree $tree ilLanguage $lng.

Parameters
ilTabsGUI$tabs_gui

Reimplemented from ilObjectGUI.

Definition at line 699 of file class.ilObjRoleFolderGUI.php.

References ilObjectGUI\$lng, ilObjectGUI\$tree, and ilObjectGUI\checkPermissionBool().

{
global $tree,$lng;
if ($this->checkPermissionBool("visible,read"))
{
$tabs_gui->addTarget(
"view",
$this->ctrl->getLinkTarget($this, "view"),
array("", "view"),
get_class($this)
);
$tabs_gui->addTarget(
"settings",
$this->ctrl->getLinkTarget($this, "editSettings"),
array("editSettings"),
get_class($this)
);
}
if($this->checkPermissionBool("edit_permission"))
{
$tabs_gui->addTarget("perm_settings",
$this->ctrl->getLinkTargetByClass(array(get_class($this),'ilpermissiongui'),
"perm"),
"",
"ilpermissiongui");
}
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::ilObjRoleFolderGUI (   $a_data,
  $a_id,
  $a_call_by_reference 
)

Constructor public.

Definition at line 51 of file class.ilObjRoleFolderGUI.php.

References ilObjectGUI\$lng, and ilObjectGUI\ilObjectGUI().

{
global $lng;
$this->type = "rolf";
$this->ilObjectGUI($a_data,$a_id,$a_call_by_reference, false);
$lng->loadLanguageModule('rbac');
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::initCopyBehaviourForm ( )
protected

Show copy behaviour form.

Definition at line 262 of file class.ilObjRoleFolderGUI.php.

References $_POST, $_REQUEST, $ilCtrl, ilObject\_lookupType(), and ilFormPropertyGUI\setRequired().

Referenced by addRolePermissionsObject(), chooseCopyBehaviourObject(), copyRoleObject(), and removeRolePermissionsObject().

{
global $ilCtrl;
include_once './Services/Form/classes/class.ilPropertyFormGUI.php';
$form = new ilPropertyFormGUI();
$form->setTitle($this->lng->txt('rbac_copy_behaviour'));
$form->setFormAction($ilCtrl->getFormAction($this,'chooseCopyBehaviour'));
$ce = new ilRadioGroupInputGUI($this->lng->txt('change_existing_objects'), 'change_existing');
$ce->setRequired(true);
$ce->setValue(1);
$form->addItem($ce);
$ceo = new ilRadioOption($this->lng->txt('change_existing_objects'),1);
$ce->addOption($ceo);
$cne = new ilRadioOption($this->lng->txt('rbac_not_change_existing_objects'), 0);
$ce->addOption($cne);
$roles = new ilHiddenInputGUI('roles');
$roles->setValue(implode(',',(array) $_POST['roles']));
$form->addItem($roles);
// if source is role template show option add permission, remove permissions and copy permissions
if(ilObject::_lookupType((int) $_REQUEST['copy_source']) == 'rolt')
{
$form->addCommandButton('addRolePermissions', $this->lng->txt('rbac_copy_role_add_perm'));
$form->addCommandButton('removeRolePermissions', $this->lng->txt('rbac_copy_role_remove_perm'));
$form->addCommandButton('copyRole', $this->lng->txt('rbac_copy_role_copy'));
}
else
{
$form->addCommandButton('copyRole', $this->lng->txt('rbac_copy_role'));
}
return $form;
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::initRoleSearchForm ( )
protected

Init role search form.

Definition at line 161 of file class.ilObjRoleFolderGUI.php.

References $ilCtrl, and ilFormPropertyGUI\setRequired().

Referenced by roleSearchFormObject(), and roleSearchObject().

{
global $ilCtrl;
include_once './Services/Form/classes/class.ilPropertyFormGUI.php';
$form = new ilPropertyFormGUI();
$form->setTitle($this->lng->txt('rbac_role_title'));
$form->setFormAction($ilCtrl->getFormAction($this,'view'));
$search = new ilTextInputGUI($this->lng->txt('title'), 'title');
$search->setRequired(true);
$search->setSize(30);
$search->setMaxLength(255);
$form->addItem($search);
$form->addCommandButton('roleSearchForm', $this->lng->txt('search'));
return $form;
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::initSettingsForm ( )
protected

Definition at line 774 of file class.ilObjRoleFolderGUI.php.

References $GLOBALS, $ilUser, ilPrivacySettings\_getInstance(), ilSecuritySettings\_getInstance(), and ilFormPropertyGUI\setInfo().

Referenced by editSettingsObject(), and saveSettingsObject().

{
global $rbacreview, $ilUser;
$this->lng->loadLanguageModule('ps');
include_once('./Services/PrivacySecurity/classes/class.ilPrivacySettings.php');
include_once('./Services/PrivacySecurity/classes/class.ilSecuritySettings.php');
include_once("./Services/Form/classes/class.ilPropertyFormGUI.php");
$form = new ilPropertyFormGUI();
$form->setFormAction($this->ctrl->getFormAction($this, "saveSettings"));
$form->setTitle($this->lng->txt('settings'));
// protected admin
$admin = new ilCheckboxInputGUI($GLOBALS['lng']->txt('adm_adm_role_protect'),'admin_role');
$admin->setDisabled(!$rbacreview->isAssigned($ilUser->getId(),SYSTEM_ROLE_ID));
$admin->setInfo($this->lng->txt('adm_adm_role_protect_info'));
$admin->setChecked((int) $security->isAdminRoleProtected());
$admin->setValue(1);
$form->addItem($admin);
$check = new ilCheckboxInputGui($this->lng->txt('rbac_log'), 'rbac_log');
$check->setInfo($this->lng->txt('rbac_log_info'));
$check->setChecked($privacy->enabledRbacLog());
$form->addItem($check);
$age = new ilNumberInputGUI($this->lng->txt('rbac_log_age'),'rbac_log_age');
$age->setInfo($this->lng->txt('rbac_log_age_info'));
$age->setValue($privacy->getRbacLogAge());
$age->setMinValue(1);
$age->setMaxValue(24);
$age->setSize(2);
$age->setMaxLength(2);
$check->addSubItem($age);
$form->addCommandButton('saveSettings',$this->lng->txt('save'));
return $form;
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::removeRolePermissionsObject ( )
protected

Remove role permissions.

Definition at line 376 of file class.ilObjRoleFolderGUI.php.

References $_POST, $_REQUEST, $ilCtrl, doRemoveRolePermissions(), initCopyBehaviourForm(), and ilUtil\sendSuccess().

{
global $ilCtrl;
// Finally copy role/rolt
$roles = explode(',',$_POST['roles']);
$source = (int) $_REQUEST['copy_source'];
$form = $this->initCopyBehaviourForm();
if($form->checkInput())
{
foreach((array) $roles as $role_id)
{
if($role_id != $source)
{
$this->doRemoveRolePermissions($source,$role_id,$form->getInput('change_existing'));
}
}
ilUtil::sendSuccess($this->lng->txt('rbac_copy_finished'),true);
$ilCtrl->redirect($this,'view');
}
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::resetFilterObject ( )

Reset role filter.

Definition at line 486 of file class.ilObjRoleFolderGUI.php.

References viewObject().

{
include_once './Services/AccessControl/classes/class.ilRoleTableGUI.php';
$table = new ilRoleTableGUI($this,'view');
$table->init();
$table->resetOffset();
$table->resetFilter();
$this->viewObject();
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::roleSearchFormObject ( )
protected

Parse search query type $ilCtrl.

Returns
type

Definition at line 186 of file class.ilObjRoleFolderGUI.php.

References $_REQUEST, $_SESSION, $ilCtrl, initRoleSearchForm(), roleSearchListObject(), and ilUtil\sendFailure().

{
global $ilCtrl;
$_SESSION['rolf_search_query'] = '';
$ilCtrl->setParameter($this,'copy_source',(int) $_REQUEST['copy_source']);
$form = $this->initRoleSearchForm();
if($form->checkInput())
{
$_SESSION['rolf_search_query'] = $form->getInput('title');
return $this->roleSearchListObject();
}
ilUtil::sendFailure($this->lng->txt('msg_no_search_string'), true);
$form->setValuesByPost();
$ilCtrl->redirect($this,'roleSearch');
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::roleSearchListObject ( )
protected

List roles.

Definition at line 208 of file class.ilObjRoleFolderGUI.php.

References $_REQUEST, $_SESSION, $ilCtrl, ilUtil\sendFailure(), ilUtil\sendInfo(), and ilRoleTableGUI\TYPE_SEARCH.

Referenced by roleSearchFormObject().

{
global $ilTabs, $ilCtrl;
$ilTabs->clearTargets();
$ilTabs->setBackTarget(
$this->lng->txt('rbac_back_to_overview'),
$this->ctrl->getLinkTarget($this,'roleSearchList')
);
$ilCtrl->setParameter($this,'copy_source',(int) $_REQUEST['copy_source']);
if(strlen($_SESSION['rolf_search_query']))
{
ilUtil::sendInfo($this->lng->txt('rbac_select_copy_targets'));
include_once './Services/AccessControl/classes/class.ilRoleTableGUI.php';
$table = new ilRoleTableGUI($this,'roleSearchList');
$table->setType(ilRoleTableGUI::TYPE_SEARCH);
$table->setRoleTitleFilter($_SESSION['rolf_search_query']);
$table->init();
$table->parse($this->object->getId());
return $this->tpl->setContent($table->getHTML());
}
ilUtil::sendFailure($this->lng->txt('msg_no_search_string'), true);
$ilCtrl->redirect($this,'roleSearch');
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::roleSearchObject ( )
protected

Search target roles.

Definition at line 136 of file class.ilObjRoleFolderGUI.php.

References $_REQUEST, $ilCtrl, $ilErr, initRoleSearchForm(), and ilUtil\sendInfo().

{
global $rbacsystem, $ilCtrl, $ilTabs;
$ilTabs->clearTargets();
$ilTabs->setBackTarget(
$this->lng->txt('rbac_back_to_overview'),
$this->ctrl->getLinkTarget($this,'view')
);
if(!$rbacsystem->checkAccess('visible,read',$this->object->getRefId()))
{
$ilErr->raiseError($this->lng->txt('permission_denied'),$ilErr->MESSAGE);
}
$ilCtrl->setParameter($this,'copy_source',(int) $_REQUEST['copy_source']);
ilUtil::sendInfo($this->lng->txt('rbac_choose_copy_targets'));
$form = $this->initRoleSearchForm();
$this->tpl->setContent($form->getHTML());
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::saveObject ( )

save object public

Reimplemented from ilObjectGUI.

Definition at line 673 of file class.ilObjRoleFolderGUI.php.

References $_GET, $_POST, and ilUtil\sendSuccess().

{
global $rbacadmin;
// role folders are created automatically
$_GET["new_type"] = $this->object->getType();
$_POST["Fobject"]["title"] = $this->object->getTitle();
$_POST["Fobject"]["desc"] = $this->object->getDescription();
// always call parent method first to create an object_data entry & a reference
$newObj = parent::saveObject();
// put here your object specific stuff
// always send a message
ilUtil::sendSuccess($this->lng->txt("rolf_added"),true);
$this->ctrl->redirect($this, "view");
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::saveSettingsObject ( )

Definition at line 740 of file class.ilObjRoleFolderGUI.php.

References $_POST, $ilErr, $ilUser, ilPrivacySettings\_getInstance(), ilSecuritySettings\_getInstance(), ilObjectGUI\checkPermissionBool(), editSettingsObject(), initSettingsForm(), and ilUtil\sendSuccess().

{
global $ilErr, $rbacreview, $ilUser;
if (!$this->checkPermissionBool("write"))
{
$ilErr->raiseError($this->lng->txt('permission_denied'),$ilErr->MESSAGE);
}
$form = $this->initSettingsForm();
if($form->checkInput())
{
include_once('./Services/PrivacySecurity/classes/class.ilPrivacySettings.php');
$privacy->enableRbacLog((int) $_POST['rbac_log']);
$privacy->setRbacLogAge((int) $_POST['rbac_log_age']);
$privacy->save();
if($rbacreview->isAssigned($ilUser->getId(),SYSTEM_ROLE_ID))
{
include_once('./Services/PrivacySecurity/classes/class.ilSecuritySettings.php');
$security->protectedAdminRole((int) $_POST['admin_role']);
$security->save();
}
ilUtil::sendSuccess($this->lng->txt("settings_saved"), true);
$this->ctrl->redirect($this, "editSettings");
}
$form->setValuesByPost();
$this->editSettingsObject($form);
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::showPossibleSubObjects (   $a_tpl)

show possible subobjects (pulldown menu) overwritten to prevent displaying of role templates in local role folders

public

Definition at line 616 of file class.ilObjRoleFolderGUI.php.

References $d, $row, and ilUtil\formSelect().

{
global $rbacsystem;
$d = $this->objDefinition->getCreatableSubObjects($this->object->getType());
if ($this->object->getRefId() != ROLE_FOLDER_ID or !$rbacsystem->checkAccess('create_rolt',ROLE_FOLDER_ID))
{
unset($d["rolt"]);
}
if (!$rbacsystem->checkAccess('create_role',$this->object->getRefId()))
{
unset($d["role"]);
}
if (count($d) > 0)
{
foreach ($d as $row)
{
$count = 0;
if ($row["max"] > 0)
{
//how many elements are present?
for ($i=0; $i<count($this->data["ctrl"]); $i++)
{
if ($this->data["ctrl"][$i]["type"] == $row["name"])
{
$count++;
}
}
}
if ($row["max"] == "" || $count < $row["max"])
{
$subobj[] = $row["name"];
}
}
}
if (is_array($subobj))
{
//build form
$opts = ilUtil::formSelect(12,"new_type",$subobj);
$a_tpl->setCurrentBlock("add_object");
$a_tpl->setVariable("SELECT_OBJTYPE", $opts);
$a_tpl->setVariable("BTN_NAME", "create");
$a_tpl->setVariable("TXT_ADD", $this->lng->txt("add"));
$a_tpl->parseCurrentBlock();
}
return $a_tpl;
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::viewObject ( )

ilErrorHandler $ilErr ilRbacSystem $rbacsystem ilToolbarGUI $ilToolbar

Reimplemented from ilObjectGUI.

Definition at line 96 of file class.ilObjRoleFolderGUI.php.

References $ilErr.

Referenced by applyFilterObject(), and resetFilterObject().

{
global $ilErr, $rbacsystem, $ilToolbar,$rbacreview,$ilTabs;
$ilTabs->activateTab('view');
if(!$rbacsystem->checkAccess('visible,read',$this->object->getRefId()))
{
$ilErr->raiseError($this->lng->txt('permission_denied'),$ilErr->MESSAGE);
}
$this->ctrl->setParameter($this,'new_type','role');
$ilToolbar->addButton(
$this->lng->txt('rolf_create_role'),
$this->ctrl->getLinkTarget($this,'create')
);
$this->ctrl->setParameter($this,'new_type','rolt');
$ilToolbar->addButton(
$this->lng->txt('rolf_create_rolt'),
$this->ctrl->getLinkTarget($this,'create')
);
$this->ctrl->clearParameters($this);
$ilToolbar->addButton(
$this->lng->txt('rbac_import_role'),
$this->ctrl->getLinkTargetByClass('ilPermissionGUI','displayImportRoleForm')
);
include_once './Services/AccessControl/classes/class.ilRoleTableGUI.php';
$table = new ilRoleTableGUI($this,'view');
$table->init();
$table->parse($this->object->getId());
$this->tpl->setContent($table->getHTML());
}

+ Here is the caller graph for this function:

Field Documentation

ilObjRoleFolderGUI::$type

Definition at line 45 of file class.ilObjRoleFolderGUI.php.


The documentation for this class was generated from the following file: