Skip to content

This sample shows how to connect your Node.js web app to Microsoft Graph and send an email.

Notifications You must be signed in to change notification settings

jiayeZhu/O365-Nodejs-Microsoft-Graph-Connect

 
 

Repository files navigation

Office 365 Node.js Connect sample using Microsoft Graph

Build Status

Connecting to Office 365 is the first step every app must take to start working with Office 365 services and data. This sample shows how to connect and then call one endpoint through the Microsoft Graph API (previously called Office 365 unified API), and uses the Office Fabric UI to create an Office 365 experience.

Try out the Get started with Office 365 APIs page which simplifies registration so you can get this sample running faster.

Office 365 Node.js Connect sample screenshot

Note: For an in-depth look at the code for calling the Microsoft Graph API in a Node.js app, see Call Microsoft Graph with a Node.js app.

Prerequisites

To use the Office 365 Node.js Connect sample, you need the following:

  • An Office 365 account. You can sign up for an Office 365 Developer subscription that includes the resources that you need to start building Office 365 apps.

    Note: If you already have a subscription, the previous link sends you to a page with the message Sorry, you can’t add that to your current account. In that case use an account from your current Office 365 subscription.

    If you are already signed-in to Office 365, the Sign-in button in the previous link shows the message Sorry, we can't process your request. In that case sign-out from Office 365 in that same page and sign-in again.

  • A Microsoft Azure tenant to register your application. Azure Active Directory (AD) provides identity services that applications use for authentication and authorization. A trial subscription can be acquired here: Microsoft Azure.

    Important: You also need to make sure your Azure subscription is bound to your Office 365 tenant. To do this, see the Active Directory team's blog post, Creating and Managing Multiple Windows Azure Active Directories. The section Adding a new directory will explain how to do this. You can also see Set up your Office 365 development environment and the section Associate your Office 365 account with Azure AD to create and manage apps for more information.

  • A client ID, client secret, and redirect URI values of an application registered in Azure. This sample application must be granted the Send mail as signed-in user permission for Microsoft Graph. Add a web application in Azure and grant proper permissions to it.

    Note: During the app registration process, make sure to specify http://localhost:3000/login as the Sign-on URL.

  • Consult the section Configure and run the app for platform specific prerequisites.

Configure and run the app

  1. Update authHelper.js/client_id with your application's client id
  2. Update authHelper.js/client_secret with your application's client secret
  3. Update authHelper.js/redirect_uri with your application's redirect uri

Prerequisites

  • node - JavaScript runtime built on Chrome V8
  • npm - Node Package Manager

To run the app, type the following into your command line:

  1. npm install - install application dependencies
  2. npm start - starts the application server

Launch the app in your browser

Once the application server has been started, open your favorite web browser to http://localhost:3000

Questions and comments

We'd love to get your feedback about the Office 365 Node.js Connect sample. You can send your questions and suggestions to us in the Issues section of this repository.

Questions about Office 365 development in general should be posted to Stack Overflow. Make sure that your questions or comments are tagged with [Office365] and [MicrosoftGraph].

Additional resources

Copyright

Copyright (c) 2016 Microsoft. All rights reserved.

About

This sample shows how to connect your Node.js web app to Microsoft Graph and send an email.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 83.9%
  • HTML 13.1%
  • CSS 3.0%