mirror of
https://github.com/element-hq/element-web.git
synced 2024-12-14 00:53:40 +03:00
751a1dc543
App checks at startup for an existing session, if there isn't one, it will start the tool to check for a login in the file:// origin. If there is one, it will copy the login over to the vector://vector origin. In principle this could also be used to migrate logins between other origins on the web if this were ever required. This includes a minified copy of the browserified js-sdk with a getAllEndToEndSessions() function added to the crypto store (https://github.com/matrix-org/matrix-js-sdk/pull/812). This is not great, but for a short-lived tool this seems better than introducing more entry points into webpack only used for the electron app.
125 lines
4.2 KiB
JavaScript
125 lines
4.2 KiB
JavaScript
/*
|
|
Copyright 2018 New Vector Ltd
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
const SOURCE_ORIGIN = 'file://';
|
|
|
|
const IndexedDBCryptoStore = window.matrixcs.IndexedDBCryptoStore;
|
|
const cryptoStore = new IndexedDBCryptoStore(window.indexedDB, 'matrix-js-sdk:crypto');
|
|
|
|
let accountStored = 0;
|
|
let sessionsStored = 0;
|
|
let inboundGroupSessionsStored = 0;
|
|
let deviceDataStored = 0;
|
|
let roomsStored = 0;
|
|
let localStorageKeysStored = 0;
|
|
|
|
const promises = [];
|
|
|
|
async function onMessage(e) {
|
|
if (e.origin !== SOURCE_ORIGIN) return;
|
|
|
|
const data = e.data.data; // bleh, naming clash
|
|
switch (e.data.cmd) {
|
|
case 'init':
|
|
// start with clean stores before we migrate data in
|
|
window.localStorage.clear();
|
|
await cryptoStore.deleteAllData();
|
|
|
|
e.source.postMessage({
|
|
cmd: 'initOK',
|
|
}, SOURCE_ORIGIN);
|
|
break;
|
|
case 'storeAccount':
|
|
promises.push(cryptoStore.doTxn(
|
|
'readwrite', [IndexedDBCryptoStore.STORE_ACCOUNT],
|
|
(txn) => {
|
|
cryptoStore.storeAccount(txn, data);
|
|
},
|
|
).then(() => {
|
|
++accountStored;
|
|
}));
|
|
break;
|
|
case 'storeSessions':
|
|
promises.push(cryptoStore.doTxn(
|
|
'readwrite', [IndexedDBCryptoStore.STORE_SESSIONS],
|
|
(txn) => {
|
|
for (const sess of data) {
|
|
cryptoStore.storeEndToEndSession(sess.deviceKey, sess.sessionId, sess, txn);
|
|
}
|
|
},
|
|
).then(() => {
|
|
sessionsStored += data.length;
|
|
}));
|
|
break;
|
|
case 'storeInboundGroupSessions':
|
|
promises.push(cryptoStore.doTxn(
|
|
'readwrite', [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS],
|
|
(txn) => {
|
|
for (const sess of data) {
|
|
cryptoStore.addEndToEndInboundGroupSession(
|
|
sess.senderKey, sess.sessionId, sess.sessionData, txn,
|
|
);
|
|
}
|
|
},
|
|
).then(() => {
|
|
inboundGroupSessionsStored += data.length;
|
|
}));
|
|
break;
|
|
case 'storeDeviceData':
|
|
promises.push(cryptoStore.doTxn(
|
|
'readwrite', [IndexedDBCryptoStore.STORE_DEVICE_DATA],
|
|
(txn) => {
|
|
cryptoStore.storeEndToEndDeviceData(data, txn);
|
|
},
|
|
).then(() => {
|
|
++deviceDataStored;
|
|
}));
|
|
break;
|
|
case 'storeRooms':
|
|
promises.push(cryptoStore.doTxn(
|
|
'readwrite', [IndexedDBCryptoStore.STORE_ROOMS],
|
|
(txn) => {
|
|
for (const [roomId, roomInfo] of Object.entries(data)) {
|
|
cryptoStore.storeEndToEndRoom(roomId, roomInfo, txn);
|
|
}
|
|
},
|
|
).then(() => {
|
|
++roomsStored;
|
|
}));
|
|
break;
|
|
case 'storeLocalStorage':
|
|
window.localStorage.setItem(data.key, data.val);
|
|
++localStorageKeysStored;
|
|
break;
|
|
case 'getSummary':
|
|
await Promise.all(promises);
|
|
e.source.postMessage({
|
|
cmd: 'summary',
|
|
data: {
|
|
accountStored,
|
|
sessionsStored,
|
|
inboundGroupSessionsStored,
|
|
deviceDataStored,
|
|
roomsStored,
|
|
localStorageKeysStored,
|
|
},
|
|
}, SOURCE_ORIGIN);
|
|
break;
|
|
}
|
|
}
|
|
|
|
window.addEventListener('message', onMessage);
|
|
|