DotNet Core MVC5 Sample app using .NET Standard SDK
The Intuit Developer team has written this OAuth 2.0 Sample App in .Net Core(C#) MVC5 to provide working examples of OAuth 2.0 concepts, and how to integrate with Intuit endpoints. It uses the Owin Context to save the user cookies for the session. More details can be read here and here
Before beginning, it may be helpful to have a basic understanding of OAuth 2.0 flow. There are plenty of tutorials and guides to get started with OAuth 2.0. Check out the docs on https://developer.intuit.com/
- Visual Studio 2019 or above
- Microsoft.Net.Compilers 2.10.0
- .Net Core 3.1
Clone this repository/Download the sample app.
All configuration for this app is located in appsettings.json. Locate and open this file.
We will need to update the below items items:
- ClientId
- ClientSecret
- RedirectURL
- Environment
- DBConnectionString (Optional)
- QBOBaseURL
Once you have created an app on Intuit's Developer Portal, you can find your credentials (Client ID and Client Secret) under the "Keys" tab. You will also find a section to enter your Redirect URL here.
You'll have to set a Redirect URI in both 'web.config' and the Developer Portal ("Keys" section). With this app, the typical value would be https://localhost:47331/connect/index, unless you host this sample app in a different way (if you were testing HTTPS, for example or changing the port).
This sample app requires Accounting scope, please choose this if creating a new app.
This sample app uses a SQLite database to store the tokens(AccessToken and RefreshToken) used for doing our API calls and also update the token with new tokens when the token expires. This database is created for you the first time your run the sample.
After setting up both Developer Portal and your appsettings.json, run the sample app.
This flow goes through authorization flow where QBO user logs in and authorizes your app. At the end of this process, the app will end up with tokens and if you are a first time user it will create new tokens in the database and if you a recurring user and if your tokens are expired then it will update the database.
Access tokens from Connect to QuickBooks flow are used to make a Customer and Invoice request which allows to create a customer and invoice in your company. If any tokens are expired, then it refresh those tokens based on the refresh token.