open-vault/ui/lib/pki/addon/components/pki-role-generate.ts

49 lines
1.5 KiB
TypeScript
Raw Normal View History

import Component from '@glimmer/component';
import { action } from '@ember/object';
import { task } from 'ember-concurrency';
import { service } from '@ember/service';
import Router from '@ember/routing/router';
import Store from '@ember-data/store';
import { tracked } from '@glimmer/tracking';
import errorMessage from 'vault/utils/error-message';
import FlashMessageService from 'vault/services/flash-messages';
import DownloadService from 'vault/services/download';
2023-01-04 18:18:55 +00:00
import PkiCertificateGenerateModel from 'vault/models/pki/certificate/generate';
interface Args {
onSuccess: CallableFunction;
model: PkiCertificateGenerateModel;
2022-12-15 22:42:18 +00:00
type: string;
}
export default class PkiRoleGenerate extends Component<Args> {
@service declare readonly router: Router;
@service declare readonly store: Store;
@service declare readonly flashMessages: FlashMessageService;
@service declare readonly download: DownloadService;
@tracked errorBanner = '';
2022-12-15 22:42:18 +00:00
get verb() {
return this.args.type === 'sign' ? 'sign' : 'generate';
}
@task
*save(evt: Event) {
evt.preventDefault();
this.errorBanner = '';
const { model, onSuccess } = this.args;
try {
yield model.save();
onSuccess();
} catch (err) {
2022-12-15 22:42:18 +00:00
this.errorBanner = errorMessage(err, `Could not ${this.verb} certificate. See Vault logs for details.`);
}
}
@action cancel() {
this.args.model.unloadRecord();
this.router.transitionTo('vault.cluster.secrets.backend.pki.roles.role.details');
}
}