SlideShare uma empresa Scribd logo
1 de 36
DEEP DIVE INTO OFFICE 365 APIS FOR
SHAREPOINT SITE SERVICES
Bram de Jager
Technology Consultant | Macaw Workplace Solutions
Microsoft Certified Solutions Master: SharePoint
@bramdejager | bramdejager.wordpress.com
AGENDA
• Overview
• Get Started with Office 365 APIs
• File Operations with SharePointClient
• List Operations with REST
• Wrap-up
OVERVIEW
Deep Dive into Office 365 APIs for SharePoint Site services
API’S EVERYWHERE!
• SharePoint APIs
o .NET SSOM
o .NET CSOM
o JavaScript JSOM
o REST/OData endpoints
• Office 365 API
o Connect to your users' mail, calendars, contacts, and files into your app
• Microsoft Graph (previously known as Office 365 Unified API)
o Single endpoint for connecting to all of the Office 365 services
OFFICE 365API
SharePointExchange &
Outlook.com
OneDriveActive
Directory
Search
Sites, Lists
and Libs
Taxonomy
BCSWorkflow
…
MICROSOFT GRAPH
https://graph.microsoft.com/
WHY DO I NEED THE OFFICE 365APIS?
• Access Office 365 data outside of the Office 365 context
o But also integrate with the Office 365 and App Launcher
• Single set of APIs for (almost) all Office 365 services
• Uniform authentication, with support for
o Federation support (AD FS)
o Multi-Factor Authentication (MFA)
GET STARTED WITH OFFICE 365APIS
Deep Dive into Office 365 APIs for SharePoint Site services
DISCOVERY SERVICE
• Returns a collection of endpoints specific to current user
• Intended as the starting point for application
o 1. Sign-In
o 2. Get authorized
o 3. Discover endpoints for resource
o 4. Get Token
o 5. Access resource
• API Libraries simplify necessary code
• Capabilities: https://api.office.com/discovery/v1.0/me/allServices
AUTHENTICATION FLOW
Native Application
Azure AD Authorization
Endpoint
Azure AD Token
Endpoint
Office 365 API
Request authorization code
Return authorization code
Sign-in via browser (pop-up)
Redeem authorization code and acquire access token for Office 365 resource
Return access token and refresh token
Call Office 365 API using the access token
Return Http Response
ADAL
• Azure AD Authentication Library (ADAL) supports:
o Token Acquisition
o Token Cache storing access tokens and refresh tokens
o Automatic Token Refresh
o Asynchronous Methods
PERMISSIONS (CONNECTED SERVICE)
GRANTACCESS TO OFFICE 365
REVOKE CONSENT
• Navigate to https://portal.office.com/myapps
APP LAUNCHER INTEGRATION
DEMO
• Get started with Office 365 App development
o Register Office 365 App in Visual Studio
o Grant access (user consent)
o Implement ADAL for .NET
FILE OPERATIONS WITH SHAREPOINTCLIENT
Deep Dive into Office 365 APIs for SharePoint Site services
SHAREPOINT SITES SERVICES
• Provides access to SharePoint Online REST API
• SharePointClient class simplifies programming, but limited functionality
• Direct REST API calls more complex, but exposes more functionality
SHAREPOINTCLIENT CLASS
• Discovery Service discovers resource
• SharePointClient.Files abstracts Files API
https://api.office.com/discovery/v1.0/me/
https://api.office.com/discovery/
https://company.sharepoint.com/
GET FILES COLLECTION
• Get folders and files collection and read file metadata
• Get files in specific folder
• Type property is either “File” or “Folder”
BUTTHERE ISACATCH!
• The API searches for two document libraries, named
o (1) Shared Documents
o (2) Documents
• If libraries do not exist, then…
o {"error":{"code":"-2146232832,
Microsoft.SharePoint.SPException","message":"The file |0 does not exist."}}
DOCUMENT LIBRARIES DO NOT EXIST
DEMO
• Implement Get Files collection
• Scenario for the supported document libraries used by the Office 365 API for
Sites
o Site contains 3 document libraries, named: Shared Documents, Documents,
Other Documents
o Remove Shared Documents library
o Remove Documents library
ADD NEW FILE
• Use AddAsync() method
• Provide a file name and the file stream
DELETINGAFILE
• Get the file using GetById() method
• Delete using DeleteAsync() method
LIST OPERATIONS WITH REST
Deep Dive into Office 365 APIs for SharePoint Site services
READING LIST ITEMS
• Office 365 APIs do not support list operations
• Access the SharePoint REST API with the Access Token from the Office 365 API
GETACCESS TOKEN
DEMO
• Implement Reading List Items collection
• Use Office 365 API to retrieve Access Token
OTHER REST OPERATIONS
• List Items
o Adding a list item
o Updating a list item
o Deleting a list item
• Other REST APIs
o Taxonomy
o Search (Office Graph)
o BCS
o Workflow
o …
WRAP-UP
Deep Dive into Office 365 APIs for SharePoint Site services
KEY TAKEAWAY
• One API for accessing all Office 365 data
o API makes it easier, limited functionality
o Reuse the Access Token for REST calls
• Single repeatable pattern for
o Mail
o Contact
o Calendar
o Files
o OneDrive
o …
KEY TAKEAWAY
• Another approach to providing solutions
o Build a solution which connects to all Office 365 service
o App Launcher integration
o Use all capabilities provided by ASP.NET web application
o Integrate these Office 365 services into
o SharePoint Add-ins
o Office Add-ins
o Native apps: Windows Universal Apps, iOS, Android
RESOURCES
• Office Dev Center, http://dev.office.com
• Get started with Office 365 APIs, http://dev.office.com/getting-started/office365apis
• Office 365 API reference, https://msdn.microsoft.com/en-
us/office/office365/api/api-catalog
• Files REST API reference, https://msdn.microsoft.com/office/office365/APi/files-
rest-operations
• Authorization Code Grant Flow, https://msdn.microsoft.com/en-
us/library/azure/dn645542.aspx
• Kirk Evans Fiddler add-in (oAuth inspector),
http://blogs.msdn.com/b/kaevans/archive/2015/03/30/updated-fiddler-oauth-
inspector.aspx
SharePoint Client Browser
• Audience: Developer and IT Pro
• Insights into your Office 365 Tenant
and/or Site Collection
• Exposes the SharePoint CSOM
• Supports SharePoint Online and
SharePoint Server
• Just released new version
• Over 29.000 downloads already!
• http://spcb.codeplex.com
QUESTIONS?
Bram de Jager
@bramdejager | bramdejager.wordpress.com

Mais conteúdo relacionado

Destaque

Как заработать в облаке? FAQ для реселлеров и интеграторов
Как заработать в облаке? FAQ для реселлеров и интеграторовКак заработать в облаке? FAQ для реселлеров и интеграторов
Как заработать в облаке? FAQ для реселлеров и интеграторовMichael Kozloff
 
The 3 Secrets of Highly Successful Graduates
The 3 Secrets of Highly Successful GraduatesThe 3 Secrets of Highly Successful Graduates
The 3 Secrets of Highly Successful GraduatesReid Hoffman
 
Himmelstein SP Connections HAD207 SharePoint Logging & Debugging
Himmelstein SP Connections HAD207 SharePoint Logging & DebuggingHimmelstein SP Connections HAD207 SharePoint Logging & Debugging
Himmelstein SP Connections HAD207 SharePoint Logging & DebuggingSentri
 
Common Data Service (CDS), a new database?
Common Data Service (CDS), a new database?Common Data Service (CDS), a new database?
Common Data Service (CDS), a new database?Pedro Azevedo
 
Andrea a alfabetización escaleta
Andrea a alfabetización escaletaAndrea a alfabetización escaleta
Andrea a alfabetización escaletaandrearanxa
 
The #1 Skill Every Marketer Needs to Have!
The  #1 Skill Every Marketer Needs to Have!The  #1 Skill Every Marketer Needs to Have!
The #1 Skill Every Marketer Needs to Have!Manpreet Jassal
 
Introduction to jenkins for the net developer
Introduction to jenkins for the net developerIntroduction to jenkins for the net developer
Introduction to jenkins for the net developerAbe Diaz
 
You've Made It - Pitching to TechCrunch & Using AngelList
You've Made It - Pitching to TechCrunch & Using AngelListYou've Made It - Pitching to TechCrunch & Using AngelList
You've Made It - Pitching to TechCrunch & Using AngelListRandy Ksar
 

Destaque (12)

Как заработать в облаке? FAQ для реселлеров и интеграторов
Как заработать в облаке? FAQ для реселлеров и интеграторовКак заработать в облаке? FAQ для реселлеров и интеграторов
Как заработать в облаке? FAQ для реселлеров и интеграторов
 
Arrival & departure
Arrival & departureArrival & departure
Arrival & departure
 
The 3 Secrets of Highly Successful Graduates
The 3 Secrets of Highly Successful GraduatesThe 3 Secrets of Highly Successful Graduates
The 3 Secrets of Highly Successful Graduates
 
Himmelstein SP Connections HAD207 SharePoint Logging & Debugging
Himmelstein SP Connections HAD207 SharePoint Logging & DebuggingHimmelstein SP Connections HAD207 SharePoint Logging & Debugging
Himmelstein SP Connections HAD207 SharePoint Logging & Debugging
 
Common Data Service (CDS), a new database?
Common Data Service (CDS), a new database?Common Data Service (CDS), a new database?
Common Data Service (CDS), a new database?
 
Andrea a alfabetización escaleta
Andrea a alfabetización escaletaAndrea a alfabetización escaleta
Andrea a alfabetización escaleta
 
The #1 Skill Every Marketer Needs to Have!
The  #1 Skill Every Marketer Needs to Have!The  #1 Skill Every Marketer Needs to Have!
The #1 Skill Every Marketer Needs to Have!
 
Cbhpm 5 edicao
Cbhpm 5 edicaoCbhpm 5 edicao
Cbhpm 5 edicao
 
E-ntrepreneur
E-ntrepreneurE-ntrepreneur
E-ntrepreneur
 
Introduction to jenkins for the net developer
Introduction to jenkins for the net developerIntroduction to jenkins for the net developer
Introduction to jenkins for the net developer
 
PowerApps Deep Dive
PowerApps Deep DivePowerApps Deep Dive
PowerApps Deep Dive
 
You've Made It - Pitching to TechCrunch & Using AngelList
You've Made It - Pitching to TechCrunch & Using AngelListYou've Made It - Pitching to TechCrunch & Using AngelList
You've Made It - Pitching to TechCrunch & Using AngelList
 

Último

Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...
Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...
Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...soniya singh
 
Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...aditisharan08
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxComplianceQuest1
 
Introduction to Decentralized Applications (dApps)
Introduction to Decentralized Applications (dApps)Introduction to Decentralized Applications (dApps)
Introduction to Decentralized Applications (dApps)Intelisync
 
What is Binary Language? Computer Number Systems
What is Binary Language?  Computer Number SystemsWhat is Binary Language?  Computer Number Systems
What is Binary Language? Computer Number SystemsJheuzeDellosa
 
BATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASE
BATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASEBATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASE
BATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASEOrtus Solutions, Corp
 
why an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdfwhy an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdfjoe51371421
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVshikhaohhpro
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Modelsaagamshah0812
 
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed DataAlluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed DataAlluxio, Inc.
 
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...stazi3110
 
Professional Resume Template for Software Developers
Professional Resume Template for Software DevelopersProfessional Resume Template for Software Developers
Professional Resume Template for Software DevelopersVinodh Ram
 
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...kellynguyen01
 
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdfThe Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdfkalichargn70th171
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfkalichargn70th171
 
Engage Usergroup 2024 - The Good The Bad_The Ugly
Engage Usergroup 2024 - The Good The Bad_The UglyEngage Usergroup 2024 - The Good The Bad_The Ugly
Engage Usergroup 2024 - The Good The Bad_The UglyFrank van der Linden
 
EY_Graph Database Powered Sustainability
EY_Graph Database Powered SustainabilityEY_Graph Database Powered Sustainability
EY_Graph Database Powered SustainabilityNeo4j
 
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...Christina Lin
 
TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providermohitmore19
 
Building Real-Time Data Pipelines: Stream & Batch Processing workshop Slide
Building Real-Time Data Pipelines: Stream & Batch Processing workshop SlideBuilding Real-Time Data Pipelines: Stream & Batch Processing workshop Slide
Building Real-Time Data Pipelines: Stream & Batch Processing workshop SlideChristina Lin
 

Último (20)

Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...
Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...
Russian Call Girls in Karol Bagh Aasnvi ➡️ 8264348440 💋📞 Independent Escort S...
 
Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...Unit 1.1 Excite Part 1, class 9, cbse...
Unit 1.1 Excite Part 1, class 9, cbse...
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docx
 
Introduction to Decentralized Applications (dApps)
Introduction to Decentralized Applications (dApps)Introduction to Decentralized Applications (dApps)
Introduction to Decentralized Applications (dApps)
 
What is Binary Language? Computer Number Systems
What is Binary Language?  Computer Number SystemsWhat is Binary Language?  Computer Number Systems
What is Binary Language? Computer Number Systems
 
BATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASE
BATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASEBATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASE
BATTLEFIELD ORM: TIPS, TACTICS AND STRATEGIES FOR CONQUERING YOUR DATABASE
 
why an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdfwhy an Opensea Clone Script might be your perfect match.pdf
why an Opensea Clone Script might be your perfect match.pdf
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTV
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Models
 
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed DataAlluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
Alluxio Monthly Webinar | Cloud-Native Model Training on Distributed Data
 
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
Building a General PDE Solving Framework with Symbolic-Numeric Scientific Mac...
 
Professional Resume Template for Software Developers
Professional Resume Template for Software DevelopersProfessional Resume Template for Software Developers
Professional Resume Template for Software Developers
 
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
Short Story: Unveiling the Reasoning Abilities of Large Language Models by Ke...
 
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdfThe Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
The Essentials of Digital Experience Monitoring_ A Comprehensive Guide.pdf
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
 
Engage Usergroup 2024 - The Good The Bad_The Ugly
Engage Usergroup 2024 - The Good The Bad_The UglyEngage Usergroup 2024 - The Good The Bad_The Ugly
Engage Usergroup 2024 - The Good The Bad_The Ugly
 
EY_Graph Database Powered Sustainability
EY_Graph Database Powered SustainabilityEY_Graph Database Powered Sustainability
EY_Graph Database Powered Sustainability
 
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
ODSC - Batch to Stream workshop - integration of Apache Spark, Cassandra, Pos...
 
TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service provider
 
Building Real-Time Data Pipelines: Stream & Batch Processing workshop Slide
Building Real-Time Data Pipelines: Stream & Batch Processing workshop SlideBuilding Real-Time Data Pipelines: Stream & Batch Processing workshop Slide
Building Real-Time Data Pipelines: Stream & Batch Processing workshop Slide
 

Deep Dive into Office 365 APIs for SharePoint Site services

  • 1. DEEP DIVE INTO OFFICE 365 APIS FOR SHAREPOINT SITE SERVICES Bram de Jager Technology Consultant | Macaw Workplace Solutions Microsoft Certified Solutions Master: SharePoint @bramdejager | bramdejager.wordpress.com
  • 2. AGENDA • Overview • Get Started with Office 365 APIs • File Operations with SharePointClient • List Operations with REST • Wrap-up
  • 3. OVERVIEW Deep Dive into Office 365 APIs for SharePoint Site services
  • 4. API’S EVERYWHERE! • SharePoint APIs o .NET SSOM o .NET CSOM o JavaScript JSOM o REST/OData endpoints • Office 365 API o Connect to your users' mail, calendars, contacts, and files into your app • Microsoft Graph (previously known as Office 365 Unified API) o Single endpoint for connecting to all of the Office 365 services
  • 7. WHY DO I NEED THE OFFICE 365APIS? • Access Office 365 data outside of the Office 365 context o But also integrate with the Office 365 and App Launcher • Single set of APIs for (almost) all Office 365 services • Uniform authentication, with support for o Federation support (AD FS) o Multi-Factor Authentication (MFA)
  • 8. GET STARTED WITH OFFICE 365APIS Deep Dive into Office 365 APIs for SharePoint Site services
  • 9. DISCOVERY SERVICE • Returns a collection of endpoints specific to current user • Intended as the starting point for application o 1. Sign-In o 2. Get authorized o 3. Discover endpoints for resource o 4. Get Token o 5. Access resource • API Libraries simplify necessary code • Capabilities: https://api.office.com/discovery/v1.0/me/allServices
  • 10. AUTHENTICATION FLOW Native Application Azure AD Authorization Endpoint Azure AD Token Endpoint Office 365 API Request authorization code Return authorization code Sign-in via browser (pop-up) Redeem authorization code and acquire access token for Office 365 resource Return access token and refresh token Call Office 365 API using the access token Return Http Response
  • 11. ADAL • Azure AD Authentication Library (ADAL) supports: o Token Acquisition o Token Cache storing access tokens and refresh tokens o Automatic Token Refresh o Asynchronous Methods
  • 14. REVOKE CONSENT • Navigate to https://portal.office.com/myapps
  • 16. DEMO • Get started with Office 365 App development o Register Office 365 App in Visual Studio o Grant access (user consent) o Implement ADAL for .NET
  • 17. FILE OPERATIONS WITH SHAREPOINTCLIENT Deep Dive into Office 365 APIs for SharePoint Site services
  • 18. SHAREPOINT SITES SERVICES • Provides access to SharePoint Online REST API • SharePointClient class simplifies programming, but limited functionality • Direct REST API calls more complex, but exposes more functionality
  • 19. SHAREPOINTCLIENT CLASS • Discovery Service discovers resource • SharePointClient.Files abstracts Files API https://api.office.com/discovery/v1.0/me/ https://api.office.com/discovery/ https://company.sharepoint.com/
  • 20. GET FILES COLLECTION • Get folders and files collection and read file metadata • Get files in specific folder • Type property is either “File” or “Folder”
  • 21. BUTTHERE ISACATCH! • The API searches for two document libraries, named o (1) Shared Documents o (2) Documents • If libraries do not exist, then… o {"error":{"code":"-2146232832, Microsoft.SharePoint.SPException","message":"The file |0 does not exist."}}
  • 23. DEMO • Implement Get Files collection • Scenario for the supported document libraries used by the Office 365 API for Sites o Site contains 3 document libraries, named: Shared Documents, Documents, Other Documents o Remove Shared Documents library o Remove Documents library
  • 24. ADD NEW FILE • Use AddAsync() method • Provide a file name and the file stream
  • 25. DELETINGAFILE • Get the file using GetById() method • Delete using DeleteAsync() method
  • 26. LIST OPERATIONS WITH REST Deep Dive into Office 365 APIs for SharePoint Site services
  • 27. READING LIST ITEMS • Office 365 APIs do not support list operations • Access the SharePoint REST API with the Access Token from the Office 365 API
  • 29. DEMO • Implement Reading List Items collection • Use Office 365 API to retrieve Access Token
  • 30. OTHER REST OPERATIONS • List Items o Adding a list item o Updating a list item o Deleting a list item • Other REST APIs o Taxonomy o Search (Office Graph) o BCS o Workflow o …
  • 31. WRAP-UP Deep Dive into Office 365 APIs for SharePoint Site services
  • 32. KEY TAKEAWAY • One API for accessing all Office 365 data o API makes it easier, limited functionality o Reuse the Access Token for REST calls • Single repeatable pattern for o Mail o Contact o Calendar o Files o OneDrive o …
  • 33. KEY TAKEAWAY • Another approach to providing solutions o Build a solution which connects to all Office 365 service o App Launcher integration o Use all capabilities provided by ASP.NET web application o Integrate these Office 365 services into o SharePoint Add-ins o Office Add-ins o Native apps: Windows Universal Apps, iOS, Android
  • 34. RESOURCES • Office Dev Center, http://dev.office.com • Get started with Office 365 APIs, http://dev.office.com/getting-started/office365apis • Office 365 API reference, https://msdn.microsoft.com/en- us/office/office365/api/api-catalog • Files REST API reference, https://msdn.microsoft.com/office/office365/APi/files- rest-operations • Authorization Code Grant Flow, https://msdn.microsoft.com/en- us/library/azure/dn645542.aspx • Kirk Evans Fiddler add-in (oAuth inspector), http://blogs.msdn.com/b/kaevans/archive/2015/03/30/updated-fiddler-oauth- inspector.aspx
  • 35. SharePoint Client Browser • Audience: Developer and IT Pro • Insights into your Office 365 Tenant and/or Site Collection • Exposes the SharePoint CSOM • Supports SharePoint Online and SharePoint Server • Just released new version • Over 29.000 downloads already! • http://spcb.codeplex.com
  • 36. QUESTIONS? Bram de Jager @bramdejager | bramdejager.wordpress.com

Notas do Editor

  1. Office 365 REST APIs let you plug in your users' mail, calendars, contacts, and files into your app. Office 365 REST API endpoint: Mail Contacts Calendars Outlook notifications (preview) Outlook user photo (preview) Discovery service Files OneDrive (preview) Video (preview) Office 365 Management APIs Service Communications API (preview) Management Activity API Reference (preview) Source: http://dev.office.com/getting-started/office365apis
  2. Single authentication and API endpoint for Office 365 and Microsoft Services, thus a single AccessToken for all services! Single endpoint, no discovery service required Require only 1 AccessToken Office 365 unified API endpoint Users Groups Files Mail Calendar Contacts and Office Graph Source: http://dev.office.com/unifiedAPIs
  3. Single auth flow for O365 Azure AD Graph, Exchange, SharePoint Device apps and web sites Admin and end-user consent Secure protocol OAuth 2.0 No capturing user credentials Fine-grained access scopes Supports MFA and federated user sign-in Long-term access through refresh tokens
  4. Authentication to Office 365 APIs using resource id Authorization Code Grant Flow The client application starts the flow by redirecting the user agent to the Azure AD authorization endpoint. The user authenticates and consents, if consent is required. The Azure AD authorization endpoint redirects the user agent back to the client application with an authorization code. The user agent returns authorization code to the client application’s redirect URI. The client application requests an access token from the Azure AD token issuance endpoint. It presents the authorization code to prove that the user has consented. The Azure AD token issuance endpoint returns an access token and a refresh token. The refresh token can be used to request additional access tokens. The client application uses the access token to authenticate to the Web API. After authenticating the client application, the web API returns the requested data. https://msdn.microsoft.com/en-us/library/azure/dn645542.aspx
  5. https://msdn.microsoft.com/en-us/library/azure/jj573266.aspx
  6. Grant access per person Grant access per organization
  7. How To Delete An App You Consented to in Azure AD https://samlman.wordpress.com/2015/02/27/how-to-delete-an-app-you-consented-to-in-azure-ad/
  8. Integrate Office 365 APIs into .NET Visual Studio projects https://msdn.microsoft.com/en-us/office/office365/howto/authenticate-and-use-services
  9. Paging is based on post-query using LINQ (left out)
  10. Office 365 API Sites Site with library named “Documents” or “Shared Documents” is only for OneDrive! Not for Files API
  11. Examples Macaw Colleague Sync Get all Macaw colleagues from Azure AD Retrieve user profile information from SharePoint via REST API by using the AccessToken Add every colleague to your personal Contacts Time registration Retrieve time information based on your personal Calendar Add entries to time registration tool based on calendar information Save a monthly report to your personal OneDrive Files Examples Macaw Colleague Sync Time registration