open-vault/ui/app/components/secret-list/database-list-item.js
Chelsea Shaw 67ba021e36
UI: add Database static role password rotation (#14268)
* Add UI feature allowing database role credential rotation

* Only show the 'rotate credentials' option for static roles

* rotate role path uses id for permissions

* Add rotate credentials button to show page on static role

* Mirage handlers for role for simple testing

* Add changelog

* lint rules

* fix lint

Co-authored-by: Bartek Marczak <bartek.marczak@gmail.com>
2022-02-25 12:16:54 -06:00

75 lines
2.1 KiB
JavaScript

/**
* @module DatabaseListItem
* DatabaseListItem components are used for the list items for the Database Secret Engines for Roles.
* This component automatically handles read-only list items if capabilities are not granted or the item is internal only.
*
* @example
* ```js
* <DatabaseListItem @item={item} />
* ```
* @param {object} item - item refers to the model item used on the list item partial
*/
import Component from '@glimmer/component';
import { tracked } from '@glimmer/tracking';
import { inject as service } from '@ember/service';
import { action } from '@ember/object';
export default class DatabaseListItem extends Component {
@tracked roleType = '';
@service store;
@service flashMessages;
get keyTypeValue() {
const item = this.args.item;
// basing this on path in case we want to remove 'type' later
if (item.path === 'roles') {
return 'dynamic';
} else if (item.path === 'static-roles') {
return 'static';
} else {
return '';
}
}
@action
resetConnection(id) {
const { backend } = this.args.item;
let adapter = this.store.adapterFor('database/connection');
adapter
.resetConnection(backend, id)
.then(() => {
this.flashMessages.success(`Success: ${id} connection was reset`);
})
.catch((e) => {
this.flashMessages.danger(e.errors);
});
}
@action
rotateRootCred(id) {
const { backend } = this.args.item;
let adapter = this.store.adapterFor('database/connection');
adapter
.rotateRootCredentials(backend, id)
.then(() => {
this.flashMessages.success(`Success: ${id} connection was rotated`);
})
.catch((e) => {
this.flashMessages.danger(e.errors);
});
}
@action
rotateRoleCred(id) {
const { backend } = this.args.item;
let adapter = this.store.adapterFor('database/credential');
adapter
.rotateRoleCredentials(backend, id)
.then(() => {
this.flashMessages.success(`Success: Credentials for ${id} role were rotated`);
})
.catch((e) => {
this.flashMessages.danger(e.errors);
});
}
}