mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-12 19:50:46 +01:00
admin cipher apis
This commit is contained in:
parent
278b4402da
commit
9b008ff382
@ -80,20 +80,28 @@ export abstract class ApiService {
|
|||||||
postFolder: (request: FolderRequest) => Promise<FolderResponse>;
|
postFolder: (request: FolderRequest) => Promise<FolderResponse>;
|
||||||
putFolder: (id: string, request: FolderRequest) => Promise<FolderResponse>;
|
putFolder: (id: string, request: FolderRequest) => Promise<FolderResponse>;
|
||||||
deleteFolder: (id: string) => Promise<any>;
|
deleteFolder: (id: string) => Promise<any>;
|
||||||
|
getCipher: (id: string) => Promise<CipherResponse>;
|
||||||
|
getCipherAdmin: (id: string) => Promise<CipherResponse>;
|
||||||
getCiphersOrganization: (organizationId: string) => Promise<ListResponse<CipherResponse>>;
|
getCiphersOrganization: (organizationId: string) => Promise<ListResponse<CipherResponse>>;
|
||||||
postCipher: (request: CipherRequest) => Promise<CipherResponse>;
|
postCipher: (request: CipherRequest) => Promise<CipherResponse>;
|
||||||
|
postCipherAdmin: (request: CipherRequest) => Promise<CipherResponse>;
|
||||||
putCipher: (id: string, request: CipherRequest) => Promise<CipherResponse>;
|
putCipher: (id: string, request: CipherRequest) => Promise<CipherResponse>;
|
||||||
|
putCipherAdmin: (id: string, request: CipherRequest) => Promise<CipherResponse>;
|
||||||
deleteCipher: (id: string) => Promise<any>;
|
deleteCipher: (id: string) => Promise<any>;
|
||||||
|
deleteCipherAdmin: (id: string) => Promise<any>;
|
||||||
deleteManyCiphers: (request: CipherBulkDeleteRequest) => Promise<any>;
|
deleteManyCiphers: (request: CipherBulkDeleteRequest) => Promise<any>;
|
||||||
putMoveCiphers: (request: CipherBulkMoveRequest) => Promise<any>;
|
putMoveCiphers: (request: CipherBulkMoveRequest) => Promise<any>;
|
||||||
putShareCipher: (id: string, request: CipherShareRequest) => Promise<any>;
|
putShareCipher: (id: string, request: CipherShareRequest) => Promise<any>;
|
||||||
putShareCiphers: (request: CipherBulkShareRequest) => Promise<any>;
|
putShareCiphers: (request: CipherBulkShareRequest) => Promise<any>;
|
||||||
putCipherCollections: (id: string, request: CipherCollectionsRequest) => Promise<any>;
|
putCipherCollections: (id: string, request: CipherCollectionsRequest) => Promise<any>;
|
||||||
|
putCipherCollectionsAdmin: (id: string, request: CipherCollectionsRequest) => Promise<any>;
|
||||||
postPurgeCiphers: (request: PasswordVerificationRequest) => Promise<any>;
|
postPurgeCiphers: (request: PasswordVerificationRequest) => Promise<any>;
|
||||||
postImportCiphers: (request: ImportCiphersRequest) => Promise<any>;
|
postImportCiphers: (request: ImportCiphersRequest) => Promise<any>;
|
||||||
postImportOrganizationCiphers: (request: ImportOrganizationCiphersRequest) => Promise<any>;
|
postImportOrganizationCiphers: (request: ImportOrganizationCiphersRequest) => Promise<any>;
|
||||||
postCipherAttachment: (id: string, data: FormData) => Promise<CipherResponse>;
|
postCipherAttachment: (id: string, data: FormData) => Promise<CipherResponse>;
|
||||||
|
postCipherAttachmentAdmin: (id: string, data: FormData) => Promise<CipherResponse>;
|
||||||
deleteCipherAttachment: (id: string, attachmentId: string) => Promise<any>;
|
deleteCipherAttachment: (id: string, attachmentId: string) => Promise<any>;
|
||||||
|
deleteCipherAttachmentAdmin: (id: string, attachmentId: string) => Promise<any>;
|
||||||
postShareCipherAttachment: (id: string, attachmentId: string, data: FormData,
|
postShareCipherAttachment: (id: string, attachmentId: string, data: FormData,
|
||||||
organizationId: string) => Promise<any>;
|
organizationId: string) => Promise<any>;
|
||||||
getCollections: (organizationId: string) => Promise<ListResponse<CollectionResponse>>;
|
getCollections: (organizationId: string) => Promise<ListResponse<CollectionResponse>>;
|
||||||
|
@ -19,6 +19,8 @@ import { I18nService } from '../../abstractions/i18n.service';
|
|||||||
import { PlatformUtilsService } from '../../abstractions/platformUtils.service';
|
import { PlatformUtilsService } from '../../abstractions/platformUtils.service';
|
||||||
import { StateService } from '../../abstractions/state.service';
|
import { StateService } from '../../abstractions/state.service';
|
||||||
|
|
||||||
|
import { Cipher } from '../../models/domain/cipher';
|
||||||
|
|
||||||
import { CardView } from '../../models/view/cardView';
|
import { CardView } from '../../models/view/cardView';
|
||||||
import { CipherView } from '../../models/view/cipherView';
|
import { CipherView } from '../../models/view/cipherView';
|
||||||
import { FieldView } from '../../models/view/fieldView';
|
import { FieldView } from '../../models/view/fieldView';
|
||||||
@ -130,7 +132,7 @@ export class AddEditComponent {
|
|||||||
await this.stateService.remove('addEditCipher');
|
await this.stateService.remove('addEditCipher');
|
||||||
if (this.cipher == null) {
|
if (this.cipher == null) {
|
||||||
if (this.editMode) {
|
if (this.editMode) {
|
||||||
const cipher = await this.cipherService.get(this.cipherId);
|
const cipher = await this.loadCipher();
|
||||||
this.cipher = await cipher.decrypt();
|
this.cipher = await cipher.decrypt();
|
||||||
} else {
|
} else {
|
||||||
this.cipher = new CipherView();
|
this.cipher = new CipherView();
|
||||||
@ -163,7 +165,7 @@ export class AddEditComponent {
|
|||||||
const cipher = await this.cipherService.encrypt(this.cipher);
|
const cipher = await this.cipherService.encrypt(this.cipher);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this.formPromise = this.cipherService.saveWithServer(cipher);
|
this.formPromise = this.saveCipher(cipher);
|
||||||
await this.formPromise;
|
await this.formPromise;
|
||||||
this.cipher.id = cipher.id;
|
this.cipher.id = cipher.id;
|
||||||
this.analytics.eventTrack.next({ action: this.editMode ? 'Edited Cipher' : 'Added Cipher' });
|
this.analytics.eventTrack.next({ action: this.editMode ? 'Edited Cipher' : 'Added Cipher' });
|
||||||
@ -233,7 +235,7 @@ export class AddEditComponent {
|
|||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this.deletePromise = this.cipherService.deleteWithServer(this.cipher.id);
|
this.deletePromise = this.deleteCipher();
|
||||||
await this.deletePromise;
|
await this.deletePromise;
|
||||||
this.analytics.eventTrack.next({ action: 'Deleted Cipher' });
|
this.analytics.eventTrack.next({ action: 'Deleted Cipher' });
|
||||||
this.toasterService.popAsync('success', null, this.i18nService.t('deletedItem'));
|
this.toasterService.popAsync('success', null, this.i18nService.t('deletedItem'));
|
||||||
@ -304,4 +306,16 @@ export class AddEditComponent {
|
|||||||
this.toasterService.popAsync('success', null, this.i18nService.t('passwordSafe'));
|
this.toasterService.popAsync('success', null, this.i18nService.t('passwordSafe'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected loadCipher() {
|
||||||
|
return this.cipherService.get(this.cipherId);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected saveCipher(cipher: Cipher) {
|
||||||
|
return this.cipherService.saveWithServer(cipher);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected deleteCipher() {
|
||||||
|
return this.cipherService.deleteWithServer(this.cipher.id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -242,6 +242,16 @@ export class ApiService implements ApiServiceAbstraction {
|
|||||||
|
|
||||||
// Cipher APIs
|
// Cipher APIs
|
||||||
|
|
||||||
|
async getCipher(id: string): Promise<CipherResponse> {
|
||||||
|
const r = await this.send('GET', '/ciphers/' + id, null, true, true);
|
||||||
|
return new CipherResponse(r);
|
||||||
|
}
|
||||||
|
|
||||||
|
async getCipherAdmin(id: string): Promise<CipherResponse> {
|
||||||
|
const r = await this.send('GET', '/ciphers/' + id + '/admin', null, true, true);
|
||||||
|
return new CipherResponse(r);
|
||||||
|
}
|
||||||
|
|
||||||
async getCiphersOrganization(organizationId: string): Promise<ListResponse<CipherResponse>> {
|
async getCiphersOrganization(organizationId: string): Promise<ListResponse<CipherResponse>> {
|
||||||
const r = await this.send('GET', '/ciphers/organization-details?organizationId=' + organizationId,
|
const r = await this.send('GET', '/ciphers/organization-details?organizationId=' + organizationId,
|
||||||
null, true, true);
|
null, true, true);
|
||||||
@ -253,15 +263,29 @@ export class ApiService implements ApiServiceAbstraction {
|
|||||||
return new CipherResponse(r);
|
return new CipherResponse(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async postCipherAdmin(request: CipherRequest): Promise<CipherResponse> {
|
||||||
|
const r = await this.send('POST', '/ciphers/admin', request, true, true);
|
||||||
|
return new CipherResponse(r);
|
||||||
|
}
|
||||||
|
|
||||||
async putCipher(id: string, request: CipherRequest): Promise<CipherResponse> {
|
async putCipher(id: string, request: CipherRequest): Promise<CipherResponse> {
|
||||||
const r = await this.send('PUT', '/ciphers/' + id, request, true, true);
|
const r = await this.send('PUT', '/ciphers/' + id, request, true, true);
|
||||||
return new CipherResponse(r);
|
return new CipherResponse(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async putCipherAdmin(id: string, request: CipherRequest): Promise<CipherResponse> {
|
||||||
|
const r = await this.send('PUT', '/ciphers/' + id + '/admin', request, true, true);
|
||||||
|
return new CipherResponse(r);
|
||||||
|
}
|
||||||
|
|
||||||
deleteCipher(id: string): Promise<any> {
|
deleteCipher(id: string): Promise<any> {
|
||||||
return this.send('DELETE', '/ciphers/' + id, null, true, false);
|
return this.send('DELETE', '/ciphers/' + id, null, true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
deleteCipherAdmin(id: string): Promise<any> {
|
||||||
|
return this.send('DELETE', '/ciphers/' + id + '/admin', null, true, false);
|
||||||
|
}
|
||||||
|
|
||||||
deleteManyCiphers(request: CipherBulkDeleteRequest): Promise<any> {
|
deleteManyCiphers(request: CipherBulkDeleteRequest): Promise<any> {
|
||||||
return this.send('DELETE', '/ciphers', request, true, false);
|
return this.send('DELETE', '/ciphers', request, true, false);
|
||||||
}
|
}
|
||||||
@ -282,6 +306,10 @@ export class ApiService implements ApiServiceAbstraction {
|
|||||||
return this.send('PUT', '/ciphers/' + id + '/collections', request, true, false);
|
return this.send('PUT', '/ciphers/' + id + '/collections', request, true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
putCipherCollectionsAdmin(id: string, request: CipherCollectionsRequest): Promise<any> {
|
||||||
|
return this.send('PUT', '/ciphers/' + id + '/collections-admin', request, true, false);
|
||||||
|
}
|
||||||
|
|
||||||
postPurgeCiphers(request: PasswordVerificationRequest): Promise<any> {
|
postPurgeCiphers(request: PasswordVerificationRequest): Promise<any> {
|
||||||
return this.send('POST', '/ciphers/purge', request, true, false);
|
return this.send('POST', '/ciphers/purge', request, true, false);
|
||||||
}
|
}
|
||||||
@ -301,10 +329,19 @@ export class ApiService implements ApiServiceAbstraction {
|
|||||||
return new CipherResponse(r);
|
return new CipherResponse(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async postCipherAttachmentAdmin(id: string, data: FormData): Promise<CipherResponse> {
|
||||||
|
const r = await this.send('POST', '/ciphers/' + id + '/attachment-admin', data, true, true);
|
||||||
|
return new CipherResponse(r);
|
||||||
|
}
|
||||||
|
|
||||||
deleteCipherAttachment(id: string, attachmentId: string): Promise<any> {
|
deleteCipherAttachment(id: string, attachmentId: string): Promise<any> {
|
||||||
return this.send('DELETE', '/ciphers/' + id + '/attachment/' + attachmentId, null, true, false);
|
return this.send('DELETE', '/ciphers/' + id + '/attachment/' + attachmentId, null, true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
deleteCipherAttachmentAdmin(id: string, attachmentId: string): Promise<any> {
|
||||||
|
return this.send('DELETE', '/ciphers/' + id + '/attachment/' + attachmentId + '/admin', null, true, false);
|
||||||
|
}
|
||||||
|
|
||||||
postShareCipherAttachment(id: string, attachmentId: string, data: FormData,
|
postShareCipherAttachment(id: string, attachmentId: string, data: FormData,
|
||||||
organizationId: string): Promise<any> {
|
organizationId: string): Promise<any> {
|
||||||
return this.send('POST', '/ciphers/' + id + '/attachment/' +
|
return this.send('POST', '/ciphers/' + id + '/attachment/' +
|
||||||
|
Loading…
Reference in New Issue
Block a user