2018-07-16 18:42:49 +02:00
|
|
|
import {
|
|
|
|
Component,
|
|
|
|
ViewChild,
|
|
|
|
ViewContainerRef,
|
|
|
|
} from '@angular/core';
|
2021-06-02 18:35:49 +02:00
|
|
|
|
2021-11-24 15:33:34 +01:00
|
|
|
import {
|
2021-11-22 14:41:40 +01:00
|
|
|
ActivatedRoute,
|
|
|
|
Router
|
|
|
|
} from '@angular/router';
|
2018-07-16 18:42:49 +02:00
|
|
|
|
|
|
|
import { ToasterService } from 'angular2-toaster';
|
2021-08-27 14:50:58 +02:00
|
|
|
import { ModalService } from 'jslib-angular/services/modal.service';
|
2018-07-16 18:42:49 +02:00
|
|
|
|
2021-06-07 20:13:58 +02:00
|
|
|
import { ApiService } from 'jslib-common/abstractions/api.service';
|
|
|
|
import { CryptoService } from 'jslib-common/abstractions/crypto.service';
|
|
|
|
import { I18nService } from 'jslib-common/abstractions/i18n.service';
|
2021-10-20 18:30:04 +02:00
|
|
|
import { LogService } from 'jslib-common/abstractions/log.service';
|
2021-06-07 20:13:58 +02:00
|
|
|
import { PlatformUtilsService } from 'jslib-common/abstractions/platformUtils.service';
|
|
|
|
import { SyncService } from 'jslib-common/abstractions/sync.service';
|
2018-07-16 18:42:49 +02:00
|
|
|
|
2021-06-07 20:13:58 +02:00
|
|
|
import { OrganizationKeysRequest } from 'jslib-common/models/request/organizationKeysRequest';
|
|
|
|
import { OrganizationUpdateRequest } from 'jslib-common/models/request/organizationUpdateRequest';
|
2021-06-02 18:35:49 +02:00
|
|
|
|
2021-06-07 20:13:58 +02:00
|
|
|
import { OrganizationResponse } from 'jslib-common/models/response/organizationResponse';
|
2018-07-16 18:42:49 +02:00
|
|
|
|
2020-11-10 22:13:42 +01:00
|
|
|
import { ApiKeyComponent } from '../../settings/api-key.component';
|
2018-09-25 15:12:24 +02:00
|
|
|
import { PurgeVaultComponent } from '../../settings/purge-vault.component';
|
2020-06-13 01:33:29 +02:00
|
|
|
import { TaxInfoComponent } from '../../settings/tax-info.component';
|
2021-06-02 18:35:49 +02:00
|
|
|
|
2018-07-16 18:42:49 +02:00
|
|
|
import { DeleteOrganizationComponent } from './delete-organization.component';
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'app-org-account',
|
|
|
|
templateUrl: 'account.component.html',
|
|
|
|
})
|
|
|
|
export class AccountComponent {
|
2020-08-17 16:04:38 +02:00
|
|
|
@ViewChild('deleteOrganizationTemplate', { read: ViewContainerRef, static: true }) deleteModalRef: ViewContainerRef;
|
|
|
|
@ViewChild('purgeOrganizationTemplate', { read: ViewContainerRef, static: true }) purgeModalRef: ViewContainerRef;
|
|
|
|
@ViewChild('apiKeyTemplate', { read: ViewContainerRef, static: true }) apiKeyModalRef: ViewContainerRef;
|
|
|
|
@ViewChild('rotateApiKeyTemplate', { read: ViewContainerRef, static: true }) rotateApiKeyModalRef: ViewContainerRef;
|
2020-06-13 01:33:29 +02:00
|
|
|
@ViewChild(TaxInfoComponent) taxInfo: TaxInfoComponent;
|
2018-07-16 18:42:49 +02:00
|
|
|
|
2020-08-28 17:22:30 +02:00
|
|
|
selfHosted = false;
|
2018-07-16 18:42:49 +02:00
|
|
|
loading = true;
|
2019-03-07 17:18:45 +01:00
|
|
|
canUseApi = false;
|
2018-07-16 18:42:49 +02:00
|
|
|
org: OrganizationResponse;
|
|
|
|
formPromise: Promise<any>;
|
2020-06-17 19:35:39 +02:00
|
|
|
taxFormPromise: Promise<any>;
|
2018-07-16 18:42:49 +02:00
|
|
|
|
|
|
|
private organizationId: string;
|
|
|
|
|
2021-08-27 14:50:58 +02:00
|
|
|
constructor(private modalService: ModalService,
|
2018-07-16 18:42:49 +02:00
|
|
|
private apiService: ApiService, private i18nService: I18nService,
|
2021-04-14 23:43:40 +02:00
|
|
|
private toasterService: ToasterService, private route: ActivatedRoute,
|
2021-06-02 18:35:49 +02:00
|
|
|
private syncService: SyncService, private platformUtilsService: PlatformUtilsService,
|
2021-11-22 14:41:40 +01:00
|
|
|
private cryptoService: CryptoService, private logService: LogService,
|
|
|
|
private router: Router) { }
|
2018-07-16 18:42:49 +02:00
|
|
|
|
|
|
|
async ngOnInit() {
|
2020-08-28 17:22:30 +02:00
|
|
|
this.selfHosted = this.platformUtilsService.isSelfHost();
|
2021-02-03 18:41:33 +01:00
|
|
|
this.route.parent.parent.params.subscribe(async params => {
|
2018-07-16 18:42:49 +02:00
|
|
|
this.organizationId = params.organizationId;
|
|
|
|
try {
|
|
|
|
this.org = await this.apiService.getOrganization(this.organizationId);
|
2019-03-07 17:18:45 +01:00
|
|
|
this.canUseApi = this.org.useApi;
|
2021-10-20 18:30:04 +02:00
|
|
|
} catch (e) {
|
|
|
|
this.logService.error(e);
|
|
|
|
}
|
2018-07-16 18:42:49 +02:00
|
|
|
});
|
|
|
|
this.loading = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
async submit() {
|
|
|
|
try {
|
|
|
|
const request = new OrganizationUpdateRequest();
|
|
|
|
request.name = this.org.name;
|
|
|
|
request.businessName = this.org.businessName;
|
|
|
|
request.billingEmail = this.org.billingEmail;
|
2020-08-12 22:46:18 +02:00
|
|
|
request.identifier = this.org.identifier;
|
2021-06-02 18:35:49 +02:00
|
|
|
|
|
|
|
// Backfill pub/priv key if necessary
|
|
|
|
if (!this.org.hasPublicAndPrivateKeys) {
|
|
|
|
const orgShareKey = await this.cryptoService.getOrgKey(this.organizationId);
|
|
|
|
const orgKeys = await this.cryptoService.makeKeyPair(orgShareKey);
|
|
|
|
request.keys = new OrganizationKeysRequest(orgKeys[0], orgKeys[1].encryptedString);
|
|
|
|
}
|
|
|
|
|
2018-07-16 18:42:49 +02:00
|
|
|
this.formPromise = this.apiService.putOrganization(this.organizationId, request).then(() => {
|
|
|
|
return this.syncService.fullSync(true);
|
|
|
|
});
|
|
|
|
await this.formPromise;
|
|
|
|
this.toasterService.popAsync('success', null, this.i18nService.t('organizationUpdated'));
|
2021-10-20 18:30:04 +02:00
|
|
|
} catch (e) {
|
|
|
|
this.logService.error(e);
|
|
|
|
}
|
2018-07-16 18:42:49 +02:00
|
|
|
}
|
|
|
|
|
2020-06-08 23:24:05 +02:00
|
|
|
async submitTaxInfo() {
|
2020-06-17 19:35:39 +02:00
|
|
|
this.taxFormPromise = this.taxInfo.submitTaxInfo();
|
|
|
|
await this.taxFormPromise;
|
2020-06-08 23:24:05 +02:00
|
|
|
this.toasterService.popAsync('success', null, this.i18nService.t('taxInfoUpdated'));
|
|
|
|
}
|
|
|
|
|
2021-08-27 14:50:58 +02:00
|
|
|
async deleteOrganization() {
|
|
|
|
await this.modalService.openViewRef(DeleteOrganizationComponent, this.deleteModalRef, comp => {
|
|
|
|
comp.organizationId = this.organizationId;
|
2021-11-22 14:41:40 +01:00
|
|
|
comp.onSuccess.subscribe(() => {
|
|
|
|
this.router.navigate(['/']);
|
|
|
|
});
|
2018-07-16 18:42:49 +02:00
|
|
|
});
|
|
|
|
}
|
2018-09-25 15:12:24 +02:00
|
|
|
|
2021-08-27 14:50:58 +02:00
|
|
|
async purgeVault() {
|
|
|
|
await this.modalService.openViewRef(PurgeVaultComponent, this.purgeModalRef, comp => {
|
|
|
|
comp.organizationId = this.organizationId;
|
2018-09-25 15:12:24 +02:00
|
|
|
});
|
|
|
|
}
|
2019-03-07 17:18:45 +01:00
|
|
|
|
2021-08-27 14:50:58 +02:00
|
|
|
async viewApiKey() {
|
|
|
|
await this.modalService.openViewRef(ApiKeyComponent, this.apiKeyModalRef, comp => {
|
|
|
|
comp.keyType = 'organization';
|
|
|
|
comp.entityId = this.organizationId;
|
|
|
|
comp.postKey = this.apiService.postOrganizationApiKey.bind(this.apiService);
|
|
|
|
comp.scope = 'api.organization';
|
|
|
|
comp.grantType = 'client_credentials';
|
|
|
|
comp.apiKeyTitle = 'apiKey';
|
|
|
|
comp.apiKeyWarning = 'apiKeyWarning';
|
|
|
|
comp.apiKeyDescription = 'apiKeyDesc';
|
2019-03-07 17:18:45 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2021-08-27 14:50:58 +02:00
|
|
|
async rotateApiKey() {
|
|
|
|
await this.modalService.openViewRef(ApiKeyComponent, this.rotateApiKeyModalRef, comp => {
|
|
|
|
comp.keyType = 'organization';
|
|
|
|
comp.isRotation = true;
|
|
|
|
comp.entityId = this.organizationId;
|
|
|
|
comp.postKey = this.apiService.postOrganizationRotateApiKey.bind(this.apiService);
|
|
|
|
comp.scope = 'api.organization';
|
|
|
|
comp.grantType = 'client_credentials';
|
|
|
|
comp.apiKeyTitle = 'apiKey';
|
|
|
|
comp.apiKeyWarning = 'apiKeyWarning';
|
|
|
|
comp.apiKeyDescription = 'apiKeyRotateDesc';
|
2019-03-07 17:18:45 +01:00
|
|
|
});
|
|
|
|
}
|
2018-07-16 18:42:49 +02:00
|
|
|
}
|