Office 365 & Microsoft Graph Library for Python
Use pip:
pip install Office365-REST-Python-Client
The list of supported API versions:
- SharePoint 2013 REST API and above
- SharePoint Online & OneDrive for Business REST API
The following auth flows are supported:
- app principals auth (refer Granting access using SharePoint App-Only for a details):
AuthenticationContext.ctx_auth.acquire_token_for_app(client_id, client_secret)
- user credentials auth:
AuthenticationContext.ctx_auth.acquire_token_for_user(username, password)
There are two approaches available to perform API queries:
ClientContext class
- where you target SharePoint resources such asWeb
,ListItem
and etc (recommended)
from office365.runtime.auth.authentication_context import AuthenticationContext
from office365.sharepoint.client_context import ClientContext
ctx_auth = AuthenticationContext(url)
if ctx_auth.acquire_token_for_user(username, password):
ctx = ClientContext(url, ctx_auth)
web = ctx.web
ctx.load(web)
ctx.execute_query()
print "Web title: {0}".format(web.properties['Title'])
else:
print ctx_auth.get_last_error()
-
ClientRequest class
- where you construct REST queries by specifying endpoint url, headers if required and payload (aka low level approach)The example demonstrates how to read
Web
properties:
import json
from office365.runtime.auth.authentication_context import AuthenticationContext
from office365.runtime.client_request import ClientRequest
from office365.runtime.utilities.request_options import RequestOptions
ctx_auth = AuthenticationContext(url)
if ctx_auth.acquire_token_for_user(username, password):
request = ClientRequest(ctx_auth)
options = RequestOptions("{0}/_api/web/".format(url))
options.set_header('Accept', 'application/json')
options.set_header('Content-Type', 'application/json')
data = request.execute_request_direct(options)
s = json.loads(data.content)
web_title = s['Title']
print "Web title: " + web_title
else:
print ctx_auth.get_last_error()
The list of supported APIs:
Since Outlook REST APIs are available in both Microsoft Graph and the Outlook API endpoint, the following clients are available:
GraphClient
which targets Outlookv2.0
version (preferable nowadays, refer transition to Microsoft Graph-based Outlook REST API for a details)OutlookClient
which targets Outlookv1.0
version (not recommended for usage sincev1.0
version is being deprecated.)
ADAL Python library is utilized to authenticate users to Active Directory (AD) and obtain tokens
The example demonstrates how to send an email via Microsoft Graph endpoint.
Note: access token is getting acquired via Client Credential flow
def get_token(auth_ctx):
token = auth_ctx.acquire_token_with_client_credentials(
"https://graph.microsoft.com",
client_id,
client_secret)
return token
tenant_name = "contoso.onmicrosoft.com"
client = GraphClient(tenant_name, get_token)
message_payload = {
"Message": {
"Subject": "Meet for lunch?",
"Body": {
"ContentType": "Text",
"Content": "The new cafeteria is open."
},
"ToRecipients": [
{
"EmailAddress": {
"Address": "jdoe@contoso.onmicrosoft.com"
}
}
]
},
"SaveToSentItems": "false"
}
login_name = "mdoe@contoso.onmicrosoft.com"
client.users[login_name].send_mail(message_payload)
client.execute_query()
ADAL Python library is utilized to authenticate users to Active Directory (AD) and obtain tokens
The example demonstrates how to print drive's url via list available drives
endpoint
Note: access token is getting acquired via Client Credential flow
def get_token(auth_ctx):
"""Acquire token via client credential flow (ADAL Python library is utilized)"""
token = auth_ctx.acquire_token_with_client_credentials(
"https://graph.microsoft.com",
client_id,
client_secret)
return token
tenant_name = "contoso.onmicrosoft.com"
client = GraphClient(tenant_name, get_token)
drives = client.drives
client.load(drives)
client.execute_query()
for drive in drives:
print("Drive url: {0}".format(drive.web_url))
Python 2.7 & 3.4–3.6
are supported.
The following libraries will be installed when you install the client library: