Home
My Books
Browse ▾
Recommendations
Choice Awards
Genres
Giveaways
New Releases
Lists
Explore
News & Interviews
Genres
Art
Biography
Business
Children's
Christian
Classics
Comics
Cookbooks
Ebooks
Fantasy
Fiction
Graphic Novels
Historical Fiction
History
Horror
Memoir
Music
Mystery
Nonfiction
Poetry
Psychology
Romance
Science
Science Fiction
Self Help
Sports
Thriller
Travel
Young Adult
More Genres
Community ▾
Groups
Quotes
Ask the Author
Sign In
Join
Sign up
View profile
Profile
Friends
Groups
Discussions
Comments
Reading Challenge
Kindle Notes & Highlights
Quotes
Favorite genres
Friends’ recommendations
Account settings
Help
Sign out
Home
My Books
Browse ▾
Recommendations
Choice Awards
Genres
Giveaways
New Releases
Lists
Explore
News & Interviews
Genres
Art
Biography
Business
Children's
Christian
Classics
Comics
Cookbooks
Ebooks
Fantasy
Fiction
Graphic Novels
Historical Fiction
History
Horror
Memoir
Music
Mystery
Nonfiction
Poetry
Psychology
Romance
Science
Science Fiction
Self Help
Sports
Thriller
Travel
Young Adult
More Genres
Community ▾
Groups
Quotes
Ask the Author
Goodreads Developers
discussion
29 views
questions
> Not able to consume api
Comments
Showing 1-2 of 2
(2 new)
post a comment »
date
newest »
message 1:
by
Vijay
(new)
Mar 25, 2015 08:09PM
I am able to get access_token and also request_token.
var baseUrl = "
http://www.goodreads.com";
var client = new RestClient(baseUrl);
client.Authenticator = OAuth1Authenticator.ForAccessToken("consumerKey", "consumerSecret", HttpContext.Current.Session["oauth_token"].ToString(), HttpContext.Current.Session["oauth_token_secret"].ToString());
var request = new RestRequest("oauth/access_token", Method.GET);
var response = client.Execute(request);
var qs = HttpUtility.ParseQueryString(response.Content);
if (qs != null && qs.Count > 0)
{
HttpContext.Current.Session["oauth_token"] = qs["oauth_token"];
HttpContext.Current.Session["oauth_token_secret"] = qs["oauth_token_secret"];
}
string goodreadsURL = "
https://www.goodreads.com/oauth/autho...
" + OAuthToken + "&oauth_callback=
http://localhost:51650/GoodReadsResul...
Response.Redirect(goodreadsURL);
Overwriting access_token on session variables
client.Authenticator = OAuth1Authenticator.ForAccessToken("consumerKey", "consumer secret", HttpContext.Current.Session["oauth_token"].ToString(), HttpContext.Current.Session["oauth_token_secret"].ToString());
var request = new RestRequest("oauth/access_token", Method.GET);
var response = client.Execute(request);
var qs = HttpUtility.ParseQueryString(response.Content);
if (qs != null && qs.Count > 0)
{
HttpContext.Current.Session["oauth_token"] = qs["oauth_token"];
HttpContext.Current.Session["oauth_token_secret"] = qs["oauth_token_secret"];
}
After this if I try to call api methods as below it throws not authorized
var client2 = new RestClient(baseUrl);
client2.Authenticator = OAuth1Authenticator.ForProtectedResource("consumer key", "consumer secret", HttpContext.Current.Session["oauth_token"].ToString(), HttpContext.Current.Session["oauth_token_secret"].ToString());
var request2 = new RestRequest("notifications.xml", Method.GET);
var response2 = client.Execute(request2);
With the above code the response2 says not authorized. Can somebody please help me?
reply
|
flag
message 2:
by
Michael
(new)
Mar 26, 2015 03:29PM
What language is that?
Looks like you're not using an oauth library, I'd recommend looking for one in your language of choice.
reply
|
flag
back to top
post a comment »
Add a reference:
Book
Author
Search for a book to add a reference
add:
link
cover
Author:
add:
link
photo
Share
Goodreads Developers
Group Home
Bookshelf
Discussions
Photos
Videos
Send invite
Members
Polls
unread topics
|
mark unread
Welcome back. Just a moment while we sign you in to your Goodreads account.
var baseUrl = "http://www.goodreads.com";
var client = new RestClient(baseUrl);
client.Authenticator = OAuth1Authenticator.ForAccessToken("consumerKey", "consumerSecret", HttpContext.Current.Session["oauth_token"].ToString(), HttpContext.Current.Session["oauth_token_secret"].ToString());
var request = new RestRequest("oauth/access_token", Method.GET);
var response = client.Execute(request);
var qs = HttpUtility.ParseQueryString(response.Content);
if (qs != null && qs.Count > 0)
{
HttpContext.Current.Session["oauth_token"] = qs["oauth_token"];
HttpContext.Current.Session["oauth_token_secret"] = qs["oauth_token_secret"];
}
string goodreadsURL = "https://www.goodreads.com/oauth/autho..." + OAuthToken + "&oauth_callback=http://localhost:51650/GoodReadsResul...
Response.Redirect(goodreadsURL);
Overwriting access_token on session variables
client.Authenticator = OAuth1Authenticator.ForAccessToken("consumerKey", "consumer secret", HttpContext.Current.Session["oauth_token"].ToString(), HttpContext.Current.Session["oauth_token_secret"].ToString());
var request = new RestRequest("oauth/access_token", Method.GET);
var response = client.Execute(request);
var qs = HttpUtility.ParseQueryString(response.Content);
if (qs != null && qs.Count > 0)
{
HttpContext.Current.Session["oauth_token"] = qs["oauth_token"];
HttpContext.Current.Session["oauth_token_secret"] = qs["oauth_token_secret"];
}
After this if I try to call api methods as below it throws not authorized
var client2 = new RestClient(baseUrl);
client2.Authenticator = OAuth1Authenticator.ForProtectedResource("consumer key", "consumer secret", HttpContext.Current.Session["oauth_token"].ToString(), HttpContext.Current.Session["oauth_token_secret"].ToString());
var request2 = new RestRequest("notifications.xml", Method.GET);
var response2 = client.Execute(request2);
With the above code the response2 says not authorized. Can somebody please help me?