aboutsummaryrefslogtreecommitdiffstats
path: root/core/js/files/client.js
diff options
context:
space:
mode:
Diffstat (limited to 'core/js/files/client.js')
-rw-r--r--core/js/files/client.js47
1 files changed, 37 insertions, 10 deletions
diff --git a/core/js/files/client.js b/core/js/files/client.js
index dc842a9d3bf..0109ab9fdbf 100644
--- a/core/js/files/client.js
+++ b/core/js/files/client.js
@@ -410,6 +410,26 @@
},
/**
+ * Parse the Sabre exception out of the given response, if any
+ *
+ * @param {Object} response object
+ * @return {Object} array of parsed message and exception (only the first one)
+ */
+ _getSabreException: function(response) {
+ var result = {};
+ var xml = response.xhr.responseXML;
+ var messages = xml.getElementsByTagNameNS('http://sabredav.org/ns', 'message');
+ var exceptions = xml.getElementsByTagNameNS('http://sabredav.org/ns', 'exception');
+ if (messages.length) {
+ result.message = messages[0].textContent;
+ }
+ if (exceptions.length) {
+ result.exception = exceptions[0].textContent;
+ }
+ return result;
+ },
+
+ /**
* Returns the default PROPFIND properties to use during a call.
*
* @return {Array.<Object>} array of properties
@@ -462,7 +482,8 @@
}
deferred.resolve(result.status, results);
} else {
- deferred.reject(result.status);
+ result = _.extend(result, self._getSabreException(result));
+ deferred.reject(result.status, result);
}
});
return promise;
@@ -536,7 +557,8 @@
var results = self._parseResult(result.body);
deferred.resolve(result.status, results);
} else {
- deferred.reject(result.status);
+ result = _.extend(result, self._getSabreException(result));
+ deferred.reject(result.status, result);
}
});
return promise;
@@ -575,7 +597,8 @@
if (self._isSuccessStatus(result.status)) {
deferred.resolve(result.status, self._parseResult([result.body])[0]);
} else {
- deferred.reject(result.status);
+ result = _.extend(result, self._getSabreException(result));
+ deferred.reject(result.status, result);
}
}
);
@@ -605,7 +628,8 @@
if (self._isSuccessStatus(result.status)) {
deferred.resolve(result.status, result.body);
} else {
- deferred.reject(result.status);
+ result = _.extend(result, self._getSabreException(result));
+ deferred.reject(result.status, result);
}
}
);
@@ -654,7 +678,8 @@
if (self._isSuccessStatus(result.status)) {
deferred.resolve(result.status);
} else {
- deferred.reject(result.status);
+ result = _.extend(result, self._getSabreException(result));
+ deferred.reject(result.status, result);
}
}
);
@@ -678,7 +703,8 @@
if (self._isSuccessStatus(result.status)) {
deferred.resolve(result.status);
} else {
- deferred.reject(result.status);
+ result = _.extend(result, self._getSabreException(result));
+ deferred.reject(result.status, result);
}
}
);
@@ -742,11 +768,12 @@
this._buildUrl(path),
headers
).then(
- function(response) {
- if (self._isSuccessStatus(response.status)) {
- deferred.resolve(response.status);
+ function(result) {
+ if (self._isSuccessStatus(result.status)) {
+ deferred.resolve(result.status);
} else {
- deferred.reject(response.status);
+ result = _.extend(result, self._getSabreException(result));
+ deferred.reject(result.status, result);
}
}
);