mirror of
https://github.com/bitwarden/browser.git
synced 2024-12-26 17:08:33 +01:00
kepper csv importer
This commit is contained in:
parent
ef75dc735e
commit
0c9fd975f7
@ -271,7 +271,7 @@ export abstract class BaseImporter {
|
|||||||
if (this.isNullOrWhitespace(key)) {
|
if (this.isNullOrWhitespace(key)) {
|
||||||
key = '';
|
key = '';
|
||||||
}
|
}
|
||||||
if (value.length > 200 || value.search(this.newLineRegex) > -1) {
|
if (value.length > 200 || value.trim().search(this.newLineRegex) > -1) {
|
||||||
if (cipher.notes == null) {
|
if (cipher.notes == null) {
|
||||||
cipher.notes = '';
|
cipher.notes = '';
|
||||||
}
|
}
|
||||||
|
70
src/importers/keeperCsvImporter.ts
Normal file
70
src/importers/keeperCsvImporter.ts
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
import { BaseImporter } from './baseImporter';
|
||||||
|
import { Importer } from './importer';
|
||||||
|
|
||||||
|
import { ImportResult } from '../models/domain/importResult';
|
||||||
|
|
||||||
|
import { FolderView } from '../models/view/folderView';
|
||||||
|
|
||||||
|
export class KeeperCsvImporter extends BaseImporter implements Importer {
|
||||||
|
parse(data: string): ImportResult {
|
||||||
|
const result = new ImportResult();
|
||||||
|
const results = this.parseCsv(data, false);
|
||||||
|
if (results == null) {
|
||||||
|
result.success = false;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
results.forEach((value) => {
|
||||||
|
if (value.length < 6) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let folderIndex = result.folders.length;
|
||||||
|
const hasFolder = !this.isNullOrWhitespace(value[0]);
|
||||||
|
let addFolder = hasFolder;
|
||||||
|
|
||||||
|
if (hasFolder) {
|
||||||
|
for (let i = 0; i < result.folders.length; i++) {
|
||||||
|
if (result.folders[i].name === value[0]) {
|
||||||
|
addFolder = false;
|
||||||
|
folderIndex = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (addFolder) {
|
||||||
|
const f = new FolderView();
|
||||||
|
f.name = value[0];
|
||||||
|
result.folders.push(f);
|
||||||
|
}
|
||||||
|
if (hasFolder) {
|
||||||
|
result.folderRelationships.push([result.ciphers.length, folderIndex]);
|
||||||
|
}
|
||||||
|
|
||||||
|
const cipher = this.initLoginCipher();
|
||||||
|
cipher.notes = this.getValueOrDefault(value[5]) + '\n';
|
||||||
|
cipher.name = this.getValueOrDefault(value[1], '--');
|
||||||
|
cipher.login.username = this.getValueOrDefault(value[2]);
|
||||||
|
cipher.login.password = this.getValueOrDefault(value[3]);
|
||||||
|
cipher.login.uris = this.makeUriArray(value[4]);
|
||||||
|
|
||||||
|
if (value.length > 7) {
|
||||||
|
// we have some custom fields.
|
||||||
|
for (let i = 7; i < value.length; i = i + 2) {
|
||||||
|
this.processKvp(cipher, value[i], value[i + 1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.cleanupCipher(cipher);
|
||||||
|
result.ciphers.push(cipher);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (this.organization) {
|
||||||
|
this.moveFoldersToCollections(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
result.success = true;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user