share command
This commit is contained in:
parent
ac9cf91002
commit
7e56a687e3
2
jslib
2
jslib
|
@ -1 +1 @@
|
||||||
Subproject commit 43c0cbce452daff9bcc4c70866a56c8cbd548b4a
|
Subproject commit 4165a78277048d7b37319e63bd7e6473cbba5156
|
|
@ -74,7 +74,7 @@ export class EditCommand {
|
||||||
return Response.notFound();
|
return Response.notFound();
|
||||||
}
|
}
|
||||||
if (cipher.organizationId == null) {
|
if (cipher.organizationId == null) {
|
||||||
return Response.error('Item does not belong to an organization. Consider sharing it first.');
|
return Response.badRequest('Item does not belong to an organization. Consider sharing it first.');
|
||||||
}
|
}
|
||||||
|
|
||||||
cipher.collectionIds = req;
|
cipher.collectionIds = req;
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
import * as program from 'commander';
|
||||||
|
|
||||||
|
import { CipherService } from 'jslib/abstractions/cipher.service';
|
||||||
|
|
||||||
|
import { Response } from '../models/response';
|
||||||
|
import { CipherResponse } from '../models/response/cipherResponse';
|
||||||
|
|
||||||
|
import { CliUtils } from '../utils';
|
||||||
|
|
||||||
|
export class ShareCommand {
|
||||||
|
constructor(private cipherService: CipherService) { }
|
||||||
|
|
||||||
|
async run(id: string, organizationId: string, requestJson: string, cmd: program.Command): Promise<Response> {
|
||||||
|
if (requestJson == null || requestJson === '') {
|
||||||
|
requestJson = await CliUtils.readStdin();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (requestJson == null || requestJson === '') {
|
||||||
|
return Response.badRequest('`requestJson` was not provided.');
|
||||||
|
}
|
||||||
|
|
||||||
|
let req: string[] = [];
|
||||||
|
try {
|
||||||
|
const reqJson = Buffer.from(requestJson, 'base64').toString();
|
||||||
|
req = JSON.parse(reqJson);
|
||||||
|
if (req == null || req.length === 0) {
|
||||||
|
return Response.badRequest('You must provide at least one collection id for this item.');
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
return Response.badRequest('Error parsing the encoded request data.');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (id != null) {
|
||||||
|
id = id.toLowerCase();
|
||||||
|
}
|
||||||
|
if (organizationId != null) {
|
||||||
|
organizationId = organizationId.toLowerCase();
|
||||||
|
}
|
||||||
|
|
||||||
|
const cipher = await this.cipherService.get(id);
|
||||||
|
if (cipher == null) {
|
||||||
|
return Response.notFound();
|
||||||
|
}
|
||||||
|
if (cipher.organizationId != null) {
|
||||||
|
return Response.badRequest('This item already belongs to an organization.');
|
||||||
|
}
|
||||||
|
const cipherView = await cipher.decrypt();
|
||||||
|
try {
|
||||||
|
await this.cipherService.shareWithServer(cipherView, organizationId, req);
|
||||||
|
const updatedCipher = await this.cipherService.get(cipher.id);
|
||||||
|
const decCipher = await updatedCipher.decrypt();
|
||||||
|
const res = new CipherResponse(decCipher);
|
||||||
|
return Response.success(res);
|
||||||
|
} catch (e) {
|
||||||
|
return Response.error(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -16,6 +16,7 @@ import { ListCommand } from './commands/list.command';
|
||||||
import { LockCommand } from './commands/lock.command';
|
import { LockCommand } from './commands/lock.command';
|
||||||
import { LoginCommand } from './commands/login.command';
|
import { LoginCommand } from './commands/login.command';
|
||||||
import { LogoutCommand } from './commands/logout.command';
|
import { LogoutCommand } from './commands/logout.command';
|
||||||
|
import { ShareCommand } from './commands/share.command';
|
||||||
import { SyncCommand } from './commands/sync.command';
|
import { SyncCommand } from './commands/sync.command';
|
||||||
import { UnlockCommand } from './commands/unlock.command';
|
import { UnlockCommand } from './commands/unlock.command';
|
||||||
import { UpdateCommand } from './commands/update.command';
|
import { UpdateCommand } from './commands/update.command';
|
||||||
|
@ -374,6 +375,38 @@ export class Program {
|
||||||
this.processResponse(response);
|
this.processResponse(response);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
program
|
||||||
|
.command('share <id> <organizationId> [encodedJson]')
|
||||||
|
.description('Share an item to an organization.')
|
||||||
|
.on('--help', () => {
|
||||||
|
writeLn('\n Id:');
|
||||||
|
writeLn('');
|
||||||
|
writeLn(' Item\'s globally unique `id`.');
|
||||||
|
writeLn('');
|
||||||
|
writeLn(' Organization Id:');
|
||||||
|
writeLn('');
|
||||||
|
writeLn(' Organization\'s globally unique `id`.');
|
||||||
|
writeLn('');
|
||||||
|
writeLn(' Notes:');
|
||||||
|
writeLn('');
|
||||||
|
writeLn(' `encodedJson` can also be piped into stdin. `encodedJson` contains ' +
|
||||||
|
'an array of collection ids.');
|
||||||
|
writeLn('');
|
||||||
|
writeLn(' Examples:');
|
||||||
|
writeLn('');
|
||||||
|
writeLn(' bw share 4af958ce-96a7-45d9-beed-1e70fabaa27a 6d82949b-b44d-468a-adae-3f3bacb0ea32 ' +
|
||||||
|
'WyI5NzQwNTNkMC0zYjMzLTRiOTgtODg2ZS1mZWNmNWM4ZGJhOTYiXQ==');
|
||||||
|
writeLn(' echo \'["974053d0-3b33-4b98-886e-fecf5c8dba96"]\' | bw encode | ' +
|
||||||
|
'bw share 4af958ce-96a7-45d9-beed-1e70fabaa27a 6d82949b-b44d-468a-adae-3f3bacb0ea32');
|
||||||
|
writeLn('', true);
|
||||||
|
})
|
||||||
|
.action(async (id, organizationId, encodedJson, cmd) => {
|
||||||
|
await this.exitIfLocked();
|
||||||
|
const command = new ShareCommand(this.main.cipherService);
|
||||||
|
const response = await command.run(id, organizationId, encodedJson, cmd);
|
||||||
|
this.processResponse(response);
|
||||||
|
});
|
||||||
|
|
||||||
program
|
program
|
||||||
.command('import [format] [input]')
|
.command('import [format] [input]')
|
||||||
.description('Import vault data from a file.')
|
.description('Import vault data from a file.')
|
||||||
|
|
Loading…
Reference in New Issue