mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-12 19:50:46 +01:00
password dragon xml importer
This commit is contained in:
parent
0c9fd975f7
commit
17d50fc90c
80
src/importers/passwordDragonXmlImporter.ts
Normal file
80
src/importers/passwordDragonXmlImporter.ts
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
import { BaseImporter } from './baseImporter';
|
||||||
|
import { Importer } from './importer';
|
||||||
|
|
||||||
|
import { ImportResult } from '../models/domain/importResult';
|
||||||
|
|
||||||
|
import { FolderView } from '../models/view/folderView';
|
||||||
|
|
||||||
|
export class PasswordDragonXmlImporter extends BaseImporter implements Importer {
|
||||||
|
parse(data: string): ImportResult {
|
||||||
|
const result = new ImportResult();
|
||||||
|
const doc = this.parseXml(data);
|
||||||
|
if (doc == null) {
|
||||||
|
result.success = false;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
const records = doc.querySelectorAll('PasswordManager > record');
|
||||||
|
Array.from(records).forEach((record) => {
|
||||||
|
const category = this.querySelectorDirectChild(record, 'Category');
|
||||||
|
|
||||||
|
let folderIndex = result.folders.length;
|
||||||
|
const hasFolder = category != null && !this.isNullOrWhitespace(category.textContent) &&
|
||||||
|
category.textContent !== 'Unfiled';
|
||||||
|
let addFolder = hasFolder;
|
||||||
|
|
||||||
|
if (hasFolder) {
|
||||||
|
for (let i = 0; i < result.folders.length; i++) {
|
||||||
|
if (result.folders[i].name === category.textContent) {
|
||||||
|
addFolder = false;
|
||||||
|
folderIndex = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (addFolder) {
|
||||||
|
const f = new FolderView();
|
||||||
|
f.name = category.textContent;
|
||||||
|
result.folders.push(f);
|
||||||
|
}
|
||||||
|
if (hasFolder) {
|
||||||
|
result.folderRelationships.push([result.ciphers.length, folderIndex]);
|
||||||
|
}
|
||||||
|
|
||||||
|
const accountName = this.querySelectorDirectChild(record, 'Account-Name');
|
||||||
|
const userId = this.querySelectorDirectChild(record, 'User-Id');
|
||||||
|
const password = this.querySelectorDirectChild(record, 'Password');
|
||||||
|
const url = this.querySelectorDirectChild(record, 'URL');
|
||||||
|
const notes = this.querySelectorDirectChild(record, 'Notes');
|
||||||
|
const cipher = this.initLoginCipher();
|
||||||
|
cipher.name = accountName != null ? this.getValueOrDefault(accountName.textContent, '--') : '--';
|
||||||
|
cipher.notes = notes != null ? this.getValueOrDefault(notes.textContent) : '';
|
||||||
|
cipher.login.username = userId != null ? this.getValueOrDefault(userId.textContent) : null;
|
||||||
|
cipher.login.password = password != null ? this.getValueOrDefault(password.textContent) : null;
|
||||||
|
cipher.login.uris = url != null ? this.makeUriArray(url.textContent) : null;
|
||||||
|
|
||||||
|
const attributes: string[] = [];
|
||||||
|
for (let i = 1; i <= 10; i++) {
|
||||||
|
attributes.push('Attribute-' + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.querySelectorAllDirectChild(record, attributes.join(',')).forEach((attr) => {
|
||||||
|
if (this.isNullOrWhitespace(attr.textContent) || attr.textContent === 'null') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.processKvp(cipher, attr.tagName, attr.textContent);
|
||||||
|
});
|
||||||
|
|
||||||
|
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