mirror of
https://github.com/bitwarden/browser.git
synced 2024-11-27 12:36:14 +01:00
padlock importer. move relationships to arrays
This commit is contained in:
parent
a6a0673af8
commit
4004449aa8
@ -10,6 +10,8 @@ import { Utils } from '../misc/utils';
|
|||||||
export abstract class BaseImporter {
|
export abstract class BaseImporter {
|
||||||
organization = false;
|
organization = false;
|
||||||
|
|
||||||
|
protected newLineRegex = /(?:\r\n|\r|\n)/;
|
||||||
|
|
||||||
protected passwordFieldNames = [
|
protected passwordFieldNames = [
|
||||||
'password', 'pass word', 'passphrase', 'pass phrase',
|
'password', 'pass word', 'passphrase', 'pass phrase',
|
||||||
'pass', 'code', 'code word', 'codeword',
|
'pass', 'code', 'code word', 'codeword',
|
||||||
@ -145,7 +147,7 @@ export abstract class BaseImporter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected splitNewLine(str: string): string[] {
|
protected splitNewLine(str: string): string[] {
|
||||||
return str.split(/(?:\r\n|\r|\n)/);
|
return str.split(this.newLineRegex);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ref https://stackoverflow.com/a/5911300
|
// ref https://stackoverflow.com/a/5911300
|
||||||
@ -207,13 +209,13 @@ export abstract class BaseImporter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected moveFoldersToCollections(result: ImportResult) {
|
protected moveFoldersToCollections(result: ImportResult) {
|
||||||
result.folderRelationships.forEach((value, key) => result.collectionRelationships.set(key, value));
|
result.folderRelationships.forEach((r) => result.collectionRelationships.push(r));
|
||||||
result.collections = result.folders.map((f) => {
|
result.collections = result.folders.map((f) => {
|
||||||
const collection = new CollectionView();
|
const collection = new CollectionView();
|
||||||
collection.name = f.name;
|
collection.name = f.name;
|
||||||
return collection;
|
return collection;
|
||||||
});
|
});
|
||||||
result.folderRelationships = new Map<number, number>();
|
result.folderRelationships = [];
|
||||||
result.folders = [];
|
result.folders = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,11 +44,11 @@ export class BitwardenCsvImporter extends BaseImporter implements Importer {
|
|||||||
result.collections.push(collection);
|
result.collections.push(collection);
|
||||||
}
|
}
|
||||||
|
|
||||||
result.collectionRelationships.set(result.ciphers.length, collectionIndex);
|
result.collectionRelationships.push([result.ciphers.length, collectionIndex]);
|
||||||
});
|
});
|
||||||
} else if (!this.organization) {
|
} else if (!this.organization) {
|
||||||
let folderIndex = result.folders.length;
|
let folderIndex = result.folders.length;
|
||||||
const hasFolder = !this.organization && !this.isNullOrWhitespace(value.folder);
|
const hasFolder = !this.isNullOrWhitespace(value.folder);
|
||||||
let addFolder = hasFolder;
|
let addFolder = hasFolder;
|
||||||
|
|
||||||
if (hasFolder) {
|
if (hasFolder) {
|
||||||
@ -68,7 +68,7 @@ export class BitwardenCsvImporter extends BaseImporter implements Importer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (hasFolder) {
|
if (hasFolder) {
|
||||||
result.folderRelationships.set(result.ciphers.length, folderIndex);
|
result.folderRelationships.push([result.ciphers.length, folderIndex]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ export class KeePassXCsvImporter extends BaseImporter implements Importer {
|
|||||||
result.folders.push(f);
|
result.folders.push(f);
|
||||||
}
|
}
|
||||||
if (hasFolder) {
|
if (hasFolder) {
|
||||||
result.folderRelationships.set(result.ciphers.length, folderIndex);
|
result.folderRelationships.push([result.ciphers.length, folderIndex]);
|
||||||
}
|
}
|
||||||
|
|
||||||
const cipher = new CipherView();
|
const cipher = new CipherView();
|
||||||
|
@ -76,7 +76,7 @@ export class LastPassCsvImporter extends BaseImporter implements Importer {
|
|||||||
result.folders.push(f);
|
result.folders.push(f);
|
||||||
}
|
}
|
||||||
if (hasFolder) {
|
if (hasFolder) {
|
||||||
result.folderRelationships.set(cipherIndex, folderIndex);
|
result.folderRelationships.push([cipherIndex, folderIndex]);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
135
src/importers/padlockCsvImporter.ts
Normal file
135
src/importers/padlockCsvImporter.ts
Normal file
@ -0,0 +1,135 @@
|
|||||||
|
import { BaseImporter } from './baseImporter';
|
||||||
|
import { Importer } from './importer';
|
||||||
|
|
||||||
|
import { ImportResult } from '../models/domain/importResult';
|
||||||
|
|
||||||
|
import { CipherView } from '../models/view/cipherView';
|
||||||
|
import { CollectionView } from '../models/view/collectionView';
|
||||||
|
import { FieldView } from '../models/view/fieldView';
|
||||||
|
import { FolderView } from '../models/view/folderView';
|
||||||
|
import { LoginView } from '../models/view/loginView';
|
||||||
|
|
||||||
|
import { CipherType } from '../enums/cipherType';
|
||||||
|
import { FieldType } from '../enums/fieldType';
|
||||||
|
|
||||||
|
export class PadlockCsvImporter 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;
|
||||||
|
}
|
||||||
|
|
||||||
|
let headers: string[] = null;
|
||||||
|
results.forEach((value) => {
|
||||||
|
if (headers == null) {
|
||||||
|
headers = value.map((v: string) => v);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (value.length < 2 || value.length !== headers.length) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this.isNullOrWhitespace(value[1])) {
|
||||||
|
if (this.organization) {
|
||||||
|
const tags = (value[1] as string).split(',');
|
||||||
|
tags.forEach((tag) => {
|
||||||
|
tag = tag.trim();
|
||||||
|
let addCollection = true;
|
||||||
|
let collectionIndex = result.collections.length;
|
||||||
|
|
||||||
|
for (let i = 0; i < result.collections.length; i++) {
|
||||||
|
if (result.collections[i].name === tag) {
|
||||||
|
addCollection = false;
|
||||||
|
collectionIndex = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (addCollection) {
|
||||||
|
const collection = new CollectionView();
|
||||||
|
collection.name = tag;
|
||||||
|
result.collections.push(collection);
|
||||||
|
}
|
||||||
|
|
||||||
|
result.collectionRelationships.push([result.ciphers.length, collectionIndex]);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
const tags = (value[1] as string).split(',');
|
||||||
|
let folderIndex = result.folders.length;
|
||||||
|
const hasFolder = tags.length > 0 && !this.isNullOrWhitespace(tags[0].trim());
|
||||||
|
let addFolder = hasFolder;
|
||||||
|
const tag = tags[0].trim();
|
||||||
|
|
||||||
|
if (hasFolder) {
|
||||||
|
for (let i = 0; i < result.folders.length; i++) {
|
||||||
|
if (result.folders[i].name === tag) {
|
||||||
|
addFolder = false;
|
||||||
|
folderIndex = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (addFolder) {
|
||||||
|
const f = new FolderView();
|
||||||
|
f.name = tag;
|
||||||
|
result.folders.push(f);
|
||||||
|
}
|
||||||
|
if (hasFolder) {
|
||||||
|
result.folderRelationships.push([result.ciphers.length, folderIndex]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const cipher = new CipherView();
|
||||||
|
cipher.type = CipherType.Login;
|
||||||
|
cipher.favorite = false;
|
||||||
|
cipher.notes = '';
|
||||||
|
cipher.fields = [];
|
||||||
|
cipher.name = this.getValueOrDefault(value[0], '--');
|
||||||
|
cipher.login = new LoginView();
|
||||||
|
|
||||||
|
for (let i = 2; i < value.length; i++) {
|
||||||
|
const header = headers[i].trim().toLowerCase();
|
||||||
|
if (this.isNullOrWhitespace(value[i]) || this.isNullOrWhitespace(header)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.usernameFieldNames.indexOf(header) > -1) {
|
||||||
|
cipher.login.username = value[i];
|
||||||
|
} else if (this.passwordFieldNames.indexOf(header) > -1) {
|
||||||
|
cipher.login.password = value[i];
|
||||||
|
} else if (this.uriFieldNames.indexOf(header) > -1) {
|
||||||
|
cipher.login.uris = this.makeUriArray(value[i]);
|
||||||
|
} else {
|
||||||
|
if (value[i].length > 200 || value[i].search(this.newLineRegex) > -1) {
|
||||||
|
cipher.notes += (headers[i] + ': ' + value[i] + '\n');
|
||||||
|
} else {
|
||||||
|
const field = new FieldView();
|
||||||
|
field.type = FieldType.Text;
|
||||||
|
field.name = headers[i];
|
||||||
|
field.value = value[i];
|
||||||
|
cipher.fields.push(field);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.isNullOrWhitespace(cipher.notes)) {
|
||||||
|
cipher.notes = null;
|
||||||
|
} else {
|
||||||
|
cipher.notes = cipher.notes.trim();
|
||||||
|
}
|
||||||
|
if (cipher.fields.length === 0) {
|
||||||
|
cipher.fields = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
result.ciphers.push(cipher);
|
||||||
|
});
|
||||||
|
|
||||||
|
result.success = true;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
@ -51,7 +51,7 @@ export class SafeInCloudXmlImporter extends BaseImporter implements Importer {
|
|||||||
if (labelIdEl != null) {
|
if (labelIdEl != null) {
|
||||||
const labelId = labelIdEl.textContent;
|
const labelId = labelIdEl.textContent;
|
||||||
if (!this.isNullOrWhitespace(labelId) && foldersMap.has(labelId)) {
|
if (!this.isNullOrWhitespace(labelId) && foldersMap.has(labelId)) {
|
||||||
result.folderRelationships.set(result.ciphers.length, foldersMap.get(labelId));
|
result.folderRelationships.push([result.ciphers.length, foldersMap.get(labelId)]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@ export class ImportResult {
|
|||||||
errorMessage: string;
|
errorMessage: string;
|
||||||
ciphers: CipherView[] = [];
|
ciphers: CipherView[] = [];
|
||||||
folders: FolderView[] = [];
|
folders: FolderView[] = [];
|
||||||
folderRelationships: Map<number, number> = new Map<number, number>();
|
folderRelationships: Array<[number, number]> = [];
|
||||||
collections: CollectionView[] = [];
|
collections: CollectionView[] = [];
|
||||||
collectionRelationships: Map<number, number> = new Map<number, number>();
|
collectionRelationships: Array<[number, number]> = [];
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user