Start 2025 on time and up to date. Seamlessly integrate your calendars into Dropbox with these simple steps.
Forum Discussion
PaulELong
6 years agoHelpful | Level 6
OAuth2 issues with Dropbox and Xamarin.Auth
I have Xamarin.Auth working with Google drive on Android/iOS/UWP, and I want to add support into my app for Dropbox. Xamarin.Auth is nice because I only have to write the code once, and it handles a ...
- 6 years ago
I found the solution, but to answer your question first, the text is output from a sniffer trace showing the HTTP Get request.
And you are right, in that the second response_type and client_id are a duplication. It confused me and at first I thought it was the HTTP body. One thing I didn't understand is that GetAuthorizeUri returns the URL plus the params. Xamarin.Auth requires just the URL, so I can just send "https://www.dropbox.com/oauth2/authorize", and I won't call GetAuthorizeUri at all, since OAuth2Authenticator takes care of building the request.
The reason there were two response_types where one was code type rather than token type was because I supplied the AccessTokenURL to OAuth2Authenticator, which is not needed in the case of token flow, as I understand. Since I started with a dropbox API example for .NET and then plugged in each into the OAuth2Authenticator call, I mistakenly sent an AccessTokenUrl. I found out from looking at the Xamarin code, if AccessTokenUrl==NULL will assume the implict flow (token flow). Interestingly, and as a note to help others, I tried setting the AccessTokenUrl to null, which caused an exception. Instead I found this version worked and now I'm authenticating.
authenticator = new Xamarin.Auth.OAuth2Authenticator( clientId: ApiKey, scope: "", authorizeUrl: new Uri("https://www.dropbox.com/oauth2/authorize"), redirectUrl: new Uri(RedirectUri), isUsingNativeUI: false) ;
Hope this information helps somebody else trying to get Xamarin.Auth working with Dropbox.
Greg-DB
6 years agoDropbox Staff
First, I should note that we can't provide support for or endorse any other third party products or libraries, such as Xamarin.Auth.
That said, on the Dropbox side of things, it's true that in the Dropbox OAuth 2 implementation, as a security feature, when using the "code" flow, the redirect URI (if provided) must start with https:// (except for localhost addresses).
So, depending on your use case, there are a few options that might make sense:
- use the "token" flow instead of the "code" flow: for the "token" flow, redirect URIs with custom URL schemes (like "anything://anything_else", which you'd register for your local app) are allowed. You can find more information on the two supported flows in the /oauth2/authorize documentation. The "token" flow is generally recommended for client-side apps anyway.
- use the "code" flow, using a http://localhost... redirect URI.
- use the "code" flow, omit the redirect URI entirely: in this case, the user would need to manually copy/paste the authorization code that Dropbox would present to them
- PaulELong6 years agoHelpful | Level 6
Based on your response I looked at a network trace because I thought I was using the token flow. But I see in the trace it sends the token flow in the HTTP header and code flow in the HTTP body. That seems strange so I'm following up with Xamarin.Auth folks.
Can you verify you use the HTTP body and the header to validate the code flow? The packet looks like this:
GET /oauth2/authorize?response_type=token&client_id=ommited&redirect_uri=com.paulyshotel.testcloud%3A%2F%2Foauth2rediect%2F&state=c4045458ac394ad78752fad786151f5e?client_id=b2w6zorouokifto&redirect_uri=com.paulyshotel.testcloud%3A%2F%2Foauth2rediect&scope=&response_type=code
Thanks -Paul
- Greg-DB6 years agoDropbox Staff
The /oauth2/authorize location is a web page, and you should just be sending the user there in their browser, so the browser should just make a GET request to it. There shouldn't be a body for that HTTP GET request, nor would Dropbox use any parameters sent in the body. The URL parameters on the URL path itself are used.
- PaulELong6 years agoHelpful | Level 6
You mentioned above that "it's true that in the Dropbox OAuth 2 implementation, as a security feature, when using the "code" flow, the redirect URI (if provided) must start with https:// (except for localhost addresses)." And then you mention "use the "token" flow instead". What I'm showing you above is that the GET request my app sends has set the parameter response_type=token as per the documentaiton link you provided above.
However, the result is that dropbox returns and error stating "Invalid redirect_uri. When response_type=code, redirect_uri must start with "https://", unless it's a localhost URI."
Why am I getting this message?
About Dropbox API Support & Feedback
Find help with the Dropbox API from other developers.5,928 PostsLatest Activity: 7 hours ago
If you need more help you can view your support options (expected response time for an email or ticket is 24 hours), or contact us on X or Facebook.
For more info on available support options for your Dropbox plan, see this article.
If you found the answer to your question in this Community thread, please 'like' the post to say thanks and to let us know it was useful!