ILIAS  Release_4_2_x_branch Revision 61807
 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 POSSIBLE DEPRECATED !!! public
 deleteObject ()
 display deletion confirmation screen
 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.
- 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 ()
 undeleteObject ()
 Get objects back from trash.
 confirmedDeleteObject ()
 confirmed deletion of object -> objects are moved to trash or deleted immediately, if trash is disabled
 cancelDeleteObject ()
 cancel deletion of object
 removeFromSystemObject ()
 remove objects from trash bin and all entries therefore every object needs a specific deleteObject() method
 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.
 trashObject ()
 Show trash content of object.
 getTemplateFile ($a_cmd, $a_type="")
 get a template blockfile format: tpl.
 cloneAllObject ()
 Clone single (not container object) Method is overwritten in ilContainerGUI.
 copyWizardHasOptions ($a_mode)
 Check if there is any modules specific option.

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.
 roleSearchListObject ()
 List roles.
 chooseCopyBehaviourObject ()
 Chosse change existing objects,...
 initCopyBehaviourForm ()
 Show copy behaviour form.
 copyRoleObject ()
 Copy role.
 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.
- 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.
 showUpperIcon ()
 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 ()
 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)
 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
 __showClipboardTable ($a_result_set, $a_from="")
 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.

Detailed Description

Member Function Documentation

ilObjRoleFolderGUI::adoptPermSaveObject ( )

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

Definition at line 545 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 342 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 212 of file class.ilObjRoleFolderGUI.php.

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

{
global $ilCtrl, $ilTabs;
$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']);
$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 370 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->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 262 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 POSSIBLE DEPRECATED !!! public

Reimplemented from ilObjectGUI.

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

References saveObject().

{
$this->object->setTitle($this->lng->txt("obj_".$this->object->getType()."_local"));
$this->object->setDescription("obj_".$this->object->getType()."_local_desc");
$this->saveObject();
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::deleteObject ( )

display deletion confirmation screen

public

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

References $_POST, $_SESSION, ilUtil\getImageTagByType(), ilObjectGUI\getTemplateFile(), ilUtil\sendQuestion(), and ilUtil\switchColor().

{
if (!isset($_POST["role_id"]))
{
$this->ilias->raiseError($this->lng->txt("no_checkbox"),$this->ilias->error_obj->MESSAGE);
}
// SAVE POST VALUES
$_SESSION["saved_post"] = $_POST["role_id"];
unset($this->data);
$this->data["cols"] = array("type", "title", "description", "last_change");
foreach($_POST["role_id"] as $id)
{
$obj_data =& $this->ilias->obj_factory->getInstanceByObjId($id);
$this->data["data"]["$id"] = array(
"type" => $obj_data->getType(),
"title" => $obj_data->getTitle(),
"desc" => $obj_data->getDescription(),
"last_update" => $obj_data->getLastUpdateDate());
}
$this->data["buttons"] = array( "cancelDelete" => $this->lng->txt("cancel"),
"confirmedDelete" => $this->lng->txt("confirm"));
$this->getTemplateFile("confirm");
ilUtil::sendQuestion($this->lng->txt("info_delete_sure"));
$this->tpl->setVariable("FORMACTION", $this->ctrl->getFormAction($this));
// BEGIN TABLE HEADER
foreach ($this->data["cols"] as $key)
{
$this->tpl->setCurrentBlock("table_header");
$this->tpl->setVariable("TEXT",$this->lng->txt($key));
$this->tpl->parseCurrentBlock();
}
// END TABLE HEADER
// BEGIN TABLE DATA
$counter = 0;
foreach ($this->data["data"] as $key => $value)
{
// BEGIN TABLE CELL
foreach ($value as $key => $cell_data)
{
$this->tpl->setCurrentBlock("table_cell");
// CREATE TEXT STRING
if ($key == "type")
{
$this->tpl->setVariable("TEXT_CONTENT",ilUtil::getImageTagByType($cell_data,$this->tpl->tplPath));
}
else
{
$this->tpl->setVariable("TEXT_CONTENT",$cell_data);
}
$this->tpl->parseCurrentBlock();
}
$this->tpl->setCurrentBlock("table_row");
$this->tpl->setVariable("CSS_ROW",ilUtil::switchColor(++$counter,"tblrow1","tblrow2"));
$this->tpl->parseCurrentBlock();
// END TABLE CELL
}
// END TABLE DATA
// BEGIN OPERATION_BTN
foreach ($this->data["buttons"] as $name => $value)
{
$this->tpl->setCurrentBlock("operation_btn");
$this->tpl->setVariable("BTN_NAME",$name);
$this->tpl->setVariable("BTN_VALUE",$value);
$this->tpl->parseCurrentBlock();
}
}

+ Here is the call graph for this function:

ilObjRoleFolderGUI::deleteRoleObject ( )
protected

Delete roles.

Definition at line 405 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::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 296 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;
// Copy role template permissions
$rbacadmin->copyRoleTemplatePermissions(
$source,
$this->object->getRefId(),
$rbacreview->getRoleFolderOfRole($target),
$target
);
if(!$change_existing)
{
return true;
}
$start = ($this->object->getRefId() == ROLE_FOLDER_ID) ?
ROOT_FOLDER_ID :
$tree->getParentId($this->object->getRefId());
include_once './Services/AccessControl/classes/class.ilObjRole.php';
if($rbacreview->isProtected($this->object->getRefId(),$source))
{
}
else
{
}
$role = new ilObjRole($target);
$role->changeExistingObjects(
$start,
$mode,
array('all')
);
}

+ 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 641 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)
);
}
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 231 of file class.ilObjRoleFolderGUI.php.

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

Referenced by chooseCopyBehaviourObject(), and copyRoleObject().

{
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);
$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 155 of file class.ilObjRoleFolderGUI.php.

References $ilCtrl, and ilFormPropertyGUI\setRequired().

Referenced by roleSearchListObject(), 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('roleSearchList', $this->lng->txt('search'));
return $form;
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjRoleFolderGUI::resetFilterObject ( )

Reset role filter.

Definition at line 356 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::roleSearchListObject ( )
protected

List roles.

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

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

{
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']);
$form = $this->initRoleSearchForm();
if($form->checkInput())
{
ilUtil::sendInfo($this->lng->txt('rbac_select_copy_targets'));
include_once './Services/AccessControl/classes/class.ilRoleTableGUI.php';
$table = new ilRoleTableGUI($this,'view');
$table->setType(ilRoleTableGUI::TYPE_SEARCH);
$table->setRoleTitleFilter($form->getInput('title'));
$table->init();
$table->parse($this->object->getId());
return $this->tpl->setContent($table->getHTML());
}
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::roleSearchObject ( )
protected

Search target roles.

Definition at line 130 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 615 of file class.ilObjRoleFolderGUI.php.

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

Referenced by createObject().

{
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:

+ Here is the caller 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 558 of file class.ilObjRoleFolderGUI.php.

References $d, $row, and 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);
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: