SlideShare a Scribd company logo
Unchain your app’s capabilities with Microsoft Graph
Yannick Plenevaux
yp_code
aOS Luxembourg
16 mai 2019
Yannick Plenevaux
SharePoint & Office 365 Architect
MCSD App Builder
@ yannick.plenevaux@pvx-solutions.com
@yp_code
https://ypcode.wordpress.com
Founder of PVX Solutions
https://www.pvx-solutions.com
aOS Luxembourg
16 mai 2019
Agenda
 Corporate data
 The Microsoft Graph API
 The Graph Explorer
 Security
 Permissions
 Authorization Flow
 Create your app !
 Microsoft Graph in SPFx solutions
 Q&A
aOS Luxembourg
16 mai 2019
Corporate data
Me
E-mails
Events
Documents
Tasks
Content
Groups
People
Organization
Conversations
/ Chats
Devices
Activities
aOS Luxembourg
16 mai 2019
Microsoft 365 data
Me
E-mails
Events
Documents
Tasks
Content
Groups
People
Organization
Conversations
/ Chats
Devices
Activities
aOS Luxembourg
16 mai 2019
The Microsoft Graph API
One API to access and manipulate all corporate data in your app !
V1.0 : Stable and fully supported by Microsoft for Production usage
Beta : Preview of upcoming capabilities.
 Subject to changes  Not supported by Microsoft for Production usage
aOS Luxembourg
16 mai 2019
The Microsoft Graph API
 Only on Microsoft 365 / Office 365 (Cloud)
 Will most likely never come fully on premises !
 Why ?
 It continuously evolves (release each month)
 It uses a lot of machine learning algorithms on interconnected data
from various Microsoft services
 Would be very difficult to setup and maintain…
 It is THE Microsoft Cloud “killer app”  !
 However, some hybrid scenarios are feasible
 Announced at Build 2019 : Include your local Data in Microsoft Graph
aOS Luxembourg
16 mai 2019
The Microsoft Graph API
https://graph.microsoft.com
 Implements OData syntax in most
cases
 $filter
 $select
 $skip / $top
 $expand
 $orderby
 …
 RESTful = HTTP calls
 Read  HTTP GET
 Create  HTTP POST
 Update  HTTP PUT / PATCH
 Delete  HTTP DELETE
Get my 3 next events
GET https://graph.microsoft.com/v1.0/me/events?$filter=start/dateTime gt ‘2019-05-16T00:00:00’&$orderby=start/dateTime asc&$top=3
Get the files in my OneDrive folder
GET https://graph.microsoft.com/v1.0/me/drive/root/children
aOS Luxembourg
16 mai 2019
The Microsoft Graph API
 Accepts JSON as arguments and return JSON responses
 Can be used in any technology with HTTP capabilities
 API client implementation in various technologies
https://developer.microsoft.com/en-us/graph/get-started
aOS Luxembourg
16 mai 2019
The Graph Explorer
 Test the Microsoft Graph API
 In a playground context (read-only)
 With your tenant
real data
https://developer.microsoft.com/en-us/graph/graph-explorer
aOS Luxembourg
16 mai 2019
The Graph Explorer
DEMO
aOS Luxembourg
16 mai 2019
Security: Permissions
 Permissions have to be granted to the application
 Delegated permissions
 The application performs the actions on behalf of a signed-in user.
 “Effective permission” is the least privileged permission between the delegated permission and the real
privilege of the user
 Application permissions (app-only)
 Not signed-in user (background job, automated tasks, …)
 Consent has to be given to the application
 Delegated permissions
 The current user gives consent to the requested permissions
 Administrators can give consent for all users
 Some permissions require an administrator to give consent
 Application permissions
 Only administrators can give consent
https://docs.microsoft.com/en-us/graph/permissions-reference
aOS Luxembourg
16 mai 2019
Security: Authorization flows
Azure AD protected Web API
Authorization Flow Common usage
OpenID Connect Web applications
OAuth 2.0 Implicit Grant Client-side applications (JS)
OAuth 2.0 Auth Code Native (Desktop, Mobile) applications
OAuth 2.0 on-behalf-of Web APIs
OAuth 2.0 Client Credentials App-only (Background jobs, …)
…
The authorization endpoints :
https://login.microsoftonline.com/common/oauth2/v2.0
• /authorize (Sign-in)
• /token (Get access token)
Pass the access token in each Graph
HTTP call headers
Authorization: Bearer <access token>
These authorization flows are mostly handled by the available client APIs !
If not, it can be implemented in any technology with HTTP capabilities
common can be replaced by the tenant id
to target a specific tenant
(e.g. contoso.onmicrosoft.com)
aOS Luxembourg
16 mai 2019
Authorization flow
Web app
Data from API forwarded to user
Microsoft Graph
aOS Luxembourg
16 mai 2019
Authorization flow
Mobile/Desktop app
Microsoft Graph
1 hour
Access Token expires
after 1 hour
Refresh token expires
after 14 days
renewable up to total 90 days
aOS Luxembourg
16 mai 2019
Create your app !
 In order to access graph from an application
 Setup (by Azure AD administrator)
 Need to register the app in Azure AD
 https://aad.portal.azure.com  App registrations
 For Web applications  Need Redirect URI
 Need to request the appropriate permissions for the app to work properly
 At runtime
1. The user signs in
 At first sign-in, the user must give consent to the permissions requested by the application
 Administrators can give consent for all users (can also be done from AAD portal)
 No “sign-in” in app-only context
2. Get Access Token
3. Call the Microsoft Graph endpoint with the Authorization header
set to Bearer <access_token>
aOS Luxembourg
16 mai 2019
Create your app !
DEMO
aOS Luxembourg
16 mai 2019
Microsoft Graph in SPFx solutions
 SPFx v1.6 (Aug. 2018)
 Call to AAD registered app natively supported
 Dedicated feature support for Microsoft Graph
 As in any app using MS Graph
 The appropriate permissions needs to be requested
 The permissions must be granted by a SharePoint global
administrator
 No need to access Azure AD portal
 SPFx integrated library to automatically handle the access token
internal plumbing
aOS Luxembourg
16 mai 2019
Microsoft Graph in SPFx solutions
DEMO
aOS Luxembourg
16 mai 2019
Microsoft Graph in SPFx solutions
Leverage your corporate data using Microsoft Graph
 In your SharePoint customizations
 In your custom Microsoft Teams Tabs
 Soon in your Office add-ins ! ( Word, Excel, PowerPoint, Outlook)
 Public announcements are expected at SPC this month !
Using ONE Framework and even ONE codebase
aOS Luxembourg
16 mai 2019
Unchain your app’s capabilities with
Microsoft Graph
Questions ?
Merci à notre sponsor !

More Related Content

PDF
Push notifications may be coming to web apps in i os 15.4
PPSX
eNest_Portfolio
PPTX
Get started developing apps for SharePoint 2013
DOCX
Here are the Most Useful Tools for Mobile App Development
PDF
Facebook´s Programmatics Evolution
PPTX
SharePoint 2013 Apps and the App Model
PDF
API Design in the Age of Bots, IoT, and Voice
PPTX
How to use Microsoft Graph in your applications
Push notifications may be coming to web apps in i os 15.4
eNest_Portfolio
Get started developing apps for SharePoint 2013
Here are the Most Useful Tools for Mobile App Development
Facebook´s Programmatics Evolution
SharePoint 2013 Apps and the App Model
API Design in the Age of Bots, IoT, and Voice
How to use Microsoft Graph in your applications

Similar to 2019 05-16 aOS Luxembourg - 5 - Unchain your apps capabilities with Microsoft Graph - Yannick Plenevaux (20)

PPTX
O365 Saturday MS Graph API
PPTX
#SPSToronto The SharePoint Framework and the Microsoft Graph on steroids with...
PPTX
harePoint Framework Webinar Series: Consume Graph APIs in SharePoint Framework
PPTX
#SPSottawa The SharePoint Framework and The Microsoft Graph on steroids with ...
PDF
O365Engage17 - Supercharge Your Applications with the Microsoft Graph API
PPTX
#Techorama belgium 2018 vincent biret deep dive with the #MicrosoftGraph
PPTX
SharePoint Saturday Chicago - Everything your need to know about the Microsof...
PPTX
#SPFestSEA Introduction to #MicrosoftGraph
PPTX
#SPSOttawa introduction to the #microsoftGraph
PPTX
MS365 Dev Bootcamp Montreal 2019 - Microsoft graph introduction
PPTX
Granite state #spug The #microsoftGraph and #SPFx on steroids with #AzureFunc...
PPTX
Microsoft Graph
PPSX
Power of Microsoft Graph API by Nilesh Shah SharePoint Saturday Toronto 2017
PDF
Microsoft graph and power platform champ
PPTX
SharePoint Fest DC - Everything your need to know about the Microsoft Graph a...
PDF
Create cross-platform apps that interact with Microsoft Graph and Office 365 ...
PPTX
#SPFestSea azr302 The SharePoint Framework and the #MicrosoftGraph under ster...
PPTX
SPS Utah - Everything your need to know about the Microsoft Graph as a ShareP...
PPTX
Developing share point solutions with the microsoft graph
PPTX
SharePoint Fest Seattle 2017 - Everything your need to know about the Microso...
O365 Saturday MS Graph API
#SPSToronto The SharePoint Framework and the Microsoft Graph on steroids with...
harePoint Framework Webinar Series: Consume Graph APIs in SharePoint Framework
#SPSottawa The SharePoint Framework and The Microsoft Graph on steroids with ...
O365Engage17 - Supercharge Your Applications with the Microsoft Graph API
#Techorama belgium 2018 vincent biret deep dive with the #MicrosoftGraph
SharePoint Saturday Chicago - Everything your need to know about the Microsof...
#SPFestSEA Introduction to #MicrosoftGraph
#SPSOttawa introduction to the #microsoftGraph
MS365 Dev Bootcamp Montreal 2019 - Microsoft graph introduction
Granite state #spug The #microsoftGraph and #SPFx on steroids with #AzureFunc...
Microsoft Graph
Power of Microsoft Graph API by Nilesh Shah SharePoint Saturday Toronto 2017
Microsoft graph and power platform champ
SharePoint Fest DC - Everything your need to know about the Microsoft Graph a...
Create cross-platform apps that interact with Microsoft Graph and Office 365 ...
#SPFestSea azr302 The SharePoint Framework and the #MicrosoftGraph under ster...
SPS Utah - Everything your need to know about the Microsoft Graph as a ShareP...
Developing share point solutions with the microsoft graph
SharePoint Fest Seattle 2017 - Everything your need to know about the Microso...
Ad

More from aOS Community (20)

PPTX
Commencer le IaaS sur Azure - aOS Tahiti 03-03-2020
PPTX
Migrer vers O365. Quelles stragtégies? - aOS Tahiti 03-03-2020
PPTX
Passer des macro Excel à la power plateform - aOS Tahiti 03-03-2020
PDF
Serverless avec azure functions - aOS Tahiti 03-03-2020
PPTX
Passer des macro Excel à la power plateform - aOS Nouméa 28-02-2020
PDF
MS ignite : les nouveautés autour des content services et projet cortex - aOS...
PDF
Cybersecurité dans M365 - aOS Noumea 28-02-2020
PDF
Introduction a Power Automate - aOS Nouméa 28-02-2020
PDF
aOS Monaco 2019 - S3 - Présentation Varonis - Cloud Data Protection - Benjami...
PDF
aOS Monaco 2019 - S2 - Présentation ARKADIN - TEAMS Adoption - Laurent Pilo
PDF
aOS Monaco 2019 - C1 - Sécuriser sa messagerie sur Office 365 - Hakim Taoussi...
PDF
aOS Monaco 2019 - B7 - I Developed a SPFx solution, what to do next and how t...
PDF
aOS Monaco 2019 - B6 - Mister Governance and Doctor Teams - Jean-François Ber...
PDF
aOS Monaco 2019 - B5 - The good, the bad and the unexpected - a BOT story - K...
PDF
aOS Monaco 2019 - B4 - Three must have workflows with Microsoft Flow - Vlad C...
PDF
aOS Monaco 2019 - B3 - Create purchase request in PowerApps - Robi Voncina
PDF
aOS Monaco 2019 - B2 - Intégrer la Power Platform avec SharePoint - Patrick G...
PDF
aOS Monaco 2019 - B1 - Construire son infrastructure sur Azure un jeu d'enfan...
PDF
aOS Monaco 2019 - A7 - Sécurisez votre SI et vos services Office 365 partie 2...
PDF
aOS Monaco 2019 - A6 - Sécurisez votre SI et vos services Office 365 partie 1...
Commencer le IaaS sur Azure - aOS Tahiti 03-03-2020
Migrer vers O365. Quelles stragtégies? - aOS Tahiti 03-03-2020
Passer des macro Excel à la power plateform - aOS Tahiti 03-03-2020
Serverless avec azure functions - aOS Tahiti 03-03-2020
Passer des macro Excel à la power plateform - aOS Nouméa 28-02-2020
MS ignite : les nouveautés autour des content services et projet cortex - aOS...
Cybersecurité dans M365 - aOS Noumea 28-02-2020
Introduction a Power Automate - aOS Nouméa 28-02-2020
aOS Monaco 2019 - S3 - Présentation Varonis - Cloud Data Protection - Benjami...
aOS Monaco 2019 - S2 - Présentation ARKADIN - TEAMS Adoption - Laurent Pilo
aOS Monaco 2019 - C1 - Sécuriser sa messagerie sur Office 365 - Hakim Taoussi...
aOS Monaco 2019 - B7 - I Developed a SPFx solution, what to do next and how t...
aOS Monaco 2019 - B6 - Mister Governance and Doctor Teams - Jean-François Ber...
aOS Monaco 2019 - B5 - The good, the bad and the unexpected - a BOT story - K...
aOS Monaco 2019 - B4 - Three must have workflows with Microsoft Flow - Vlad C...
aOS Monaco 2019 - B3 - Create purchase request in PowerApps - Robi Voncina
aOS Monaco 2019 - B2 - Intégrer la Power Platform avec SharePoint - Patrick G...
aOS Monaco 2019 - B1 - Construire son infrastructure sur Azure un jeu d'enfan...
aOS Monaco 2019 - A7 - Sécurisez votre SI et vos services Office 365 partie 2...
aOS Monaco 2019 - A6 - Sécurisez votre SI et vos services Office 365 partie 1...
Ad

Recently uploaded (20)

PDF
Spectral efficient network and resource selection model in 5G networks
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
PDF
Approach and Philosophy of On baking technology
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PPTX
Cloud computing and distributed systems.
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
Empathic Computing: Creating Shared Understanding
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PPTX
MYSQL Presentation for SQL database connectivity
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PDF
NewMind AI Monthly Chronicles - July 2025
PPTX
Big Data Technologies - Introduction.pptx
PDF
Review of recent advances in non-invasive hemoglobin estimation
Spectral efficient network and resource selection model in 5G networks
Understanding_Digital_Forensics_Presentation.pptx
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Peak of Data & AI Encore- AI for Metadata and Smarter Workflows
Approach and Philosophy of On baking technology
Building Integrated photovoltaic BIPV_UPV.pdf
Cloud computing and distributed systems.
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Dropbox Q2 2025 Financial Results & Investor Presentation
Empathic Computing: Creating Shared Understanding
Digital-Transformation-Roadmap-for-Companies.pptx
20250228 LYD VKU AI Blended-Learning.pptx
Per capita expenditure prediction using model stacking based on satellite ima...
NewMind AI Weekly Chronicles - August'25 Week I
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
MYSQL Presentation for SQL database connectivity
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
NewMind AI Monthly Chronicles - July 2025
Big Data Technologies - Introduction.pptx
Review of recent advances in non-invasive hemoglobin estimation

2019 05-16 aOS Luxembourg - 5 - Unchain your apps capabilities with Microsoft Graph - Yannick Plenevaux

  • 1. Unchain your app’s capabilities with Microsoft Graph Yannick Plenevaux yp_code
  • 2. aOS Luxembourg 16 mai 2019 Yannick Plenevaux SharePoint & Office 365 Architect MCSD App Builder @ yannick.plenevaux@pvx-solutions.com @yp_code https://ypcode.wordpress.com Founder of PVX Solutions https://www.pvx-solutions.com
  • 3. aOS Luxembourg 16 mai 2019 Agenda  Corporate data  The Microsoft Graph API  The Graph Explorer  Security  Permissions  Authorization Flow  Create your app !  Microsoft Graph in SPFx solutions  Q&A
  • 4. aOS Luxembourg 16 mai 2019 Corporate data Me E-mails Events Documents Tasks Content Groups People Organization Conversations / Chats Devices Activities
  • 5. aOS Luxembourg 16 mai 2019 Microsoft 365 data Me E-mails Events Documents Tasks Content Groups People Organization Conversations / Chats Devices Activities
  • 6. aOS Luxembourg 16 mai 2019 The Microsoft Graph API One API to access and manipulate all corporate data in your app ! V1.0 : Stable and fully supported by Microsoft for Production usage Beta : Preview of upcoming capabilities.  Subject to changes  Not supported by Microsoft for Production usage
  • 7. aOS Luxembourg 16 mai 2019 The Microsoft Graph API  Only on Microsoft 365 / Office 365 (Cloud)  Will most likely never come fully on premises !  Why ?  It continuously evolves (release each month)  It uses a lot of machine learning algorithms on interconnected data from various Microsoft services  Would be very difficult to setup and maintain…  It is THE Microsoft Cloud “killer app”  !  However, some hybrid scenarios are feasible  Announced at Build 2019 : Include your local Data in Microsoft Graph
  • 8. aOS Luxembourg 16 mai 2019 The Microsoft Graph API https://graph.microsoft.com  Implements OData syntax in most cases  $filter  $select  $skip / $top  $expand  $orderby  …  RESTful = HTTP calls  Read  HTTP GET  Create  HTTP POST  Update  HTTP PUT / PATCH  Delete  HTTP DELETE Get my 3 next events GET https://graph.microsoft.com/v1.0/me/events?$filter=start/dateTime gt ‘2019-05-16T00:00:00’&$orderby=start/dateTime asc&$top=3 Get the files in my OneDrive folder GET https://graph.microsoft.com/v1.0/me/drive/root/children
  • 9. aOS Luxembourg 16 mai 2019 The Microsoft Graph API  Accepts JSON as arguments and return JSON responses  Can be used in any technology with HTTP capabilities  API client implementation in various technologies https://developer.microsoft.com/en-us/graph/get-started
  • 10. aOS Luxembourg 16 mai 2019 The Graph Explorer  Test the Microsoft Graph API  In a playground context (read-only)  With your tenant real data https://developer.microsoft.com/en-us/graph/graph-explorer
  • 11. aOS Luxembourg 16 mai 2019 The Graph Explorer DEMO
  • 12. aOS Luxembourg 16 mai 2019 Security: Permissions  Permissions have to be granted to the application  Delegated permissions  The application performs the actions on behalf of a signed-in user.  “Effective permission” is the least privileged permission between the delegated permission and the real privilege of the user  Application permissions (app-only)  Not signed-in user (background job, automated tasks, …)  Consent has to be given to the application  Delegated permissions  The current user gives consent to the requested permissions  Administrators can give consent for all users  Some permissions require an administrator to give consent  Application permissions  Only administrators can give consent https://docs.microsoft.com/en-us/graph/permissions-reference
  • 13. aOS Luxembourg 16 mai 2019 Security: Authorization flows Azure AD protected Web API Authorization Flow Common usage OpenID Connect Web applications OAuth 2.0 Implicit Grant Client-side applications (JS) OAuth 2.0 Auth Code Native (Desktop, Mobile) applications OAuth 2.0 on-behalf-of Web APIs OAuth 2.0 Client Credentials App-only (Background jobs, …) … The authorization endpoints : https://login.microsoftonline.com/common/oauth2/v2.0 • /authorize (Sign-in) • /token (Get access token) Pass the access token in each Graph HTTP call headers Authorization: Bearer <access token> These authorization flows are mostly handled by the available client APIs ! If not, it can be implemented in any technology with HTTP capabilities common can be replaced by the tenant id to target a specific tenant (e.g. contoso.onmicrosoft.com)
  • 14. aOS Luxembourg 16 mai 2019 Authorization flow Web app Data from API forwarded to user Microsoft Graph
  • 15. aOS Luxembourg 16 mai 2019 Authorization flow Mobile/Desktop app Microsoft Graph 1 hour Access Token expires after 1 hour Refresh token expires after 14 days renewable up to total 90 days
  • 16. aOS Luxembourg 16 mai 2019 Create your app !  In order to access graph from an application  Setup (by Azure AD administrator)  Need to register the app in Azure AD  https://aad.portal.azure.com  App registrations  For Web applications  Need Redirect URI  Need to request the appropriate permissions for the app to work properly  At runtime 1. The user signs in  At first sign-in, the user must give consent to the permissions requested by the application  Administrators can give consent for all users (can also be done from AAD portal)  No “sign-in” in app-only context 2. Get Access Token 3. Call the Microsoft Graph endpoint with the Authorization header set to Bearer <access_token>
  • 17. aOS Luxembourg 16 mai 2019 Create your app ! DEMO
  • 18. aOS Luxembourg 16 mai 2019 Microsoft Graph in SPFx solutions  SPFx v1.6 (Aug. 2018)  Call to AAD registered app natively supported  Dedicated feature support for Microsoft Graph  As in any app using MS Graph  The appropriate permissions needs to be requested  The permissions must be granted by a SharePoint global administrator  No need to access Azure AD portal  SPFx integrated library to automatically handle the access token internal plumbing
  • 19. aOS Luxembourg 16 mai 2019 Microsoft Graph in SPFx solutions DEMO
  • 20. aOS Luxembourg 16 mai 2019 Microsoft Graph in SPFx solutions Leverage your corporate data using Microsoft Graph  In your SharePoint customizations  In your custom Microsoft Teams Tabs  Soon in your Office add-ins ! ( Word, Excel, PowerPoint, Outlook)  Public announcements are expected at SPC this month ! Using ONE Framework and even ONE codebase
  • 21. aOS Luxembourg 16 mai 2019 Unchain your app’s capabilities with Microsoft Graph Questions ?
  • 22. Merci à notre sponsor !