vault/ui/app/mixins/policy-edit-controller.js
claire bontempo 4df3a7c4fb
UI/Wrong sentinel error message for auth methods (#14551)
* priortize adapter error over model error

* glimmerize message-error component

* message error tweaks

* fix glimmerize

* fix some tests

* change error handling for mount backend form

* throw API error for secret engine not mounting

* fix tests"

* fix tests

* cleanup error handling for secret engine mounts

* fix test selector

* add changelog

* STOP BEING FLAKY
2022-03-18 16:47:42 -07:00

49 lines
1.5 KiB
JavaScript

import { inject as service } from '@ember/service';
import Mixin from '@ember/object/mixin';
export default Mixin.create({
flashMessages: service(),
wizard: service(),
actions: {
deletePolicy(model) {
let policyType = model.get('policyType');
let name = model.get('name');
let flash = this.flashMessages;
model
.destroyRecord()
.then(() => {
flash.success(`${policyType.toUpperCase()} policy "${name}" was successfully deleted.`);
return this.transitionToRoute('vault.cluster.policies', policyType);
})
.catch((e) => {
let errors = e.errors ? e.errors.join('') : e.message;
flash.danger(
`There was an error deleting the ${policyType.toUpperCase()} policy "${name}": ${errors}.`
);
});
},
savePolicy(model) {
let flash = this.flashMessages;
let policyType = model.get('policyType');
let name = model.get('name');
model
.save()
.then((m) => {
flash.success(`${policyType.toUpperCase()} policy "${name}" was successfully saved.`);
if (this.wizard.featureState === 'create') {
this.wizard.transitionFeatureMachine('create', 'CONTINUE', policyType);
}
return this.transitionToRoute('vault.cluster.policy.show', m.get('policyType'), m.get('name'));
})
.catch((e) => {
model.set('errors', e.errors);
});
},
setModelName(model, e) {
model.set('name', e.target.value.toLowerCase());
},
},
});