RESOLVED FIXED 118849
[Curl] Http response code 401 (Authentication required) is not handled.
https://bugs.webkit.org/show_bug.cgi?id=118849
Summary [Curl] Http response code 401 (Authentication required) is not handled.
peavo
Reported 2013-07-18 06:23:24 PDT
The current Curl implementation does not handle a 401 response. When receiving http code 401, we need to give a notification that authorization is required, by calling the appropriate notification method. This gives a WebKit client the possibility to present a password dialog to the user. In response to this, we should provide Curl with the given username and password, so another request can be sent with the given credentials.
Attachments
Patch (20.77 KB, patch)
2013-07-18 11:53 PDT, peavo
no flags
Patch (21.00 KB, patch)
2013-07-19 05:53 PDT, peavo
no flags
peavo
Comment 1 2013-07-18 11:53:06 PDT
Peter Gal
Comment 2 2013-07-19 01:11:37 PDT
View in context: https://bugs.webkit.org/attachment.cgi?id=207008&action=review This looks cool, I've also wanted to implement this :) > Source/WebCore/platform/network/curl/ResourceHandleManager.cpp:299 > + err = curl_easy_getinfo(h, CURLINFO_EFFECTIVE_URL, &url); The 'err'-s are only set but not used elsewhere, this could cause compiler warnings. > Source/WebCore/platform/network/curl/ResourceHandleManager.cpp:823 > + // <rdar://problem/7174050> - For URLs that match the paths of those previously challenged for HTTP Basic authentication, > + // try and reuse the credential preemptively, as allowed by RFC 2617. I don't know if we should keep this rdar url as we don't have a way to access it.
peavo
Comment 3 2013-07-19 05:53:16 PDT
peavo
Comment 4 2013-07-19 05:55:18 PDT
(In reply to comment #2) Thanks for reviewing! Updated patch according to comments. > View in context: https://bugs.webkit.org/attachment.cgi?id=207008&action=review > > This looks cool, I've also wanted to implement this :) > > > Source/WebCore/platform/network/curl/ResourceHandleManager.cpp:299 > > + err = curl_easy_getinfo(h, CURLINFO_EFFECTIVE_URL, &url); > > The 'err'-s are only set but not used elsewhere, this could cause compiler warnings. > > > Source/WebCore/platform/network/curl/ResourceHandleManager.cpp:823 > > + // <rdar://problem/7174050> - For URLs that match the paths of those previously challenged for HTTP Basic authentication, > > + // try and reuse the credential preemptively, as allowed by RFC 2617. > > I don't know if we should keep this rdar url as we don't have a way to access it.
Brent Fulgham
Comment 5 2013-07-19 10:28:38 PDT
Comment on attachment 207083 [details] Patch Nice job! r=me.
Brent Fulgham
Comment 6 2013-07-19 10:30:03 PDT
(In reply to comment #2) > > Source/WebCore/platform/network/curl/ResourceHandleManager.cpp:823 > > + // <rdar://problem/7174050> - For URLs that match the paths of those previously challenged for HTTP Basic authentication, > > + // try and reuse the credential preemptively, as allowed by RFC 2617. > > I don't know if we should keep this rdar url as we don't have a way to access it. Please leave the rdar tag in place. This is a reminder why we added this code on the CFNetwork side, and I imagine it would be good to have on the cURL side as well. The bug had to do with authentication on certain wireless routers that failed if this case was not handled properly.
WebKit Commit Bot
Comment 7 2013-07-19 10:51:31 PDT
Comment on attachment 207083 [details] Patch Clearing flags on attachment: 207083 Committed r152908: <http://trac.webkit.org/changeset/152908>
WebKit Commit Bot
Comment 8 2013-07-19 10:51:33 PDT
All reviewed patches have been landed. Closing bug.
peavo
Comment 9 2013-07-19 11:05:02 PDT
(In reply to comment #5) > (From update of attachment 207083 [details]) > Nice job! r=me. Thanks for the review, Brent :)
await_me
Comment 10 2014-01-01 17:30:58 PST
In this patch,when given username and password was wrong,Will webkit or curl resend the request? And Does WebCore resend the request ? or client? or Curl automatic?
peavo
Comment 11 2014-01-03 11:39:52 PST
(In reply to comment #10) > In this patch,when given username and password was wrong,Will webkit or curl resend the request? > And Does WebCore resend the request ? or client? or Curl automatic? When given username or password is incorrect, I believe we will receive another 401 response, and give the user another chance to provide credentials. If new credentials are provided, we will give the user/password to curl by calling curl_easy_setopt(curlHandle, CURLOPT_USERPWD, usernameAndPassword). AFAIK this will make curl resend the request automatically.
await_me
Comment 12 2014-01-05 19:09:41 PST
(In reply to comment #11) > (In reply to comment #10) > > In this patch,when given username and password was wrong,Will webkit or curl resend the request? > > And Does WebCore resend the request ? or client? or Curl automatic? > > When given username or password is incorrect, I believe we will receive another 401 response, and give the user another chance to provide credentials. > If new credentials are provided, we will give the user/password to curl by calling curl_easy_setopt(curlHandle, CURLOPT_USERPWD, usernameAndPassword). > AFAIK this will make curl resend the request automatically. Thanks for your replay. I had met some problems.My browser is developed on WinCE SYS。 I had patched the webcore part of this patch to my browser and code FrameLoaderClientWinCE::dispatchDidReceiveAuthenticationChallenge() as follow: void FrameLoaderClientWinCE::dispatchDidReceiveAuthenticationChallenge(DocumentLoader*, unsigned long, const AuthenticationChallenge& challenge) { String user; String pwd; if (m_webView->requestAuthentication(challenge,user,pwd) == 0) { Credential credential(user,pwd,CredentialPersistenceNone); challenge.authenticationClient()->receivedCredential(challenge,credential); return; } challenge.authenticationClient()->receivedRequestToContinueWithoutCredential(challenge); } In WebView::requestAuthentication(),I will give user a dialog to input username and password. In expect,when visit a website with basic authentication,browser should given user a dialog to input username and password.if username and password is correct,the page will dispaly.if username and password is incorrect,browser should given user a dialog again until user inputs a right username and password or cancel the visit. In actually,on my browser,if user's first input is correct,the request page will be dispalyed. but if the first input is incorrect,whaterver the second input is ,401 error page will be displayed and there is not dialog yet. When degbugging in curl,I find "hand->state.authproblem" has been set to "true" when user inputs wrong usename and password. Then request will be ended with 401 error. I don't know why it does not work well as expectation.Does this patch could implement the expectation as above?
peavo
Comment 13 2014-01-14 11:47:08 PST
(In reply to comment #12) > (In reply to comment #11) > > (In reply to comment #10) > > > In this patch,when given username and password was wrong,Will webkit or curl resend the request? > > > And Does WebCore resend the request ? or client? or Curl automatic? > > > > When given username or password is incorrect, I believe we will receive another 401 response, and give the user another chance to provide credentials. > > If new credentials are provided, we will give the user/password to curl by calling curl_easy_setopt(curlHandle, CURLOPT_USERPWD, usernameAndPassword). > > AFAIK this will make curl resend the request automatically. > > Thanks for your replay. > I had met some problems.My browser is developed on WinCE SYS。 > I had patched the webcore part of this patch to my browser and code FrameLoaderClientWinCE::dispatchDidReceiveAuthenticationChallenge() as follow: > void FrameLoaderClientWinCE::dispatchDidReceiveAuthenticationChallenge(DocumentLoader*, unsigned long, const AuthenticationChallenge& challenge) > { > String user; > String pwd; > if (m_webView->requestAuthentication(challenge,user,pwd) == 0) > { > Credential credential(user,pwd,CredentialPersistenceNone); > challenge.authenticationClient()->receivedCredential(challenge,credential); > return; > } > > challenge.authenticationClient()->receivedRequestToContinueWithoutCredential(challenge); > } > > In WebView::requestAuthentication(),I will give user a dialog to input username and password. > I think this code looks fine. > In expect,when visit a website with basic authentication,browser should given user a dialog to input username and password.if username and password is correct,the page will dispaly.if username and password is incorrect,browser should given user a dialog again until user inputs a right username and password or cancel the visit. > > In actually,on my browser,if user's first input is correct,the request page will be dispalyed. but if the first input is incorrect,whaterver the second input is ,401 error page will be displayed and there is not dialog yet. > I guess the behaviour also depends on how many times the server will send back a 401 response, before it sends an error page. Have you tried other sites? How does other browsers behave on your test site?
Note You need to log in before you can comment on or make changes to this bug.