1
0
mirror of https://github.com/bitwarden/jslib synced 2025-12-20 10:13:43 +00:00

Move encrypt to CipherView

This commit is contained in:
Hinton
2022-04-20 10:55:21 +02:00
parent f19e0bcbb5
commit a75962a49e
5 changed files with 10 additions and 12 deletions

View File

@@ -42,7 +42,7 @@ export class FolderAddEditComponent implements OnInit {
}
try {
const folder = await this.folderService.encrypt(this.folder);
const folder = await this.folder.encrypt(this.cryptoService);
this.formPromise = this.folderService.saveWithServer(folder);
await this.formPromise;
this.platformUtilsService.showToast(

View File

@@ -6,7 +6,6 @@ import { FolderView } from "../models/view/folderView";
export abstract class FolderService {
clearCache: (userId?: string) => Promise<void>;
encrypt: (model: FolderView, key?: SymmetricCryptoKey) => Promise<Folder>;
get: (id: string) => Promise<Folder>;
getAll: () => Promise<Folder[]>;
getAllDecrypted: () => Promise<FolderView[]>;

View File

@@ -1,7 +1,6 @@
import { CryptoService } from "jslib-common/abstractions/crypto.service";
import { Folder } from "../domain/folder";
import { SymmetricCryptoKey } from "../domain/symmetricCryptoKey";
import { ITreeNodeObject } from "../domain/treeNode";
export class FolderView implements ITreeNodeObject {
@@ -9,6 +8,14 @@ export class FolderView implements ITreeNodeObject {
name: string = null;
revisionDate: Date = null;
async encrypt(cryptoService: CryptoService): Promise<Folder> {
return {
id: this.id,
name: await cryptoService.encrypt(this.name),
revisionDate: null,
};
}
static async fromFolder(cryptoService: CryptoService, folder: Folder): Promise<FolderView> {
const view = new FolderView();
view.id = folder.id;

View File

@@ -30,14 +30,6 @@ export class FolderService implements FolderServiceAbstraction {
await this.stateService.setDecryptedFolders(null, { userId: userId });
}
async encrypt(model: FolderView, key?: SymmetricCryptoKey): Promise<Folder> {
return {
id: model.id,
name: await this.cryptoService.encrypt(model.name, key),
revisionDate: null,
};
}
async decrypt(model: Folder, key?: SymmetricCryptoKey): Promise<FolderView> {
const view = new FolderView();
view.id = model.id;

View File

@@ -296,7 +296,7 @@ export class ImportService implements ImportServiceAbstraction {
}
if (importResult.folders != null) {
for (let i = 0; i < importResult.folders.length; i++) {
const f = await this.folderService.encrypt(importResult.folders[i]);
const f = await importResult.folders[i].encrypt(this.cryptoService);
request.folders.push(new FolderRequest(f));
}
}