mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-11 09:07:00 +02:00
70 lines
2.2 KiB
TypeScript
70 lines
2.2 KiB
TypeScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import Component from '@glimmer/component';
|
|
import { inject as service } from '@ember/service';
|
|
import { action } from '@ember/object';
|
|
import { getOwner } from '@ember/application';
|
|
import errorMessage from 'vault/utils/error-message';
|
|
|
|
import type LdapRoleModel from 'vault/models/ldap/role';
|
|
import type SecretEngineModel from 'vault/models/secret-engine';
|
|
import type FlashMessageService from 'vault/services/flash-messages';
|
|
import type { Breadcrumb, EngineOwner } from 'vault/vault/app-types';
|
|
import type RouterService from '@ember/routing/router-service';
|
|
import type StoreService from 'vault/services/store';
|
|
|
|
interface Args {
|
|
roles: Array<LdapRoleModel>;
|
|
promptConfig: boolean;
|
|
backendModel: SecretEngineModel;
|
|
breadcrumbs: Array<Breadcrumb>;
|
|
pageFilter: string;
|
|
}
|
|
|
|
export default class LdapRolesPageComponent extends Component<Args> {
|
|
@service declare readonly flashMessages: FlashMessageService;
|
|
@service declare readonly router: RouterService;
|
|
@service declare readonly store: StoreService;
|
|
|
|
get mountPoint(): string {
|
|
const owner = getOwner(this) as EngineOwner;
|
|
return owner.mountPoint;
|
|
}
|
|
|
|
get paginationQueryParams() {
|
|
return (page: number) => ({ page });
|
|
}
|
|
|
|
@action
|
|
onFilterChange(pageFilter: string) {
|
|
this.router.transitionTo('vault.cluster.secrets.backend.ldap.roles', { queryParams: { pageFilter } });
|
|
}
|
|
|
|
@action
|
|
async onRotate(model: LdapRoleModel) {
|
|
try {
|
|
const message = `Successfully rotated credentials for ${model.name}.`;
|
|
await model.rotateStaticPassword();
|
|
this.flashMessages.success(message);
|
|
} catch (error) {
|
|
this.flashMessages.danger(`Error rotating credentials \n ${errorMessage(error)}`);
|
|
}
|
|
}
|
|
|
|
@action
|
|
async onDelete(model: LdapRoleModel) {
|
|
try {
|
|
const message = `Successfully deleted role ${model.name}.`;
|
|
await model.destroyRecord();
|
|
this.store.clearDataset('ldap/role');
|
|
this.router.transitionTo('vault.cluster.secrets.backend.ldap.roles');
|
|
this.flashMessages.success(message);
|
|
} catch (error) {
|
|
this.flashMessages.danger(`Error deleting role \n ${errorMessage(error)}`);
|
|
}
|
|
}
|
|
}
|