mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-05 08:02:13 +00:00
Merge pull request #2079 from snnd/bugfix_reloads
fix(core): prevent endless reload on cache requests
This commit is contained in:
commit
42dc51784e
@ -15,27 +15,40 @@ var syncthing = angular.module('syncthing', [
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
var urlbase = 'rest';
|
var urlbase = 'rest';
|
||||||
var guiVersion = null;
|
|
||||||
var deviceId = null;
|
|
||||||
|
|
||||||
syncthing.config(function ($httpProvider, $translateProvider, LocaleServiceProvider) {
|
syncthing.config(function ($httpProvider, $translateProvider, LocaleServiceProvider) {
|
||||||
$httpProvider.interceptors.push(function () {
|
$httpProvider.interceptors.push(function xHeadersResponseInterceptor() {
|
||||||
|
var guiVersion = null;
|
||||||
|
var deviceId = null;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
response: function (response) {
|
response: function onResponse(response) {
|
||||||
var responseVersion = response.headers()['x-syncthing-version'];
|
var headers = response.headers();
|
||||||
|
var responseVersion;
|
||||||
|
var deviceIdShort;
|
||||||
|
|
||||||
|
// angular template cache sends no headers
|
||||||
|
if(Object.keys(headers).length === 0) {
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
responseVersion = headers['x-syncthing-version'];
|
||||||
|
|
||||||
if (!guiVersion) {
|
if (!guiVersion) {
|
||||||
guiVersion = responseVersion;
|
guiVersion = responseVersion;
|
||||||
} else if (guiVersion != responseVersion) {
|
} else if (guiVersion != responseVersion) {
|
||||||
document.location.reload(true);
|
document.location.reload(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!deviceId) {
|
if (!deviceId) {
|
||||||
deviceId = response.headers()['x-syncthing-id'];
|
deviceId = headers['x-syncthing-id'];
|
||||||
if (deviceId) {
|
if (deviceId) {
|
||||||
var deviceIdShort = deviceId.substring(0, 5);
|
deviceIdShort = deviceId.substring(0, 5);
|
||||||
$httpProvider.defaults.xsrfHeaderName = 'X-CSRF-Token-' + deviceIdShort;
|
$httpProvider.defaults.xsrfHeaderName = 'X-CSRF-Token-' + deviceIdShort;
|
||||||
$httpProvider.defaults.xsrfCookieName = 'CSRF-Token-' + deviceIdShort;
|
$httpProvider.defaults.xsrfCookieName = 'CSRF-Token-' + deviceIdShort;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user