moodle/auth/upgrade.txt
Jakob cffd0fa138 MDL-53306 auth: Add hook for auth plugins to access user object.
Add a hook for auth plugins to be able to modify or check a user, before
raising any authentication errors.

The auth plugin needs to add a public function like this:

/**
 * Pre user_login hook.
 * This method is called from authenticate_user_login() right after the user
 * object is generated. This gives the auth plugins an option to make adjustments
 * before the verification process starts.
 *
 * @param object $user user object, later used for $USER
*/
public function pre_user_login_hook(&$user) {
    // Override if needed.
}
2016-05-30 11:57:03 -07:00

55 lines
2.1 KiB
Plaintext

This files describes API changes in /auth/* - plugins,
information provided here is intended especially for developers.
=== 3.2 ===
* New auth hook - pre_user_login_hook() - available, triggered right after the user object is created.
This can be used to modify the user object before any authentication errors are raised.
=== 3.0 ===
* login_signup_form::signup_captcha_enabled() now calls is_captcha_enabled() from the current auth plugin instead of from auth_email
=== 2.9 ===
* Do not update user->firstaccess from any auth plugin, the complete_user_login() does it automatically.
* Add user_add_password_history() to user_signup() method.
* New auth hook - pre_loginpage_hook() - available, triggered before redirecting to the login page.
=== 2.8 ===
* \core\session\manager::session_exists() now verifies the session is active
instead of only checking the session data is present in low level session handler
* MNet is no longer sending logs between the client and parent sites. auth_plugin_mnet::refresh_log() is now deprecated. There is
no alternative. Please don't use this function.
=== 2.7 ===
* If you are returning a url in method change_password_url() from config, please make sure it is set before trying to use it.
=== 2.6 ===
* can_be_manually_set() - This function was introduced in the base class and returns false by default. If overriden by
an authentication plugin to return true, the authentication plugin will be able to be manually set for users. For example,
when bulk uploading users you will be able to select it as the authentication method they use.
=== 2.4 ===
required changes in code:
* use role_get_name() or role_fix_names() if you need any role names, using role.name
directly from database is not correct any more
optional - no changes needed:
* add support for custom user signup form - see auth_plugin_base::signup_form() function
=== 2.2 ===
required changes in code:
* the correct sequence to set up global $USER is:
$user = get_complete_user_data('username', $username); // or $user = authenticate_user_login()
enrol_check_plugins($user);
session_set_user($user);