Created
May 28, 2014 19:17
-
-
Save IntuitDeveloperRelations/2c02053808b5fde5b681 to your computer and use it in GitHub Desktop.
QuickBooks API - .NET/DevDefined - Call QBO Entitlements API
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
using DevDefined.OAuth.Consumer; | |
using DevDefined.OAuth.Framework; | |
using System.IO; | |
using System.Text; | |
using System.Net; | |
namespace IPPQbApiConsoleApp | |
{ | |
static class SampleCalls | |
{ | |
public static string CallEntitlementsApi(string consumerKey, string consumerSecret, string accessToken, string accessTokenSecret, string realmId) | |
{ | |
HttpWebRequest httpWebRequest = WebRequest.Create("https://qbo.sbfinance.intuit.com/manage/entitlements/v2/" + realmId) as HttpWebRequest; | |
httpWebRequest.Method = "GET"; | |
httpWebRequest.Headers.Add("Authorization", GetDevDefinedOAuthHeader(httpWebRequest, consumerKey, consumerSecret, accessToken, accessTokenSecret)); | |
UTF8Encoding encoding = new UTF8Encoding(); | |
HttpWebResponse httpWebResponse = httpWebRequest.GetResponse() as HttpWebResponse; | |
using (Stream data = httpWebResponse.GetResponseStream()) | |
{ | |
//return XML response | |
return new StreamReader(data).ReadToEnd(); | |
} | |
} | |
static string GetDevDefinedOAuthHeader(HttpWebRequest webRequest, string consumerKey, string consumerSecret, string accessToken, string accessTokenSecret) | |
{ | |
OAuthConsumerContext consumerContext = new OAuthConsumerContext | |
{ | |
ConsumerKey = consumerKey, | |
ConsumerSecret = consumerSecret, | |
SignatureMethod = SignatureMethod.HmacSha1, | |
UseHeaderForOAuthParameters = true | |
}; | |
consumerContext.UseHeaderForOAuthParameters = true; | |
//URIs not used - we already have Oauth tokens | |
OAuthSession oSession = new OAuthSession(consumerContext, "https://www.example.com", | |
"https://www.example.com", | |
"https://www.example.com"); | |
oSession.AccessToken = new TokenBase | |
{ | |
Token = accessToken, | |
ConsumerKey = consumerKey, | |
TokenSecret = accessTokenSecret | |
}; | |
IConsumerRequest consumerRequest = oSession.Request(); | |
consumerRequest = ConsumerRequestExtensions.ForMethod(consumerRequest, webRequest.Method); | |
consumerRequest = ConsumerRequestExtensions.ForUri(consumerRequest, webRequest.RequestUri); | |
consumerRequest = consumerRequest.SignWithToken(); | |
return consumerRequest.Context.GenerateOAuthParametersForHeader(); | |
} | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment