mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-14 18:47:01 +02:00
* refactor ss+modal to accept multiple models * create policy form * cleanup and fix test * add tabs to policy modal form * add search select with modal to entity form * update group form; * allow modal to fit-content * add changelog * add check for policy create ability * add id so tests pass * filter out root option * fix test * add cleanup method * add ACL policy link * cleanup from comments * refactor sending action to parent * refactor, data down actions up! * cleanup comments * form field refactor * add ternary to options * update tests * Remodel component structure for clearer logic Includes fixing the wizard * address comments * cleanup args * refactor inline oidc assignment form * add line break * cleanup comments * fix tests * add policy template to ss+modal test * cleanup =true from test * final cleanup!!!!!! * actual final cleanup * fix typo, please be done Co-authored-by: Chelsea Shaw <82459713+hashishaw@users.noreply.github.com>
55 lines
1.6 KiB
JavaScript
55 lines
1.6 KiB
JavaScript
import { hasMany, attr } from '@ember-data/model';
|
|
import { computed } from '@ember/object';
|
|
import { alias } from '@ember/object/computed';
|
|
import IdentityModel from './_base';
|
|
import apiPath from 'vault/utils/api-path';
|
|
import attachCapabilities from 'vault/lib/attach-capabilities';
|
|
import lazyCapabilities from 'vault/macros/lazy-capabilities';
|
|
|
|
const Model = IdentityModel.extend({
|
|
formFields: computed(function () {
|
|
return ['name', 'disabled', 'policies', 'metadata'];
|
|
}),
|
|
name: attr('string'),
|
|
disabled: attr('boolean', {
|
|
defaultValue: false,
|
|
label: 'Disable entity',
|
|
helpText: 'All associated tokens cannot be used, but are not revoked.',
|
|
}),
|
|
mergedEntityIds: attr(),
|
|
metadata: attr({
|
|
editType: 'kv',
|
|
}),
|
|
policies: attr({
|
|
editType: 'yield',
|
|
isSectionHeader: true,
|
|
}),
|
|
creationTime: attr('string', {
|
|
readOnly: true,
|
|
}),
|
|
lastUpdateTime: attr('string', {
|
|
readOnly: true,
|
|
}),
|
|
aliases: hasMany('identity/entity-alias', { async: false, readOnly: true }),
|
|
groupIds: attr({
|
|
readOnly: true,
|
|
}),
|
|
directGroupIds: attr({
|
|
readOnly: true,
|
|
}),
|
|
inheritedGroupIds: attr({
|
|
readOnly: true,
|
|
}),
|
|
canDelete: alias('updatePath.canDelete'),
|
|
canEdit: alias('updatePath.canUpdate'),
|
|
canRead: alias('updatePath.canRead'),
|
|
canAddAlias: alias('aliasPath.canCreate'),
|
|
policyPath: lazyCapabilities(apiPath`sys/policies`),
|
|
canCreatePolicies: alias('policyPath.canCreate'),
|
|
});
|
|
|
|
export default attachCapabilities(Model, {
|
|
updatePath: apiPath`identity/entity/id/${'id'}`,
|
|
aliasPath: apiPath`identity/entity-alias`,
|
|
});
|