mirror of
https://github.com/bitwarden/browser
synced 2026-02-21 11:54:02 +00:00
* add generic `union-of-values` helper * migrate `GeneratorDialogAction` to a constant * migrate `VaultState` to a constant * migrate `AtRiskCarouselDialogResult` to a constant * migrate `CredentialGeneratorDialogAction` to a constant * migrate `FolderAddEditDialogResult` to a constant * migrate `ViewCipherDialogResult` to a constant * migrate `VisibleVaultBanner` to a constant * migrate `VaultFilterLabel` to a constant * migrate `WebVaultGeneratorDialogResult` to a constant * migrate `BulkDeleteDialogResult` to a constant * migrate `BulkMoveDialogResult` to a constant * migrate `AddEditCipherDialogResult` to a constant * migrate `VaultItemDialogResult` to a constant * migrate `BrowserPromptState` to a constant * migrate `NudgeType` to a constant * migrate `SecurityTaskStatus` to a constant * migrate `CipherRepromptType` to a constant * migrate `SecureNoteType` to a constant * migrate `FieldType` to a constant * migrate `LinkedIdType` to a constant * migrate `CollectionAssignmentResult` to a constant * migrate `AddEditFolderDialogResult` to a constant * migrate `AttachmentDialogResult` to a constant * fix CipherType in delete organization dialog * fix `in` statement in VaultFilter * Fix build errors across enum updates * fix two more CipherType castings * update CipherResponse `CipherType` * define type for `fieldType` parameter * refine how `cipherTypeNames` is generated and add utility function for grabbing cipher type name * use `CipherType` rather than `number` * add stricter typing for `FieldType` * add fixme for `CipherType` to be ADR-0025 compliant * remove error throw for `toCipherTypeName` and instead update typing to have `| undefined` * add helpers for CipherType conversions * prefer `undefined`
106 lines
3.4 KiB
TypeScript
106 lines
3.4 KiB
TypeScript
// FIXME: Update this file to be type safe and remove this and next line
|
|
// @ts-strict-ignore
|
|
import { Jsonify } from "type-fest";
|
|
|
|
import { CipherRepromptType } from "../../enums/cipher-reprompt-type";
|
|
import { CipherType } from "../../enums/cipher-type";
|
|
import { CipherPermissionsApi } from "../api/cipher-permissions.api";
|
|
import { CipherResponse } from "../response/cipher.response";
|
|
|
|
import { AttachmentData } from "./attachment.data";
|
|
import { CardData } from "./card.data";
|
|
import { FieldData } from "./field.data";
|
|
import { IdentityData } from "./identity.data";
|
|
import { LoginData } from "./login.data";
|
|
import { PasswordHistoryData } from "./password-history.data";
|
|
import { SecureNoteData } from "./secure-note.data";
|
|
import { SshKeyData } from "./ssh-key.data";
|
|
|
|
export class CipherData {
|
|
id: string;
|
|
organizationId: string;
|
|
folderId: string;
|
|
edit: boolean;
|
|
viewPassword: boolean;
|
|
permissions: CipherPermissionsApi;
|
|
organizationUseTotp: boolean;
|
|
favorite: boolean;
|
|
revisionDate: string;
|
|
type: CipherType;
|
|
name: string;
|
|
notes: string;
|
|
login?: LoginData;
|
|
secureNote?: SecureNoteData;
|
|
card?: CardData;
|
|
identity?: IdentityData;
|
|
sshKey?: SshKeyData;
|
|
fields?: FieldData[];
|
|
attachments?: AttachmentData[];
|
|
passwordHistory?: PasswordHistoryData[];
|
|
collectionIds?: string[];
|
|
creationDate: string;
|
|
deletedDate: string | null;
|
|
reprompt: CipherRepromptType;
|
|
key: string;
|
|
|
|
constructor(response?: CipherResponse, collectionIds?: string[]) {
|
|
if (response == null) {
|
|
return;
|
|
}
|
|
|
|
this.id = response.id;
|
|
this.organizationId = response.organizationId;
|
|
this.folderId = response.folderId;
|
|
this.edit = response.edit;
|
|
this.viewPassword = response.viewPassword;
|
|
this.permissions = response.permissions;
|
|
this.organizationUseTotp = response.organizationUseTotp;
|
|
this.favorite = response.favorite;
|
|
this.revisionDate = response.revisionDate;
|
|
this.type = response.type as CipherType;
|
|
this.name = response.name;
|
|
this.notes = response.notes;
|
|
this.collectionIds = collectionIds != null ? collectionIds : response.collectionIds;
|
|
this.creationDate = response.creationDate;
|
|
this.deletedDate = response.deletedDate;
|
|
this.reprompt = response.reprompt;
|
|
this.key = response.key;
|
|
|
|
switch (this.type) {
|
|
case CipherType.Login:
|
|
this.login = new LoginData(response.login);
|
|
break;
|
|
case CipherType.SecureNote:
|
|
this.secureNote = new SecureNoteData(response.secureNote);
|
|
break;
|
|
case CipherType.Card:
|
|
this.card = new CardData(response.card);
|
|
break;
|
|
case CipherType.Identity:
|
|
this.identity = new IdentityData(response.identity);
|
|
break;
|
|
case CipherType.SshKey:
|
|
this.sshKey = new SshKeyData(response.sshKey);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
if (response.fields != null) {
|
|
this.fields = response.fields.map((f) => new FieldData(f));
|
|
}
|
|
if (response.attachments != null) {
|
|
this.attachments = response.attachments.map((a) => new AttachmentData(a));
|
|
}
|
|
if (response.passwordHistory != null) {
|
|
this.passwordHistory = response.passwordHistory.map((ph) => new PasswordHistoryData(ph));
|
|
}
|
|
}
|
|
|
|
static fromJSON(obj: Jsonify<CipherData>) {
|
|
const result = Object.assign(new CipherData(), obj);
|
|
result.permissions = CipherPermissionsApi.fromJSON(obj.permissions);
|
|
return result;
|
|
}
|
|
}
|