mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-06 18:57:56 +01:00
session option, auth and locked checks
This commit is contained in:
parent
42819961b7
commit
892f13f8ee
@ -26,7 +26,12 @@ export class Program {
|
|||||||
run() {
|
run() {
|
||||||
program
|
program
|
||||||
.version(this.main.platformUtilsService.getApplicationVersion(), '-v, --version')
|
.version(this.main.platformUtilsService.getApplicationVersion(), '-v, --version')
|
||||||
.option('--pretty', 'Format stdout.');
|
.option('--pretty', 'Format stdout.')
|
||||||
|
.option('--session <session>', 'Session key.');
|
||||||
|
|
||||||
|
program.on('option:session', (key) => {
|
||||||
|
process.env.BW_SESSION = key;
|
||||||
|
});
|
||||||
|
|
||||||
program
|
program
|
||||||
.command('login [email] [password]')
|
.command('login [email] [password]')
|
||||||
@ -34,6 +39,7 @@ export class Program {
|
|||||||
.option('-m, --method <method>', 'Two-step login method.')
|
.option('-m, --method <method>', 'Two-step login method.')
|
||||||
.option('-c, --code <code>', 'Two-step login code.')
|
.option('-c, --code <code>', 'Two-step login code.')
|
||||||
.action(async (email: string, password: string, cmd: program.Command) => {
|
.action(async (email: string, password: string, cmd: program.Command) => {
|
||||||
|
await this.exitIfAuthed();
|
||||||
const command = new LoginCommand(this.main.authService, this.main.apiService,
|
const command = new LoginCommand(this.main.authService, this.main.apiService,
|
||||||
this.main.cryptoFunctionService);
|
this.main.cryptoFunctionService);
|
||||||
const response = await command.run(email, password, cmd);
|
const response = await command.run(email, password, cmd);
|
||||||
@ -43,7 +49,8 @@ export class Program {
|
|||||||
program
|
program
|
||||||
.command('logout')
|
.command('logout')
|
||||||
.description('Log out of the current Bitwarden user account.')
|
.description('Log out of the current Bitwarden user account.')
|
||||||
.action((cmd) => {
|
.action(async (cmd) => {
|
||||||
|
await this.exitIfNotAuthed();
|
||||||
// TODO
|
// TODO
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -66,6 +73,7 @@ export class Program {
|
|||||||
.description('Sync user\'s vault from server.')
|
.description('Sync user\'s vault from server.')
|
||||||
.option('-f, --force', 'Force a full sync.')
|
.option('-f, --force', 'Force a full sync.')
|
||||||
.action(async (cmd) => {
|
.action(async (cmd) => {
|
||||||
|
await this.exitIfLocked();
|
||||||
const command = new SyncCommand(this.main.syncService);
|
const command = new SyncCommand(this.main.syncService);
|
||||||
const response = await command.run(cmd);
|
const response = await command.run(cmd);
|
||||||
this.processResponse(response, cmd);
|
this.processResponse(response, cmd);
|
||||||
@ -75,6 +83,7 @@ export class Program {
|
|||||||
.command('list <object>')
|
.command('list <object>')
|
||||||
.description('List objects.')
|
.description('List objects.')
|
||||||
.action(async (object, cmd) => {
|
.action(async (object, cmd) => {
|
||||||
|
await this.exitIfLocked();
|
||||||
const command = new ListCommand(this.main.cipherService, this.main.folderService,
|
const command = new ListCommand(this.main.cipherService, this.main.folderService,
|
||||||
this.main.collectionService);
|
this.main.collectionService);
|
||||||
const response = await command.run(object, cmd);
|
const response = await command.run(object, cmd);
|
||||||
@ -85,6 +94,7 @@ export class Program {
|
|||||||
.command('get <object> [id]')
|
.command('get <object> [id]')
|
||||||
.description('Get an object.')
|
.description('Get an object.')
|
||||||
.action(async (object, id, cmd) => {
|
.action(async (object, id, cmd) => {
|
||||||
|
await this.exitIfLocked();
|
||||||
const command = new GetCommand(this.main.cipherService, this.main.folderService,
|
const command = new GetCommand(this.main.cipherService, this.main.folderService,
|
||||||
this.main.collectionService, this.main.totpService, this.main.syncService);
|
this.main.collectionService, this.main.totpService, this.main.syncService);
|
||||||
const response = await command.run(object, id, cmd);
|
const response = await command.run(object, id, cmd);
|
||||||
@ -95,6 +105,7 @@ export class Program {
|
|||||||
.command('create <object> <encodedData>')
|
.command('create <object> <encodedData>')
|
||||||
.description('Create an object.')
|
.description('Create an object.')
|
||||||
.action(async (object, encodedData, cmd) => {
|
.action(async (object, encodedData, cmd) => {
|
||||||
|
await this.exitIfLocked();
|
||||||
const command = new CreateCommand(this.main.cipherService, this.main.folderService);
|
const command = new CreateCommand(this.main.cipherService, this.main.folderService);
|
||||||
const response = await command.run(object, encodedData, cmd);
|
const response = await command.run(object, encodedData, cmd);
|
||||||
this.processResponse(response, cmd);
|
this.processResponse(response, cmd);
|
||||||
@ -104,6 +115,7 @@ export class Program {
|
|||||||
.command('edit <object> <id> <encodedData>')
|
.command('edit <object> <id> <encodedData>')
|
||||||
.description('Edit an object.')
|
.description('Edit an object.')
|
||||||
.action(async (object, id, encodedData, cmd) => {
|
.action(async (object, id, encodedData, cmd) => {
|
||||||
|
await this.exitIfLocked();
|
||||||
const command = new EditCommand(this.main.cipherService, this.main.folderService);
|
const command = new EditCommand(this.main.cipherService, this.main.folderService);
|
||||||
const response = await command.run(object, id, encodedData, cmd);
|
const response = await command.run(object, id, encodedData, cmd);
|
||||||
this.processResponse(response, cmd);
|
this.processResponse(response, cmd);
|
||||||
@ -113,6 +125,7 @@ export class Program {
|
|||||||
.command('delete <object> <id>')
|
.command('delete <object> <id>')
|
||||||
.description('Delete an object.')
|
.description('Delete an object.')
|
||||||
.action(async (object, id, cmd) => {
|
.action(async (object, id, cmd) => {
|
||||||
|
await this.exitIfLocked();
|
||||||
const command = new DeleteCommand(this.main.cipherService, this.main.folderService);
|
const command = new DeleteCommand(this.main.cipherService, this.main.folderService);
|
||||||
const response = await command.run(object, id, cmd);
|
const response = await command.run(object, id, cmd);
|
||||||
this.processResponse(response, cmd);
|
this.processResponse(response, cmd);
|
||||||
@ -174,4 +187,30 @@ export class Program {
|
|||||||
|
|
||||||
return this.hasGlobalOption(option, cmd.parent);
|
return this.hasGlobalOption(option, cmd.parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private async exitIfLocked() {
|
||||||
|
await this.exitIfNotAuthed();
|
||||||
|
const key = await this.main.cryptoService.getKey();
|
||||||
|
if (key == null) {
|
||||||
|
process.stdout.write(chalk.redBright('Vault is locked.'));
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private async exitIfAuthed() {
|
||||||
|
const authed = await this.main.userService.isAuthenticated();
|
||||||
|
if (authed) {
|
||||||
|
const email = await this.main.userService.getEmail();
|
||||||
|
process.stdout.write(chalk.redBright('You are already logged in as ' + email + '.'));
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private async exitIfNotAuthed() {
|
||||||
|
const authed = await this.main.userService.isAuthenticated();
|
||||||
|
if (!authed) {
|
||||||
|
process.stdout.write(chalk.redBright('You are not logged in.'));
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user