1
0
mirror of https://github.com/bitwarden/browser.git synced 2024-11-28 12:45:45 +01:00

Use User Key Definitions for user-scoped data (#9348)

This commit is contained in:
Matt Gibson 2024-05-27 08:12:28 -04:00 committed by GitHub
parent c0bb7b9edf
commit c61ba41b97
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
8 changed files with 59 additions and 34 deletions

View File

@ -3,28 +3,31 @@ import { Jsonify } from "type-fest";
import { import {
ActiveUserState, ActiveUserState,
KeyDefinition,
StateProvider, StateProvider,
UserKeyDefinition,
VAULT_BROWSER_MEMORY, VAULT_BROWSER_MEMORY,
} from "@bitwarden/common/platform/state"; } from "@bitwarden/common/platform/state";
import { BrowserComponentState } from "../../models/browserComponentState"; import { BrowserComponentState } from "../../models/browserComponentState";
import { BrowserGroupingsComponentState } from "../../models/browserGroupingsComponentState"; import { BrowserGroupingsComponentState } from "../../models/browserGroupingsComponentState";
export const VAULT_BROWSER_GROUPINGS_COMPONENT = new KeyDefinition<BrowserGroupingsComponentState>( export const VAULT_BROWSER_GROUPINGS_COMPONENT =
VAULT_BROWSER_MEMORY, new UserKeyDefinition<BrowserGroupingsComponentState>(
"vault_browser_groupings_component", VAULT_BROWSER_MEMORY,
{ "vault_browser_groupings_component",
deserializer: (obj: Jsonify<BrowserGroupingsComponentState>) => {
BrowserGroupingsComponentState.fromJSON(obj), deserializer: (obj: Jsonify<BrowserGroupingsComponentState>) =>
}, BrowserGroupingsComponentState.fromJSON(obj),
); clearOn: ["logout", "lock"],
},
);
export const VAULT_BROWSER_COMPONENT = new KeyDefinition<BrowserComponentState>( export const VAULT_BROWSER_COMPONENT = new UserKeyDefinition<BrowserComponentState>(
VAULT_BROWSER_MEMORY, VAULT_BROWSER_MEMORY,
"vault_browser_component", "vault_browser_component",
{ {
deserializer: (obj: Jsonify<BrowserComponentState>) => BrowserComponentState.fromJSON(obj), deserializer: (obj: Jsonify<BrowserComponentState>) => BrowserComponentState.fromJSON(obj),
clearOn: ["logout", "lock"],
}, },
); );

View File

@ -11,9 +11,9 @@ import { KdfType, PBKDF2_ITERATIONS } from "@bitwarden/common/platform/enums";
import { import {
StateProvider, StateProvider,
ActiveUserState, ActiveUserState,
KeyDefinition,
PREMIUM_BANNER_DISK_LOCAL, PREMIUM_BANNER_DISK_LOCAL,
BANNERS_DISMISSED_DISK, BANNERS_DISMISSED_DISK,
UserKeyDefinition,
} from "@bitwarden/common/platform/state"; } from "@bitwarden/common/platform/state";
import { SyncService } from "@bitwarden/common/vault/abstractions/sync/sync.service.abstraction"; import { SyncService } from "@bitwarden/common/vault/abstractions/sync/sync.service.abstraction";
@ -33,19 +33,21 @@ type PremiumBannerReprompt = {
/** Banners that will be re-shown on a new session */ /** Banners that will be re-shown on a new session */
type SessionBanners = Omit<VisibleVaultBanner, VisibleVaultBanner.Premium>; type SessionBanners = Omit<VisibleVaultBanner, VisibleVaultBanner.Premium>;
export const PREMIUM_BANNER_REPROMPT_KEY = new KeyDefinition<PremiumBannerReprompt>( export const PREMIUM_BANNER_REPROMPT_KEY = new UserKeyDefinition<PremiumBannerReprompt>(
PREMIUM_BANNER_DISK_LOCAL, PREMIUM_BANNER_DISK_LOCAL,
"bannerReprompt", "bannerReprompt",
{ {
deserializer: (bannerReprompt) => bannerReprompt, deserializer: (bannerReprompt) => bannerReprompt,
clearOn: [], // Do not clear user tutorials
}, },
); );
export const BANNERS_DISMISSED_DISK_KEY = new KeyDefinition<SessionBanners[]>( export const BANNERS_DISMISSED_DISK_KEY = new UserKeyDefinition<SessionBanners[]>(
BANNERS_DISMISSED_DISK, BANNERS_DISMISSED_DISK,
"bannersDismissed", "bannersDismissed",
{ {
deserializer: (bannersDismissed) => bannersDismissed, deserializer: (bannersDismissed) => bannersDismissed,
clearOn: [], // Do not clear user tutorials
}, },
); );

View File

@ -3,8 +3,8 @@ import { Observable } from "rxjs";
import { import {
ActiveUserState, ActiveUserState,
KeyDefinition,
StateProvider, StateProvider,
UserKeyDefinition,
VAULT_ONBOARDING, VAULT_ONBOARDING,
} from "@bitwarden/common/platform/state"; } from "@bitwarden/common/platform/state";
@ -16,9 +16,14 @@ export type VaultOnboardingTasks = {
installExtension: boolean; installExtension: boolean;
}; };
const VAULT_ONBOARDING_KEY = new KeyDefinition<VaultOnboardingTasks>(VAULT_ONBOARDING, "tasks", { const VAULT_ONBOARDING_KEY = new UserKeyDefinition<VaultOnboardingTasks>(
deserializer: (jsonData) => jsonData, VAULT_ONBOARDING,
}); "tasks",
{
deserializer: (jsonData) => jsonData,
clearOn: [], // do not clear tutorials
},
);
@Injectable() @Injectable()
export class VaultOnboardingService implements VaultOnboardingServiceAbstraction { export class VaultOnboardingService implements VaultOnboardingServiceAbstraction {

View File

@ -6,11 +6,11 @@ import { I18nService } from "../../platform/abstractions/i18n.service";
import { Utils } from "../../platform/misc/utils"; import { Utils } from "../../platform/misc/utils";
import { import {
ActiveUserState, ActiveUserState,
KeyDefinition,
StateProvider, StateProvider,
COLLECTION_DATA, COLLECTION_DATA,
DeriveDefinition, DeriveDefinition,
DerivedState, DerivedState,
UserKeyDefinition,
} from "../../platform/state"; } from "../../platform/state";
import { CollectionId, OrganizationId, UserId } from "../../types/guid"; import { CollectionId, OrganizationId, UserId } from "../../types/guid";
import { CollectionService as CollectionServiceAbstraction } from "../../vault/abstractions/collection.service"; import { CollectionService as CollectionServiceAbstraction } from "../../vault/abstractions/collection.service";
@ -20,11 +20,12 @@ import { TreeNode } from "../models/domain/tree-node";
import { CollectionView } from "../models/view/collection.view"; import { CollectionView } from "../models/view/collection.view";
import { ServiceUtils } from "../service-utils"; import { ServiceUtils } from "../service-utils";
const ENCRYPTED_COLLECTION_DATA_KEY = KeyDefinition.record<CollectionData, CollectionId>( const ENCRYPTED_COLLECTION_DATA_KEY = UserKeyDefinition.record<CollectionData, CollectionId>(
COLLECTION_DATA, COLLECTION_DATA,
"collections", "collections",
{ {
deserializer: (jsonData: Jsonify<CollectionData>) => CollectionData.fromJSON(jsonData), deserializer: (jsonData: Jsonify<CollectionData>) => CollectionData.fromJSON(jsonData),
clearOn: ["logout"],
}, },
); );

View File

@ -4,7 +4,7 @@ import {
CIPHERS_DISK, CIPHERS_DISK,
CIPHERS_DISK_LOCAL, CIPHERS_DISK_LOCAL,
CIPHERS_MEMORY, CIPHERS_MEMORY,
KeyDefinition, UserKeyDefinition,
} from "../../../platform/state"; } from "../../../platform/state";
import { CipherId } from "../../../types/guid"; import { CipherId } from "../../../types/guid";
import { CipherData } from "../../models/data/cipher.data"; import { CipherData } from "../../models/data/cipher.data";
@ -12,27 +12,30 @@ import { LocalData } from "../../models/data/local.data";
import { CipherView } from "../../models/view/cipher.view"; import { CipherView } from "../../models/view/cipher.view";
import { AddEditCipherInfo } from "../../types/add-edit-cipher-info"; import { AddEditCipherInfo } from "../../types/add-edit-cipher-info";
export const ENCRYPTED_CIPHERS = KeyDefinition.record<CipherData>(CIPHERS_DISK, "ciphers", { export const ENCRYPTED_CIPHERS = UserKeyDefinition.record<CipherData>(CIPHERS_DISK, "ciphers", {
deserializer: (obj: Jsonify<CipherData>) => CipherData.fromJSON(obj), deserializer: (obj: Jsonify<CipherData>) => CipherData.fromJSON(obj),
clearOn: ["logout"],
}); });
export const DECRYPTED_CIPHERS = KeyDefinition.record<CipherView>( export const DECRYPTED_CIPHERS = UserKeyDefinition.record<CipherView>(
CIPHERS_MEMORY, CIPHERS_MEMORY,
"decryptedCiphers", "decryptedCiphers",
{ {
deserializer: (cipher: Jsonify<CipherView>) => CipherView.fromJSON(cipher), deserializer: (cipher: Jsonify<CipherView>) => CipherView.fromJSON(cipher),
clearOn: ["logout", "lock"],
}, },
); );
export const LOCAL_DATA_KEY = new KeyDefinition<Record<CipherId, LocalData>>( export const LOCAL_DATA_KEY = new UserKeyDefinition<Record<CipherId, LocalData>>(
CIPHERS_DISK_LOCAL, CIPHERS_DISK_LOCAL,
"localData", "localData",
{ {
deserializer: (localData) => localData, deserializer: (localData) => localData,
clearOn: ["logout"],
}, },
); );
export const ADD_EDIT_CIPHER_INFO_KEY = new KeyDefinition<AddEditCipherInfo>( export const ADD_EDIT_CIPHER_INFO_KEY = new UserKeyDefinition<AddEditCipherInfo>(
CIPHERS_MEMORY, CIPHERS_MEMORY,
"addEditCipherInfo", "addEditCipherInfo",
{ {
@ -48,5 +51,6 @@ export const ADD_EDIT_CIPHER_INFO_KEY = new KeyDefinition<AddEditCipherInfo>(
return { cipher, collectionIds: addEditCipherInfo.collectionIds }; return { cipher, collectionIds: addEditCipherInfo.collectionIds };
}, },
clearOn: ["logout", "lock"],
}, },
); );

View File

@ -1,9 +1,10 @@
import { KeyDefinition, VAULT_FILTER_DISK } from "../../../platform/state"; import { UserKeyDefinition, VAULT_FILTER_DISK } from "../../../platform/state";
export const COLLAPSED_GROUPINGS = KeyDefinition.array<string>( export const COLLAPSED_GROUPINGS = UserKeyDefinition.array<string>(
VAULT_FILTER_DISK, VAULT_FILTER_DISK,
"collapsedGroupings", "collapsedGroupings",
{ {
deserializer: (obj) => obj, deserializer: (obj) => obj,
clearOn: ["logout", "lock"],
}, },
); );

View File

@ -1,15 +1,20 @@
import { Jsonify } from "type-fest"; import { Jsonify } from "type-fest";
import { CryptoService } from "../../../platform/abstractions/crypto.service"; import { CryptoService } from "../../../platform/abstractions/crypto.service";
import { DeriveDefinition, FOLDER_DISK, KeyDefinition } from "../../../platform/state"; import { DeriveDefinition, FOLDER_DISK, UserKeyDefinition } from "../../../platform/state";
import { FolderService } from "../../abstractions/folder/folder.service.abstraction"; import { FolderService } from "../../abstractions/folder/folder.service.abstraction";
import { FolderData } from "../../models/data/folder.data"; import { FolderData } from "../../models/data/folder.data";
import { Folder } from "../../models/domain/folder"; import { Folder } from "../../models/domain/folder";
import { FolderView } from "../../models/view/folder.view"; import { FolderView } from "../../models/view/folder.view";
export const FOLDER_ENCRYPTED_FOLDERS = KeyDefinition.record<FolderData>(FOLDER_DISK, "folders", { export const FOLDER_ENCRYPTED_FOLDERS = UserKeyDefinition.record<FolderData>(
deserializer: (obj: Jsonify<FolderData>) => FolderData.fromJSON(obj), FOLDER_DISK,
}); "folders",
{
deserializer: (obj: Jsonify<FolderData>) => FolderData.fromJSON(obj),
clearOn: ["logout"],
},
);
export const FOLDER_DECRYPTED_FOLDERS = DeriveDefinition.from< export const FOLDER_DECRYPTED_FOLDERS = DeriveDefinition.from<
Record<string, FolderData>, Record<string, FolderData>,

View File

@ -1,4 +1,4 @@
import { VAULT_SETTINGS_DISK, KeyDefinition } from "../../../platform/state"; import { VAULT_SETTINGS_DISK, KeyDefinition, UserKeyDefinition } from "../../../platform/state";
export const USER_ENABLE_PASSKEYS = new KeyDefinition<boolean>( export const USER_ENABLE_PASSKEYS = new KeyDefinition<boolean>(
VAULT_SETTINGS_DISK, VAULT_SETTINGS_DISK,
@ -8,16 +8,20 @@ export const USER_ENABLE_PASSKEYS = new KeyDefinition<boolean>(
}, },
); );
export const SHOW_CARDS_CURRENT_TAB = new KeyDefinition<boolean>( export const SHOW_CARDS_CURRENT_TAB = new UserKeyDefinition<boolean>(
VAULT_SETTINGS_DISK, VAULT_SETTINGS_DISK,
"showCardsCurrentTab", "showCardsCurrentTab",
{ {
deserializer: (obj) => obj, deserializer: (obj) => obj,
clearOn: [], // do not clear user settings
}, },
); );
export const SHOW_IDENTITIES_CURRENT_TAB = new KeyDefinition<boolean>( export const SHOW_IDENTITIES_CURRENT_TAB = new UserKeyDefinition<boolean>(
VAULT_SETTINGS_DISK, VAULT_SETTINGS_DISK,
"showIdentitiesCurrentTab", "showIdentitiesCurrentTab",
{ deserializer: (obj) => obj }, {
deserializer: (obj) => obj,
clearOn: [], // do not clear user settings
},
); );