1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-24 21:41:33 +01:00

Fix storage reseed on logout

The check for the set vault-timeout needs to happen before all cleaning stateService
Remove check inside of reseedStorage as happens outside prior to calling it (logout/settings.component)
This commit is contained in:
Daniel James Smith 2023-01-23 19:47:39 +01:00
parent e2c25c6aad
commit 35b480af5b
No known key found for this signature in database
GPG Key ID: 03E4BD365FF06726

View File

@ -678,6 +678,9 @@ export default class MainBackground {
this.vaultFilterService.clear(), this.vaultFilterService.clear(),
]); ]);
//Needs to be checked before state is cleaned
const needStorageReseed = await this.needsStorageReseed();
await this.stateService.clean({ userId: userId }); await this.stateService.clean({ userId: userId });
if (userId == null || userId === (await this.stateService.getUserId())) { if (userId == null || userId === (await this.stateService.getUserId())) {
@ -685,17 +688,25 @@ export default class MainBackground {
this.messagingService.send("doneLoggingOut", { expired: expired, userId: userId }); this.messagingService.send("doneLoggingOut", { expired: expired, userId: userId });
} }
if (needStorageReseed) {
await this.reseedStorage();
}
if (BrowserApi.manifestVersion === 3) { if (BrowserApi.manifestVersion === 3) {
BrowserApi.sendMessage("updateBadge"); BrowserApi.sendMessage("updateBadge");
} }
await this.refreshBadge(); await this.refreshBadge();
await this.mainContextMenuHandler.noAccess(); await this.mainContextMenuHandler.noAccess();
await this.reseedStorage();
this.notificationsService.updateConnection(false); this.notificationsService.updateConnection(false);
await this.systemService.clearPendingClipboard(); await this.systemService.clearPendingClipboard();
await this.systemService.startProcessReload(this.authService); await this.systemService.startProcessReload(this.authService);
} }
private async needsStorageReseed(): Promise<boolean> {
const currentVaultTimeout = await this.stateService.getVaultTimeout();
return currentVaultTimeout == null ? false : true;
}
async collectPageDetailsForContentScript(tab: any, sender: string, frameId: number = null) { async collectPageDetailsForContentScript(tab: any, sender: string, frameId: number = null) {
if (tab == null || !tab.id) { if (tab == null || !tab.id) {
return; return;
@ -736,11 +747,6 @@ export default class MainBackground {
return; return;
} }
const currentVaultTimeout = await this.stateService.getVaultTimeout();
if (currentVaultTimeout == null) {
return;
}
const getStorage = (): Promise<any> => const getStorage = (): Promise<any> =>
new Promise((resolve) => { new Promise((resolve) => {
chrome.storage.local.get(null, (o: any) => resolve(o)); chrome.storage.local.get(null, (o: any) => resolve(o));