ILIAS  Release_4_0_x_branch Revision 61816
 All Data Structures Namespaces Files Functions Variables Groups Pages
ilObjAuthSettingsGUI Class Reference

Class ilObjAuthSettingsGUI. More...

+ Inheritance diagram for ilObjAuthSettingsGUI:
+ Collaboration diagram for ilObjAuthSettingsGUI:

Public Member Functions

 ilObjAuthSettingsGUI ($a_data, $a_id, $a_call_by_reference, $a_prepare_output=true)
 Constructor public.
 viewObject ()
 list childs of current object
 authSettingsObject ()
 display settings menu
 saveLoginInfoObject ()
 saves the login information data
 loginInfoObject ()
 displays login information of all installed languages
 initLoginForm ()
 Init login form.
 setDefLangFirst ($a_def_language, $a_languages)
 returns an array of all installed languages, default language at the first position
 cancelObject ()
 setAuthModeObject ()
 editCASObject ()
 Configure cas settings.
 saveCASObject ()
 validates all input data, save them to database if correct and active chosen auth mode
 editSOAPObject ()
 Configure soap settings.
 testSoapAuthConnectionObject ()
 saveSOAPObject ()
 validates all input data, save them to database if correct and active chosen auth mode
 editScriptObject ()
 Configure Custom settings.
 saveScriptObject ()
 validates all input data, save them to database if correct and active chosen auth mode
 getAuthModeTitle ()
 get the title of auth mode
 updateAuthRolesObject ()
 updateAuthModeDeterminationObject ()
 update auth mode determination
executeCommand ()
 execute command
 getAdminTabs (&$tabs_gui)
 administration tabs show only permissions and trash folder
 getTabs (&$tabs_gui)
 get tabs public
 setSubTabs ($a_tab)
 set sub tabs
- 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
 createObject ()
 create new object form
 cancelObject ($in_rep=false)
 cancel action and go back to previous page public
 saveObject ()
 save object
 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.

Protected Member Functions

 initAuthModeDetermination ()
 init auth mode determinitation form
- Protected Member Functions inherited from ilObjectGUI
 assignObject ()
 prepareOutput ()
 prepare output
 setTitleAndDescription ()
 called by prepare output
 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)
 displayEditForm ($fields)
 display edit form (usually called by editObject)
 afterUpdate ()
 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
 __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.
 fillCloneSearchTemplate ($a_tpl_varname, $a_type)
 Add an object search in case the number of existing objects is too big to offer a selection list.
 searchCloneSourceObject ()
 Search clone source by title.
 buildCloneSelect ($existing_objs)
 Build a select box for clonable objects (permission write)
 getCenterColumnHTML ()
 Get center column.
 getRightColumnHTML ()
 Display right column.
 setColumnSettings ($column_gui)
 May be overwritten in subclasses.
 checkPermission ($a_perm, $a_cmd="")

Additional Inherited Members

- 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

Detailed Description

Member Function Documentation

ilObjAuthSettingsGUI::authSettingsObject ( )

display settings menu

public

Definition at line 56 of file class.ilObjAuthSettingsGUI.php.

References $ilSetting, $name, ilAuthUtils\_getActiveAuthModes(), ilLDAPServer\_getActiveServerList(), ilAuthUtils\_getAllAuthModes(), ilAuthUtils\_getAuthModeName(), ilObjUser\_getNumberOfUsersPerAuthMode(), ilObjRole\_lookupRegisterAllowed(), AUTH_CAS, AUTH_LDAP, AUTH_LOCAL, AUTH_RADIUS, AUTH_SCRIPT, AUTH_SHIBBOLETH, ilObjectGUI\getTemplateFile(), initAuthModeDetermination(), and setSubTabs().

Referenced by updateAuthModeDeterminationObject().

