export file format option

This commit is contained in:
Kyle Spearrin 2018-12-17 10:36:40 -05:00
parent 33deb4cda6
commit 920ce30dd0
3 changed files with 15 additions and 8 deletions

2
jslib

@ -1 +1 @@
Subproject commit 94f103c474655a81f43ad1f108b4408e4ffdcc17 Subproject commit e7b5868aadf8412f49bfaba378d05c692124e265

View File

@ -28,16 +28,17 @@ export class ExportCommand {
const keyHash = await this.cryptoService.hashPassword(password, null); const keyHash = await this.cryptoService.hashPassword(password, null);
const storedKeyHash = await this.cryptoService.getKeyHash(); const storedKeyHash = await this.cryptoService.getKeyHash();
if (storedKeyHash != null && keyHash != null && storedKeyHash === keyHash) { if (storedKeyHash != null && keyHash != null && storedKeyHash === keyHash) {
const csv = await this.exportService.getExport('csv'); const format = cmd.format !== 'json' ? 'csv' : 'json';
return await this.saveFile(csv, cmd); const csv = await this.exportService.getExport(format);
return await this.saveFile(csv, cmd, format);
} else { } else {
return Response.error('Invalid master password.'); return Response.error('Invalid master password.');
} }
} }
async saveFile(csv: string, cmd: program.Command): Promise<Response> { async saveFile(csv: string, cmd: program.Command, format: string): Promise<Response> {
try { try {
const filePath = await CliUtils.saveFile(csv, cmd.output, this.exportService.getFileName()); const filePath = await CliUtils.saveFile(csv, cmd.output, this.exportService.getFileName(null, format));
const res = new MessageResponse('Saved ' + filePath, null); const res = new MessageResponse('Saved ' + filePath, null);
res.raw = filePath; res.raw = filePath;
return Response.success(res); return Response.success(res);

View File

@ -429,15 +429,21 @@ export class Program {
program program
.command('export [password]') .command('export [password]')
.description('Export vault data to a CSV file.') .description('Export vault data to a CSV or JSON file.')
.option('--output <output>', 'Output directory or filename.') .option('--output <output>', 'Output directory or filename.')
.option('--format <format>', 'Export file format.')
.on('--help', () => { .on('--help', () => {
writeLn('\n Examples:'); writeLn('\n Notes:');
writeLn('');
writeLn(' Valid formats are `csv` and `json`. Default format is `csv`.');
writeLn('');
writeLn(' Examples:');
writeLn(''); writeLn('');
writeLn(' bw export'); writeLn(' bw export');
writeLn(' bw export myPassword321'); writeLn(' bw export myPassword321');
writeLn(' bw export myPassword321 --format json');
writeLn(' bw export --output ./exp/bw.csv'); writeLn(' bw export --output ./exp/bw.csv');
writeLn(' bw export myPassword321 --output bw.csv'); writeLn(' bw export myPassword321 --output bw.json --format json');
writeLn('', true); writeLn('', true);
}) })
.action(async (password, cmd) => { .action(async (password, cmd) => {