jellyfin-web/dashboard-ui/apiclient/sync/serversync.js

112 lines
3.2 KiB
JavaScript
Raw Normal View History

2015-09-09 10:49:44 -07:00
(function (globalScope) {
function serverSync(connectionManager) {
2015-09-09 20:22:52 -07:00
var self = this;
2015-09-09 10:49:44 -07:00
self.sync = function (server) {
var deferred = DeferredBuilder.Deferred();
if (!server.AccessToken && !server.ExchangeToken) {
Logger.log('Skipping sync to server ' + server.Id + ' because there is no saved authentication information.');
deferred.resolve();
2015-09-10 11:28:22 -07:00
return deferred.promise();
2015-09-09 10:49:44 -07:00
}
var connectionOptions = {
updateDateLastAccessed: false,
enableWebSocket: false,
reportCapabilities: false
};
connectionManager.connectToServer(server, connectionOptions).done(function (result) {
if (result.State == MediaBrowser.ConnectionState.SignedIn) {
performSync(server, deferred);
} else {
Logger.log('Unable to connect to server id: ' + server.Id);
deferred.reject();
}
}).fail(function () {
Logger.log('Unable to connect to server id: ' + server.Id);
deferred.reject();
});
return deferred.promise();
};
function performSync(server, deferred) {
Logger.log("Creating ContentUploader to server: " + server.Id);
require(['contentuploader'], function () {
new MediaBrowser.ContentUploader(connectionManager).uploadImages(server).done(function () {
2015-09-09 20:22:52 -07:00
Logger.log("ContentUploaded succeeded to server: " + server.Id);
syncOfflineUsers(server, deferred);
}).fail(function () {
Logger.log("ContentUploaded failed to server: " + server.Id);
syncOfflineUsers(server, deferred);
});
});
}
function syncOfflineUsers(server, deferred) {
require(['offlineusersync'], function () {
var apiClient = connectionManager.getApiClient(server.Id);
2015-09-10 11:28:22 -07:00
new MediaBrowser.OfflineUserSync().sync(apiClient, server).done(function () {
2015-09-09 20:22:52 -07:00
Logger.log("OfflineUserSync succeeded to server: " + server.Id);
syncMedia(server, deferred);
2015-09-09 10:49:44 -07:00
}).fail(function () {
2015-09-09 20:22:52 -07:00
Logger.log("OfflineUserSync failed to server: " + server.Id);
deferred.reject();
});
});
}
function syncMedia(server, deferred) {
require(['mediasync'], function () {
var apiClient = connectionManager.getApiClient(server.Id);
new MediaBrowser.MediaSync().sync(apiClient).done(function () {
Logger.log("MediaSync succeeded to server: " + server.Id);
2015-09-09 10:49:44 -07:00
deferred.resolve();
2015-09-09 20:22:52 -07:00
}).fail(function () {
Logger.log("MediaSync failed to server: " + server.Id);
deferred.reject();
2015-09-09 10:49:44 -07:00
});
});
}
}
if (!globalScope.MediaBrowser) {
globalScope.MediaBrowser = {};
}
globalScope.MediaBrowser.ServerSync = serverSync;
})(this);