cryptpad/www/drive/main.js

89 lines
3.4 KiB
JavaScript
Raw Normal View History

2017-09-27 08:31:35 +00:00
// Load #1, load as little as possible because we are in a race to get the loading screen up.
2016-11-03 17:51:30 +00:00
define([
2017-09-27 08:31:35 +00:00
'/bower_components/nthen/index.js',
'/api/config',
2017-12-01 15:05:20 +00:00
'/common/dom-ready.js',
2017-09-27 08:31:35 +00:00
'/common/requireconfig.js',
'/common/sframe-common-outer.js',
2017-12-01 15:05:20 +00:00
], function (nThen, ApiConfig, DomReady, RequireConfig, SFCommonO) {
2017-09-27 08:31:35 +00:00
var requireConfig = RequireConfig();
// Loaded in load #2
nThen(function (waitFor) {
2017-12-01 15:05:20 +00:00
DomReady.onReady(waitFor());
2017-09-27 08:31:35 +00:00
}).nThen(function (waitFor) {
var req = {
cfg: requireConfig,
req: [ '/common/loading.js' ],
pfx: window.location.origin
};
window.rc = requireConfig;
window.apiconf = ApiConfig;
2017-12-01 15:05:20 +00:00
document.getElementById('sbox-iframe').setAttribute('src',
2017-09-27 08:31:35 +00:00
ApiConfig.httpSafeOrigin + '/drive/inner.html?' + requireConfig.urlArgs +
'#' + encodeURIComponent(JSON.stringify(req)));
// This is a cheap trick to avoid loading sframe-channel in parallel with the
// loading screen setup.
var done = waitFor();
var onMsg = function (msg) {
var data = JSON.parse(msg.data);
if (data.q !== 'READY') { return; }
window.removeEventListener('message', onMsg);
var _done = done;
done = function () { };
_done();
};
window.addEventListener('message', onMsg);
}).nThen(function (/*waitFor*/) {
2017-11-30 14:01:17 +00:00
var getSecrets = function (Cryptpad, Utils, cb) {
2017-11-23 11:28:49 +00:00
var hash = window.location.hash.slice(1) || Utils.LocalStore.getUserHash() ||
Utils.LocalStore.getFSHash();
2017-11-30 14:01:17 +00:00
cb(null, Utils.Hash.getSecrets('drive', hash));
2017-09-27 08:31:35 +00:00
};
var addRpc = function (sframeChan, Cryptpad, Utils) {
sframeChan.on('EV_BURN_ANON_DRIVE', function () {
if (Utils.LocalStore.isLoggedIn()) { return; }
Utils.LocalStore.setFSHash('');
Utils.LocalStore.clearThumbnail();
window.location.reload();
});
sframeChan.on('Q_DRIVE_USEROBJECT', function (data, cb) {
Cryptpad.userObjectCommand(data, cb);
});
sframeChan.on('Q_DRIVE_GETOBJECT', function (data, cb) {
Cryptpad.getUserObject(function (obj) {
cb(obj);
});
});
2018-01-25 16:54:21 +00:00
sframeChan.on('Q_DRIVE_GETDELETED', function (data, cb) {
Cryptpad.getDeletedPads(function (err, obj) {
if (err) { return void console.error(err); }
cb(obj);
});
});
Cryptpad.onNetworkDisconnect.reg(function () {
sframeChan.event('EV_NETWORK_DISCONNECT');
});
Cryptpad.onNetworkReconnect.reg(function (data) {
sframeChan.event('EV_NETWORK_RECONNECT', data);
});
2017-12-05 17:09:43 +00:00
Cryptpad.drive.onLog.reg(function (msg) {
sframeChan.event('EV_DRIVE_LOG', msg);
});
2017-12-05 17:09:43 +00:00
Cryptpad.drive.onChange.reg(function (data) {
sframeChan.event('EV_DRIVE_CHANGE', data);
});
Cryptpad.drive.onRemove.reg(function (data) {
sframeChan.event('EV_DRIVE_REMOVE', data);
2017-09-27 08:31:35 +00:00
});
2017-12-05 17:09:43 +00:00
};
SFCommonO.start({
getSecrets: getSecrets,
noHash: true,
driveEvents: true,
addRpc: addRpc
});
2017-02-17 14:16:03 +00:00
});
2016-11-03 17:51:30 +00:00
});