{
global $rbacsystem, $ilSetting;
if (!$rbacsystem->checkAccess("visible,read",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
$this->tabs_gui->setTabActive('authentication_settings');
$this->setSubTabs('authSettings');
$this->tabs_gui->setSubTabActive("auth_settings");
$this->getTemplateFile("general");
$this->tpl->setVariable("FORMACTION", $this->ctrl->getFormAction($this));
$this->tpl->setVariable("TXT_AUTH_TITLE", $this->lng->txt("auth_select"));
$this->tpl->setVariable("TXT_AUTH_MODE", $this->lng->txt("auth_mode"));
$this->tpl->setVariable("TXT_AUTH_DEFAULT", $this->lng->txt("default"));
$this->tpl->setVariable("TXT_AUTH_ACTIVE", $this->lng->txt("active"));
$this->tpl->setVariable("TXT_AUTH_NUM_USERS", $this->lng->txt("num_users"));
$this->tpl->setVariable("TXT_LOCAL", $this->lng->txt("auth_local"));
$this->tpl->setVariable("TXT_LDAP", $this->lng->txt("auth_ldap"));
$this->tpl->setVariable("TXT_SHIB", $this->lng->txt("auth_shib"));
$this->tpl->setVariable("TXT_CAS", $this->lng->txt("auth_cas"));
$this->tpl->setVariable("TXT_RADIUS", $this->lng->txt("auth_radius"));
$this->tpl->setVariable("TXT_SCRIPT", $this->lng->txt("auth_script"));
foreach($auth_modes as $mode => $mode_name)
{
//echo "-".$ilSetting->get('auth_mode')."-".$mode."-";
if ($ilSetting->get('auth_mode') == $mode)
{
$this->tpl->setVariable("NUM_".strtoupper($mode_name),
((int) $auth_cnt[$mode_name] + $auth_cnt["default"])." (".$this->lng->txt("auth_per_default").
": ".$auth_cnt["default"].")");
}
else
{
$this->tpl->setVariable("NUM_".strtoupper($mode_name),
(int) $auth_cnt[$mode_name]);
}
}
$this->tpl->setVariable("TXT_CONFIGURE", $this->lng->txt("auth_configure"));
$this->tpl->setVariable("TXT_AUTH_REMARK", $this->lng->txt("auth_remark_non_local_auth"));
$this->tpl->setVariable("TXT_SUBMIT", $this->lng->txt("save"));
$this->tpl->setVariable("CMD_SUBMIT", "setAuthMode");
// local vars
$checked = "checked=\"checked\"";
$disabled = "disabled=\"disabled\"";
$style_disabled = "_disabled";
// icon handlers
$icon_ok = "<img src=\"".ilUtil::getImagePath("icon_ok.gif")."\" alt=\"".$this->lng->txt("enabled")."\" title=\"".$this->lng->txt("enabled")."\" border=\"0\" vspace=\"0\"/>";
$icon_not_ok = "<img src=\"".ilUtil::getImagePath("icon_not_ok.gif")."\" alt=\"".$this->lng->txt("disabled")."\" title=\"".$this->lng->txt("disabled")."\" border=\"0\" vspace=\"0\"/>";
$this->tpl->setVariable("AUTH_LOCAL_ACTIVE", $icon_ok);
include_once('Services/LDAP/classes/class.ilLDAPServer.php');
$this->tpl->setVariable('AUTH_LDAP_ACTIVE',count(ilLDAPServer::_getActiveServerList()) ? $icon_ok : $icon_not_ok);
#$this->tpl->setVariable("AUTH_LDAP_ACTIVE", $this->ilias->getSetting('ldap_active') ? $icon_ok : $icon_not_ok);
$this->tpl->setVariable("AUTH_RADIUS_ACTIVE", $this->ilias->getSetting('radius_active') ? $icon_ok : $icon_not_ok);
$this->tpl->setVariable("AUTH_SHIB_ACTIVE", $this->ilias->getSetting('shib_active') ? $icon_ok : $icon_not_ok);
$this->tpl->setVariable("AUTH_SCRIPT_ACTIVE", $this->ilias->getSetting('script_active') ? $icon_ok : $icon_not_ok);
$this->tpl->setVariable("AUTH_CAS_ACTIVE", $this->ilias->getSetting('cas_active') ? $icon_ok : $icon_not_ok);
// alter style and disable buttons depending on current selection
switch ($this->ilias->getSetting('auth_mode'))
{
case AUTH_LOCAL: // default
$this->tpl->setVariable("CHK_LOCAL", $checked);
break;
case AUTH_LDAP: // LDAP
$this->tpl->setVariable("CHK_LDAP", $checked);
break;
case AUTH_SHIBBOLETH: // SHIB
$this->tpl->setVariable("CHK_SHIB", $checked);
break;
case AUTH_RADIUS: // RADIUS
$this->tpl->setVariable("CHK_RADIUS", $checked);
break;
case AUTH_CAS: // CAS
$this->tpl->setVariable("CHK_CAS", $checked);
break;
case AUTH_SCRIPT: // script
$this->tpl->setVariable("CHK_SCRIPT", $checked);
break;
}
// auth mode determinitation
{
$this->tpl->setVariable('TABLE_AUTH_DETERMINATION',$this->form->getHTML());
}
// roles table
$this->tpl->setVariable("FORMACTION_ROLES",
$this->ctrl->getFormAction($this));
$this->tpl->setVariable("TXT_AUTH_ROLES", $this->lng->txt("auth_active_roles"));
$this->tpl->setVariable("TXT_ROLE", $this->lng->txt("obj_role"));
$this->tpl->setVariable("TXT_ROLE_AUTH_MODE", $this->lng->txt("auth_role_auth_mode"));
$this->tpl->setVariable("CMD_SUBMIT_ROLES", "updateAuthRoles");
include_once("./Services/AccessControl/classes/class.ilObjRole.php");
// auth mode selection
include_once('./Services/Authentication/classes/class.ilAuthUtils.php');
$active_auth_modes = ilAuthUtils::_getActiveAuthModes();
foreach ($reg_roles as $role)
{
foreach ($active_auth_modes as $auth_name => $auth_key)
{
// do not list auth modes with external login screen
// even not default, because it can easily be set to
// a non-working auth mode
if ($auth_name == "default" || $auth_name == "cas"
|| $auth_name == "shibboleth" || $auth_name == 'ldap')
{
continue;
}
$this->tpl->setCurrentBlock("auth_mode_selection");
if ($auth_name == 'default')
{
$name = $this->lng->txt('auth_'.$auth_name)." (".$this->lng->txt('auth_'.ilAuthUtils::_getAuthModeName($auth_key)).")";
}
else
{
$name = $this->lng->txt('auth_'.$auth_name);
}
$this->tpl->setVariable("AUTH_MODE_NAME", $name);
$this->tpl->setVariable("AUTH_MODE", $auth_name);
if ($role['auth_mode'] == $auth_name)
{
$this->tpl->setVariable("SELECTED_AUTH_MODE", "selected=\"selected\"");
}
$this->tpl->parseCurrentBlock();
} // END auth_mode selection
$this->tpl->setCurrentBlock("roles");
$this->tpl->setVariable("ROLE", $role['title']);
$this->tpl->setVariable("ROLE_ID", $role['id']);
$this->tpl->parseCurrentBlock();
}
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::cancelObject ( )

Definition at line 413 of file class.ilObjAuthSettingsGUI.php.

{
$this->ctrl->redirect($this, "authSettings");
}
ilObjAuthSettingsGUI::editCASObject ( )

Configure cas settings.

public

Definition at line 491 of file class.ilObjAuthSettingsGUI.php.

References $_SESSION, $ilSetting, formSelect(), and ilObjectGUI\getTemplateFile().

{
global $rbacsystem, $rbacreview, $ilSetting;
if (!$rbacsystem->checkAccess("read",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
$this->tabs_gui->setTabActive('auth_cas');
// get template
$this->getTemplateFile("cas");
// get all settings
$settings = $ilSetting->getAll();
// get values in error case
if ($_SESSION["error_post_vars"])
{
if ($_SESSION["error_post_vars"]["cas"]["active"] == "1")
{
$this->tpl->setVariable("CHK_CAS_ACTIVE", "checked=\"checked\"");
}
if ($_SESSION["error_post_vars"]["cas"]["create_users"] == "1")
{
$this->tpl->setVariable("CHK_CREATE_USERS", "checked=\"checked\"");
}
if ($_SESSION["error_post_vars"]["cas"]["allow_local"] == "1")
{
$this->tpl->setVariable("CHK_ALLOW_LOCAL", "checked=\"checked\"");
}
$this->tpl->setVariable("CAS_SERVER", $_SESSION["error_post_vars"]["cas"]["server"]);
$this->tpl->setVariable("CAS_PORT", $_SESSION["error_post_vars"]["cas"]["port"]);
$this->tpl->setVariable("CAS_URI", $_SESSION["error_post_vars"]["cas"]["uri"]);
$this->tpl->setVariable("CAS_LOGIN_INSTRUCTIONS", $_SESSION["error_post_vars"]["cas"]["login_instructions"]);
$current_default_role = $_SESSION["error_post_vars"]["cas"]["user_default_role"];
}
else
{
if ($settings["cas_active"] == "1")
{
$this->tpl->setVariable("CHK_CAS_ACTIVE", "checked=\"checked\"");
}
if ($settings["cas_create_users"] == "1")
{
$this->tpl->setVariable("CHK_CREATE_USERS", "checked=\"checked\"");
}
if ($settings["cas_allow_local"] == "1")
{
$this->tpl->setVariable("CHK_ALLOW_LOCAL", "checked=\"checked\"");
}
$this->tpl->setVariable("CAS_SERVER", $settings["cas_server"]);
$this->tpl->setVariable("CAS_PORT", $settings["cas_port"]);
$this->tpl->setVariable("CAS_URI", $settings["cas_uri"]);
$this->tpl->setVariable("CAS_LOGIN_INSTRUCTIONS", $settings["cas_login_instructions"]);
$current_default_role = $settings["cas_user_default_role"];
}
// compose role list
$role_list = $rbacreview->getRolesByFilter(2,$this->object->getId());
if (!$current_default_role)
{
$current_default_role = 4;
}
$roles = array();
foreach ($role_list as $role)
{
$roles[$role['obj_id']] = $role['title'];
}
$selectElement = ilUtil::formSelect($current_default_role,
"cas[user_default_role]", $roles, false, true);
$this->tpl->setVariable("CAS_USER_DEFAULT_ROLE", $selectElement);
$this->tpl->setVariable("FORMACTION", $this->ctrl->getFormAction($this));
$this->tpl->setVariable("COLSPAN", 3);
$this->tpl->setVariable("TXT_CAS_TITLE", $this->lng->txt("auth_cas_auth"));
$this->tpl->setVariable("TXT_CAS_DESC", $this->lng->txt("auth_cas_auth_desc"));
$this->tpl->setVariable("TXT_OPTIONS", $this->lng->txt("options"));
$this->tpl->setVariable("TXT_CAS_ACTIVE", $this->lng->txt("active"));
$this->tpl->setVariable("TXT_CAS_SERVER", $this->lng->txt("server"));
$this->tpl->setVariable("TXT_CAS_SERVER_DESC", $this->lng->txt("auth_cas_server_desc"));
$this->tpl->setVariable("TXT_CAS_PORT", $this->lng->txt("port"));
$this->tpl->setVariable("TXT_CAS_PORT_DESC", $this->lng->txt("auth_cas_port_desc"));
$this->tpl->setVariable("TXT_CAS_URI", $this->lng->txt("uri"));
$this->tpl->setVariable("TXT_CAS_URI_DESC", $this->lng->txt("auth_cas_uri_desc"));
$this->tpl->setVariable("TXT_CAS_LOGIN_INSTRUCTIONS", $this->lng->txt("auth_login_instructions"));
$this->tpl->setVariable("TXT_CREATE_USERS", $this->lng->txt("auth_create_users"));
$this->tpl->setVariable("TXT_CREATE_USERS_DESC", $this->lng->txt("auth_cas_create_users_desc"));
$this->tpl->setVariable("TXT_CAS_USER_DEFAULT_ROLE", $this->lng->txt("auth_user_default_role"));
$this->tpl->setVariable("TXT_CAS_USER_DEFAULT_ROLE_DESC",
$this->lng->txt("auth_cas_user_default_role_desc"));
$this->tpl->setVariable("TXT_ALLOW_LOCAL", $this->lng->txt("auth_allow_local"));
$this->tpl->setVariable("TXT_ALLOW_LOCAL_DESC", $this->lng->txt("auth_cas_allow_local_desc"));
$this->tpl->setVariable("TXT_REQUIRED_FLD", $this->lng->txt("required_field"));
$this->tpl->setVariable("TXT_CANCEL", $this->lng->txt("cancel"));
$this->tpl->setVariable("TXT_SUBMIT", $this->lng->txt("save"));
$this->tpl->setVariable("CMD_SUBMIT", "saveCAS");
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::editScriptObject ( )

Configure Custom settings.

public

Definition at line 851 of file class.ilObjAuthSettingsGUI.php.

References $_SESSION, and ilObjectGUI\getTemplateFile().

{
global $rbacsystem;
if (!$rbacsystem->checkAccess("write",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
if ($_SESSION["error_post_vars"])
{
$this->tpl->setVariable("AUTH_SCRIPT_NAME", $_SESSION["error_post_vars"]["auth_script"]["name"]);
}
else
{
// set already saved data
$settings = $this->ilias->getAllSettings();
$this->tpl->setVariable("AUTH_SCRIPT_NAME", $settings["auth_script_name"]);
}
$this->tabs_gui->setTabActive('auth_script');
$this->getTemplateFile("script");
$this->tpl->setVariable("FORMACTION", $this->ctrl->getFormAction($this));
$this->tpl->setVariable("COLSPAN", 3);
$this->tpl->setVariable("TXT_AUTH_SCRIPT_TITLE", $this->lng->txt("auth_script_configure"));
$this->tpl->setVariable("TXT_OPTIONS", $this->lng->txt("options"));
$this->tpl->setVariable("TXT_AUTH_SCRIPT_NAME", $this->lng->txt("auth_script_name"));
$this->tpl->setVariable("TXT_REQUIRED_FLD", $this->lng->txt("required_field"));
$this->tpl->setVariable("TXT_CANCEL", $this->lng->txt("cancel"));
$this->tpl->setVariable("TXT_SUBMIT", $this->lng->txt("save"));
$this->tpl->setVariable("CMD_SUBMIT", "saveScript");
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::editSOAPObject ( )

Configure soap settings.

public

Definition at line 638 of file class.ilObjAuthSettingsGUI.php.

References $_POST, $_SESSION, $ilCtrl, $ilSetting, ilObjectGUI\$lng, $ret, formSelect(), and ilUtil\stripSlashes().

Referenced by testSoapAuthConnectionObject().

{
global $rbacsystem, $rbacreview, $ilSetting, $ilCtrl, $lng;
if (!$rbacsystem->checkAccess("read",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
$this->tabs_gui->setTabActive('auth_soap');
// get template
$stpl = new ilTemplate("tpl.auth_soap.html", true, true, "");
//$this->getTemplateFile("soap");
// get all settings
$settings = $ilSetting->getAll();
// get values in error case
if ($_SESSION["error_post_vars"])
{
if ($_SESSION["error_post_vars"]["soap"]["active"] == "1")
{
$stpl->setVariable("CHK_SOAP_ACTIVE", "checked=\"checked\"");
}
if ($_SESSION["error_post_vars"]["soap"]["use_https"] == "1")
{
$stpl->setVariable("CHK_USE_HTTPS", "checked=\"checked\"");
}
if ($_SESSION["error_post_vars"]["soap"]["create_users"] == "1")
{
$stpl->setVariable("CHK_CREATE_USERS", "checked=\"checked\"");
}
if ($_SESSION["error_post_vars"]["soap"]["allow_local"] == "1")
{
$stpl->setVariable("CHK_ALLOW_LOCAL", "checked=\"checked\"");
}
if ($_SESSION["error_post_vars"]["soap"]["account_mail"] == "1")
{
$stpl->setVariable("CHK_ACCOUNT_MAIL", "checked=\"checked\"");
}
if ($_SESSION["error_post_vars"]["soap"]["use_dotnet"] == "1")
{
$stpl->setVariable("CHK_USEDOTNET", "checked=\"checked\"");
}
$stpl->setVariable("SOAP_SERVER", $_SESSION["error_post_vars"]["soap"]["server"]);
$stpl->setVariable("SOAP_PORT", $_SESSION["error_post_vars"]["soap"]["port"]);
$stpl->setVariable("SOAP_URI", $_SESSION["error_post_vars"]["soap"]["uri"]);
$stpl->setVariable("SOAP_NAMESPACE", $_SESSION["error_post_vars"]["soap"]["namespace"]);
$current_default_role = $_SESSION["error_post_vars"]["soap"]["user_default_role"];
}
else
{
if ($settings["soap_auth_active"] == "1")
{
$stpl->setVariable("CHK_SOAP_ACTIVE", "checked=\"checked\"");
}
if ($settings["soap_auth_use_https"] == "1")
{
$stpl->setVariable("CHK_USE_HTTPS", "checked=\"checked\"");
}
if ($settings["soap_auth_create_users"] == "1")
{
$stpl->setVariable("CHK_CREATE_USERS", "checked=\"checked\"");
}
if ($settings["soap_auth_allow_local"] == "1")
{
$stpl->setVariable("CHK_ALLOW_LOCAL", "checked=\"checked\"");
}
if ($settings["soap_auth_account_mail"] == "1")
{
$stpl->setVariable("CHK_ACCOUNT_MAIL", "checked=\"checked\"");
}
if ($settings["soap_auth_use_dotnet"] == "1")
{
$stpl->setVariable("CHK_USE_DOTNET", "checked=\"checked\"");
}
$stpl->setVariable("SOAP_SERVER", $settings["soap_auth_server"]);
$stpl->setVariable("SOAP_PORT", $settings["soap_auth_port"]);
$stpl->setVariable("SOAP_URI", $settings["soap_auth_uri"]);
$stpl->setVariable("SOAP_NAMESPACE", $settings["soap_auth_namespace"]);
$current_default_role = $settings["soap_auth_user_default_role"];
}
// compose role list
$role_list = $rbacreview->getRolesByFilter(2,$this->object->getId());
if (!$current_default_role)
{
$current_default_role = 4;
}
$roles = array();
foreach ($role_list as $role)
{
$roles[$role['obj_id']] = $role['title'];
}
$selectElement = ilUtil::formSelect($current_default_role,
"soap[user_default_role]", $roles, false, true);
$stpl->setVariable("SOAP_USER_DEFAULT_ROLE", $selectElement);
$stpl->setVariable("FORMACTION", $this->ctrl->getFormAction($this));
$stpl->setVariable("COLSPAN", 3);
$stpl->setVariable("TXT_SOAP_TITLE", $this->lng->txt("auth_soap_auth"));
$stpl->setVariable("TXT_SOAP_DESC", $this->lng->txt("auth_soap_auth_desc"));
$stpl->setVariable("TXT_OPTIONS", $this->lng->txt("options"));
$stpl->setVariable("TXT_SOAP_ACTIVE", $this->lng->txt("active"));
$stpl->setVariable("TXT_SOAP_SERVER", $this->lng->txt("server"));
$stpl->setVariable("TXT_SOAP_SERVER_DESC", $this->lng->txt("auth_soap_server_desc"));
$stpl->setVariable("TXT_SOAP_PORT", $this->lng->txt("port"));
$stpl->setVariable("TXT_SOAP_PORT_DESC", $this->lng->txt("auth_soap_port_desc"));
$stpl->setVariable("TXT_SOAP_URI", $this->lng->txt("uri"));
$stpl->setVariable("TXT_SOAP_URI_DESC", $this->lng->txt("auth_soap_uri_desc"));
$stpl->setVariable("TXT_SOAP_NAMESPACE", $this->lng->txt("auth_soap_namespace"));
$stpl->setVariable("TXT_SOAP_NAMESPACE_DESC", $this->lng->txt("auth_soap_namespace_desc"));
$stpl->setVariable("TXT_USE_DOTNET", $this->lng->txt("auth_soap_use_dotnet"));
$stpl->setVariable("TXT_USE_HTTPS", $this->lng->txt("auth_soap_use_https"));
$stpl->setVariable("TXT_CREATE_USERS", $this->lng->txt("auth_create_users"));
$stpl->setVariable("TXT_CREATE_USERS_DESC", $this->lng->txt("auth_soap_create_users_desc"));
$stpl->setVariable("TXT_ACCOUNT_MAIL", $this->lng->txt("user_send_new_account_mail"));
$stpl->setVariable("TXT_ACCOUNT_MAIL_DESC", $this->lng->txt("auth_new_account_mail_desc"));
$stpl->setVariable("TXT_SOAP_USER_DEFAULT_ROLE", $this->lng->txt("auth_user_default_role"));
$stpl->setVariable("TXT_SOAP_USER_DEFAULT_ROLE_DESC",
$this->lng->txt("auth_soap_user_default_role_desc"));
$stpl->setVariable("TXT_ALLOW_LOCAL", $this->lng->txt("auth_allow_local"));
$stpl->setVariable("TXT_ALLOW_LOCAL_DESC", $this->lng->txt("auth_soap_allow_local_desc"));
$stpl->setVariable("TXT_REQUIRED_FLD", $this->lng->txt("required_field"));
$stpl->setVariable("TXT_CANCEL", $this->lng->txt("cancel"));
$stpl->setVariable("TXT_SUBMIT", $this->lng->txt("save"));
$stpl->setVariable("CMD_SUBMIT", "saveSOAP");
// test form
include_once("./Services/Form/classes/class.ilPropertyFormGUI.php");
$form = new ilPropertyFormGUI();
$form->setFormAction($ilCtrl->getFormAction($this));
$form->setTitle("Test Request");
$text_prop = new ilTextInputGUI("ext_uid", "ext_uid");
$form->addItem($text_prop);
$text_prop2 = new ilTextInputGUI("soap_pw", "soap_pw");
$form->addItem($text_prop2);
$cb = new ilCheckboxInputGUI("new_user", "new_user");
$form->addItem($cb);
$form->addCommandButton("testSoapAuthConnection",
"Send");
if ($ilCtrl->getCmd() == "testSoapAuthConnection")
{
include_once("./Services/SOAPAuth/classes/class.ilSOAPAuth.php");
$ret = "<br />".ilSOAPAuth::testConnection(
(boolean) $_POST["new_user"]
);
}
$stpl->setVariable("TEST_FORM", $form->getHtml().$ret);
$this->tpl->setContent($stpl->get());
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

& ilObjAuthSettingsGUI::executeCommand ( )

execute command

Reimplemented from ilObjectGUI.

Definition at line 1072 of file class.ilObjAuthSettingsGUI.php.

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

{
global $ilAccess,$ilErr;
$next_class = $this->ctrl->getNextClass($this);
$cmd = $this->ctrl->getCmd();
$this->prepareOutput();
if(!$ilAccess->checkAccess('read','',$this->object->getRefId()))
{
$ilErr->raiseError($this->lng->txt('msg_no_perm_read'),$ilErr->WARNING);
}
switch($next_class)
{
case 'ilregistrationsettingsgui':
include_once './Services/Registration/classes/class.ilRegistrationSettingsGUI.php';
// Enable tabs
$this->tabs_gui->setTabActive('registration_settings');
$registration_gui =& new ilRegistrationSettingsGUI();
$this->ctrl->forwardCommand($registration_gui);
break;
case 'ilpermissiongui':
// Enable tabs
$this->tabs_gui->setTabActive('perm_settings');
include_once("Services/AccessControl/classes/class.ilPermissionGUI.php");
$perm_gui =& new ilPermissionGUI($this);
$ret =& $this->ctrl->forwardCommand($perm_gui);
break;
case 'illdapsettingsgui':
// Enable Tabs
$this->tabs_gui->setTabActive('auth_ldap');
include_once './Services/LDAP/classes/class.ilLDAPSettingsGUI.php';
$ldap_settings_gui = new ilLDAPSettingsGUI($this->object->getRefId());
$this->ctrl->forwardCommand($ldap_settings_gui);
break;
case 'ilauthshibbolethsettingsgui':
$this->tabs_gui->setTabActive('auth_shib');
include_once('./Services/AuthShibboleth/classes/class.ilAuthShibbolethSettingsGUI.php');
$shib_settings_gui = new ilAuthShibbolethSettingsGUI($this->object->getRefId());
$this->ctrl->forwardCommand($shib_settings_gui);
break;
case 'ilradiussettingsgui':
$this->tabs_gui->setTabActive('auth_radius');
include_once './Services/Radius/classes/class.ilRadiusSettingsGUI.php';
$radius_settings_gui = new ilRadiusSettingsGUI($this->object->getRefId());
$this->ctrl->forwardCommand($radius_settings_gui);
break;
default:
if(!$cmd)
{
$cmd = "authSettings";
}
$cmd .= "Object";
$this->$cmd();
break;
}
return true;
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::getAdminTabs ( $tabs_gui)

administration tabs show only permissions and trash folder

Reimplemented from ilObjectGUI.

Definition at line 1148 of file class.ilObjAuthSettingsGUI.php.

References getTabs().

{
$this->getTabs($tabs_gui);
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::getAuthModeTitle ( )

get the title of auth mode

public

Returns
string language dependent title of auth mode

Definition at line 925 of file class.ilObjAuthSettingsGUI.php.

References AUTH_LDAP, AUTH_LOCAL, AUTH_RADIUS, AUTH_SCRIPT, and AUTH_SHIBBOLETH.

Referenced by saveScriptObject(), and setAuthModeObject().

{
switch ($this->ilias->getSetting("auth_mode"))
{
case AUTH_LOCAL:
return $this->lng->txt("auth_local");
break;
case AUTH_LDAP:
return $this->lng->txt("auth_ldap");
break;
return $this->lng->txt("auth_shib");
break;
return $this->lng->txt("auth_radius");
break;
return $this->lng->txt("auth_script");
break;
default:
return $this->lng->txt("unknown");
break;
}
}

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::getTabs ( $tabs_gui)

get tabs public

Parameters
objecttabs gui object

Reimplemented from ilObjectGUI.

Definition at line 1158 of file class.ilObjAuthSettingsGUI.php.

Referenced by getAdminTabs().

{
global $rbacsystem;
$this->ctrl->setParameter($this,"ref_id",$this->object->getRefId());
if ($rbacsystem->checkAccess("visible,read",$this->object->getRefId()))
{
$tabs_gui->addTarget('registration_settings',
$this->ctrl->getLinkTargetByClass('ilregistrationsettingsgui','view'));
$tabs_gui->addTarget("authentication_settings", $this->ctrl->getLinkTarget($this, "authSettings"),
"", "", "");
$tabs_gui->addTarget("auth_ldap", $this->ctrl->getLinkTargetByClass('illdapsettingsgui','serverList'),
"", "", "");
#$tabs_gui->addTarget("auth_ldap", $this->ctrl->getLinkTarget($this, "editLDAP"),
# "", "", "");
$tabs_gui->addTarget('auth_shib',$this->ctrl->getLinkTargetByClass('ilauthshibbolethsettingsgui','settings'));
$tabs_gui->addTarget("auth_cas", $this->ctrl->getLinkTarget($this, "editCAS"),
"", "", "");
$tabs_gui->addTarget("auth_radius", $this->ctrl->getLinkTargetByClass('ilradiussettingsgui', "settings"),
"", "", "");
$tabs_gui->addTarget("auth_soap", $this->ctrl->getLinkTarget($this, "editSOAP"),
"", "", "");
}
if ($rbacsystem->checkAccess('edit_permission',$this->object->getRefId()))
{
$tabs_gui->addTarget("perm_settings",
$this->ctrl->getLinkTargetByClass(array(get_class($this),'ilpermissiongui'), "perm"),
array("perm","info","owner"), 'ilpermissiongui');
}
}

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::ilObjAuthSettingsGUI (   $a_data,
  $a_id,
  $a_call_by_reference,
  $a_prepare_output = true 
)

Constructor public.

Definition at line 25 of file class.ilObjAuthSettingsGUI.php.

References ilObjectGUI\ilObjectGUI().

{
$this->type = "auth";
$this->ilObjectGUI($a_data,$a_id,$a_call_by_reference,$a_prepare_output);
$this->lng->loadLanguageModule('registration');
define('LDAP_DEFAULT_PORT',389);
define('RADIUS_DEFAULT_PORT',1812);
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::initAuthModeDetermination ( )
protected

init auth mode determinitation form

protected

Definition at line 976 of file class.ilObjAuthSettingsGUI.php.

References ilAuthModeDetermination\_getInstance(), AUTH_LDAP, AUTH_LOCAL, AUTH_RADIUS, AUTH_SOAP, and ilFormPropertyGUI\setInfo().

Referenced by authSettingsObject().

{
if(is_object($this->form))
{
return true;
}
// Are there any authentication methods that support automatic determination ?
include_once('Services/Authentication/classes/class.ilAuthModeDetermination.php');
if($det->getCountActiveAuthModes() <= 1)
{
return false;
}
include_once('./Services/Form/classes/class.ilPropertyFormGUI.php');
$this->form = new ilPropertyFormGUI();
$this->form->setFormAction($this->ctrl->getFormAction($this));
$this->form->setTableWidth('100%');
$this->form->setTitle($this->lng->txt('auth_auth_mode_determination'));
$this->form->addCommandButton('updateAuthModeDetermination',$this->lng->txt('save'));
$this->form->addCommandButton('authSettings',$this->lng->txt('cancel'));
$kind = new ilRadioGroupInputGUI($this->lng->txt('auth_kind_determination'),'kind');
$kind->setInfo($this->lng->txt('auth_mode_determination_info'));
$kind->setValue($det->getKind());
$kind->setRequired(true);
$option_user = new ilRadioOption($this->lng->txt('auth_by_user'),0);
$kind->addOption($option_user);
$option_determination = new ilRadioOption($this->lng->txt('auth_automatic'),1);
include_once('Services/Authentication/classes/class.ilAuthUtils.php');
$auth_sequenced = $det->getAuthModeSequence();
$counter = 1;
foreach($auth_sequenced as $auth_mode)
{
switch($auth_mode)
{
case AUTH_LDAP:
$text = $this->lng->txt('auth_ldap');
break;
$text = $this->lng->txt('auth_radius');
break;
case AUTH_LOCAL:
$text = $this->lng->txt('auth_local');
break;
case AUTH_SOAP:
$text = $this->lng->txt('auth_soap');
break;
}
$pos = new ilTextInputGUI($text,'position['.$auth_mode.']');
$pos->setValue($counter++);
$pos->setSize(1);
$pos->setMaxLength(1);
$option_determination->addSubItem($pos);
}
$kind->addOption($option_determination);
$this->form->addItem($kind);
return true;
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::initLoginForm ( )

Init login form.

Definition at line 299 of file class.ilObjAuthSettingsGUI.php.

References $ilSetting, $key, ilObjectGUI\$lng, ilLDAPServer\_getFirstActiveServer(), ilRadiusSettings\_getInstance(), AUTH_LDAP, AUTH_LOCAL, AUTH_RADIUS, setDefLangFirst(), ilTextAreaInputGUI\setRows(), and ilSelectInputGUI\setValue().

Referenced by loginInfoObject(), and saveLoginInfoObject().

{
global $rbacsystem, $lng,$ilSetting;
include_once("./Services/Form/classes/class.ilPropertyFormGUI.php");
$this->form = new ilPropertyFormGUI();
$this->form->setFormAction($this->ctrl->getFormAction($this,'saveLoginInfo'));
$this->form->setTableWidth('80%');
$this->form->setTitle($this->lng->txt('login_information'));
#$form->setInfo($this->lng->txt('login_information_desc'));
$this->form->addCommandButton('saveLoginInfo',$this->lng->txt('save'));
$this->form->addCommandButton('cancel',$this->lng->txt('cancel'));
include_once('Services/LDAP/classes/class.ilLDAPServer.php');
include_once('Services/Radius/classes/class.ilRadiusSettings.php');
$rad_settings = ilRadiusSettings::_getInstance();
if($ldap_id = ilLDAPServer::_getFirstActiveServer() or $rad_settings->isActive())
{
$select = new ilSelectInputGUI($this->lng->txt('default_auth_mode'),'default_auth_mode');
$select->setValue($ilSetting->get('default_auth_mode',AUTH_LOCAL));
$select->setInfo($this->lng->txt('default_auth_mode_info'));
$options[AUTH_LOCAL] = $this->lng->txt('auth_local');
if($ldap_id)
{
$options[AUTH_LDAP] = $this->lng->txt('auth_ldap');
}
if($rad_settings->isActive())
{
$options [AUTH_RADIUS] = $this->lng->txt('auth_radius');
}
$select->setOptions($options);
$this->form->addItem($select);
}
if (!is_object($this->loginSettings))
{
$this->loginSettings = new ilSetting("login_settings");
}
$login_settings = $this->loginSettings->getAll();
$languages = $lng->getInstalledLanguages();
$def_language = $lng->getDefaultLanguage();
foreach ($this->setDefLangFirst($def_language, $languages) as $lang_key)
{
$add = "";
if ($lang_key == $def_language)
{
$add = " (".$lng->txt("default").")";
}
$textarea = new ilTextAreaInputGUI($lng->txt("meta_l_".$lang_key).$add,
'login_message_'.$lang_key);
$textarea->setRows(10);
$textarea->setValue($login_settings["login_message_".$lang_key]);
$textarea->setUseRte(true);
$this->form->addItem($textarea);
unset($login_settings["login_message_".$lang_key]);
}
foreach ($login_settings as $key => $message)
{
$lang_key = substr($key, strrpos($key, "_") + 1, strlen($key) - strrpos($key, "_"));
$textarea = new ilTextAreaInputGUI($lng->txt("meta_l_".$lang_key).$add,
'login_message_'.$lang_key);
$textarea->setRows(10);
$textarea->setValue($message);
$textarea->setUseRte(true);
if(!in_array($lang_key,$languages))
{
$textarea->setAlert($lng->txt("not_installed"));
}
$this->form->addItem($textarea);
}
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::loginInfoObject ( )

displays login information of all installed languages

public

Author
Michael Jansen

Definition at line 272 of file class.ilObjAuthSettingsGUI.php.

References $ilSetting, ilObjectGUI\$lng, initLoginForm(), and setSubTabs().

Referenced by saveLoginInfoObject().

{
global $rbacsystem, $lng,$ilSetting;
if (!$rbacsystem->checkAccess("visible,read", $this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"), $this->ilias->error_obj->MESSAGE);
}
$this->tabs_gui->setTabActive("authentication_settings");
$this->setSubTabs("authSettings");
$this->tabs_gui->setSubTabActive("login_information");
$lng->loadLanguageModule("meta");
$this->tpl->addBlockFile("ADM_CONTENT", "adm_content", "tpl.auth_login_messages.html");
$this->tpl->setVariable("FORMACTION", $this->ctrl->getFormAction($this));
$this->tpl->setVariable("TXT_HEADLINE", $this->lng->txt("login_information"));
$this->tpl->setVariable("TXT_DESCRIPTION", $this->lng->txt("login_information_desc"));
$this->tpl->setVariable("TXT_SUBMIT", $this->lng->txt("save"));
$this->initLoginForm();
$this->tpl->setVariable('LOGIN_INFO',$this->form->getHTML());
}

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::saveCASObject ( )

validates all input data, save them to database if correct and active chosen auth mode

public

Definition at line 598 of file class.ilObjAuthSettingsGUI.php.

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

{
global $ilUser, $ilSetting, $rbacsystem;
if (!$rbacsystem->checkAccess("write",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
// validate required data
if (!$_POST["cas"]["server"] or !$_POST["cas"]["port"])
{
$this->ilias->raiseError($this->lng->txt("fill_out_all_required_fields"),$this->ilias->error_obj->MESSAGE);
}
// validate port
if ((preg_match("/^[0-9]{0,5}$/",$_POST["cas"]["port"])) == false)
{
$this->ilias->raiseError($this->lng->txt("err_invalid_port"),$this->ilias->error_obj->MESSAGE);
}
$ilSetting->set("cas_server", $_POST["cas"]["server"]);
$ilSetting->set("cas_port", $_POST["cas"]["port"]);
$ilSetting->set("cas_uri", $_POST["cas"]["uri"]);
$ilSetting->set("cas_login_instructions", $_POST["cas"]["login_instructions"]);
$ilSetting->set("cas_active", $_POST["cas"]["active"]);
$ilSetting->set("cas_create_users", $_POST["cas"]["create_users"]);
$ilSetting->set("cas_allow_local", $_POST["cas"]["allow_local"]);
$ilSetting->set("cas_active", $_POST["cas"]["active"]);
$ilSetting->set("cas_user_default_role", $_POST["cas"]["user_default_role"]);
ilUtil::sendSuccess($this->lng->txt("auth_cas_settings_saved"),true);
$this->ctrl->redirect($this,'editCAS');
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::saveLoginInfoObject ( )

saves the login information data

public

Author
Michael Jansen

Definition at line 230 of file class.ilObjAuthSettingsGUI.php.

References $_POST, $ilSetting, $key, ilObjectGUI\$lng, initLoginForm(), loginInfoObject(), and ilUtil\sendSuccess().

{
global $rbacsystem, $lng,$ilSetting;
if (!$rbacsystem->checkAccess("write",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
$this->initLoginForm();
if ($this->form->checkInput())
{
if (is_array($_POST))
{
$this->loginSettings = new ilSetting("login_settings");
foreach ($_POST as $key => $val)
{
if (substr($key, 0, 14) == "login_message_")
{
$this->loginSettings->set($key, $val);
}
}
}
if($_POST['default_auth_mode'])
{
$ilSetting->set('default_auth_mode',(int) $_POST['default_auth_mode']);
}
ilUtil::sendSuccess($this->lng->txt("login_information_settings_saved"));
}
$this->loginInfoObject();
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::saveScriptObject ( )

validates all input data, save them to database if correct and active chosen auth mode

public

Definition at line 893 of file class.ilObjAuthSettingsGUI.php.

References $_POST, AUTH_SCRIPT, getAuthModeTitle(), and ilUtil\sendSuccess().

{
// validate required data
if (!$_POST["auth_script"]["name"])
{
$this->ilias->raiseError($this->lng->txt("fill_out_all_required_fields"),$this->ilias->error_obj->MESSAGE);
}
// validate script url
/*
if (( TODO ,$_POST["ldap"]["server"])) == false)
{
$this->ilias->raiseError($this->lng->txt("err_invalid_server"),$this->ilias->error_obj->MESSAGE);
}*/
// TODO: check connection to server
// all ok. save settings and activate auth by external script
$this->ilias->setSetting("auth_script_name", $_POST["auth_script"]["name"]);
$this->ilias->setSetting("auth_mode", AUTH_SCRIPT);
ilUtil::sendSuccess($this->lng->txt("auth_mode_changed_to")." ".$this->getAuthModeTitle(),true);
$this->ctrl->redirect($this,'editScript');
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::saveSOAPObject ( )

validates all input data, save them to database if correct and active chosen auth mode

public

Definition at line 809 of file class.ilObjAuthSettingsGUI.php.

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

{
global $ilUser, $ilSetting, $rbacsystem;
if (!$rbacsystem->checkAccess("write",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
// validate required data
if (!$_POST["soap"]["server"])
{
$this->ilias->raiseError($this->lng->txt("fill_out_all_required_fields"),$this->ilias->error_obj->MESSAGE);
}
// validate port
if ($_POST["soap"]["server"] != "" && (preg_match("/^[0-9]{0,5}$/",$_POST["soap"]["port"])) == false)
{
$this->ilias->raiseError($this->lng->txt("err_invalid_port"),$this->ilias->error_obj->MESSAGE);
}
$ilSetting->set("soap_auth_server", $_POST["soap"]["server"]);
$ilSetting->set("soap_auth_port", $_POST["soap"]["port"]);
$ilSetting->set("soap_auth_active", $_POST["soap"]["active"]);
$ilSetting->set("soap_auth_uri", $_POST["soap"]["uri"]);
$ilSetting->set("soap_auth_namespace", $_POST["soap"]["namespace"]);
$ilSetting->set("soap_auth_create_users", $_POST["soap"]["create_users"]);
$ilSetting->set("soap_auth_allow_local", $_POST["soap"]["allow_local"]);
$ilSetting->set("soap_auth_account_mail", $_POST["soap"]["account_mail"]);
$ilSetting->set("soap_auth_use_https", $_POST["soap"]["use_https"]);
$ilSetting->set("soap_auth_use_dotnet", $_POST["soap"]["use_dotnet"]);
$ilSetting->set("soap_auth_user_default_role", $_POST["soap"]["user_default_role"]);
ilUtil::sendSuccess($this->lng->txt("auth_soap_settings_saved"),true);
$this->ctrl->redirect($this,'editSOAP');
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::setAuthModeObject ( )

Definition at line 418 of file class.ilObjAuthSettingsGUI.php.

References $_POST, $ilSetting, AUTH_LDAP, AUTH_RADIUS, AUTH_SCRIPT, getAuthModeTitle(), ilObjectGUI\getReturnLocation(), ilUtil\redirect(), ilUtil\sendFailure(), ilUtil\sendInfo(), and ilUtil\sendSuccess().

{
global $rbacsystem,$ilSetting;
if (!$rbacsystem->checkAccess("write",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
if (empty($_POST["auth_mode"]))
{
$this->ilias->raiseError($this->lng->txt("auth_err_no_mode_selected"),$this->ilias->error_obj->MESSAGE);
}
if ($_POST["auth_mode"] == AUTH_DEFAULT)
{
ilUtil::sendInfo($this->lng->txt("auth_mode").": ".$this->getAuthModeTitle()." ".$this->lng->txt("auth_mode_not_changed"),true);
$this->ctrl->redirect($this,'authSettings');
}
switch ($_POST["auth_mode"])
{
case AUTH_LDAP:
/*
if ($this->object->checkAuthLDAP() !== true)
{
ilUtil::sendInfo($this->lng->txt("auth_ldap_not_configured"),true);
ilUtil::redirect($this->getReturnLocation("authSettings",$this->ctrl->getLinkTarget($this,"editLDAP")));
}
*/
break;
case AUTH_SHIB:
if ($this->object->checkAuthSHIB() !== true)
{
ilUtil::sendFailure($this->lng->txt("auth_shib_not_configured"),true);
ilUtil::redirect($this->getReturnLocation("authSettings",$this->ctrl->getLinkTarget($this,"editSHIB")));
}
break;
if ($this->object->checkAuthRADIUS() !== true)
{
ilUtil::sendFailure($this->lng->txt("auth_radius_not_configured"),true);
$this->ctrl->redirect($this,'editRADIUS');
}
break;
if ($this->object->checkAuthScript() !== true)
{
ilUtil::sendFailure($this->lng->txt("auth_script_not_configured"),true);
ilUtil::redirect($this->getReturnLocation("authSettings",$this->ctrl->getLinkTarget($this,"editScript")));
}
break;
}
$this->ilias->setSetting("auth_mode",$_POST["auth_mode"]);
ilUtil::sendSuccess($this->lng->txt("auth_default_mode_changed_to")." ".$this->getAuthModeTitle(),true);
$this->ctrl->redirect($this,'authSettings');
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::setDefLangFirst (   $a_def_language,
  $a_languages 
)

returns an array of all installed languages, default language at the first position

Parameters
string$a_def_languageDefault language of the current installation
array$a_languagesArray of all installed languages
Returns
array $languages Array of the installed languages, default language at first position public
Author
Michael Jansen

Definition at line 390 of file class.ilObjAuthSettingsGUI.php.

Referenced by initLoginForm().

{
if (is_array($a_languages) && $a_def_language != "")
{
$languages = array();
$languages[] = $a_def_language;
foreach ($a_languages as $val)
{
if (!in_array($val, $languages))
{
$languages[] = $val;
}
}
return $languages;
}
else
{
return array();
}
}

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::setSubTabs (   $a_tab)

set sub tabs

Definition at line 1204 of file class.ilObjAuthSettingsGUI.php.

Referenced by authSettingsObject(), and loginInfoObject().

{
global $rbacsystem,$ilUser,$ilAccess;
switch ($a_tab)
{
case 'authSettings':
if($ilAccess->checkAccess('write','',$this->object->getRefId()))
{
$this->tabs_gui->addSubTabTarget("auth_settings",
$this->ctrl->getLinkTarget($this,'authSettings'),
"");
}
if($ilAccess->checkAccess('write','',$this->object->getRefId()))
{
$this->tabs_gui->addSubTabTarget("login_information",
$this->ctrl->getLinkTarget($this,'loginInfo'),
"");
}
break;
}
}

+ Here is the caller graph for this function:

ilObjAuthSettingsGUI::testSoapAuthConnectionObject ( )

Definition at line 799 of file class.ilObjAuthSettingsGUI.php.

References editSOAPObject().

{
$this->editSOAPObject();
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::updateAuthModeDeterminationObject ( )

update auth mode determination

public

Definition at line 1049 of file class.ilObjAuthSettingsGUI.php.

References $_POST, ilAuthModeDetermination\_getInstance(), authSettingsObject(), and ilUtil\sendSuccess().

{
include_once('Services/Authentication/classes/class.ilAuthModeDetermination.php');
$det->setKind((int) $_POST['kind']);
$pos = $_POST['position'] ? $_POST['position'] : array();
asort($pos,SORT_NUMERIC);
$counter = 0;
foreach($pos as $auth_mode => $dummy)
{
$position[$counter++] = $auth_mode;
}
$det->setAuthModeSequence($position ? $position : array());
$det->save();
ilUtil::sendSuccess($this->lng->txt('settings_saved'));
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::updateAuthRolesObject ( )

Definition at line 955 of file class.ilObjAuthSettingsGUI.php.

References $_POST, ilObjRole\_updateAuthMode(), and ilUtil\sendSuccess().

{
global $rbacsystem;
if (!$rbacsystem->checkAccess("write",$this->object->getRefId()))
{
$this->ilias->raiseError($this->lng->txt("permission_denied"),$this->ilias->error_obj->MESSAGE);
}
include_once('./Services/AccessControl/classes/class.ilObjRole.php');
ilUtil::sendSuccess($this->lng->txt("auth_mode_roles_changed"),true);
$this->ctrl->redirect($this,'authSettings');
}

+ Here is the call graph for this function:

ilObjAuthSettingsGUI::viewObject ( )

list childs of current object

public

Reimplemented from ilObjectGUI.

Definition at line 36 of file class.ilObjAuthSettingsGUI.php.

{
// load ilRegistrationSettingsGUI
include_once './Services/Registration/classes/class.ilRegistrationSettingsGUI.php';
// Enable tabs
$this->tabs_gui->setTabActive('registration_settings');
$registration_gui =& new ilRegistrationSettingsGUI();
$this->ctrl->setCmdClass('ilregistrationsettingsgui');
$this->ctrl->forwardCommand($registration_gui);
}

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