Call Graph API function to update user details is skipped (caused by a bad get_config call?) #2624
Labels
Feature - user sync
Issue type - bug
Bugs in existing code that needs to be fixed.
Plugin - auth_oidc
Plugin - local_o365
Status - PR ready / pending release
Dev is done and PR ready. Will be included in the next release.
Milestone
Hi!
We updated our Moodle a couple of months ago and have just realized that certain fields in user profiles are no longer updating when they log in.
Here our setup before the update :
Moodle 4.1.3 (Build: 20230424)
Plugin local_o365 4.1.1 (2022112805)
Plugin auth_oidc 4.1.1 (2022112805)
And after the update :
Moodle 4.3.5+ (Build: 20240614)
Plugin local_o365 4.3.3 (2023100915)
Plugin auth_oidc 4.3.3 (2023100915)
We also have a test environment that is updated more regularly:
Moodle 4.3.6+ (Build: 20240821)
Plugin local_o365 4.3.5 (202310092)
Plugin auth_oidc 4.3.4 (2023100920)
I’m fairly certain the synchronization was working correctly before the update, but now it’s not working in both our test and production environments.
After investigating, I think I may have found the root of the issue.
This line :
o365-moodle/auth/oidc/classes/loginflow/base.php
Line 127 in 591e1de
was modified in December 2023:
data:image/s3,"s3://crabby-images/6db50/6db508e3514f29db5264510fcf4845267e1e0a6f" alt="image"
The commit in question :
9f84a45
If I understand this code correctly, it compares the value of the configuration “microsofttenantid” with the tenant ID of the currently used token. If they are not the same, it assumes the user is from another tenant and synchronizes only the fields contained in the token (UPN, first name, last name, email). If the tenant IDs are the same, a call is made to the Graph API to retrieve more fields to sync in the Moodle user profile (e.g., city, department, etc.):
I realized that the call to the Graph API is never made because get_config('local_o365', 'microsofttenantid') always returns an empty value. I checked our mdl_config_plugin table, and this configuration ('local_o365', 'microsofttenantid') does not exist:
data:image/s3,"s3://crabby-images/63db0/63db0345ab28b04e15dda3a9c969b43ad72cbc9c" alt="image"
Is it possible that this line (L127 of base.php) should be:
$hostingtenantid = get_config('local_o365', 'entratenantid');
instead of
$hostingtenantid = get_config('local_o365', 'microsofttenantid');
Thanks so much!
The text was updated successfully, but these errors were encountered: