From 456913dc8b057cc44df753223e31800da62d8e98 Mon Sep 17 00:00:00 2001 From: James Lal Date: Fri, 10 May 2013 17:25:19 -0700 Subject: Rework http error validation so it can be reused r=kgrandon --- caldav.js | 62 +++++++++++++++++++++++++++++++++----------------------------- 1 file changed, 33 insertions(+), 29 deletions(-) (limited to 'caldav.js') diff --git a/caldav.js b/caldav.js index 6947e17..6f43d34 100644 --- a/caldav.js +++ b/caldav.js @@ -2107,6 +2107,7 @@ function write (chunk) { */ (function(module, ns) { var Native; + var Errors = ns.require('errors'); if (typeof(window) === 'undefined') { Native = require('xmlhttprequest').XMLHttpRequest; @@ -2114,6 +2115,19 @@ function write (chunk) { Native = window.XMLHttpRequest; } + function determineHttpStatusError(status) { + var message = 'Cannot handle request due to server response'; + var err = 'Unknown'; + + if (status === 500) + err = 'ServerFailure'; + + if (status === 401) + err = 'Authentication'; + + return new Errors[err](message); + } + /** * Creates a XHR wrapper. * Depending on the platform this is loaded @@ -2155,6 +2169,7 @@ function write (chunk) { password: null, url: null, streaming: true, + validateStatus: false, headers: {}, data: null, @@ -2272,7 +2287,18 @@ function write (chunk) { } this.waiting = false; - callback(null, this.xhr); + + if ( + !this.validateStatus || + ( + this.xhr.status > 199 && + this.xhr.status < 300 + ) + ) { + return callback(null, this.xhr); + } + + callback(determineHttpStatusError(this.xhr.status), this.xhr); } }.bind(this)); @@ -2581,7 +2607,8 @@ function write (chunk) { } BasicAuth.prototype = { - __proto__: XHR.prototype + __proto__: XHR.prototype, + validateStatus: true }; @@ -2640,6 +2667,8 @@ function write (chunk) { Oauth2.prototype = { __proto__: XHR.prototype, + validateStatus: true, + _sendXHR: function(xhr) { xhr.setRequestHeader( 'Authorization', 'Bearer ' + this.connection.oauth.access_token @@ -3166,20 +3195,6 @@ function write (chunk) { var SAX = ns.require('sax'); var XHR = ns.require('xhr'); - var Errors = ns.require('errors'); - - function determineHttpStatusError(status) { - var message = 'Cannot handle request due to server response'; - var err = 'Unknown'; - - if (status === 500) - err = 'ServerFailure'; - - if (status === 401) - err = 'Authentication'; - - return new Errors[err](message); - } /** * Creates an (Web/Cal)Dav request. @@ -3249,19 +3264,8 @@ function write (chunk) { return callback(err); } - // handle the success case - if (xhr.status > 199 && xhr.status < 300) { - self.sax.close(); - return self._processResult(req, callback); - } - - // probable error cases - callback( - determineHttpStatusError(xhr.status), - xhr - ); - - + self.sax.close(); + return self._processResult(req, callback); }); return req; -- cgit