19 declare(strict_types=1);
66 private readonly \ILIAS\HTTP\GlobalHttpState
$http;
76 $this->
ctrl = $DIC->ctrl();
77 $this->tabs_gui = $DIC->tabs();
78 $this->
lng = $DIC->language();
79 $this->
lng->loadLanguageModule(
'ldap');
80 $this->
lng->loadLanguageModule(
'ui');
81 $this->ilErr = $DIC[
'ilErr'];
83 $this->component_repository = $DIC[
"component.repository"];
84 $this->rbacReview = $DIC->rbac()->review();
85 $this->rbacSystem = $DIC->rbac()->system();
86 $this->
toolbar = $DIC->toolbar();
87 $this->main_tpl = $DIC->ui()->mainTemplate();
88 $this->
http = $DIC->http();
89 $this->ui_factory = $DIC->ui()->factory();
90 $this->ui_renderer = $DIC->ui()->renderer();
93 $this->tpl = $DIC->ui()->mainTemplate();
95 if ($this->
ctrl->getCmd() !==
"addServerSettings") {
96 $this->
ctrl->saveParameter($this,
'ldap_server_id');
99 $http_wrapper = $DIC->http()->wrapper();
100 $is_post_request = $DIC->http()->request()->getMethod() ===
"POST";
101 $refinery = $DIC->refinery();
102 if ($http_wrapper->query()->has(
"rule_id")) {
103 $this->rule_id = $http_wrapper->query()->retrieve(
105 $refinery->kindlyTo()->int()
109 if ($http_wrapper->query()->has(
'ldap_server_id')) {
110 $this->ldap_server_id = $http_wrapper->query()->retrieve(
112 $refinery->kindlyTo()->int()
114 } elseif ($http_wrapper->query()->has(
'ldap_servers_server_id')) {
115 $this->ldap_server_id = $http_wrapper->query()->retrieve(
116 'ldap_servers_server_id',
118 $refinery->kindlyTo()->listOf(
119 $refinery->kindlyTo()->int()
121 $this->
refinery->custom()->constraint(
122 fn($value):
bool => count($value) === 1,
123 $this->
lng->txt(
'select_one')
125 $this->
refinery->custom()->transformation(
126 fn($value):
int => $value[0]
132 if ($http_wrapper->query()->has(
"mapping_id")) {
133 $this->mapping_id = $http_wrapper->query()->retrieve(
135 $refinery->kindlyTo()->int()
138 if ($is_post_request) {
139 if ($http_wrapper->post()->has(
'rule_ids')) {
140 $this->rule_ids = $http_wrapper->post()->retrieve(
142 $refinery->kindlyTo()->listOf($refinery->kindlyTo()->int())
145 if ($http_wrapper->post()->has(
'role_id')) {
146 $this->role_id = $http_wrapper->post()->retrieve(
148 $refinery->kindlyTo()->int()
151 if ($http_wrapper->post()->has(
'mappings')) {
152 $this->mappings = $http_wrapper->post()->retrieve(
154 $refinery->kindlyTo()->listOf($refinery->kindlyTo()->int())
157 if ($http_wrapper->post()->has(
'server_ids')) {
158 $this->server_ids = $http_wrapper->post()->retrieve(
160 $refinery->kindlyTo()->listOf($refinery->kindlyTo()->int())
163 if ($http_wrapper->post()->has(
'mapping_template')) {
164 $this->mapping_template = $http_wrapper->post()->retrieve(
166 $refinery->kindlyTo()->string()
169 if ($http_wrapper->post()->has(
'role_bind_user')) {
172 $refinery->kindlyTo()->string()
175 if ($http_wrapper->post()->has(
'role_bind_pass')) {
178 $refinery->kindlyTo()->string()
181 if ($http_wrapper->post()->has(
'role_sync_active')) {
182 $this->role_sync_active = $http_wrapper->post()->retrieve(
184 $refinery->kindlyTo()->bool()
188 if ($http_wrapper->post()->has($key .
'_value')) {
191 $refinery->kindlyTo()->string()
192 )), $http_wrapper->post()->has($key .
'_update')];
194 $this->attribute_mappings[$key] = [
"",
false];
199 $this->ref_id = $a_auth_ref_id;
210 $next_class = $this->
ctrl->getNextClass($this);
211 $cmd = $this->
ctrl->getCmd();
213 if ($cmd !==
"serverList" && !$this->rbacSystem->checkAccess(
"visible,read", $this->ref_id)) {
214 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'msg_no_perm_write'),
true);
215 $this->
ctrl->redirect($this,
"serverList");
217 switch ($next_class) {
230 if (!$this->
ilAccess->checkAccess($a_permission,
'', $this->ref_id)) {
231 $this->ilErr->raiseError($this->
lng->txt(
'msg_no_perm_read'), $this->ilErr->WARNING);
246 $keys[] =
'udf_' . $definition[
'field_id'];
266 $this->tabs_gui->activateTab(
'role_assignments');
268 $this->tpl->addBlockFile(
'ADM_CONTENT',
'adm_content',
'tpl.ldap_role_assignments.html',
'components/ILIAS/LDAP');
272 $this->tpl->setVariable(
'NEW_ASSIGNMENT_TBL', $this->
form->getHTML());
277 $table_gui->setTitle($this->
lng->txt(
"ldap_tbl_role_ass"));
278 $table_gui->parse($rules);
279 $table_gui->addMultiCommand(
"confirmDeleteRules", $this->
lng->txt(
"delete"));
280 $table_gui->setSelectAllCheckbox(
"rule_id");
281 $this->tpl->setVariable(
'RULES_TBL', $table_gui->getHTML());
291 if (!$this->rule_id) {
292 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_one'));
297 $this->tabs_gui->activateTab(
'role_assignments');
299 $this->
ctrl->saveParameter($this,
'rule_id');
305 $this->tpl->setContent($this->
form->getHTML());
314 $role_id = $this->role_mapping_rule->getRoleId();
315 if ($this->rbacReview->isGlobalRole($role_id)) {
316 $val[
'role_name'] = 0;
319 $val[
'role_name'] = 1;
322 $val[
'add_missing'] = (
int) $this->role_mapping_rule->isAddOnUpdateEnabled();
323 $val[
'remove_deprecated'] = (
int) $this->role_mapping_rule->isRemoveOnUpdateEnabled();
324 $val[
'type'] = $this->role_mapping_rule->getType();
325 $val[
'dn'] = $this->role_mapping_rule->getDN();
326 $val[
'at'] = $this->role_mapping_rule->getMemberAttribute();
327 $val[
'isdn'] = $this->role_mapping_rule->isMemberAttributeDN();
328 $val[
'name'] = $this->role_mapping_rule->getAttributeName();
329 $val[
'value'] = $this->role_mapping_rule->getAttributeValue();
330 $val[
'plugin_id'] = $this->role_mapping_rule->getPluginId();
332 $this->
form->setValuesByArray($val);
340 if (!$this->
ilAccess->checkAccess(
'write',
'', $this->ref_id)) {
341 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'permission_denied'),
true);
348 $formWithoutErrors = $this->
form->checkInput();
350 if (!$formWithoutErrors || $roleErrorMessage !==
'') {
351 if ($roleErrorMessage !==
'') {
352 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt($roleErrorMessage));
355 $this->tpl->addBlockFile(
'ADM_CONTENT',
'adm_content',
'tpl.ldap_role_assignments.html',
'components/ILIAS/LDAP');
357 $this->
form->setValuesByPost();
358 $this->tpl->setVariable(
'NEW_ASSIGNMENT_TBL', $this->
form->getHTML());
359 $this->tabs_gui->activateSubTab(
'role_assignments');
365 $this->
ctrl->redirect($this,
'showRoleSelection');
367 $this->rule->update();
368 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'));
382 if (!$this->rule_ids) {
383 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_one'));
388 $this->tabs_gui->activateTab(
'role_assignments');
393 $c_gui->setFormAction($this->
ctrl->getFormAction($this,
"deleteRules"));
394 $c_gui->setHeaderText($this->
lng->txt(
"ldap_confirm_del_role_ass"));
395 $c_gui->setCancel($this->
lng->txt(
"cancel"),
"roleAssignments");
396 $c_gui->setConfirm($this->
lng->txt(
"confirm"),
"deleteRules");
399 foreach ($this->rule_ids as $rule_id) {
403 $this->tpl->setContent($c_gui->getHTML());
411 if (!$this->rule_ids) {
412 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_once'));
416 foreach ($this->rule_ids as $rule_id) {
420 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'ldap_deleted_rule'));
421 $this->
ctrl->redirect($this,
'roleAssignments');
429 if (!$this->
ilAccess->checkAccess(
'write',
'', $this->ref_id)) {
430 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'permission_denied'),
true);
436 $formWithoutErrors = $this->
form->checkInput();
438 if (!$formWithoutErrors || $roleErrorMessage !==
'') {
439 if ($roleErrorMessage !==
'') {
440 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt($roleErrorMessage));
443 $this->tpl->addBlockFile(
'ADM_CONTENT',
'adm_content',
'tpl.ldap_role_assignments.html',
'components/ILIAS/LDAP');
446 $this->
form->setValuesByPost();
447 $this->tpl->setVariable(
'NEW_ASSIGNMENT_TBL', $this->
form->getHTML());
449 $this->tabs_gui->activateSubTab(
'role_assignments');
454 $this->
ctrl->redirect($this,
'showRoleSelection');
456 $this->rule->create();
457 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'));
458 $this->
ctrl->redirect($this,
'roleAssignments');
465 if ($this->rule->getRoleId() > 0) {
469 $rule[
'server_id'] = $this->
getServer()->getServerId();
470 $rule[
'rule_id'] = $this->rule_id ?: 0;
471 $rule[
'role_search'] = $this->
form->getInput(
'role_search');
472 $rule[
'add_on_update'] = $this->
form->getInput(
'add_missing');
473 $rule[
'remove_on_update'] = $this->
form->getInput(
'remove_deprecated');
474 $rule[
'type'] = $this->
form->getInput(
'type');
475 $rule[
'dn'] = $this->
form->getInput(
'dn');
476 $rule[
'at'] = $this->
form->getInput(
'at');
477 $rule[
'isdn'] = $this->
form->getInput(
'isdn');
478 $rule[
'name'] = $this->
form->getInput(
'name');
479 $rule[
'value'] = $this->
form->getInput(
'value');
480 $rule[
'plugin'] = $this->
form->getInput(
'plugin_id');
482 $this->
ctrl->saveParameter($this,
'rule_id');
494 $this->tabs_gui->activateTab(
'role_assignment');
495 $this->
ctrl->saveParameter($this,
'rule_id');
498 $parser->setMinWordLength(1);
503 $object_search->setFilter(array(
'role'));
504 $res = $object_search->performSearch();
506 $entries =
$res->getEntries();
509 $table->setTitle($this->
lng->txt(
'ldap_role_selection'));
510 $table->addMultiCommand(
'saveRoleSelection', $this->
lng->txt(
'ldap_choose_role'));
511 $table->parse($entries);
513 $this->tpl->setContent($table->getHTML());
523 if (!$this->
ilAccess->checkAccess(
'write',
'', $this->ref_id)) {
524 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'permission_denied'),
true);
529 if (!$this->role_id) {
530 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_one'));
536 $this->rule->setRoleId($this->role_id);
538 if ($this->rule_id) {
539 $this->rule->update();
541 $this->rule->create();
544 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'));
556 $this->rule->validate();
557 return $this->ilErr->getMessage();
567 $table_gui->setTitle($this->
lng->txt(
"ldap_tbl_role_ass"));
568 $table_gui->parse($rules);
569 $table_gui->addMultiCommand(
"confirmDeleteRules", $this->
lng->txt(
"delete"));
570 $table_gui->setSelectAllCheckbox(
"rule_id");
571 return $table_gui->getHTML();
582 if (is_object($this->rule)) {
588 if ($load_from_form) {
589 if ($this->
form->getInput(
'role_name') ===
'0') {
590 $this->rule->setRoleId((
int) $this->
form->getInput(
'role_id'));
591 } elseif ($this->
form->getInput(
'role_search')) {
600 $object_search->setFilter(array(
'role'));
601 $res = $object_search->performSearch();
603 $entries =
$res->getEntries();
604 if (count($entries) === 1) {
605 $role = current($entries);
606 $this->rule->setRoleId($role[
'obj_id']);
607 } elseif (count($entries) > 1) {
608 $this->rule->setRoleId(-1);
612 $this->rule->setAttributeName($this->
form->getInput(
'name'));
613 $this->rule->setAttributeValue($this->
form->getInput(
'value'));
614 $this->rule->setDN($this->
form->getInput(
'dn'));
615 $this->rule->setMemberAttribute($this->
form->getInput(
'at'));
616 $this->rule->setMemberIsDN((
bool) $this->
form->getInput(
'isdn'));
617 $this->rule->enableAddOnUpdate((
bool) $this->
form->getInput(
'add_missing'));
618 $this->rule->enableRemoveOnUpdate((
bool) $this->
form->getInput(
'remove_deprecated'));
619 $this->rule->setPluginId((
int) $this->
form->getInput(
'plugin_id'));
620 $this->rule->setType((
int) $this->
form->getInput(
'type'));
621 $this->rule->setServerId($this->
getServer()->getServerId());
626 $this->rule->setServerId($this->
getServer()->getServerId());
627 $rule = unserialize(
ilSession::get(
'ldap_role_ass'), [
"allowed_classes" =>
false]);
629 $this->rule->enableAddOnUpdate((
bool) ($rule[
'add_on_update'] ??
false));
630 $this->rule->enableRemoveOnUpdate((
bool) ($rule[
'remove_on_update'] ??
false));
644 if (!$this->mappings) {
645 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_one'));
652 foreach ($this->mappings as $mapping_id) {
653 $this->role_mapping->delete($mapping_id);
655 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'ldap_deleted_role_mapping'));
662 if (!$this->mapping_template) {
668 $this->mapping->clearRules();
671 $this->mapping->setRule($key, $value,
false);
679 $this->tabs_gui->activateTab(
'role_mapping');
682 $this->mapping->setRule(
684 $this->attribute_mappings[$key][0],
685 $this->attribute_mappings[$key][1]
689 foreach ($this->udf->getDefinitions() as $definition) {
690 $key =
'udf_' . $definition[
'field_id'];
691 $this->mapping->setRule(
693 $this->attribute_mappings[$key][0],
694 $this->attribute_mappings[$key][1]
698 $this->mapping->save();
701 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'));
706 $action = $this->
http->wrapper()->query()->retrieve(
707 'ldap_servers_table_action',
709 $this->refinery->kindlyTo()->string(),
718 default => $this->
ctrl->redirect($this,
'serverList'),
724 if (!$this->rbacSystem->checkAccess(
'visible,read', $this->ref_id)) {
725 $this->ilErr->raiseError($this->
lng->txt(
'msg_no_perm_read'), $this->ilErr->WARNING);
729 $this->main_tpl->setOnScreenMessage(
'failure',
'Missing LDAP libraries. Please ensure that the PHP LDAP module is installed on your server.');
732 if ($this->rbacSystem->checkAccess(
'write', $this->ref_id)) {
734 $this->
lng->txt(
'add_ldap_server'),
735 $this->
ctrl->getLinkTarget($this,
'addServerSettings')
739 $table = new \ILIAS\LDAP\Server\UI\ServerTable(
746 $this->
http->request(),
747 new \ILIAS\Data\Factory(),
748 'handleServerTableActions',
749 $this->rbacSystem->checkAccess(
'write', $this->ref_id)
752 $this->tpl->setContent($this->ui_renderer->render($table->getComponent()));
757 $this->form_gui->setValuesByArray(array(
758 'active' => $this->
server->isActive(),
759 'ds' => !$this->
server->isAuthenticationEnabled(),
760 'server_name' => $this->
server->getName(),
761 'server_url' => $this->
server->getUrlString(),
762 'version' => $this->
server->getVersion(),
763 'base_dn' => $this->
server->getBaseDN(),
764 'referrals' => $this->
server->isActiveReferrer(),
765 'tls' => $this->
server->isActiveTLS(),
766 'binding_type' => $this->
server->getBindingType(),
767 'bind_dn' => $this->
server->getBindUser(),
768 'bind_pass' => $this->
server->getBindPassword(),
769 'bind_pass_retype' => $this->
server->getBindPassword(),
770 'search_base' => $this->
server->getSearchBase(),
771 'user_scope' => $this->
server->getUserScope(),
772 'user_attribute' => $this->
server->getUserAttribute(),
773 'filter' => $this->
server->getFilter(),
774 'group_dn' => $this->
server->getGroupDN(),
775 'group_scope' => $this->
server->getGroupScope(),
776 'group_filter' => $this->
server->getGroupFilter(),
777 'group_member' => $this->
server->getGroupMember(),
778 'memberisdn' => $this->
server->enabledGroupMemberIsDN(),
779 'group' => $this->
server->getGroupName(),
780 'group_attribute' => $this->
server->getGroupAttribute(),
781 'group_optional' => $this->
server->isMembershipOptional(),
782 'group_user_filter' => $this->
server->getGroupUserFilter(),
783 'sync_on_login' => $this->
server->enabledSyncOnLogin(),
784 'sync_per_cron' => $this->
server->enabledSyncPerCron(),
786 'migration' => (
int) $this->
server->isAccountMigrationEnabled(),
787 "name_filter" => $this->
server->getUsernameFilter(),
788 'escape_dn' => $this->
server->enabledEscapeDN()
795 $this->form_gui->setFormAction($this->
ctrl->getFormAction($this,
'save'));
796 $this->form_gui->setTitle($this->
lng->txt(
'ldap_configure'));
799 $active->setValue(
"1");
800 $this->form_gui->addItem($active);
804 $ds->setInfo($this->
lng->txt(
'ldap_as_ds_info'));
805 $this->form_gui->addItem($ds);
807 $servername =
new ilTextInputGUI($this->
lng->txt(
'ldap_server_name'),
'server_name');
808 $servername->setRequired(
true);
809 $servername->setInfo($this->
lng->txt(
'ldap_server_name_info'));
810 $servername->setSize(32);
811 $servername->setMaxLength(32);
812 $this->form_gui->addItem($servername);
815 $namefilter =
new ilTextInputGUI($this->
lng->txt(
'ldap_username_filter'),
"name_filter");
816 $namefilter->setInfo($this->
lng->txt(
"ldap_username_filter_info"));
817 $namefilter->setSize(64);
818 $namefilter->setMaxLength(255);
819 $this->form_gui->addItem($namefilter);
823 $serverurl->setRequired(
true);
824 $serverurl->setInfo($this->
lng->txt(
'ldap_server_url_info'));
825 $serverurl->setSize(64);
826 $serverurl->setMaxLength(255);
827 $this->form_gui->addItem($serverurl);
830 $version->setOptions(array(2 => 2, 3 => 3));
831 $version->setInfo($this->
lng->txt(
'ldap_server_version_info'));
835 $basedsn->setRequired(
true);
836 $basedsn->setSize(64);
837 $basedsn->setMaxLength(255);
838 $this->form_gui->addItem($basedsn);
841 $referrals->setValue(
"1");
842 $referrals->setInfo($this->
lng->txt(
'ldap_referrals_info'));
843 $this->form_gui->addItem($referrals);
846 $section_security->setTitle($this->
lng->txt(
'ldap_server_security_settings'));
847 $this->form_gui->addItem($section_security);
851 $this->form_gui->addItem($tls);
855 $binding->addOption($anonymous);
859 $dn->setMaxLength(255);
860 $user->addSubItem($dn);
864 $pass->setMaxLength(100);
865 $user->addSubItem($pass);
866 $binding->addOption($user);
867 $this->form_gui->addItem($binding);
870 $section_auth->setTitle($this->
lng->txt(
'ldap_authentication_settings'));
871 $this->form_gui->addItem($section_auth);
873 $search_base =
new ilTextInputGUI($this->
lng->txt(
'ldap_user_dn'),
'search_base');
874 $search_base->setInfo($this->
lng->txt(
'ldap_search_base_info'));
875 $search_base->setSize(64);
876 $search_base->setMaxLength(255);
877 $this->form_gui->addItem($search_base);
882 $user_scope->setInfo($this->
lng->txt(
'ldap_user_scope_info'));
883 $this->form_gui->addItem($user_scope);
885 $user_attribute =
new ilTextInputGUI($this->
lng->txt(
'ldap_user_attribute'),
'user_attribute');
886 $user_attribute->setSize(16);
887 $user_attribute->setMaxLength(64);
888 $user_attribute->setRequired(
true);
889 $this->form_gui->addItem($user_attribute);
892 $filter->setInfo($this->
lng->txt(
'ldap_filter_info'));
893 $filter->setSize(64);
894 $filter->setMaxLength(512);
895 $this->form_gui->addItem($filter);
898 $section_restrictions->setTitle($this->
lng->txt(
'ldap_group_restrictions'));
899 $this->form_gui->addItem($section_restrictions);
901 $group_dn =
new ilTextInputGUI($this->
lng->txt(
'ldap_group_search_base'),
'group_dn');
902 $group_dn->setInfo($this->
lng->txt(
'ldap_group_dn_info'));
903 $group_dn->setSize(64);
904 $group_dn->setMaxLength(255);
905 $this->form_gui->addItem($group_dn);
910 $group_scope->setInfo($this->
lng->txt(
'ldap_group_scope_info'));
911 $this->form_gui->addItem($group_scope);
913 $group_filter =
new ilTextInputGUI($this->
lng->txt(
'ldap_group_filter'),
'group_filter');
914 $group_filter->setInfo($this->
lng->txt(
'ldap_group_filter_info'));
915 $group_filter->setSize(64);
916 $group_filter->setMaxLength(255);
917 $this->form_gui->addItem($group_filter);
919 $group_member =
new ilTextInputGUI($this->
lng->txt(
'ldap_group_member'),
'group_member');
920 $group_member->setInfo($this->
lng->txt(
'ldap_group_member_info'));
921 $group_member->setSize(32);
922 $group_member->setMaxLength(255);
923 $this->form_gui->addItem($group_member);
927 #$group_member_isdn->setInfo($this->lng->txt('ldap_group_member_info')); 928 $this->form_gui->addItem($group_member_isdn);
929 #$group_member->addSubItem($group_member_isdn); 932 $escapedn->setValue(
"1");
933 $escapedn->setInfo($this->
lng->txt(
'ldap_escapedn_info'));
934 $this->form_gui->addItem($escapedn);
937 $group->setInfo($this->
lng->txt(
'ldap_group_name_info'));
939 $group->setMaxLength(255);
940 $this->form_gui->addItem($group);
942 $group_atrr =
new ilTextInputGUI($this->
lng->txt(
'ldap_group_attribute'),
'group_attribute');
943 $group_atrr->setInfo($this->
lng->txt(
'ldap_group_attribute_info'));
944 $group_atrr->setSize(16);
945 $group_atrr->setMaxLength(64);
946 $this->form_gui->addItem($group_atrr);
948 $group_optional =
new ilCheckboxInputGUI($this->
lng->txt(
'ldap_group_membership'),
'group_optional');
949 $group_optional->setOptionTitle($this->
lng->txt(
'ldap_group_member_optional'));
950 $group_optional->setInfo($this->
lng->txt(
'ldap_group_optional_info'));
951 $group_optional->setValue(
"1");
952 $group_user_filter =
new ilTextInputGUI($this->
lng->txt(
'ldap_group_user_filter'),
'group_user_filter');
953 $group_user_filter->setSize(64);
954 $group_user_filter->setMaxLength(255);
955 $group_optional->addSubItem($group_user_filter);
956 $this->form_gui->addItem($group_optional);
959 $section_sync->setTitle($this->
lng->txt(
'ldap_user_sync'));
960 $this->form_gui->addItem($section_sync);
964 $sync_on_login->setValue(
"1");
967 $sync_per_cron->setValue(
"1");
968 $ci_gui->addSubItem($sync_per_cron);
969 $ci_gui->setInfo($this->
lng->txt(
'ldap_user_sync_info'));
970 $this->form_gui->addItem($ci_gui);
972 $global_role =
new ilSelectInputGUI($this->
lng->txt(
'ldap_global_role_assignment'),
'global_role');
974 $global_role->setInfo($this->
lng->txt(
'ldap_global_role_info'));
975 $this->form_gui->addItem($global_role);
978 $migr->setInfo($this->
lng->txt(
'auth_ldap_migration_info'));
979 $migr->setValue(
"1");
980 $this->form_gui->addItem($migr);
988 $this->form_gui->addCommandButton(
'save', $this->
lng->txt(
'save'));
989 if ($this->
ctrl->getCmd() ===
"addServerSettings") {
990 $this->form_gui->addCommandButton(
'serverList', $this->
lng->txt(
'cancel'));
1000 $this->tabs_gui->setTabActive(
'settings');
1003 if ($this->form_gui->checkInput()) {
1004 $this->
server->toggleActive((
bool) $this->form_gui->getInput(
'active'));
1005 $this->
server->enableAuthentication(!(
bool) $this->form_gui->getInput(
'ds'));
1006 $this->
server->setName($this->form_gui->getInput(
'server_name'));
1007 $this->
server->setUrl($this->form_gui->getInput(
'server_url'));
1008 $this->
server->setVersion((
int) $this->form_gui->getInput(
'version'));
1009 $this->
server->setBaseDN($this->form_gui->getInput(
'base_dn'));
1010 $this->
server->toggleReferrer((
bool) $this->form_gui->getInput(
'referrals'));
1011 $this->
server->toggleTLS((
bool) $this->form_gui->getInput(
'tls'));
1012 $this->
server->setBindingType((
int) $this->form_gui->getInput(
'binding_type'));
1013 $this->
server->setBindUser($this->form_gui->getInput(
'bind_dn'));
1014 $this->
server->setBindPassword($this->form_gui->getInput(
'bind_pass'));
1015 $this->
server->setSearchBase($this->form_gui->getInput(
'search_base'));
1016 $this->
server->setUserScope((
int) $this->form_gui->getInput(
'user_scope'));
1017 $this->
server->setUserAttribute($this->form_gui->getInput(
'user_attribute'));
1018 $this->
server->setFilter($this->form_gui->getInput(
'filter'));
1019 $this->
server->setGroupDN($this->form_gui->getInput(
'group_dn'));
1020 $this->
server->setGroupScope((
int) $this->form_gui->getInput(
'group_scope'));
1021 $this->
server->setGroupFilter($this->form_gui->getInput(
'group_filter'));
1022 $this->
server->setGroupMember($this->form_gui->getInput(
'group_member'));
1023 $this->
server->enableGroupMemberIsDN((
bool) $this->form_gui->getInput(
'memberisdn'));
1024 $this->
server->setGroupName($this->form_gui->getInput(
'group'));
1025 $this->
server->setGroupAttribute($this->form_gui->getInput(
'group_attribute'));
1026 $this->
server->setGroupUserFilter($this->form_gui->getInput(
'group_user_filter'));
1027 $this->
server->toggleMembershipOptional((
bool) $this->form_gui->getInput(
'group_optional'));
1028 $this->
server->enableSyncOnLogin((
bool) $this->form_gui->getInput(
'sync_on_login'));
1029 $this->
server->enableSyncPerCron((
bool) $this->form_gui->getInput(
'sync_per_cron'));
1030 $this->
server->setGlobalRole((
int) $this->form_gui->getInput(
'global_role'));
1031 $this->
server->enableAccountMigration((
bool) $this->form_gui->getInput(
'migration'));
1032 $this->
server->setUsernameFilter($this->form_gui->getInput(
"name_filter"));
1033 $this->
server->enableEscapeDN((
bool) $this->form_gui->getInput(
'escape_dn'));
1034 if (!$this->
server->validate()) {
1035 $this->main_tpl->setOnScreenMessage(
'failure', $this->ilErr->getMessage());
1036 $this->form_gui->setValuesByPost();
1037 $this->tpl->setContent($this->form_gui->getHTML());
1042 if ($this->
server->getServerId()) {
1050 $this->mapping->setRule(
'global_role', (
string) $this->form_gui->getInput(
'global_role'),
false);
1051 $this->mapping->save();
1053 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'),
true);
1054 $this->
ctrl->redirect($this,
'serverList');
1058 $this->form_gui->setValuesByPost();
1059 $this->tpl->setContent($this->form_gui->getHTML());
1070 $this->tabs_gui->clearTargets();
1072 $this->tabs_gui->setBackTarget(
1073 $this->
lng->txt(
"back"),
1074 $this->
ctrl->getLinkTarget($this,
'serverList')
1078 $this->tabs_gui->addTab(
1080 $this->
lng->txt(
"ldap_settings"),
1081 $this->
ctrl->getLinkTarget($this,
'editServerSettings')
1089 $this->tabs_gui->addTab(
1091 $this->
lng->txt(
"ldap_user_mapping"),
1092 $this->
ctrl->getLinkTarget($this,
'userMapping')
1095 $this->tabs_gui->addTab(
1097 $this->
lng->txt(
'ldap_role_assignments'),
1098 $this->
ctrl->getLinkTarget($this,
'roleAssignments')
1101 $this->tabs_gui->addTab(
1103 $this->
lng->txt(
"ldap_role_mapping"),
1104 $this->
ctrl->getLinkTarget($this,
'roleMapping')
1112 if ($this->ldap_server_id) {
1136 $this->rbacReview->getGlobalRoles(),
1142 $select[0] = $this->
lng->txt(
'links_select_one');
1143 foreach ($global_roles as $role_id) {
1151 return array(
'gender' => $this->
lng->txt(
'gender'),
1152 'firstname' => $this->
lng->txt(
'firstname'),
1153 'lastname' => $this->
lng->txt(
'lastname'),
1154 'title' => $this->
lng->txt(
'person_title'),
1155 'institution' => $this->
lng->txt(
'institution'),
1156 'department' => $this->
lng->txt(
'department'),
1157 'street' => $this->
lng->txt(
'street'),
1158 'city' => $this->
lng->txt(
'city'),
1159 'zipcode' => $this->
lng->txt(
'zipcode'),
1160 'country' => $this->
lng->txt(
'country'),
1161 'phone_office' => $this->
lng->txt(
'phone_office'),
1162 'phone_home' => $this->
lng->txt(
'phone_home'),
1163 'phone_mobile' => $this->
lng->txt(
'phone_mobile'),
1164 'fax' => $this->
lng->txt(
'fax'),
1165 'email' => $this->
lng->txt(
'email'),
1166 'second_email' => $this->
lng->txt(
'second_email'),
1167 'hobby' => $this->
lng->txt(
'hobby'),
1168 'matriculation' => $this->
lng->txt(
'matriculation'));
1179 $this->mapping_template,
1181 [0 => $this->
lng->txt(
'ldap_mapping_template'),
1182 "inetOrgPerson" =>
'inetOrgPerson',
1183 "organizationalPerson" =>
'organizationalPerson',
1184 "person" =>
'person',
1185 "ad_2003" =>
'Active Directory (Win 2003)' 1200 $this->
form->setFormAction($this->
ctrl->getFormAction($this));
1204 $this->
form->setTitle($this->
lng->txt(
'ldap_edit_role_ass_rule'));
1205 $this->
form->addCommandButton(
'updateRoleAssignment', $this->
lng->txt(
'save'));
1209 $this->
form->setTitle($this->
lng->txt(
'ldap_add_role_ass_rule'));
1210 $this->
form->addCommandButton(
'addRoleAssignment', $this->
lng->txt(
'ldap_btn_add_role_ass'));
1221 $role->addOption($global);
1225 $global->addSubItem($role_select);
1229 $role->addOption($local);
1232 $role_search->setSize(40);
1233 $local->addSubItem($role_search);
1235 $role->setInfo($this->
lng->txt(
'ldap_role_name_info'));
1236 $this->
form->addItem($role);
1240 $update->setValue($this->
lng->txt(
'ldap_check_role_assignment'));
1243 $add->setOptionTitle($this->
lng->txt(
'ldap_add_missing'));
1244 $update->addSubItem($add);
1247 $remove->setOptionTitle($this->
lng->txt(
'ldap_remove_deprecated'));
1248 $update->addSubItem($remove);
1250 $this->
form->addItem($update);
1256 #$group->setValue($current_rule->getType()); 1263 #$dn->setValue($current_rule->getDN()); 1265 $dn->setMaxLength(512);
1266 $dn->setInfo($this->
lng->txt(
'ldap_role_grp_dn_info'));
1267 $radio_group->addSubItem($dn);
1269 #$at->setValue($current_rule->getMemberAttribute()); 1271 $at->setMaxLength(128);
1272 $radio_group->addSubItem($at);
1274 #$isdn->setChecked($current_rule->isMemberAttributeDN()); 1275 $isdn->setInfo($this->
lng->txt(
'ldap_group_member_info'));
1276 $radio_group->addSubItem($isdn);
1277 $radio_group->setInfo($this->
lng->txt(
'ldap_role_grp_info'));
1279 $group->addOption($radio_group);
1284 #$name->setValue($current_rule->getAttributeName()); 1286 $name->setMaxLength(128);
1287 #$name->setInfo($this->lng->txt('ldap_role_at_name_info')); 1288 $radio_attribute->addSubItem($name);
1292 #$val->setValue($current_rule->getAttributeValue()); 1294 $val->setMaxLength(128);
1295 #$val->setInfo($this->lng->txt('ldap_role_at_value_info')); 1296 $radio_attribute->addSubItem($val);
1297 $radio_attribute->setInfo($this->
lng->txt(
'ldap_role_at_info'));
1299 $group->addOption($radio_attribute);
1302 $pl_active = $this->component_repository->getPluginSlotById(
"ldaphk")->hasActivePlugins();
1305 $pl->
setInfo($this->
lng->txt(
'ldap_plugin_info'));
1306 $pl->setDisabled(!$pl_active);
1309 $id->setDisabled(!$pl_active);
1311 $id->setMaxLength(3);
1312 $id->setMaxValue(999);
1313 $id->setMinValue(1);
1314 $pl->addSubItem(
$id);
1316 $group->addOption($pl);
1317 $this->
form->addItem($group);
1335 $select_form->setPostVar(
"mapping_template");
1337 "" => $this->
lng->txt(
'ldap_mapping_template'),
1338 "inetOrgPerson" =>
'inetOrgPerson',
1339 "organizationalPerson" =>
'organizationalPerson',
1340 "person" =>
'person',
1341 "ad_2003" =>
'Active Directory (Win 2003)');
1342 $select_form->setOptions($options);
1343 $select_form->setValue($this->mapping_template);
1345 $this->
toolbar->addInputItem($select_form);
1346 $this->
toolbar->addFormButton($this->
lng->txt(
'show'),
"chooseMapping");
1347 $this->
toolbar->setFormAction($this->
ctrl->getFormAction($this,
"chooseMapping"));
1356 $propertie_form->setTitle($this->
lng->txt(
'ldap_mapping_table'));
1357 $propertie_form->setFormAction($this->
ctrl->getFormAction($this,
'saveMapping'));
1358 $propertie_form->addCommandButton(
'saveMapping', $this->
lng->txt(
'save'));
1362 $text_form->setPostVar($mapping .
"_value");
1363 $text_form->setValue($this->mapping->getValue($mapping));
1364 $text_form->setSize(32);
1365 $text_form->setMaxLength(255);
1366 $propertie_form->addItem($text_form);
1369 $checkbox_form->setPostVar($mapping .
"_update");
1370 $checkbox_form->setChecked($this->mapping->enabledUpdate($mapping));
1371 $checkbox_form->setOptionTitle($this->
lng->txt(
'ldap_update_field_info'));
1372 $propertie_form->addItem($checkbox_form);
1376 foreach ($this->udf->getDefinitions() as $definition) {
1378 $text_form->setPostVar(
'udf_' . $definition[
'field_id'] .
'_value');
1379 $text_form->setValue($this->mapping->getValue(
'udf_' . $definition[
'field_id']));
1380 $text_form->setSize(32);
1381 $text_form->setMaxLength(255);
1382 $propertie_form->addItem($text_form);
1385 $checkbox_form->setPostVar(
'udf_' . $definition[
'field_id'] .
'_update');
1386 $checkbox_form->setChecked($this->mapping->enabledUpdate(
'udf_' . $definition[
'field_id']));
1387 $checkbox_form->setOptionTitle($this->
lng->txt(
'ldap_update_field_info'));
1388 $propertie_form->addItem($checkbox_form);
1391 return $propertie_form;
1400 $this->tabs_gui->setTabActive(
'role_mapping');
1402 $this->
lng->txt(
"ldap_new_role_assignment"),
1403 $this->
ctrl->getLinkTarget($this,
'addRoleMapping')
1408 $propertie_form->setTitle($this->
lng->txt(
'ldap_role_settings'));
1409 $propertie_form->setFormAction($this->
ctrl->getFormAction($this,
"saveSyncronizationSettings"));
1410 $propertie_form->addCommandButton(
"saveSyncronizationSettings", $this->
lng->txt(
'save'));
1412 $role_active->setPostVar(
'role_sync_active');
1413 $role_active->setChecked($this->
server->enabledRoleSynchronization());
1414 $propertie_form->addItem($role_active);
1416 $binding->
setInfo($this->
lng->txt(
'ldap_role_bind_user_info'));
1418 $user->setPostVar(
"role_bind_user");
1419 $user->setValue($this->
server->getRoleBindDN());
1421 $user->setMaxLength(255);
1422 $binding->addCombinationItem(
"0", $user, $this->
lng->txt(
'ldap_role_bind_user'));
1425 $pass->setPostVar(
"role_bind_pass");
1426 $pass->setValue($this->
server->getRoleBindPassword());
1428 $pass->setMaxLength(100);
1429 $pass->setRetype(
false);
1430 $binding->addCombinationItem(
"1", $pass, $this->
lng->txt(
'ldap_role_bind_pass'));
1432 $propertie_form->addItem($binding);
1434 $this->tpl->addBlockFile(
'ADM_CONTENT',
'adm_content',
'tpl.ldap_role_mappings.html',
'components/ILIAS/LDAP');
1435 $this->tpl->setVariable(
"NEW_ASSIGNMENT_TBL", $propertie_form->getHTML());
1439 $mappings = $mapping_instance->getMappings();
1440 if (count($mappings)) {
1442 $table_gui->
setTitle($this->
lng->txt(
'ldap_role_group_assignments'));
1443 $table_gui->setData($mappings);
1444 $this->tpl->setVariable(
"RULES_TBL", $table_gui->getHTML());
1457 $propertie_form->setTitle($this->
lng->txt(
'ldap_edit_role_assignment'));
1458 if ($propertie_form->getItemByPostVar(
"url")) {
1459 $propertie_form->getItemByPostVar(
"url")->setValue($mapping->getURL());
1461 if ($propertie_form->getItemByPostVar(
"dn")) {
1462 $propertie_form->getItemByPostVar(
"dn")->setValue($mapping->getDN());
1464 if ($propertie_form->getItemByPostVar(
"member")) {
1465 $propertie_form->getItemByPostVar(
"member")->setValue($mapping->getMemberAttribute());
1467 if ($propertie_form->getItemByPostVar(
"memberisdn")) {
1468 $propertie_form->getItemByPostVar(
"memberisdn")->setChecked($mapping->getMemberISDN());
1470 if ($propertie_form->getItemByPostVar(
"role")) {
1471 $propertie_form->getItemByPostVar(
"role")->setValue($mapping->getRoleName());
1473 if ($propertie_form->getItemByPostVar(
"info")) {
1474 $propertie_form->getItemByPostVar(
"info")->setValue($mapping->getMappingInfo());
1476 if ($propertie_form->getItemByPostVar(
"info_type")) {
1477 $propertie_form->getItemByPostVar(
"info_type")->setChecked($mapping->getMappingInfoType());
1480 $this->tpl->setContent($propertie_form->getHTML());
1492 if ($propertie_form->checkInput() && $this->rbacReview->roleExists($propertie_form->getInput(
"role"))) {
1494 $mapping->setServerId($this->
server->getServerId());
1495 $mapping->setURL($propertie_form->getInput(
"url"));
1496 $mapping->setDN($propertie_form->getInput(
"dn"));
1497 $mapping->setMemberAttribute($propertie_form->getInput(
"member"));
1498 $mapping->setMemberISDN((
bool) $propertie_form->getInput(
"memberisdn"));
1499 $mapping->setRoleByName($propertie_form->getInput(
"role"));
1500 $mapping->setMappingInfo($propertie_form->getInput(
"info"));
1501 $mapping->setMappingInfoType((
bool) $propertie_form->getInput(
"info_type"));
1504 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'),
true);
1505 $this->
ctrl->redirect($this,
"roleMapping");
1507 if (!$this->rbacReview->roleExists($propertie_form->getInput(
"role"))) {
1508 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
"ldap_role_not_exists") .
" " .
1509 $propertie_form->getInput(
"role"));
1511 $propertie_form->setValuesByPost();
1512 $this->tpl->setContent($propertie_form->getHTML());
1521 if (!$this->mappings) {
1522 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_one'),
true);
1523 $this->
ctrl->redirect($this,
"roleMapping");
1530 $c_gui->setFormAction($this->
ctrl->getFormAction($this,
"deleteRoleMapping"));
1531 $c_gui->setHeaderText($this->
lng->txt(
"ldap_confirm_del_role_ass"));
1532 $c_gui->setCancel($this->
lng->txt(
"cancel"),
"roleMapping");
1533 $c_gui->setConfirm($this->
lng->txt(
"confirm"),
"deleteRoleMapping");
1535 foreach ($this->mappings as
$id) {
1538 $txt = $this->
lng->txt(
'obj_role') .
": " . $mapping->getRoleName() .
", ";
1539 $txt .= $this->
lng->txt(
'ldap_group_dn') .
": " . $mapping->getDN() .
", ";
1540 $txt .= $this->
lng->txt(
'ldap_server_short') .
" " . $mapping->getURL() .
", ";
1541 $txt .= $this->
lng->txt(
'ldap_group_member_short') .
" " . $mapping->getMemberAttribute();
1543 $c_gui->addItem(
"mappings[]", (
string) $id,
$txt);
1545 $this->tpl->setContent($c_gui->getHTML());
1552 $this->
ctrl->clearParameters($this);
1555 $this->tpl->setContent($this->form_gui->getHTML());
1563 $this->tabs_gui->setTabActive(
'settings');
1567 $this->tpl->setContent($this->form_gui->getHTML());
1578 if (!$this->ldap_server_id) {
1579 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_one'));
1587 $c_gui->setFormAction($this->
ctrl->getFormAction($this,
"deleteServerSettings"));
1588 $c_gui->setHeaderText($this->
lng->txt(
"ldap_confirm_del_server_settings"));
1589 $c_gui->setCancel($this->
lng->txt(
"cancel"),
"serverList");
1590 $c_gui->setConfirm($this->
lng->txt(
"confirm"),
"deleteServerSettings");
1594 $c_gui->addItem(
'server_ids[]', (
string) $setting->getServerId(), $setting->getName());
1596 $this->tpl->setContent($c_gui->getHTML());
1604 if (!$this->server_ids) {
1605 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
'select_one'));
1610 foreach ($this->server_ids as $server_id) {
1614 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'deleted'));
1615 $this->
ctrl->redirect($this,
"serverlist");
1626 $this->tabs_gui->activateTab(
'user_mapping');
1631 $this->tpl->setContent($propertie_form->getHTML());
1640 $this->
server->toggleActive(
true);
1649 $this->
server->toggleActive(
false);
1664 $this->tabs_gui->activateTab(
'role_mapping');
1666 if ($this->mapping_id) {
1667 $this->
ctrl->setParameter($this,
'mapping_id', $this->mapping_id);
1671 $propertie_form->setTitle($this->
lng->txt(
'ldap_mapping_table'));
1672 $propertie_form->setFormAction($this->
ctrl->getFormAction($this, $command));
1673 $propertie_form->addCommandButton($command, $this->
lng->txt(
'save'));
1674 $propertie_form->addCommandButton(
"roleMapping", $this->
lng->txt(
'cancel'));
1677 $url->setPostVar(
"url");
1679 $url->setMaxLength(255);
1680 $url->setRequired(
true);
1683 $group_dn->setPostVar(
"dn");
1684 $group_dn->setSize(50);
1685 $group_dn->setMaxLength(255);
1686 $group_dn->setInfo($this->
lng->txt(
'ldap_dn_info'));
1687 $group_dn->setRequired(
true);
1690 $member->setPostVar(
"member");
1691 $member->setSize(32);
1692 $member->setMaxLength(255);
1693 $member->setInfo($this->
lng->txt(
'ldap_member_info'));
1694 $member->setRequired(
true);
1697 $member_isdn->setPostVar(
"memberisdn");
1698 $member_isdn->setOptionTitle($this->
lng->txt(
'ldap_memberisdn'));
1701 $role->setPostVar(
"role");
1703 $role->setMaxLength(255);
1704 $role->setInfo($this->
lng->txt(
'ldap_role_info'));
1705 $role->setRequired(
true);
1711 $info->setInfo($this->
lng->txt(
'ldap_info_text_info'));
1714 $info_type->setPostVar(
"info_type");
1715 $info_type->setOptionTitle($this->
lng->txt(
'ldap_mapping_info_type'));
1717 $propertie_form->addItem(
$url);
1718 $propertie_form->addItem($group_dn);
1719 $propertie_form->addItem($member);
1720 $propertie_form->addItem($member_isdn);
1721 $propertie_form->addItem($role);
1722 $propertie_form->addItem($info);
1723 $propertie_form->addItem($info_type);
1725 return $propertie_form;
1736 if ($propertie_form->getItemByPostVar(
"url")) {
1737 $propertie_form->getItemByPostVar(
"url")->setValue($this->
server->getUrl());
1739 if ($this->mapping_id) {
1742 if ($propertie_form->getItemByPostVar(
"url")) {
1743 $propertie_form->getItemByPostVar(
"url")->setValue($mapping->getURL());
1745 if ($propertie_form->getItemByPostVar(
"dn")) {
1746 $propertie_form->getItemByPostVar(
"dn")->setValue($mapping->getDN());
1748 if ($propertie_form->getItemByPostVar(
"member")) {
1749 $propertie_form->getItemByPostVar(
"member")->setValue($mapping->getMemberAttribute());
1751 if ($propertie_form->getItemByPostVar(
"memberisdn")) {
1752 $propertie_form->getItemByPostVar(
"memberisdn")->setChecked($mapping->getMemberISDN());
1754 if ($propertie_form->getItemByPostVar(
"role")) {
1755 $propertie_form->getItemByPostVar(
"role")->setValue($mapping->getRoleName());
1757 if ($propertie_form->getItemByPostVar(
"info")) {
1758 $propertie_form->getItemByPostVar(
"info")->setValue($mapping->getMappingInfo());
1760 if ($propertie_form->getItemByPostVar(
"info_type")) {
1761 $propertie_form->getItemByPostVar(
"info_type")->setChecked($mapping->getMappingInfoType());
1765 $this->tpl->setContent($propertie_form->getHTML());
1776 if ($propertie_form->checkInput() && $this->rbacReview->roleExists($propertie_form->getInput(
"role"))) {
1778 $mapping->setServerId($this->
server->getServerId());
1779 $mapping->setURL($propertie_form->getInput(
"url"));
1780 $mapping->setDN($propertie_form->getInput(
"dn"));
1781 $mapping->setMemberAttribute($propertie_form->getInput(
"member"));
1782 $mapping->setMemberISDN((
bool) $propertie_form->getInput(
"memberisdn"));
1783 $mapping->setRoleByName($propertie_form->getInput(
"role"));
1784 $mapping->setMappingInfo($propertie_form->getInput(
"info"));
1785 $mapping->setMappingInfoType((
bool) $propertie_form->getInput(
"info_type"));
1788 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'),
true);
1789 $this->
ctrl->redirect($this,
"roleMapping");
1791 if (!$this->rbacReview->roleExists($propertie_form->getInput(
"role"))) {
1792 $this->main_tpl->setOnScreenMessage(
'failure', $this->
lng->txt(
"ldap_role_not_exists") .
" " .
1793 $propertie_form->getInput(
"role"));
1795 $propertie_form->setValuesByPost();
1796 $this->tpl->setContent($propertie_form->getHTML());
1805 $this->
server->setRoleBindDN($this->role_bind_user);
1806 $this->
server->setRoleBindPassword($this->role_bind_pass);
1807 $this->
server->enableRoleSynchronization($this->role_sync_active);
1810 if ($this->
server->getServerId()) {
1813 $this->main_tpl->setOnScreenMessage(
'success', $this->
lng->txt(
'settings_saved'),
true);
1814 $this->
ctrl->redirect($this,
"roleMapping");
static checkLDAPLib()
Check if ldap module is installed.
confirmDeleteRules()
Confirm delete rules.
userMappingToolbar()
Create Toolbar.
static get(string $a_var)
checkRoleAssignmentInput(int $a_rule_id=0)
Check role assignment input.
This class represents an option in a radio group.
Readable part of repository interface to ilComponentDataDB.
createRoleMapping()
Check add screen input and save to db.
loadRoleAssignmentRule(int $a_rule_id, bool $load_from_form=true)
Load input from form.
ilLDAPRoleGroupMappingSettings $role_mapping
__construct(int $a_auth_ref_id)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
initFormRoleAssignments(string $a_mode)
Init form table for new role assignments.
saveSyncronizationSettings()
save Syncronization Settings on Role Mapping screen
static _getServerList()
Get list of all configured servers.
readonly ILIAS UI Factory $ui_factory
Additional user data fields definition.
static stripSlashes(string $a_str, bool $a_strip_html=true, string $a_allow="")
static _getAllServer()
Get list of all configured servers.
readonly ILIAS Refinery Factory $refinery
prepareGlobalRoleSelection()
New implementation for InputForm.
getServer()
Get server settings.
updateRoleMapping()
Check edit screen input and save to db.
setSubTabs()
Set sub tabs for ldap section.
editRoleAssignment()
Edit role assignment.
static _getMappingRulesByClass(string $a_class)
Get mapping rule by objectClass.
server()
description: > This example shows how a Progress Bar can be rendered and updated by the server...
setValuesByArray()
set values of form array
ilGlobalTemplateInterface $main_tpl
showRoleSelection()
show role selection
ilGlobalTemplateInterface $tpl
confirmDeleteRoleMapping()
confirm delete role mappings
static _getRules($a_server_id)
Get all rules.
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
setMinWordLength(int $a_length)
ilPropertyFormGUI $form_gui
checkAccess(string $a_permission)
addRoleMapping()
Add Assigments for role mapping.
ilAccessHandler $ilAccess
ilComponentRepository $component_repository
const LDAP_BIND_ANONYMOUS
handleServerTableActions()
confirmDeleteServerSettings()
Confirm delete rules.
static http()
Fetches the global http state from ILIAS.
readonly ILIAS HTTP GlobalHttpState $http
static _lookupTitle(int $obj_id)
deleteRules()
delete role assignment rule
ilLDAPAttributeMapping $mapping
addRoleAutoCompleteObject()
Add Member for autoComplete.
addRoleAssignment()
add new role assignment
static _lookupGlobalRole(int $a_server_id)
userMapping()
Ldap User Mapping.
roleAssignments()
Edit role assignments.
roleMapping()
Role Mapping Tab.
updateRoleAssignment()
update role assignment
setTitle(string $a_title, string $a_icon="", string $a_icon_alt="")
array $attribute_mappings
This class stores the settings that define the mapping between LDAP attribute and user profile fields...
static _sortIds(array $a_ids, string $a_table, string $a_field, string $a_id_name)
Function that sorts ids by a given table field using WHERE IN E.g: __sort(array(6,7),'usr_data','lastname','usr_id') => sorts by lastname.
initUserMappingForm()
Create Property Form GUI for User Mapping.
saveRoleSelection()
Save role selection.
static _getInstanceByRuleId(int $a_rule_id)
form( $class_path, string $cmd, string $submit_caption="")
static _getInstanceByServerId(int $a_server_id)
Get instance of class.
readonly ILIAS UI Renderer $ui_renderer
read()
Read mapping settings from db.
getAttributeMappingKeys()
Get all possible attribute keys for mapping ldap attribute to ilias user attributes.
$id
plugin.php for ilComponentBuildPluginInfoObjectiveTest::testAddPlugins
This class represents a text area property in a property form.
save()
Save mapping rules to db.
ilLDAPRoleAssignmentRule $rule
initRoleMappingForm(string $command)
init propertyformgui for Assignment of LDAP Attributes to ILIAS User Profile
static set(string $a_var, $a_val)
Set a value.
static _getInstanceByServerId(int $a_server_id)
ilLDAPRoleAssignmentRule $role_mapping_rule
getRoleAssignmentTable()
Show active role assignments.
editRoleMapping()
Edit Assigments for role mapping.