summaryrefslogtreecommitdiffstats
path: root/webkit/plugins/ppapi/ppb_url_loader_impl.cc
diff options
context:
space:
mode:
authorbbudge@chromium.org <bbudge@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-06-16 21:48:32 +0000
committerbbudge@chromium.org <bbudge@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-06-16 21:48:32 +0000
commit11c872189721c56a4a0801a58f8d4a250a9b4914 (patch)
tree41e5c9e876503711bfc0366f6a3528c513983c67 /webkit/plugins/ppapi/ppb_url_loader_impl.cc
parentc9fcaecb9eb89955f6f9602d4fd73d15b3fe6420 (diff)
downloadchromium_src-11c872189721c56a4a0801a58f8d4a250a9b4914.zip
chromium_src-11c872189721c56a4a0801a58f8d4a250a9b4914.tar.gz
chromium_src-11c872189721c56a4a0801a58f8d4a250a9b4914.tar.bz2
Patch to fix problems with PPB_URLLoader_Impl and PPAPITests.URLLoader. The cross-origin test doesn't properly check for an error, and the custom-referrer change broke cross-origin requests as a result. Also, there was confusion with some errors being reported as PP_ERROR_FAILED and others as PP_ERROR_NOACCESS. After conversations with WebKit folks, it seems unlikely that a consistent system of error codes can be added, so instead, have PPB_URLLoader_Impl::didFail report PP_ERROR_NOACCESS for unknown error domains (WebKit) and switch on net::kErrorDomain errors from our lower level WebURLLoader.
Review URL: http://codereview.chromium.org/7046091 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@89405 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/plugins/ppapi/ppb_url_loader_impl.cc')
-rw-r--r--webkit/plugins/ppapi/ppb_url_loader_impl.cc35
1 files changed, 25 insertions, 10 deletions
diff --git a/webkit/plugins/ppapi/ppb_url_loader_impl.cc b/webkit/plugins/ppapi/ppb_url_loader_impl.cc
index d0d4f06..193b461 100644
--- a/webkit/plugins/ppapi/ppb_url_loader_impl.cc
+++ b/webkit/plugins/ppapi/ppb_url_loader_impl.cc
@@ -5,6 +5,7 @@
#include "webkit/plugins/ppapi/ppb_url_loader_impl.h"
#include "base/logging.h"
+#include "net/base/net_errors.h"
#include "ppapi/c/pp_completion_callback.h"
#include "ppapi/c/pp_errors.h"
#include "ppapi/c/ppb_url_loader.h"
@@ -16,6 +17,7 @@
#include "third_party/WebKit/Source/WebKit/chromium/public/WebKitClient.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/WebPluginContainer.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/WebSecurityOrigin.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLError.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLLoader.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLLoaderOptions.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLRequest.h"
@@ -247,7 +249,7 @@ int32_t PPB_URLLoader_Impl::Open(PPB_URLRequestInfo_Impl* request,
return rv;
if (request->RequiresUniversalAccess() && !has_universal_access_)
- return PP_ERROR_BADARGUMENT;
+ return PP_ERROR_NOACCESS;
if (loader_.get())
return PP_ERROR_INPROGRESS;
@@ -276,13 +278,11 @@ int32_t PPB_URLLoader_Impl::Open(PPB_URLRequestInfo_Impl* request,
return PP_ERROR_FAILED;
loader_->loadAsynchronously(web_request, this);
- // Check for immediate failure; The AssociatedURLLoader will call our
- // didFail method synchronously for certain kinds of access violations
- // so we must return an error to the caller.
- // TODO(bbudge) Modify the underlying AssociatedURLLoader to only call
- // back asynchronously.
- if (done_status_ == PP_ERROR_FAILED)
- return PP_ERROR_NOACCESS;
+ // TODO(bbudge) Remove this code when AssociatedURLLoader is changed to
+ // return errors asynchronously.
+ if (done_status_ == PP_ERROR_FAILED ||
+ done_status_ == PP_ERROR_NOACCESS)
+ return done_status_;
request_info_ = scoped_refptr<PPB_URLRequestInfo_Impl>(request);
@@ -475,8 +475,23 @@ void PPB_URLLoader_Impl::didFinishLoading(WebURLLoader* loader,
void PPB_URLLoader_Impl::didFail(WebURLLoader* loader,
const WebURLError& error) {
- // TODO(darin): Provide more detailed error information.
- done_status_ = PP_ERROR_FAILED;
+ if (error.domain.equals(WebString::fromUTF8(net::kErrorDomain))) {
+ // TODO(bbudge): Extend pp_errors.h to cover interesting network errors
+ // from the net error domain.
+ switch (error.reason) {
+ case net::ERR_ACCESS_DENIED:
+ case net::ERR_NETWORK_ACCESS_DENIED:
+ done_status_ = PP_ERROR_NOACCESS;
+ break;
+ default:
+ done_status_ = PP_ERROR_FAILED;
+ break;
+ }
+ } else {
+ // It's a WebKit error.
+ done_status_ = PP_ERROR_NOACCESS;
+ }
+
RunCallback(done_status_);
}