mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-22 15:11:07 +02:00
* Completed initial replacement of editor * fixing ts issues * removing codemirror modifier and deps * working on replacing the code editor * addressing linting concerns * cleaning up policy-form editor * fixing linting issues * fixing linting issues * fixing tests * fixing tests * fixing tests * fixing tests * fixing failing tests * cleaning up PR * fixing tests * remove outdated message for navigating editor * fix linting in tests * add changelog * fix tests * update naming * remove unused lint param + name changes * update test selector usage * update test selector usage * update test selector usage * lint fixes * replace page object selectors * lint fix * fix lint * fix lint after merge * update tests * remove import --------- Co-authored-by: Lane Wetmore <lane.wetmore@hashicorp.com>
56 lines
1.5 KiB
JavaScript
56 lines
1.5 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import { isBlank } from '@ember/utils';
|
|
import { set } from '@ember/object';
|
|
import RoleEdit from './role-edit';
|
|
const SHOW_ROUTE = 'vault.cluster.secrets.backend.show';
|
|
|
|
export default RoleEdit.extend({
|
|
actions: {
|
|
createOrUpdate(type, event) {
|
|
event.preventDefault();
|
|
|
|
// all of the attributes with fieldValue:'id' are called `name`
|
|
const modelId = this.model.id || this.model.name;
|
|
// prevent from submitting if there's no key
|
|
// maybe do something fancier later
|
|
if (type === 'create' && isBlank(modelId)) {
|
|
return;
|
|
}
|
|
var credential_type = this.model.credential_type;
|
|
if (credential_type == 'iam_user') {
|
|
set(this, 'model.role_arns', []);
|
|
}
|
|
if (credential_type == 'assumed_role') {
|
|
set(this, 'model.policy_arns', []);
|
|
}
|
|
if (credential_type == 'federation_token') {
|
|
set(this, 'model.role_arns', []);
|
|
set(this, 'model.policy_arns', []);
|
|
}
|
|
|
|
var policy_document = this.model.policy_document;
|
|
if (policy_document == '{}') {
|
|
set(this, 'model.policy_document', '');
|
|
}
|
|
|
|
this.persist('save', () => {
|
|
this.hasDataChanges();
|
|
this.transitionToRoute(SHOW_ROUTE, modelId);
|
|
});
|
|
},
|
|
|
|
editorUpdated(attr, val) {
|
|
// wont set invalid JSON to the model
|
|
try {
|
|
set(this.model, attr, JSON.parse(val));
|
|
} catch {
|
|
// linting is handled by the component
|
|
}
|
|
},
|
|
},
|
|
});
|