1
0
mirror of https://github.com/bitwarden/browser synced 2026-02-07 12:13:45 +00:00

Merge branch 'PM-25685' into PM-25686

This commit is contained in:
Jordan Aasen
2025-11-07 22:03:19 -08:00
committed by GitHub
4 changed files with 17 additions and 13 deletions

View File

@@ -25,6 +25,6 @@ export class FolderExport {
// Use build method instead of ctor so that we can control order of JSON stringify for pretty print
build(o: FolderView | FolderDomain) {
this.name = safeGetString(o.name) ?? "";
this.name = safeGetString(o.name ?? "") ?? "";
}
}

View File

@@ -60,9 +60,8 @@ describe("Folder", () => {
it("initializes empty properties when no FolderData is provided", () => {
const folder = new Folder();
expect(folder.id).toBe("");
expect(folder.name).toBeInstanceOf(EncString);
expect((folder.name as EncString).encryptedString).toBe("");
expect(folder.id).toBe(undefined);
expect(folder.name).toBe(undefined);
expect(folder.revisionDate).toBeInstanceOf(Date);
});
});

View File

@@ -8,8 +8,8 @@ import { FolderData } from "../data/folder.data";
import { FolderView } from "../view/folder.view";
export class Folder extends Domain {
id: string = "";
name: EncString = new EncString("");
id?: string;
name?: EncString;
revisionDate: Date;
constructor(obj?: FolderData) {
@@ -41,10 +41,10 @@ export class Folder extends Domain {
encryptService: EncryptService,
): Promise<FolderView> {
const folderView = new FolderView();
folderView.id = this.id;
folderView.id = this.id ?? "";
folderView.revisionDate = this.revisionDate;
try {
folderView.name = await encryptService.decryptString(this.name, key);
folderView.name = await encryptService.decryptString(this.name ?? new EncString(""), key);
} catch (e) {
// Note: This should be replaced by the owning team with appropriate, domain-specific behavior.
// eslint-disable-next-line no-console
@@ -58,6 +58,10 @@ export class Folder extends Domain {
if (obj == null) {
return null;
}
return new Folder({ name: obj.name, revisionDate: obj.revisionDate, id: obj.id });
return new Folder({
name: obj.name ?? "",
revisionDate: obj.revisionDate,
id: obj.id ?? "",
});
}
}

View File

@@ -10,20 +10,21 @@ export class FolderView implements View, ITreeNodeObject {
name: string = "";
revisionDate: Date;
constructor(f?: Folder | DecryptedObject<Folder, "name">) {
constructor(f?: Folder | DecryptedObject<Folder, undefined>) {
if (!f) {
this.revisionDate = new Date();
return;
}
this.id = f.id;
this.id = f.id ?? "";
this.name = f.name?.decryptedValue ?? "";
this.revisionDate = f.revisionDate;
}
static fromJSON(obj: Jsonify<FolderView>) {
const folderView = new FolderView();
folderView.id = obj.id;
folderView.name = obj.name;
folderView.id = obj.id ?? "";
folderView.name = obj.name ?? "";
folderView.revisionDate = new Date(obj.revisionDate);
return folderView;
}