Skip to content

Releases: microsoft/o365-moodle

Release 3.10.7 for Moodle 3.10

21 Jun 10:02
Compare
Choose a tag to compare

Release 3.10.7 of Microsoft plugins for Moodle 3.10.

This release contains:

  • Full support of Single Sign Out feature for connected users.
  • Other bug fixes and small changes.

Full support of Single Sign Out feature for connected users (#2014)

The auth_oidc plugin now provides an endpoint which Microsoft services can request to trigger the logout of the connected Moodle users from Microsoft. The URL is https://url.to.moodle/auth/oidc/logout.php, and it can be configured in the "Front-channel logout URL" setting of Azure app.

Bug fixes and small changes

  • Improved support for matching users by email in the user sync task. (#2034, thanks to @phager-at)
  • Bug fix to prevent unexpected user suspension when full user sync fails. (#2048)
  • More flexible schedule options to run user suspension/deletion part of the user sync task. (#2023)
  • Bug fix on whether profile photo sync needs to run in the user sync task. (#1898)
  • Fix broken unit tests. (#2018)
  • Bug fix in observer definition. (#2040)
  • Remove Teams app ID detection dependancy on course sync enable status.
  • Add missing delegated permissions required to configure multi-tenancy to PowerShell script and permission check.
  • Update SDS sync feature to work with incomplete Graph API responses in user profile sync.
  • Add help text about Teams app provisioning when bot feature is enabled.
  • Move deploying bot button image to image folder of local_o365 from external sources.

Release 4.0.0 for Moodle 4.0

12 May 08:49
Compare
Choose a tag to compare

This is the initial release of the plugins for Moodle 4.0.

The release is based on Release 3.11.3, with changes to allow it to be compatible with core Moodle changes in Moodle 4.0 (#2032, #2045).

The release also contains the following changes:

  • Fix broken unit tests in multiple plugins (#2018, #2033)
  • Improvements in user profile photo sync (#1898)
  • Fix invalid observer function definition (#2040)
  • Fix broken bot deployment button on the integration configuration page.
  • Remove unnecessary dependency on Teams APP ID detection function on the Teams integration configuration page.

Release 3.9.9 for Moodle 3.9

11 Apr 12:47
Compare
Choose a tag to compare

Release 3.9.9 of Microsoft plugins for Moodle 3.9.

NOTE - Azure app changes is required in this release. Refer to this page for Azure app change details.

This release contains:

  • Multi-tenant SSO alternative domain name support: Support login of additional tenant users whose UPN contains non-initial domain names.
  • Remove filter_oembed from the suite: Remove filter_oembed from the Microsoft plugins suite.
  • Other bug fixes and small changes.

Multi-tenant SSO alternative domain name support

Previously SSO integration for additional tenants stores only the original domain name of the additional tenants (the one used when creating the tenant), and if users from the additional tenants are created using UPN other than the original domain name, the users are not being recognised in the multi-tenant SSO process.

This release introduces a change to save the ID of the additional tenant, along with all registered domains, so that users from additional tenants can be recognised regardless the domain name in their UPN.

NOTE this requires Moodle site admins updating multi-tenant configurations.

Remove filter_oembed from the suite

Plugin filter_oembed is removed from the Microsoft plugins suite as it is not a required plugins anymore. Some features in the filter_oembed plugin still require the other plugins in the suite to work though.

Bug fixes and small changes

  • Force field mapping of email profile field to avoid users being created without email and cannot update own email, #1953.
  • Improvement in handling sync of Outlook calendar all day events into Moodle, #1434.
  • Fix error output on the SDS sync configuration page when Moodle and Microsoft 365 integration is not fully configured #1957.
  • Update the logic used to allow only one run of user suspension/deletion part in the user sync task #1944.
  • Prevent duplicate user mapping records being create, #1723.
  • Bug fix in the Graph API call to list teams, #1904.
  • Bug fix in applying user field mappings for installations with only auth_oidc and not local_o365, #1925.
  • Bug fix in the observer function to delete group/team when the connected Moodle course is deleted, #1979.
  • Bug fix in database queries handling empty return values in SDS and user sync features, #1981.
  • Fix broken upgrade script in the local_o365 plugin, #1985.
  • Add null privacy provider to theme_boosto365teams, #1923, thanks to @golenkovm.
  • Fix inconsistency in database field type in local_onenote, #246.
  • Force a user sync task run after the Azure application ID site configuration is updated, in order to rebuild user connection records.
  • Prevent various local_o365 scheduled tasks from failing when the Moodle and Microsoft 365 integration is not fully configured.
  • Update PowerShell script to create new Azure app with required permissions.
  • Bug fix in handling response in some Graph API calls that paginate response values using skip tokens.
  • Update validation of the sync of language profile fields in user sync.
  • Clean up old SDS schools disabled for sync.
  • Remove hardcoded role checks in bot question implementations.
  • Add missing delegated permission check required by the calendar sync.
  • Fix UI for the "Provide admin consent" button on local_o365 configuration page.

Release 3.11.3 for Moodle 3.11

11 Apr 12:48
Compare
Choose a tag to compare

Release 3.11.3 of Microsoft plugins for Moodle 3.11.

NOTE - This is a major upgrade of the plugins, and requires Azure app changes. Refer to this page for Azure app change details.

This release contains:

  • Teams Classes LTI app support: Major change in the Moodle course and Microsoft Teams integration feature to support Teams Classes LTI.
  • Drop "System API user" connection method: The only connection method supported going forward is application access.
  • Multi-tenant SSO alternative domain name support: Support login of additional tenant users whose UPN contains non-initial domain names.
  • Remove filter_oembed from the suite: Remove filter_oembed from the Microsoft plugins suite.
  • Other bug fixes and small changes.

Teams Classes LTI app support

This release contains a complete rewrite of the course sync feature in the plugins. The main changes include:

  • Renamed the "Create user groups in Microsoft 365" (\local_o365\task\groupcreate) scheduled task to "Sync Moodle courses to Microsoft Teams" (\local_o365\task\coursesync).
  • The option to sync a Moodle course to groups only but not Teams is removed. If a sync of a course is enabled, it will always sync to a group, and a Team if a suitable owner is found.
  • The decision whether to create a standard team or a class team is controlled by whether the hosting tenant has an education license, rather than configuration setting made by Moodle site admin. The check to determine whether the hosting tenant has an education license is performed automatically by the plugin using Graph API calls.
  • The Graph APIs used to create/update/archive/delete groups/teams connected to Moodle courses, as well as those used to manage initial and subsequent group/team ownership/membership changes, are all updated according to LMS integration guidelines provided by Microsoft. Notably, the integration will always create a group first, and try to create a Team from the group when appropriate Team owner is found.
  • If the hosting tenant has an education license, additional education specific attributes will be stamped in the group created, which will allow Moodle users use the Teams Classes LTI app by adding the Team as an external tool in the course using mod_lti.

NOTE this requires several configuration changes in both local_o365 settings and Azure app permissions. Refer to this page for Azure app change details.

Drop "System API user" connection method

The support for "System API user" connection method has officially ended since this release. The decision was made for two main reasons:

  • Increasing number of Graph APIs used in the integration support only application permissions, which effectively means the feature cannot be achieved if "System API user" connection is selected, which would depend on delegated permissions.
  • Using the "System API user" connections for Teams integration has the unexpected outcomes that the system API user is added as owner of all Teams created.
    Most Moodle site should be using "Application access" connection method now, which are unaffected by this change. For those sites currently using "System API user" connection method, site admins will be given the chance to make the change. Changes in Azure app permissions may be required as part of the migration.

Multi-tenant SSO alternative domain name support

Previously SSO integration for additional tenants stores only the original domain name of the additional tenants (the one used when creating the tenant), and if users from the additional tenants are created using UPN other than the original domain name, the users are not being recognised in the multi-tenant SSO process.

This release introduces a change to save the ID of the additional tenant, along with all registered domains, so that users from additional tenants can be recognised regardless the domain name in their UPN.

NOTE this requires Moodle site admins updating multi-tenant configurations.

Remove filter_oembed from the suite

Plugin filter_oembed is removed from the Microsoft plugins suite as it is not a required plugins anymore. Some features in the filter_oembed plugin still require the other plugins in the suite to work though.

Bug fixes and small changes

  • Force field mapping of email profile field to avoid users being created without email and cannot update own email, #1953.
  • Improvement in handling sync of Outlook calendar all day events into Moodle, #1434.
  • Fix error output on the SDS sync configuration page when Moodle and Microsoft 365 integration is not fully configured #1957.
  • Update the logic used to allow only one run of user suspension/deletion part in the user sync task #1944.
  • Prevent duplicate user mapping records being create, #1723.
  • Bug fix in the Graph API call to list teams, #1904.
  • Bug fix in applying user field mappings for installations with only auth_oidc and not local_o365, #1925.
  • Bug fix in the observer function to delete group/team when the connected Moodle course is deleted, #1979.
  • Bug fix in database queries handling empty return values in SDS and user sync features, #1981.
  • Fix broken upgrade script in the local_o365 plugin, #1985.
  • Add null privacy provider to theme_boosto365teams, #1923, thanks to @golenkovm.
  • Fix inconsistency in database field type in local_onenote, #246.
  • Move profile photo sync and timezone sync from block_microsoft to observer functions in local_o365, #1945.
  • Bug fix in handling response in some Graph API calls that paginate response values using skip tokens, #1746.
  • Force a user sync task run after the Azure application ID site configuration is updated, in order to rebuild user connection records.
  • Prevent various local_o365 scheduled tasks from failing when the Moodle and Microsoft 365 integration is not fully configured.
  • Update PowerShell script to create new Azure app with required permissions.
  • Update validation of the sync of language profile fields in user sync.
  • Clean up old SDS schools disabled for sync.
  • Remove hardcoded role checks in bot question implementations.
  • Add missing delegated permission check required by the calendar sync.
  • Fix UI for the "Provide admin consent" button on local_o365 configuration page.

Release 3.10.6 for Moodle 3.10

11 Apr 12:47
Compare
Choose a tag to compare

Release 3.10.6 of Microsoft plugins for Moodle 3.10.

NOTE - This is a major upgrade of the plugins, and requires Azure app changes. Refer to this page for Azure app change details.

This release contains:

  • Teams Classes LTI app support: Major change in the Moodle course and Microsoft Teams integration feature to support Teams Classes LTI.
  • Drop "System API user" connection method: The only connection method supported going forward is application access.
  • Multi-tenant SSO alternative domain name support: Support login of additional tenant users whose UPN contains non-initial domain names.
  • Remove filter_oembed from the suite: Remove filter_oembed from the Microsoft plugins suite.
  • Other bug fixes and small changes.

Teams Classes LTI app support

This release contains a complete rewrite of the course sync feature in the plugins. The main changes include:

  • Renamed the "Create user groups in Microsoft 365" (\local_o365\task\groupcreate) scheduled task to "Sync Moodle courses to Microsoft Teams" (\local_o365\task\coursesync).
  • The option to sync a Moodle course to groups only but not Teams is removed. If a sync of a course is enabled, it will always sync to a group, and a Team if a suitable owner is found.
  • The decision whether to create a standard team or a class team is controlled by whether the hosting tenant has an education license, rather than configuration setting made by Moodle site admin. The check to determine whether the hosting tenant has an education license is performed automatically by the plugin using Graph API calls.
  • The Graph APIs used to create/update/archive/delete groups/teams connected to Moodle courses, as well as those used to manage initial and subsequent group/team ownership/membership changes, are all updated according to LMS integration guidelines provided by Microsoft. Notably, the integration will always create a group first, and try to create a Team from the group when appropriate Team owner is found.
  • If the hosting tenant has an education license, additional education specific attributes will be stamped in the group created, which will allow Moodle users use the Teams Classes LTI app by adding the Team as an external tool in the course using mod_lti.

NOTE this requires several configuration changes in both local_o365 settings and Azure app permissions. Refer to this page for Azure app change details.

Drop "System API user" connection method

The support for "System API user" connection method has officially ended since this release. The decision was made for two main reasons:

  • Increasing number of Graph APIs used in the integration support only application permissions, which effectively means the feature cannot be achieved if "System API user" connection is selected, which would depend on delegated permissions.
  • Using the "System API user" connections for Teams integration has the unexpected outcomes that the system API user is added as owner of all Teams created.
    Most Moodle site should be using "Application access" connection method now, which are unaffected by this change. For those sites currently using "System API user" connection method, site admins will be given the chance to make the change. Changes in Azure app permissions may be required as part of the migration.

Multi-tenant SSO alternative domain name support

Previously SSO integration for additional tenants stores only the original domain name of the additional tenants (the one used when creating the tenant), and if users from the additional tenants are created using UPN other than the original domain name, the users are not being recognised in the multi-tenant SSO process.

This release introduces a change to save the ID of the additional tenant, along with all registered domains, so that users from additional tenants can be recognised regardless the domain name in their UPN.

NOTE this requires Moodle site admins updating multi-tenant configurations.

Remove filter_oembed from the suite

Plugin filter_oembed is removed from the Microsoft plugins suite as it is not a required plugins anymore. Some features in the filter_oembed plugin still require the other plugins in the suite to work though.

Bug fixes and small changes

  • Force field mapping of email profile field to avoid users being created without email and cannot update own email, #1953.
  • Improvement in handling sync of Outlook calendar all day events into Moodle, #1434.
  • Fix error output on the SDS sync configuration page when Moodle and Microsoft 365 integration is not fully configured #1957.
  • Update the logic used to allow only one run of user suspension/deletion part in the user sync task #1944.
  • Prevent duplicate user mapping records being create, #1723.
  • Bug fix in the Graph API call to list teams, #1904.
  • Bug fix in applying user field mappings for installations with only auth_oidc and not local_o365, #1925.
  • Bug fix in the observer function to delete group/team when the connected Moodle course is deleted, #1979.
  • Bug fix in database queries handling empty return values in SDS and user sync features, #1981.
  • Fix broken upgrade script in the local_o365 plugin, #1985.
  • Add null privacy provider to theme_boosto365teams, #1923, thanks to @golenkovm.
  • Fix inconsistency in database field type in local_onenote, #246.
  • Move profile photo sync and timezone sync from block_microsoft to observer functions in local_o365, #1945.
  • Bug fix in handling response in some Graph API calls that paginate response values using skip tokens, #1746.
  • Force a user sync task run after the Azure application ID site configuration is updated, in order to rebuild user connection records.
  • Prevent various local_o365 scheduled tasks from failing when the Moodle and Microsoft 365 integration is not fully configured.
  • Update PowerShell script to create new Azure app with required permissions.
  • Update validation of the sync of language profile fields in user sync.
  • Clean up old SDS schools disabled for sync.
  • Remove hardcoded role checks in bot question implementations.
  • Add missing delegated permission check required by the calendar sync.
  • Fix UI for the "Provide admin consent" button on local_o365 configuration page.

Release 3.9.8 for Moodle 3.9: v20211207

09 Dec 11:37
Compare
Choose a tag to compare

Release 3.9.8 for Moodle 3.9.x.

The two main changes in this release are:
1. A rewrite of the SDS sync feature to use the Graph API. (#1864, #1346, #1333, #1330, #1263)
The updated SDS sync feature allows:

  • Synchronisation of student / teacher profiles from a selected school. (only supported in application access connection type)
  • Creation of Moodle courses from classes in multiple SDS schools.
  • Bi-directional synchronisation of users between Moodle courses and SDS classes.
    Note additional permissions need to be given to the Azure app to allow for SDS sync feature to work:
  • EduRoster.Read.All and Member.Read.Hidden for application access connection type,
  • EduRoster.ReadBasic for system API user connection type.

2. multiple fixes to the multi-tenant feature, which allows users from additional tenants to login to Moodle. (#1863, #1835, #1750, #1477)

Other changes includes:

  • In the single sign off feature, only redirect to SSO login URL for users connected to Microsoft 365 (#1886)
  • Fix broken unit tests (#1256, #1260, #1351, #1352, #1353, #1360, #1485, #1701)
  • Add missing required delegated permissions in the permission check when using application access connection type.
  • Bug fix in setcreds function in auth_oidc plugin. (#1361 Thanks to @alexmorrisnz)
  • Display missing permission name as well as description. (#1899)
  • Fix multiple calls to Graph API to list objects to handle pagination in API response.
  • Add back feature to enable sync on all courses on all pages in the customize course sync page.
  • Bug fix in auth_oidc upgrade script.
  • General code cleanup.

Release 3.11.2 for Moodle 3.11: v20211207

09 Dec 11:40
Compare
Choose a tag to compare

Release 3.11.2 for Moodle 3.11.x.

The two main changes in this release are:
1. A rewrite of the SDS sync feature to use the Graph API. (#1864, #1346, #1333, #1330, #1263)
The updated SDS sync feature allows:

  • Synchronisation of student / teacher profiles from a selected school. (only supported in application access connection type)
  • Creation of Moodle courses from classes in multiple SDS schools.
  • Bi-directional synchronisation of users between Moodle courses and SDS classes.
    Note additional permissions need to be given to the Azure app to allow for SDS sync feature to work:
  • EduRoster.Read.All and Member.Read.Hidden for application access connection type,
  • EduRoster.ReadBasic for system API user connection type.

2. multiple fixes to the multi-tenant feature, which allows users from additional tenants to login to Moodle. (#1863, #1835, #1750, #1477)

Other changes includes:

  • In the single sign off feature, only redirect to SSO login URL for users connected to Microsoft 365 (#1886)
  • Fix broken unit tests (#1256, #1260, #1351, #1352, #1353, #1360, #1485, #1701)
  • Add missing required delegated permissions in the permission check when using application access connection type.
  • Bug fix in setcreds function in auth_oidc plugin. (#1361 Thanks to @alexmorrisnz)
  • Display missing permission name as well as description. (#1899)
  • Fix multiple calls to Graph API to list objects to handle pagination in API response.
  • Add back feature to enable sync on all courses on all pages in the customize course sync page.
  • Bug fix in auth_oidc upgrade script.
  • General code cleanup.

Release 3.10.5 for Moodle 3.10: v20211207

09 Dec 11:39
Compare
Choose a tag to compare

Release 3.10.5 for Moodle 3.10.x.

The two main changes in this release are:
1. A rewrite of the SDS sync feature to use the Graph API. (#1864, #1346, #1333, #1330, #1263)
The updated SDS sync feature allows:

  • Synchronisation of student / teacher profiles from a selected school. (only supported in application access connection type)
  • Creation of Moodle courses from classes in multiple SDS schools.
  • Bi-directional synchronisation of users between Moodle courses and SDS classes.
    Note additional permissions need to be given to the Azure app to allow for SDS sync feature to work:
  • EduRoster.Read.All and Member.Read.Hidden for application access connection type,
  • EduRoster.ReadBasic for system API user connection type.

2. multiple fixes to the multi-tenant feature, which allows users from additional tenants to login to Moodle. (#1863, #1835, #1750, #1477)

Other changes includes:

  • In the single sign off feature, only redirect to SSO login URL for users connected to Microsoft 365 (#1886)
  • Fix broken unit tests (#1256, #1260, #1351, #1352, #1353, #1360, #1485, #1701)
  • Add missing required delegated permissions in the permission check when using application access connection type.
  • Bug fix in setcreds function in auth_oidc plugin. (#1361 Thanks to @alexmorrisnz)
  • Display missing permission name as well as description. (#1899)
  • Fix multiple calls to Graph API to list objects to handle pagination in API response.
  • Add back feature to enable sync on all courses on all pages in the customize course sync page.
  • Bug fix in auth_oidc upgrade script.
  • General code cleanup.

Release 3.11.0 for Moodle 3.11: v20210901

01 Sep 13:46
Compare
Choose a tag to compare

This is the initial release 3.11.0 of the Microsoft Moodle plugins for Moodle 3.11.

It's based on Release 3.10.2

Release 3.9.6 for Moodle 3.9: v20210702

02 Jul 09:32
Compare
Choose a tag to compare

Release 3.9.6 for Moodle 3.9.x.

This is an emergency bug fix release that fix the following bugs:

  • Microsoft 365 Group Membership user creation restrictions was broken in the 3.9.5 release. (#1719)
  • The feature to sync guest users cannot process guest users with email addresses with uppercase letters after the initial user creation.