Merge branch 'serviceworker' into staging
commit
4896fe81fe
@ -1,193 +1,96 @@
|
|||||||
define([
|
define([
|
||||||
'/common/outer/async-store.js'
|
'/common/outer/async-store.js'
|
||||||
], function (Store) {
|
], function (AStore) {
|
||||||
|
|
||||||
|
var create = function () {
|
||||||
|
var Store = AStore.create();
|
||||||
|
|
||||||
var Rpc = {};
|
var Rpc = {};
|
||||||
|
|
||||||
Rpc.query = function (cmd, data, cb) {
|
var queries = Rpc.queries = {
|
||||||
switch (cmd) {
|
// Ready
|
||||||
// READY
|
CONNECT: Store.init,
|
||||||
case 'CONNECT': {
|
DISCONNECT: Store.disconnect,
|
||||||
Store.init(data, cb); break;
|
CREATE_README: Store.createReadme,
|
||||||
}
|
MIGRATE_ANON_DRIVE: Store.migrateAnonDrive,
|
||||||
case 'DISCONNECT': {
|
|
||||||
Store.disconnect(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'CREATE_README': {
|
|
||||||
Store.createReadme(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'MIGRATE_ANON_DRIVE': {
|
|
||||||
Store.migrateAnonDrive(data, cb); break;
|
|
||||||
}
|
|
||||||
// RPC
|
// RPC
|
||||||
case 'INIT_RPC': {
|
INIT_RPC: Store.initRpc,
|
||||||
Store.initRpc(data, cb); break;
|
UPDATE_PIN_LIMIT: Store.updatePinLimit,
|
||||||
}
|
GET_PIN_LIMIT: Store.getPinLimit,
|
||||||
case 'UPDATE_PIN_LIMIT': {
|
CLEAR_OWNED_CHANNEL: Store.clearOwnedChannel,
|
||||||
Store.updatePinLimit(data, cb); break;
|
REMOVE_OWNED_CHANNEL: Store.removeOwnedChannel,
|
||||||
}
|
UPLOAD_CHUNK: Store.uploadChunk,
|
||||||
case 'GET_PIN_LIMIT': {
|
UPLOAD_COMPLETE: Store.uploadComplete,
|
||||||
Store.getPinLimit(data, cb); break;
|
UPLOAD_STATUS: Store.uploadStatus,
|
||||||
}
|
UPLOAD_CANCEL: Store.uploadCancel,
|
||||||
case 'CLEAR_OWNED_CHANNEL': {
|
PIN_PADS: Store.pinPads,
|
||||||
Store.clearOwnedChannel(data, cb); break;
|
UNPIN_PADS: Store.unpinPads,
|
||||||
}
|
GET_DELETED_PADS: Store.getDeletedPads,
|
||||||
case 'REMOVE_OWNED_CHANNEL': {
|
GET_PINNED_USAGE: Store.getPinnedUsage,
|
||||||
Store.removeOwnedChannel(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'UPLOAD_CHUNK': {
|
|
||||||
Store.uploadChunk(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'UPLOAD_COMPLETE': {
|
|
||||||
Store.uploadComplete(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'UPLOAD_STATUS': {
|
|
||||||
Store.uploadStatus(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'UPLOAD_CANCEL': {
|
|
||||||
Store.uploadCancel(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'PIN_PADS': {
|
|
||||||
Store.pinPads(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'UNPIN_PADS': {
|
|
||||||
Store.unpinPads(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_DELETED_PADS': {
|
|
||||||
Store.getDeletedPads(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_PINNED_USAGE': {
|
|
||||||
Store.getPinnedUsage(data, cb); break;
|
|
||||||
}
|
|
||||||
// ANON RPC
|
// ANON RPC
|
||||||
case 'INIT_ANON_RPC': {
|
INIT_ANON_RPC: Store.initAnonRpc,
|
||||||
Store.initAnonRpc(data, cb); break;
|
ANON_RPC_MESSAGE: Store.anonRpcMsg,
|
||||||
}
|
GET_FILE_SIZE: Store.getFileSize,
|
||||||
case 'ANON_RPC_MESSAGE': {
|
GET_MULTIPLE_FILE_SIZE: Store.getMultipleFileSize,
|
||||||
Store.anonRpcMsg(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_FILE_SIZE': {
|
|
||||||
Store.getFileSize(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_MULTIPLE_FILE_SIZE': {
|
|
||||||
Store.getMultipleFileSize(data, cb); break;
|
|
||||||
}
|
|
||||||
// Store
|
// Store
|
||||||
case 'GET': {
|
GET: Store.get,
|
||||||
Store.get(data, cb); break;
|
SET: Store.set,
|
||||||
}
|
ADD_PAD: Store.addPad,
|
||||||
case 'SET': {
|
SET_PAD_TITLE: Store.setPadTitle,
|
||||||
Store.set(data, cb); break;
|
MOVE_TO_TRASH: Store.moveToTrash,
|
||||||
}
|
RESET_DRIVE: Store.resetDrive,
|
||||||
case 'ADD_PAD': {
|
GET_METADATA: Store.getMetadata,
|
||||||
Store.addPad(data, cb); break;
|
SET_DISPLAY_NAME: Store.setDisplayName,
|
||||||
}
|
SET_PAD_ATTRIBUTE: Store.setPadAttribute,
|
||||||
case 'SET_PAD_TITLE': {
|
GET_PAD_ATTRIBUTE: Store.getPadAttribute,
|
||||||
Store.setPadTitle(data, cb); break;
|
SET_ATTRIBUTE: Store.setAttribute,
|
||||||
}
|
GET_ATTRIBUTE: Store.getAttribute,
|
||||||
case 'MOVE_TO_TRASH': {
|
LIST_ALL_TAGS: Store.listAllTags,
|
||||||
Store.moveToTrash(data, cb); break;
|
GET_TEMPLATES: Store.getTemplates,
|
||||||
}
|
GET_SECURE_FILES_LIST: Store.getSecureFilesList,
|
||||||
case 'RESET_DRIVE': {
|
GET_PAD_DATA: Store.getPadData,
|
||||||
Store.resetDrive(data, cb); break;
|
GET_STRONGER_HASH: Store.getStrongerHash,
|
||||||
}
|
INCREMENT_TEMPLATE_USE: Store.incrementTemplateUse,
|
||||||
case 'GET_METADATA': {
|
|
||||||
Store.getMetadata(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'SET_DISPLAY_NAME': {
|
|
||||||
Store.setDisplayName(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'SET_PAD_ATTRIBUTE': {
|
|
||||||
Store.setPadAttribute(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_PAD_ATTRIBUTE': {
|
|
||||||
Store.getPadAttribute(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'SET_ATTRIBUTE': {
|
|
||||||
Store.setAttribute(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_ATTRIBUTE': {
|
|
||||||
Store.getAttribute(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'LIST_ALL_TAGS': {
|
|
||||||
Store.listAllTags(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_TEMPLATES': {
|
|
||||||
Store.getTemplates(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_SECURE_FILES_LIST': {
|
|
||||||
Store.getSecureFilesList(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_PAD_DATA': {
|
|
||||||
Store.getPadData(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_STRONGER_HASH': {
|
|
||||||
Store.getStrongerHash(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'INCREMENT_TEMPLATE_USE': {
|
|
||||||
Store.incrementTemplateUse(data); break;
|
|
||||||
}
|
|
||||||
// Messaging
|
// Messaging
|
||||||
case 'INVITE_FROM_USERLIST': {
|
INVITE_FROM_USERLIST: Store.inviteFromUserlist,
|
||||||
Store.inviteFromUserlist(data, cb); break;
|
ADD_DIRECT_MESSAGE_HANDLERS: Store.addDirectMessageHandlers,
|
||||||
}
|
|
||||||
// Messenger
|
// Messenger
|
||||||
case 'CONTACTS_GET_FRIEND_LIST': {
|
CONTACTS_GET_FRIEND_LIST: Store.messenger.getFriendList,
|
||||||
Store.messenger.getFriendList(data, cb); break;
|
CONTACTS_GET_MY_INFO: Store.messenger.getMyInfo,
|
||||||
}
|
CONTACTS_GET_FRIEND_INFO: Store.messenger.getFriendInfo,
|
||||||
case 'CONTACTS_GET_MY_INFO': {
|
CONTACTS_REMOVE_FRIEND: Store.messenger.removeFriend,
|
||||||
Store.messenger.getMyInfo(data, cb); break;
|
CONTACTS_OPEN_FRIEND_CHANNEL: Store.messenger.openFriendChannel,
|
||||||
}
|
CONTACTS_GET_FRIEND_STATUS: Store.messenger.getFriendStatus,
|
||||||
case 'CONTACTS_GET_FRIEND_INFO': {
|
CONTACTS_GET_MORE_HISTORY: Store.messenger.getMoreHistory,
|
||||||
Store.messenger.getFriendInfo(data, cb); break;
|
CONTACTS_SEND_MESSAGE: Store.messenger.sendMessage,
|
||||||
}
|
CONTACTS_SET_CHANNEL_HEAD: Store.messenger.setChannelHead,
|
||||||
case 'CONTACTS_REMOVE_FRIEND': {
|
|
||||||
Store.messenger.removeFriend(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'CONTACTS_OPEN_FRIEND_CHANNEL': {
|
|
||||||
Store.messenger.openFriendChannel(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'CONTACTS_GET_FRIEND_STATUS': {
|
|
||||||
Store.messenger.getFriendStatus(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'CONTACTS_GET_MORE_HISTORY': {
|
|
||||||
Store.messenger.getMoreHistory(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'CONTACTS_SEND_MESSAGE': {
|
|
||||||
Store.messenger.sendMessage(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'CONTACTS_SET_CHANNEL_HEAD': {
|
|
||||||
Store.messenger.setChannelHead(data, cb); break;
|
|
||||||
}
|
|
||||||
// Pad
|
// Pad
|
||||||
case 'SEND_PAD_MSG': {
|
SEND_PAD_MSG: Store.sendPadMsg,
|
||||||
Store.sendPadMsg(data, cb); break;
|
JOIN_PAD: Store.joinPad,
|
||||||
}
|
GET_FULL_HISTORY: Store.getFullHistory,
|
||||||
case 'JOIN_PAD': {
|
IS_NEW_CHANNEL: Store.isNewChannel,
|
||||||
Store.joinPad(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'GET_FULL_HISTORY': {
|
|
||||||
Store.getFullHistory(data, cb); break;
|
|
||||||
}
|
|
||||||
// Drive
|
// Drive
|
||||||
case 'DRIVE_USEROBJECT': {
|
DRIVE_USEROBJECT: Store.userObjectCommand,
|
||||||
Store.userObjectCommand(data, cb); break;
|
// Settings,
|
||||||
}
|
DELETE_ACCOUNT: Store.deleteAccount,
|
||||||
// Settings
|
};
|
||||||
case 'DELETE_ACCOUNT': {
|
|
||||||
Store.deleteAccount(data, cb); break;
|
|
||||||
}
|
|
||||||
case 'IS_NEW_CHANNEL': {
|
|
||||||
Store.isNewChannel(data, cb); break;
|
|
||||||
}
|
|
||||||
default: {
|
|
||||||
console.error("UNHANDLED_STORE_RPC");
|
|
||||||
|
|
||||||
break;
|
Rpc.query = function (cmd, data, cb) {
|
||||||
}
|
if (queries[cmd]) {
|
||||||
|
queries[cmd]('0', data, cb);
|
||||||
|
} else {
|
||||||
|
console.error('UNHANDLED_STORE_RPC');
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Internal calls
|
||||||
|
Rpc._removeClient = Store._removeClient;
|
||||||
|
Rpc._subscribeToDrive = Store._subscribeToDrive;
|
||||||
|
Rpc._subscribeToMessenger = Store._subscribeToMessenger;
|
||||||
|
|
||||||
return Rpc;
|
return Rpc;
|
||||||
|
};
|
||||||
|
|
||||||
|
return create;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -0,0 +1,147 @@
|
|||||||
|
// This file provides the API for the channel for talking to and from the sandbox iframe.
|
||||||
|
define([
|
||||||
|
//'/common/sframe-protocol.js',
|
||||||
|
'/common/common-util.js'
|
||||||
|
], function (/*SFrameProtocol,*/ Util) {
|
||||||
|
|
||||||
|
var mkTxid = function () {
|
||||||
|
return Math.random().toString(16).replace('0.', '') + Math.random().toString(16).replace('0.', '');
|
||||||
|
};
|
||||||
|
|
||||||
|
var create = function (onMsg, postMsg, cb, isWorker) {
|
||||||
|
if (!isWorker) {
|
||||||
|
var chanLoaded = false;
|
||||||
|
var waitingData = [];
|
||||||
|
onMsg.reg(function (data) {
|
||||||
|
if (chanLoaded) { return; }
|
||||||
|
waitingData.push(data);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
var evReady = Util.mkEvent(true);
|
||||||
|
|
||||||
|
var handlers = {};
|
||||||
|
var queries = {};
|
||||||
|
|
||||||
|
// list of handlers which are registered from the other side...
|
||||||
|
var insideHandlers = [];
|
||||||
|
var callWhenRegistered = {};
|
||||||
|
|
||||||
|
var chan = {};
|
||||||
|
|
||||||
|
// Send a query. channel.query('Q_SOMETHING', { args: "whatever" }, function (reply) { ... });
|
||||||
|
chan.query = function (q, content, cb) {
|
||||||
|
var txid = mkTxid();
|
||||||
|
var timeout = setTimeout(function () {
|
||||||
|
delete queries[txid];
|
||||||
|
//console.log("Timeout making query " + q);
|
||||||
|
}, 30000);
|
||||||
|
queries[txid] = function (data, msg) {
|
||||||
|
clearTimeout(timeout);
|
||||||
|
delete queries[txid];
|
||||||
|
cb(undefined, data.content, msg);
|
||||||
|
};
|
||||||
|
evReady.reg(function () {
|
||||||
|
postMsg(JSON.stringify({
|
||||||
|
txid: txid,
|
||||||
|
content: content,
|
||||||
|
q: q
|
||||||
|
}));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// Fire an event. channel.event('EV_SOMETHING', { args: "whatever" });
|
||||||
|
var event = chan.event = function (e, content) {
|
||||||
|
evReady.reg(function () {
|
||||||
|
postMsg(JSON.stringify({ content: content, q: e }));
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// Be notified on query or event. channel.on('EV_SOMETHING', function (args, reply) { ... });
|
||||||
|
// If the type is a query, your handler will be invoked with a reply function that takes
|
||||||
|
// one argument (the content to reply with).
|
||||||
|
chan.on = function (queryType, handler, quiet) {
|
||||||
|
(handlers[queryType] = handlers[queryType] || []).push(function (data, msg) {
|
||||||
|
handler(data.content, function (replyContent) {
|
||||||
|
postMsg(JSON.stringify({
|
||||||
|
txid: data.txid,
|
||||||
|
content: replyContent
|
||||||
|
}));
|
||||||
|
}, msg);
|
||||||
|
});
|
||||||
|
if (!quiet) {
|
||||||
|
event('EV_REGISTER_HANDLER', queryType);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// If a particular handler is registered, call the callback immediately, otherwise it will be called
|
||||||
|
// when that handler is first registered.
|
||||||
|
// channel.whenReg('Q_SOMETHING', function () { ...query Q_SOMETHING?... });
|
||||||
|
chan.whenReg = function (queryType, cb, always) {
|
||||||
|
var reg = always;
|
||||||
|
if (insideHandlers.indexOf(queryType) > -1) {
|
||||||
|
cb();
|
||||||
|
} else {
|
||||||
|
reg = true;
|
||||||
|
}
|
||||||
|
if (reg) {
|
||||||
|
(callWhenRegistered[queryType] = callWhenRegistered[queryType] || []).push(cb);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Same as whenReg except it will invoke every time there is another registration, not just once.
|
||||||
|
chan.onReg = function (queryType, cb) { chan.whenReg(queryType, cb, true); };
|
||||||
|
|
||||||
|
chan.on('EV_REGISTER_HANDLER', function (content) {
|
||||||
|
if (callWhenRegistered[content]) {
|
||||||
|
callWhenRegistered[content].forEach(function (f) { f(); });
|
||||||
|
delete callWhenRegistered[content];
|
||||||
|
}
|
||||||
|
insideHandlers.push(content);
|
||||||
|
});
|
||||||
|
chan.whenReg('EV_REGISTER_HANDLER', evReady.fire);
|
||||||
|
|
||||||
|
// Make sure both iframes are ready
|
||||||
|
var isReady =false;
|
||||||
|
chan.onReady = function (h) {
|
||||||
|
if (isReady) {
|
||||||
|
return void h();
|
||||||
|
}
|
||||||
|
if (typeof(h) !== "function") { return; }
|
||||||
|
chan.on('EV_RPC_READY', function () { isReady = true; h(); });
|
||||||
|
};
|
||||||
|
chan.ready = function () {
|
||||||
|
chan.whenReg('EV_RPC_READY', function () {
|
||||||
|
chan.event('EV_RPC_READY');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
onMsg.reg(function (msg) {
|
||||||
|
var data = JSON.parse(msg.data);
|
||||||
|
if (typeof(data.q) === 'string' && handlers[data.q]) {
|
||||||
|
handlers[data.q].forEach(function (f) {
|
||||||
|
f(data || JSON.parse(msg.data), msg);
|
||||||
|
data = undefined;
|
||||||
|
});
|
||||||
|
} else if (typeof(data.q) === 'undefined' && queries[data.txid]) {
|
||||||
|
queries[data.txid](data, msg);
|
||||||
|
} else {
|
||||||
|
console.log("DROP Unhandled message");
|
||||||
|
console.log(msg.data, isWorker);
|
||||||
|
console.log(msg);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (isWorker) {
|
||||||
|
evReady.fire();
|
||||||
|
} else {
|
||||||
|
chanLoaded = true;
|
||||||
|
waitingData.forEach(function (d) {
|
||||||
|
onMsg.fire(d);
|
||||||
|
});
|
||||||
|
waitingData = [];
|
||||||
|
}
|
||||||
|
cb(chan);
|
||||||
|
};
|
||||||
|
|
||||||
|
return { create: create };
|
||||||
|
});
|
@ -0,0 +1,69 @@
|
|||||||
|
/* jshint ignore:start */
|
||||||
|
var id;
|
||||||
|
//= Math.floor(Math.random()*100000);
|
||||||
|
|
||||||
|
var postMsg = function (client, data) {
|
||||||
|
client.postMessage(data);
|
||||||
|
};
|
||||||
|
|
||||||
|
var broadcast = function (data, excludes) {
|
||||||
|
// Loop over all available clients
|
||||||
|
clients.matchAll().then(function (clients) {
|
||||||
|
clients.forEach(function (client) {
|
||||||
|
if (excludes.indexOf(client.id) === -1) {
|
||||||
|
postMsg(client, data);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
};
|
||||||
|
var sendTo = function (data, clientId){
|
||||||
|
clients.matchAll().then(function (clients) {
|
||||||
|
clients.some(function (client) {
|
||||||
|
if (client.id === clientId) {
|
||||||
|
postMsg(client, data)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
};
|
||||||
|
var getClients = function () {
|
||||||
|
clients.matchAll().then(function (clients) {
|
||||||
|
var cl = clients.map(function (c) {
|
||||||
|
console.log(JSON.stringify(c));
|
||||||
|
return c.id;
|
||||||
|
});
|
||||||
|
console.log(cl);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
self.addEventListener('message', function (e) {
|
||||||
|
console.log(clients);
|
||||||
|
console.log('worker received');
|
||||||
|
console.log(e.data);
|
||||||
|
console.log(e.source);
|
||||||
|
var cId = e.source.id;
|
||||||
|
if (e.data === "INIT") {
|
||||||
|
if (!id) {
|
||||||
|
id = Math.floor(Math.random()*100000);
|
||||||
|
}
|
||||||
|
broadcast(cId + ' has joined!', [cId]);
|
||||||
|
postMsg(e.source, {state: 'READY'});
|
||||||
|
postMsg(e.source, "Welcome to SW " + id + "!");
|
||||||
|
postMsg(e.source, "You are identified as " + cId);
|
||||||
|
} else {
|
||||||
|
console.log(e.data);
|
||||||
|
postMsg(e.source, 'Yo (Re: '+e.data+')');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
self.addEventListener('install', function (e) {
|
||||||
|
console.log(e);
|
||||||
|
console.log('V1 installing…');
|
||||||
|
self.skipWaiting();
|
||||||
|
});
|
||||||
|
|
||||||
|
self.addEventListener('activate', function (e) {
|
||||||
|
console.log(e);
|
||||||
|
console.log('V1 now ready to handle fetches!');
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in New Issue