mirror of
https://github.com/bitwarden/web
synced 2026-01-09 03:53:28 +00:00
* Update guard services and routing * Add depenent checkbox to handle sub permissions * Present new collections premissions * Use new split permissions * Rename to nested-checkbox.component * Clarify css class name * update jslib
83 lines
3.4 KiB
TypeScript
83 lines
3.4 KiB
TypeScript
import {
|
|
Component,
|
|
EventEmitter,
|
|
Output,
|
|
} from '@angular/core';
|
|
|
|
import { ToasterService } from 'angular2-toaster';
|
|
|
|
import { ApiService } from 'jslib-common/abstractions/api.service';
|
|
import { CipherService } from 'jslib-common/abstractions/cipher.service';
|
|
import { EventService } from 'jslib-common/abstractions/event.service';
|
|
import { I18nService } from 'jslib-common/abstractions/i18n.service';
|
|
import { PasswordRepromptService } from 'jslib-common/abstractions/passwordReprompt.service';
|
|
import { PlatformUtilsService } from 'jslib-common/abstractions/platformUtils.service';
|
|
import { SearchService } from 'jslib-common/abstractions/search.service';
|
|
import { TotpService } from 'jslib-common/abstractions/totp.service';
|
|
import { UserService } from 'jslib-common/abstractions/user.service';
|
|
|
|
import { Organization } from 'jslib-common/models/domain/organization';
|
|
import { CipherView } from 'jslib-common/models/view/cipherView';
|
|
|
|
import { CiphersComponent as BaseCiphersComponent } from '../../vault/ciphers.component';
|
|
|
|
@Component({
|
|
selector: 'app-org-vault-ciphers',
|
|
templateUrl: '../../vault/ciphers.component.html',
|
|
})
|
|
export class CiphersComponent extends BaseCiphersComponent {
|
|
@Output() onEventsClicked = new EventEmitter<CipherView>();
|
|
|
|
organization: Organization;
|
|
accessEvents = false;
|
|
|
|
protected allCiphers: CipherView[] = [];
|
|
|
|
constructor(searchService: SearchService, toasterService: ToasterService, i18nService: I18nService,
|
|
platformUtilsService: PlatformUtilsService, cipherService: CipherService,
|
|
private apiService: ApiService, eventService: EventService, totpService: TotpService,
|
|
userService: UserService, passwordRepromptService: PasswordRepromptService) {
|
|
super(searchService, toasterService, i18nService, platformUtilsService, cipherService,
|
|
eventService, totpService, userService, passwordRepromptService);
|
|
}
|
|
|
|
async load(filter: (cipher: CipherView) => boolean = null) {
|
|
if (this.organization.canViewAllCollections) {
|
|
this.accessEvents = this.organization.useEvents;
|
|
this.allCiphers = await this.cipherService.getAllFromApiForOrganization(this.organization.id);
|
|
} else {
|
|
this.allCiphers = (await this.cipherService.getAllDecrypted()).filter(c => c.organizationId === this.organization.id);
|
|
}
|
|
await this.searchService.indexCiphers(this.organization.id, this.allCiphers);
|
|
await this.applyFilter(filter);
|
|
this.loaded = true;
|
|
}
|
|
|
|
async applyFilter(filter: (cipher: CipherView) => boolean = null) {
|
|
if (this.organization.canViewAllCollections) {
|
|
await super.applyFilter(filter);
|
|
} else {
|
|
const f = (c: CipherView) => c.organizationId === this.organization.id && (filter == null || filter(c));
|
|
await super.applyFilter(f);
|
|
}
|
|
}
|
|
|
|
async search(timeout: number = null) {
|
|
await super.search(timeout, this.allCiphers);
|
|
}
|
|
events(c: CipherView) {
|
|
this.onEventsClicked.emit(c);
|
|
}
|
|
|
|
protected deleteCipher(id: string) {
|
|
if (!this.organization.canEditAnyCollection) {
|
|
return super.deleteCipher(id, this.deleted);
|
|
}
|
|
return this.deleted ? this.apiService.deleteCipherAdmin(id) : this.apiService.putDeleteCipherAdmin(id);
|
|
}
|
|
|
|
protected showFixOldAttachments(c: CipherView) {
|
|
return this.organization.canEditAnyCollection && c.hasOldAttachments;
|
|
}
|
|
}
|