Microsoft Graph
Links
Useful information:
App
Configuration
Configure Settings (register your application in Azure)
Add
MSGRAPH_GROUP_NAME_TO_SYNC
tosettings/base.py
:MSGRAPH_GROUP_NAME_TO_SYNC = get_env_variable("MSGRAPH_GROUP_NAME_TO_SYNC")
This is the name of the group e.g.
kbuk
in this screenshot:
data:image/s3,"s3://crabby-images/00565/00565c9d8ac8cee4c825869f925da87c0a460c9d" alt="_images/2022-05-25-azure-ad-group-name.png"
Diagostics
Click here for Microsoft Graph error responses and resource types
Here is an example error:
format 500: The operation has timed out. ('generalException')
The Microsoft Graph error responses and resource types says
generalException
, An unspecified error has occurred.…
Management Commands
To see if the Graph API is working:
django-admin microsoft-graph-user code@pkimber.net
To run update_microsoft_graph_users
(from msgraph.service
):
django-admin update-microsoft-graph-users
The update-microsoft-graph-users
management command will:
Retrieve all users from the Graph API
Select the list of users to synchronise by finding the members of the Active Directory group (
settings.MSGRAPH_GROUP_NAME_TO_SYNC
).Add the users to the
MicrosoftGraphUser
model.If a user has been removed from Active Directory, then the
MicrosoftGraphUser
record will be soft-deleted.Retrieve all user managers from the Graph API
Add the managers to the
MicrosoftGraphUserSupervisor
model.
To download the Microsoft Graph users to a CSV file:
django-admin microsoft-graph-users-as-csv
To download the Microsoft Graph groups to a CSV file:
django-admin microsoft-graph-groups-as-csv
Pagination
Paging Microsoft Graph data in your app https://docs.microsoft.com/en-us/graph/paging
Example diff https://gitlab.com/kb/msgraph/-/commit/b12a03bb1d174b94cd9a3a28d3303dc88de89c25
URLs
urlpatterns = [
url(regex=r"^microsoft/graph/", view=include("msgraph.urls")),
]
Template (Settings)
{% block content %}
<div class="pure-g">
{% include 'msgraph/_settings.html' %}
</div>
{% endblock content %}
Settings
Register an application with the Microsoft identity platform
e.g. for an app called
ticket-3597-v1
:
data:image/s3,"s3://crabby-images/db800/db8003943875456cd34b79bedfbad90f69e18f24" alt="_images/msgraph-overview.png"
data:image/s3,"s3://crabby-images/22138/22138f7558ba1d08f7f456046bbba9a6a738d2bb" alt="_images/msgraph-redirect-uris.png"
Under the applications API permissions page, choose Add a permission, select Microsoft Graph, and then choose the permissions your app requires under Application permissions:
data:image/s3,"s3://crabby-images/8f02a/8f02a6b0444267177685d8f5af1bf942cb38640d" alt="_images/2021-08-19-api-permissions-with-group.png"
Note
The User.Read
permission does not need to be selected.
It is automatically Delegated when you select User.ReadWrite
.
Note
If you change permissions, users and/or admins will have to consent even if they have done so previously.
Tip
19/08/2021, The group permissions were added to allow us to Sync user permissions from Active Directory.
Under the applications Certificates & secrets page in the Client secrets section, create a New client secret:
data:image/s3,"s3://crabby-images/53026/53026ca06cf1d0e4eb33053421a633b476078d2b" alt="_images/msgraph-client-secret.png"
Warning
I think you only get a single chance to copy this secret!
Copy the Application (client) ID to and client secret to your environment e.g:
# .private set -x MSGRAPH_APPLICATION_ID "6731de76-14a6-4931de76-14a6-49ae" set -x MSGRAPH_CLIENT_SECRET "the-client-secret"
Browse to Settings, Microsoft Graph, Get Consent
data:image/s3,"s3://crabby-images/2a600/2a60018b5968e98acdee19149803de7a3c733a38" alt="_images/msgraph-settings-get-consent.png"
Make a note of the Redirect URI for the next step:
data:image/s3,"s3://crabby-images/84457/8445703f01e88ee539c85cf4f01e915e1239c23e" alt="_images/msgraph-get-consent.png"
Under the applications Authentication page in the Redirect URIs section, set the redirect URI for your web site.
data:image/s3,"s3://crabby-images/3203e/3203ed5ffc8a43cd338476d2be522ca93a7bf1fd" alt="_images/msgraph-redirect-uri.png"
Tip
The Redirect URI is displayed on your web site under Settings, Microsoft Graph, Get Consent.