mirror of
https://github.com/bitwarden/browser
synced 2025-12-18 17:23:37 +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:
committed by
GitHub
parent
235fb8f6ee
commit
0e78910582
52
libs/common/src/importers/passwordagent-csv-importer.ts
Normal file
52
libs/common/src/importers/passwordagent-csv-importer.ts
Normal file
@@ -0,0 +1,52 @@
|
||||
import { ImportResult } from "../models/domain/import-result";
|
||||
|
||||
import { BaseImporter } from "./base-importer";
|
||||
import { Importer } from "./importer";
|
||||
|
||||
export class PasswordAgentCsvImporter extends BaseImporter implements Importer {
|
||||
parse(data: string): Promise<ImportResult> {
|
||||
const result = new ImportResult();
|
||||
const results = this.parseCsv(data, false);
|
||||
if (results == null) {
|
||||
result.success = false;
|
||||
return Promise.resolve(result);
|
||||
}
|
||||
|
||||
let newVersion = true;
|
||||
results.forEach((value) => {
|
||||
if (value.length !== 5 && value.length < 9) {
|
||||
return;
|
||||
}
|
||||
const altFormat = value.length === 10 && value[0] === "0";
|
||||
const cipher = this.initLoginCipher();
|
||||
cipher.name = this.getValueOrDefault(value[altFormat ? 1 : 0], "--");
|
||||
cipher.login.username = this.getValueOrDefault(value[altFormat ? 2 : 1]);
|
||||
cipher.login.password = this.getValueOrDefault(value[altFormat ? 3 : 2]);
|
||||
if (value.length === 5) {
|
||||
newVersion = false;
|
||||
cipher.notes = this.getValueOrDefault(value[4]);
|
||||
cipher.login.uris = this.makeUriArray(value[3]);
|
||||
} else {
|
||||
const folder = this.getValueOrDefault(value[altFormat ? 9 : 8], "(None)");
|
||||
let folderName = folder !== "(None)" ? folder.split("\\").join("/") : null;
|
||||
if (folderName != null) {
|
||||
folderName = folder.split(" > ").join("/");
|
||||
folderName = folder.split(">").join("/");
|
||||
}
|
||||
this.processFolder(result, folderName);
|
||||
cipher.notes = this.getValueOrDefault(value[altFormat ? 5 : 3]);
|
||||
cipher.login.uris = this.makeUriArray(value[4]);
|
||||
}
|
||||
this.convertToNoteIfNeeded(cipher);
|
||||
this.cleanupCipher(cipher);
|
||||
result.ciphers.push(cipher);
|
||||
});
|
||||
|
||||
if (newVersion && this.organization) {
|
||||
this.moveFoldersToCollections(result);
|
||||
}
|
||||
|
||||
result.success = true;
|
||||
return Promise.resolve(result);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user