abort decrypt requests when changing room

This commit is contained in:
Bruno Windels 2020-09-10 17:43:01 +02:00
parent 0bf1723d99
commit de1cc0d739
8 changed files with 21 additions and 21 deletions

View file

@ -38,7 +38,7 @@ export class RoomViewModel extends ViewModel {
async load() { async load() {
this._room.on("change", this._onRoomChange); this._room.on("change", this._onRoomChange);
try { try {
this._timeline = this._room.openTimeline(); this._timeline = this.track(this._room.openTimeline());
await this._timeline.load(); await this._timeline.load();
this._timelineVM = new TimelineViewModel(this.childOptions({ this._timelineVM = new TimelineViewModel(this.childOptions({
room: this._room, room: this._room,
@ -63,17 +63,15 @@ export class RoomViewModel extends ViewModel {
} }
dispose() { dispose() {
// this races with enable, on the await openTimeline() super.dispose();
if (this._timeline) {
// will stop the timeline from delivering updates on entries
this._timeline.close();
}
if (this._clearUnreadTimout) { if (this._clearUnreadTimout) {
this._clearUnreadTimout.abort(); this._clearUnreadTimout.abort();
this._clearUnreadTimout = null; this._clearUnreadTimout = null;
} }
} }
// called from view to close room
// parent vm will dispose this vm
close() { close() {
this._closeCallback(); this._closeCallback();
} }

View file

@ -292,11 +292,9 @@ class BatchDecryptionResult {
constructor(results, errors) { constructor(results, errors) {
this.results = results; this.results = results;
this.errors = errors; this.errors = errors;
console.log("BatchDecryptionResult", this);
} }
applyToEntries(entries) { applyToEntries(entries) {
console.log("BatchDecryptionResult.applyToEntries", this);
for (const entry of entries) { for (const entry of entries) {
const result = this.results.get(entry.id); const result = this.results.get(entry.id);
if (result) { if (result) {

View file

@ -39,8 +39,8 @@ export class Decryption {
constructor({pickleKey, olm}) { constructor({pickleKey, olm}) {
this._pickleKey = pickleKey; this._pickleKey = pickleKey;
this._olm = olm; this._olm = olm;
// this._decryptor = new DecryptionWorker(new Worker("./src/worker.js"));
this._decryptor = new DecryptionWorker(new WorkerPool("worker-1039452087.js", 4)); this._decryptor = new DecryptionWorker(new WorkerPool("worker-1039452087.js", 4));
//this._decryptor = new DecryptionWorker(new WorkerPool("./src/worker.js", 4));
this._initPromise = this._decryptor.init(); this._initPromise = this._decryptor.init();
} }

View file

@ -28,6 +28,9 @@ export class DecryptionPreparation {
} }
async decrypt() { async decrypt() {
// console.log("start sleeping");
// await new Promise(resolve => setTimeout(resolve, 5000));
// console.log("done sleeping");
try { try {
const errors = this._initialErrors; const errors = this._initialErrors;
const results = new Map(); const results = new Map();

View file

@ -94,7 +94,6 @@ export class WorkerPool {
} }
this._requests.delete(message.replyToId); this._requests.delete(message.replyToId);
} }
console.log("got worker reply", message, this._requests.size);
this._sendPending(); this._sendPending();
} else if (e.type === "error") { } else if (e.type === "error") {
console.error("worker error", e); console.error("worker error", e);
@ -119,13 +118,11 @@ export class WorkerPool {
_sendPending() { _sendPending() {
this._pendingFlag = false; this._pendingFlag = false;
console.log("seeing if there is anything to send", this._requests.size);
let success; let success;
do { do {
success = false; success = false;
const request = this._getPendingRequest(); const request = this._getPendingRequest();
if (request) { if (request) {
console.log("sending pending request", request);
const worker = this._getFreeWorker(); const worker = this._getFreeWorker();
if (worker) { if (worker) {
this._sendWith(request, worker); this._sendWith(request, worker);
@ -138,7 +135,6 @@ export class WorkerPool {
_sendWith(request, worker) { _sendWith(request, worker) {
request._worker = worker; request._worker = worker;
worker.busy = true; worker.busy = true;
console.log("sending message to worker", request._message);
worker.worker.postMessage(request._message); worker.worker.postMessage(request._message);
} }
@ -162,7 +158,7 @@ export class WorkerPool {
// assumes all workers are free atm // assumes all workers are free atm
sendAll(message) { sendAll(message) {
const promises = this._workers.map(worker => { const promises = this._workers.map(worker => {
const request = this._enqueueRequest(message); const request = this._enqueueRequest(Object.assign({}, message));
this._sendWith(request, worker); this._sendWith(request, worker);
return request.response(); return request.response();
}); });
@ -208,6 +204,6 @@ export class DecryptionWorker {
async init() { async init() {
await this._workerPool.sendAll({type: "load_olm", path: "olm_legacy-3232457086.js"}); await this._workerPool.sendAll({type: "load_olm", path: "olm_legacy-3232457086.js"});
// return this._send({type: "load_olm", path: "../lib/olm/olm_legacy.js"}); //await this._workerPool.sendAll({type: "load_olm", path: "../lib/olm/olm_legacy.js"});
} }
} }

View file

@ -19,7 +19,6 @@ import {Disposables} from "../../../utils/Disposables.js";
import {Direction} from "./Direction.js"; import {Direction} from "./Direction.js";
import {TimelineReader} from "./persistence/TimelineReader.js"; import {TimelineReader} from "./persistence/TimelineReader.js";
import {PendingEventEntry} from "./entries/PendingEventEntry.js"; import {PendingEventEntry} from "./entries/PendingEventEntry.js";
import {EventEntry} from "./entries/EventEntry.js";
export class Timeline { export class Timeline {
constructor({roomId, storage, closeCallback, fragmentIdComparer, pendingEvents, user}) { constructor({roomId, storage, closeCallback, fragmentIdComparer, pendingEvents, user}) {
@ -99,10 +98,9 @@ export class Timeline {
} }
/** @public */ /** @public */
close() { dispose() {
if (this._closeCallback) { if (this._closeCallback) {
this._readerRequest?.dispose(); this._disposables.dispose();
this._readerRequest = null;
this._closeCallback(); this._closeCallback();
this._closeCallback = null; this._closeCallback = null;
} }

View file

@ -28,6 +28,9 @@ export class Disposables {
} }
track(disposable) { track(disposable) {
if (this.isDisposed) {
throw new Error("Already disposed, check isDisposed after await if needed");
}
this._disposables.push(disposable); this._disposables.push(disposable);
return disposable; return disposable;
} }
@ -41,8 +44,12 @@ export class Disposables {
} }
} }
get isDisposed() {
return this._disposables === null;
}
disposeTracked(value) { disposeTracked(value) {
if (value === undefined || value === null) { if (value === undefined || value === null || this.isDisposed) {
return null; return null;
} }
const idx = this._disposables.indexOf(value); const idx = this._disposables.indexOf(value);