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

[PS-1805] BEEEP: Renamed importers based on agreed naming-convention (#3978)

* Rename all importer related files

Renamed all files based on our naming convention which we decided on with https://github.com/bitwarden/adr/blob/master/decisions/0012-angular-filename-convention.md

* Removed entries from whitelist-capital-letters.txt

* Rename missing safeInCloud test data

* Fix broken import

* Renamed folders (removed capital letters)

* Fix filename of BitwardenCsvImporter

* Fix imports of onepassword mac/win importer tests

* Remove already renamed folders from whitelist

* Rename dashlaneImporters to dashlane

Rename the folder
Fix all the imports
Remove dashlaneImporters from white-list

* Rename keeperImporters to keeper

Rename the folder
Fix all the imports
Remove keeperImporters from white-list

* Rename onepasswordImporters to onepassword

Rename the folder
Fix all the imports
Remove onepasswordImporters from white-list

* Rename safeinCloud test data folder

* Fix onepassword importer type imports
This commit is contained in:
Daniel James Smith
2022-11-11 16:20:03 +01:00
committed by GitHub
parent 235fb8f6ee
commit 0e78910582
141 changed files with 217 additions and 354 deletions

View File

@@ -0,0 +1,81 @@
import { ImportResult } from "../models/domain/import-result";
import { CipherView } from "../models/view/cipher.view";
import { BaseImporter } from "./base-importer";
import { Importer } from "./importer";
export class ZohoVaultCsvImporter extends BaseImporter implements Importer {
parse(data: string): Promise<ImportResult> {
const result = new ImportResult();
const results = this.parseCsv(data, true);
if (results == null) {
result.success = false;
return Promise.resolve(result);
}
results.forEach((value) => {
if (
this.isNullOrWhitespace(value["Password Name"]) &&
this.isNullOrWhitespace(value["Secret Name"])
) {
return;
}
this.processFolder(result, this.getValueOrDefault(value.ChamberName));
const cipher = this.initLoginCipher();
cipher.favorite = this.getValueOrDefault(value.Favorite, "0") === "1";
cipher.notes = this.getValueOrDefault(value.Notes);
cipher.name = this.getValueOrDefault(
value["Password Name"],
this.getValueOrDefault(value["Secret Name"], "--")
);
cipher.login.uris = this.makeUriArray(
this.getValueOrDefault(value["Password URL"], this.getValueOrDefault(value["Secret URL"]))
);
this.parseData(cipher, value.SecretData);
this.parseData(cipher, value.CustomData);
this.convertToNoteIfNeeded(cipher);
this.cleanupCipher(cipher);
result.ciphers.push(cipher);
});
if (this.organization) {
this.moveFoldersToCollections(result);
}
result.success = true;
return Promise.resolve(result);
}
private parseData(cipher: CipherView, data: string) {
if (this.isNullOrWhitespace(data)) {
return;
}
const dataLines = this.splitNewLine(data);
dataLines.forEach((line) => {
const delimPosition = line.indexOf(":");
if (delimPosition < 0) {
return;
}
const field = line.substring(0, delimPosition);
const value = line.length > delimPosition ? line.substring(delimPosition + 1) : null;
if (
this.isNullOrWhitespace(field) ||
this.isNullOrWhitespace(value) ||
field === "SecretType"
) {
return;
}
const fieldLower = field.toLowerCase();
if (cipher.login.username == null && this.usernameFieldNames.indexOf(fieldLower) > -1) {
cipher.login.username = value;
} else if (
cipher.login.password == null &&
this.passwordFieldNames.indexOf(fieldLower) > -1
) {
cipher.login.password = value;
} else {
this.processKvp(cipher, field, value);
}
});
}
}