1
0
mirror of https://github.com/bitwarden/browser synced 2025-12-19 09:43:23 +00:00

list and get commands

This commit is contained in:
Kyle Spearrin
2018-05-14 13:37:52 -04:00
parent 2557f7239c
commit 3dd38cbe12
5 changed files with 150 additions and 11 deletions

View File

@@ -0,0 +1,93 @@
import * as program from 'commander';
import { CipherType } from 'jslib/enums/cipherType';
import { CipherService } from 'jslib/abstractions/cipher.service';
import { CollectionService } from 'jslib/abstractions/collection.service';
import { FolderService } from 'jslib/abstractions/folder.service';
import { TotpService } from 'jslib/abstractions/totp.service';
export class GetCommand {
constructor(private cipherService: CipherService, private folderService: FolderService,
private collectionService: CollectionService, private totpService: TotpService) { }
async run(object: string, id: string, cmd: program.Command) {
switch (object) {
case 'item':
await this.getCipher(id);
break;
case 'totp':
await this.getTotp(id);
break;
case 'folder':
await this.getFolder(id);
break;
case 'collection':
await this.getCollection(id);
break;
default:
console.log('Unknown object: ' + object);
break;
}
}
private async getCipher(id: string) {
const cipher = await this.cipherService.get(id);
if (cipher == null) {
console.log('Not found.');
return;
}
const decCipher = await cipher.decrypt();
console.log(JSON.stringify(decCipher));
}
private async getTotp(id: string) {
const cipher = await this.cipherService.get(id);
if (cipher == null) {
console.log('Not found.');
return;
}
if (cipher.type !== CipherType.Login) {
console.log('Not a login.');
return;
}
const decCipher = await cipher.decrypt();
if (decCipher.login.totp == null || decCipher.login.totp === '') {
console.log('No TOTP available.');
return;
}
const totp = await this.totpService.getCode(decCipher.login.totp);
if (totp == null) {
console.log('Couldn\'t generate TOTP code.');
return;
}
console.log(JSON.stringify(totp));
}
private async getFolder(id: string) {
const folder = await this.folderService.get(id);
if (folder == null) {
console.log('Not found.');
return;
}
const decFolder = await folder.decrypt();
console.log(JSON.stringify(decFolder));
}
private async getCollection(id: string) {
const collection = await this.collectionService.get(id);
if (collection == null) {
console.log('Not found.');
return;
}
const decCollection = await collection.decrypt();
console.log(JSON.stringify(decCollection));
}
}

View File

@@ -0,0 +1,42 @@
import * as program from 'commander';
import { CipherService } from 'jslib/abstractions/cipher.service';
import { CollectionService } from 'jslib/services/collection.service';
import { FolderService } from 'jslib/services/folder.service';
export class ListCommand {
constructor(private cipherService: CipherService, private folderService: FolderService,
private collectionService: CollectionService) { }
async run(object: string, cmd: program.Command) {
switch (object) {
case 'items':
await this.listCiphers();
break;
case 'folders':
await this.listFolders();
break;
case 'collections':
await this.listCollections();
break;
default:
console.log('Unknown object: ' + object);
break;
}
}
private async listCiphers() {
const ciphers = await this.cipherService.getAllDecrypted();
console.log(JSON.stringify(ciphers));
}
private async listFolders() {
const folders = await this.folderService.getAllDecrypted();
console.log(JSON.stringify(folders));
}
private async listCollections() {
const collections = await this.collectionService.getAllDecrypted();
console.log(JSON.stringify(collections));
}
}

View File

@@ -3,9 +3,7 @@ import * as program from 'commander';
import { SyncService } from 'jslib/abstractions/sync.service';
export class SyncCommand {
constructor(private syncService: SyncService) {
}
constructor(private syncService: SyncService) { }
async run(cmd: program.Command) {
try {