OAuth2 Services: Difference between revisions
Damyon Wiese (talk | contribs) No edit summary |
m (Note about intent to not migrate this page to moodledev.io) |
||
(31 intermediate revisions by one other user not shown) | |||
Line 1: | Line 1: | ||
{{Template:WillNotMigrate}} | |||
{{Template:Work in progress}} | |||
= OAuth 2 Services = | = OAuth 2 Services = | ||
{{Moodle 3.3}} | {{Moodle 3.3}} | ||
Line 15: | Line 17: | ||
1. Create the OAuth 2 Service using the administration page at "Site administration -> Server -> OAuth 2 Services". There are templates available to create a pre-configured OAuth 2 service for Google, Office 365 and Facebook or you can manually enter all the required details for a custom OAuth 2 service. | 1. Create the OAuth 2 Service using the administration page at "Site administration -> Server -> OAuth 2 Services". There are templates available to create a pre-configured OAuth 2 service for Google, Office 365 and Facebook or you can manually enter all the required details for a custom OAuth 2 service. | ||
2. Register a new application with the OAuth 2 Service provider. Instructions for how to do this with Google | 2. Register a new application with the OAuth 2 Service provider. Instructions for how to do this with Google, Office 365 and Facebook are listed below. | ||
3. Enter the Client ID and Secret into the configuration page for the OAuth 2 service in Moodle. | 3. Enter the Client ID and Secret into the configuration page for the OAuth 2 service in Moodle. | ||
Line 25: | Line 27: | ||
Open ID Connect is a standard for OAuth 2 login services that makes it easier to setup a working login system. If the service you are setting up is Open ID Connect compliant, you will only have to enter the base url for the service, and Moodle will discover all the other information required by requesting the "discovery document" which is expected to exist at <issuer base url>/.well-known/openid-configuration. | Open ID Connect is a standard for OAuth 2 login services that makes it easier to setup a working login system. If the service you are setting up is Open ID Connect compliant, you will only have to enter the base url for the service, and Moodle will discover all the other information required by requesting the "discovery document" which is expected to exist at <issuer base url>/.well-known/openid-configuration. | ||
=== | === How do I get a clientid and secret? === | ||
The client ID and secret are created outside of Moodle when setting up the OAuth provider. Instructions for prominent OAuth 2 providers are linked here. | |||
* [[OAuth2_Services_Setup_Project_In_Google|Setup Project In Google]] | |||
* [[OAuth2_Services_Setup_Project_In_Microsoft|Setup Project In Microsoft]] | |||
[[ | * [[OAuth2_Services_Setup_Project_In_Facebook|Setup Project In Facebook]] | ||
* [[OAuth2_Services_Setup_Project_In_LinkedIn|Setup Project In LinkedIn]] | |||
[[ | |||
[[ | |||
Setup | |||
[[ | |||
Setup | |||
Latest revision as of 16:05, 30 April 2024
Warning: This page is no longer in use. The information contained on the page should NOT be seen as relevant or reliable. |
Note: This page is a work-in-progress. Feedback and suggested improvements are welcome. Please join the discussion on moodle.org or use the page comments.
OAuth 2 Services
Moodle 3.3
Moodle 3.3 adds support for OAuth 2 services in core which can be used by any plugins to provide authenticated access to external services either as the current user, or using a system account.
OAuth 2 services are used for example, to provide a "Login using Google/Microsoft/Facebook" feature on the login page, and then to share that authenticated session with repositories like Google Drive and Office 365 without having to re-authenticate.
OAuth 2 services can be used by plugins even if they do not use them on the login page, and it's possible to login to multiple services at the same time.
Login
The steps required to enable login using an OAuth 2 service are:
1. Create the OAuth 2 Service using the administration page at "Site administration -> Server -> OAuth 2 Services". There are templates available to create a pre-configured OAuth 2 service for Google, Office 365 and Facebook or you can manually enter all the required details for a custom OAuth 2 service.
2. Register a new application with the OAuth 2 Service provider. Instructions for how to do this with Google, Office 365 and Facebook are listed below.
3. Enter the Client ID and Secret into the configuration page for the OAuth 2 service in Moodle.
4. Enable the OAuth 2 Authentication module.
Open ID Connect
Open ID Connect is a standard for OAuth 2 login services that makes it easier to setup a working login system. If the service you are setting up is Open ID Connect compliant, you will only have to enter the base url for the service, and Moodle will discover all the other information required by requesting the "discovery document" which is expected to exist at <issuer base url>/.well-known/openid-configuration.
How do I get a clientid and secret?
The client ID and secret are created outside of Moodle when setting up the OAuth provider. Instructions for prominent OAuth 2 providers are linked here.