data:image/s3,"s3://crabby-images/f3fed/f3fed8b829facd1b2702c9586d75fff0923c9d2b" alt="Moodle 3.x Developer's Guide"
Authentication
Log in to your development Moodle as an administrator and, from the Site administration menu, slide down to Plugins, then Authentication, and then click on Manage authentication:
data:image/s3,"s3://crabby-images/2a3f2/2a3f200b5c2a3dd085a40443ccf6abd16e7fbcca" alt=""
The Manage authentication page lists the available authentication plugins (together with general configuration settings further down the page):
data:image/s3,"s3://crabby-images/bc59e/bc59e7230d5677d2e2e6cea6f8ff3b8898497b51" alt=""
Check out the Moodle docs for details of the authentication process at https://docs.moodle.org/dev/Authentication_plugins#Overview_of_Moodle_authentication_process. What is important to realize about the authentication process is that it isn't simply a question of either creating a new user account in Moodle or verifying user credentials against a third-party system.
Let's spend a little time studying the authentication process in detail. Open Eclipse and navigate to login/index.php:
data:image/s3,"s3://crabby-images/83760/83760801fccf7acd9a3cd8c9a36ec5226b71208e" alt=""
Authentication begins and the Moodle login page is displayed. It requests the user's credentials:
data:image/s3,"s3://crabby-images/1beda/1beda18d3cff37bd1fc7175f2a1e9b2ae9420e3e" alt=""
When the login form is submitted, login/index.php loops through the enabled authentication plugins, in order, to fire the login event to each plugin's login hook:
data:image/s3,"s3://crabby-images/5b2b5/5b2b5eb43942443b401a01268d61f521ac9cce68" alt=""
An authentication plugin hook may return user details at this point--typically preventing the user logging in as part of a debugging process or because of a configuration error of some kind. The authentication plugins are called from the authenticate_user_login() function in lib/moodlelib.php. The auth_login() function is called on each authentication plugin:
data:image/s3,"s3://crabby-images/32acb/32acbc551932f839e730f31011a08d8e7f87f02b" alt=""
The authentication plugins themselves are to be found in the auth folder; for example, the default authentication method is manual accounts:
data:image/s3,"s3://crabby-images/42da4/42da4677f439e5a1a32fcd1e4f26b209dcdfdf9f" alt=""
Feel free to take a look now at the structure of the manual authentication plugin. Authentication plugins have the same general structure:
data:image/s3,"s3://crabby-images/fe590/fe5907816eb34267bdd685f819eaa0d00996c984" alt=""
The script that actually authenticates, and each plugin contains one, is auth.php. The auth.php file contains a declaration of a class based on auth_plugin_base, the authentication base class declared in /lib/authlib.php. We will be studying the structure and operation of authentication plugins in general (as well as developing our own) in Chapter 6, Managing Users - Letting in the Crowds.