b0dfbde741
* always use ?force for kmip scope delete * update the delete message when deleting a scope * support disabling and not showing help text for checkboxes * group TLS fields and render new allowed operations widget * add operation-field-display component for kmip roles * use operation-field-display component * switch glyph for false value in info-table-row * divvy up roles and tls * fix JSDoc - showHelpText defaults to true * fix tests and linting * rename vars in operation-field-display component * make the action name clearer re: what it's actually doing * align the allowed-ops header * show all operations as checked if you check to allow all
82 lines
2.6 KiB
JavaScript
82 lines
2.6 KiB
JavaScript
import DS from 'ember-data';
|
|
import { computed } from '@ember/object';
|
|
import { expandAttributeMeta } from 'vault/utils/field-to-attrs';
|
|
import fieldToAttrs from 'vault/utils/field-to-attrs';
|
|
import apiPath from 'vault/utils/api-path';
|
|
import attachCapabilities from 'vault/lib/attach-capabilities';
|
|
|
|
const { attr } = DS;
|
|
export const COMPUTEDS = {
|
|
operationFields: computed('newFields', function() {
|
|
return this.newFields.filter(key => key.startsWith('operation'));
|
|
}),
|
|
|
|
operationFieldsWithoutSpecial: computed('operationFields', function() {
|
|
return this.operationFields.slice().removeObjects(['operationAll', 'operationNone']);
|
|
}),
|
|
|
|
tlsFields: computed(function() {
|
|
return ['tlsClientKeyBits', 'tlsClientKeyType', 'tlsClientTtl'];
|
|
}),
|
|
|
|
nonOperationFields: computed('tlsFields', 'operationFields', function() {
|
|
let excludeFields = ['role'].concat(this.operationFields, this.tlsFields);
|
|
return this.newFields.slice().removeObjects(excludeFields);
|
|
}),
|
|
};
|
|
|
|
const Model = DS.Model.extend(COMPUTEDS, {
|
|
useOpenAPI: true,
|
|
backend: attr({ readOnly: true }),
|
|
scope: attr({ readOnly: true }),
|
|
name: attr({ readOnly: true }),
|
|
getHelpUrl(path) {
|
|
return `/v1/${path}/scope/example/role/example?help=1`;
|
|
},
|
|
fieldGroups: computed('fields', 'tlsFields', 'nonOperationFields', function() {
|
|
const groups = [{ TLS: this.tlsFields }];
|
|
if (this.nonOperationFields.length) {
|
|
groups.unshift({ default: this.nonOperationFields });
|
|
}
|
|
let ret = fieldToAttrs(this, groups);
|
|
return ret;
|
|
}),
|
|
|
|
operationFormFields: computed('operationFieldsWithoutSpecial', function() {
|
|
let objects = [
|
|
'operationCreate',
|
|
'operationActivate',
|
|
'operationGet',
|
|
'operationLocate',
|
|
'operationRekey',
|
|
'operationRevoke',
|
|
'operationDestroy',
|
|
];
|
|
|
|
let attributes = ['operationAddAttribute', 'operationGetAttributes'];
|
|
let server = ['operationDiscoverVersion'];
|
|
let others = this.operationFieldsWithoutSpecial.slice().removeObjects(objects.concat(attributes, server));
|
|
const groups = [
|
|
{ 'Managed Cryptographic Objects': objects },
|
|
{ 'Object Attributes': attributes },
|
|
{ Server: server },
|
|
];
|
|
if (others.length) {
|
|
groups.push({
|
|
'': others,
|
|
});
|
|
}
|
|
return fieldToAttrs(this, groups);
|
|
}),
|
|
tlsFormFields: computed('tlsFields', function() {
|
|
return expandAttributeMeta(this, this.tlsFields);
|
|
}),
|
|
fields: computed('nonOperationFields', function() {
|
|
return expandAttributeMeta(this, this.nonOperationFields);
|
|
}),
|
|
});
|
|
|
|
export default attachCapabilities(Model, {
|
|
updatePath: apiPath`${'backend'}/scope/${'scope'}/role/${'id'}`,
|
|
});
|