mirror of
https://github.com/bitwarden/browser.git
synced 2024-12-22 16:29:09 +01:00
[EC-417] Extracting the app name from the Android user item on CSV import (#3254)
* [EC-417] Extracting the app name from the Android user item on CSV import * [EC-417] Updated android csv pattern to match starting with 'android://' * [EC-417] Added unit tests for ChromeCsvImporter
This commit is contained in:
parent
321aee1625
commit
754ea1e09a
72
libs/common/spec/importers/chromeCsvImporter.spec.ts
Normal file
72
libs/common/spec/importers/chromeCsvImporter.spec.ts
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
import { ChromeCsvImporter as Importer } from "@bitwarden/common/importers/chromeCsvImporter";
|
||||||
|
import { CipherView } from "@bitwarden/common/models/view/cipherView";
|
||||||
|
import { LoginUriView } from "@bitwarden/common/models/view/loginUriView";
|
||||||
|
import { LoginView } from "@bitwarden/common/models/view/loginView";
|
||||||
|
|
||||||
|
import { data as androidData } from "./testData/chromeCsv/androidData.csv";
|
||||||
|
import { data as simplePasswordData } from "./testData/chromeCsv/simplePasswordData.csv";
|
||||||
|
|
||||||
|
const CipherData = [
|
||||||
|
{
|
||||||
|
title: "should parse app name",
|
||||||
|
csv: androidData,
|
||||||
|
expected: Object.assign(new CipherView(), {
|
||||||
|
id: null,
|
||||||
|
organizationId: null,
|
||||||
|
folderId: null,
|
||||||
|
name: "com.xyz.example.app.android",
|
||||||
|
login: Object.assign(new LoginView(), {
|
||||||
|
username: "username@example.com",
|
||||||
|
password: "Qh6W4Wz55YGFNU",
|
||||||
|
uris: [
|
||||||
|
Object.assign(new LoginUriView(), {
|
||||||
|
uri: "android://N2H9MndUUUt3JuQSWAKexOU9oJLJeHR4nyUGac5E1TXKppkY7xtdRl6l8vKo1hQWCqAEy4gsNLUBIbVxpdmhOP==@com.xyz.example.app.android/",
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
}),
|
||||||
|
notes: null,
|
||||||
|
type: 1,
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: "should parse password",
|
||||||
|
csv: simplePasswordData,
|
||||||
|
expected: Object.assign(new CipherView(), {
|
||||||
|
id: null,
|
||||||
|
organizationId: null,
|
||||||
|
folderId: null,
|
||||||
|
name: "www.example.com",
|
||||||
|
login: Object.assign(new LoginView(), {
|
||||||
|
username: "username@example.com",
|
||||||
|
password: "wpC9qFvsbWQK5Z",
|
||||||
|
uris: [
|
||||||
|
Object.assign(new LoginUriView(), {
|
||||||
|
uri: "https://www.example.com/",
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
}),
|
||||||
|
notes: null,
|
||||||
|
type: 1,
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
describe("Chrome CSV Importer", () => {
|
||||||
|
CipherData.forEach((data) => {
|
||||||
|
it(data.title, async () => {
|
||||||
|
const importer = new Importer();
|
||||||
|
const result = await importer.parse(data.csv);
|
||||||
|
expect(result != null).toBe(true);
|
||||||
|
expect(result.ciphers.length).toBeGreaterThan(0);
|
||||||
|
|
||||||
|
const cipher = result.ciphers.shift();
|
||||||
|
let property: keyof typeof data.expected;
|
||||||
|
for (property in data.expected) {
|
||||||
|
if (Object.prototype.hasOwnProperty.call(data.expected, property)) {
|
||||||
|
expect(Object.prototype.hasOwnProperty.call(cipher, property)).toBe(true);
|
||||||
|
expect(cipher[property]).toEqual(data.expected[property]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,2 @@
|
|||||||
|
export const data = `name,url,username,password
|
||||||
|
,android://N2H9MndUUUt3JuQSWAKexOU9oJLJeHR4nyUGac5E1TXKppkY7xtdRl6l8vKo1hQWCqAEy4gsNLUBIbVxpdmhOP==@com.xyz.example.app.android/,username@example.com,Qh6W4Wz55YGFNU`;
|
@ -0,0 +1,2 @@
|
|||||||
|
export const data = `name,url,username,password
|
||||||
|
www.example.com,https://www.example.com/,username@example.com,wpC9qFvsbWQK5Z`;
|
@ -4,6 +4,8 @@ import { BaseImporter } from "./baseImporter";
|
|||||||
import { Importer } from "./importer";
|
import { Importer } from "./importer";
|
||||||
|
|
||||||
export class ChromeCsvImporter extends BaseImporter implements Importer {
|
export class ChromeCsvImporter extends BaseImporter implements Importer {
|
||||||
|
private androidPatternRegex = new RegExp("^android:\\/\\/.*(?<=@)(.*)(?=\\/)");
|
||||||
|
|
||||||
parse(data: string): Promise<ImportResult> {
|
parse(data: string): Promise<ImportResult> {
|
||||||
const result = new ImportResult();
|
const result = new ImportResult();
|
||||||
const results = this.parseCsv(data, true);
|
const results = this.parseCsv(data, true);
|
||||||
@ -14,7 +16,11 @@ export class ChromeCsvImporter extends BaseImporter implements Importer {
|
|||||||
|
|
||||||
results.forEach((value) => {
|
results.forEach((value) => {
|
||||||
const cipher = this.initLoginCipher();
|
const cipher = this.initLoginCipher();
|
||||||
cipher.name = this.getValueOrDefault(value.name, "--");
|
let name = value.name;
|
||||||
|
if (!name && this.androidPatternRegex.test(value.url)) {
|
||||||
|
name = value.url.match(this.androidPatternRegex)[1];
|
||||||
|
}
|
||||||
|
cipher.name = this.getValueOrDefault(name, "--");
|
||||||
cipher.login.username = this.getValueOrDefault(value.username);
|
cipher.login.username = this.getValueOrDefault(value.username);
|
||||||
cipher.login.password = this.getValueOrDefault(value.password);
|
cipher.login.password = this.getValueOrDefault(value.password);
|
||||||
cipher.login.uris = this.makeUriArray(value.url);
|
cipher.login.uris = this.makeUriArray(value.url);
|
||||||
|
Loading…
Reference in New Issue
Block a user