This sample shows how to build an MVC web application that uses Azure AD for sign-in using the OpenID Connect protocol, and then calls a Office 365 API under the signed-in user's identity using tokens obtained via OAuth 2.0. This sample uses the OpenID Connect ASP.Net OWIN middleware and ADAL .Net.
Update 12/16/2014 The sample now uses a persistent ADAL token cache that uses a database for its token cache. You can see the token cache implementation in the following files:
To run this sample, you need:
- Visual Studio 2013
- Office 365 API Tools for Visual Studio 2013
- Office 365 Developer Subscription
From your Git Shell or command line:
git clone https://github.com/OfficeDev/O365-WebApp-MultiTenant.git
- Open the project in Visual Studio 2013.
- Simply Build the project to restore NuGet packages.
- Ignore any build errors for now as we will configure the project in the next steps.
Once downloaded, open the sample in Visual Studio.
Office 365 applications use Azure Active Directory (Azure AD) to authenticate and authorize users and applications respectively. All users, application registrations, permissions are stored in Azure AD.
Using the Office 365 API Tool for Visual Studio you can configure your web application to consume Office 365 APIs.
- In the Solution Explorer window, right click your project -> Add -> Connected Service.
- A Services Manager dialog box will appear. Choose Office 365 -> Office 365 API and click Register your app.
- On the sign-in dialog box, enter the username and password for your Office 365 tenant.
- After you're signed in, you will see a list of all the services.
- Initially, no permissions will be selected, as the app is not registered to consume any services yet.
- Select Users and Groups and then click Permissions
- In the Users and Groups Permissions dialog, select Enable sign-on and read users profiles' and click Apply
- Select Contacts and then click Permissions
- In the Contacts Permissions dialog, select Read users' contacts and click Apply
- Click on App Properties and select Multiple Organizations to make this app multi-tenant.
- Click Ok
After clicking OK in the Services Manager dialog box, Office 365 client libraries (in the form of NuGet packages) for connecting to Office 365 APIs will be added to your project.
In this process, Office 365 API tool registered an Azure AD Application in the Office 365 tenant that you signed in the wizard and added the Azure AD application details to web.config.
Now you are ready for a test run. Hit F5 to test the app.
The authentication startup class, App_Start/Startup.Auth.cs in the project contains the startup logic for Azure AD authentication.
The sample uses a persistent ADAL token cache that uses a database for its token cache. You can see the token cache implementation in the following files:
The sign in and sign out controls are already added to the views. You can find them under Views\Shared folder.
- _LoginPartial.cshtml is the partial view that renders the Sign In and Sign Out actions.
- _LoginPartial.cshtml is then rendered in _Layout.cshtml
- The AccountController.cs has the required methods for sign in and sign out.
Applying Authorize attribute to all controllers in your project will require the user to be authenticated before accessing these controllers. To allow the controller to be accessed anonymously, remove this attribute from the controller. If you want to set the permissions at a more granular level, apply the attribute to each method that requires authorization instead of applying it to the controller class.
You can now write code to call an Office 365 API in your web application. You can apply the Autorize attribute to the desired controller or the method in which you wish to call Office 365 API.
ContactsController.cs describes how to interact with the Office 365 API discovery service, get the endpoint URI and resource Id for Outlook Services and then query users' contacts.