mirror of
https://github.com/status-im/consul.git
synced 2025-01-25 21:19:12 +00:00
482426b13e
Adds support for ACL Roles and Service Identities CRUD, along with necessary changes to Tokens, and the CSS improvements required. Also includes refinements/improvements for easier testing of deeply nested components. 1. ember-data adapter/serializer/model triplet for Roles 2. repository, form/validations and searching filter for Roles 3. Moves potentially, repeated, or soon to to repeated functionality into a mixin (mainly for 'many policy' relationships) 4. A few styling tweaks for little edge cases around roles 5. Router additions, Route, Controller and templates for Roles Also see: * UI: ACL Roles cont. plus Service Identities (#5661 and #5720)
61 lines
1.3 KiB
JavaScript
61 lines
1.3 KiB
JavaScript
import Model from 'ember-data/model';
|
|
import attr from 'ember-data/attr';
|
|
import writable from 'consul-ui/utils/model/writable';
|
|
|
|
export const PRIMARY_KEY = 'uid';
|
|
export const SLUG_KEY = 'AccessorID';
|
|
|
|
const model = Model.extend({
|
|
[PRIMARY_KEY]: attr('string'),
|
|
[SLUG_KEY]: attr('string'),
|
|
IDPName: attr('string'),
|
|
SecretID: attr('string'),
|
|
// Legacy
|
|
Type: attr('string'),
|
|
Name: attr('string', {
|
|
defaultValue: '',
|
|
}),
|
|
Rules: attr('string'),
|
|
// End Legacy
|
|
Legacy: attr('boolean'),
|
|
Description: attr('string', {
|
|
defaultValue: '',
|
|
}),
|
|
Datacenter: attr('string'),
|
|
Local: attr('boolean'),
|
|
Policies: attr({
|
|
defaultValue: function() {
|
|
return [];
|
|
},
|
|
}),
|
|
Roles: attr({
|
|
defaultValue: function() {
|
|
return [];
|
|
},
|
|
}),
|
|
ServiceIdentities: attr({
|
|
defaultValue: function() {
|
|
return [];
|
|
},
|
|
}),
|
|
CreateTime: attr('date'),
|
|
Hash: attr('string'),
|
|
CreateIndex: attr('number'),
|
|
ModifyIndex: attr('number'),
|
|
});
|
|
// Name and Rules is only for legacy tokens
|
|
export const ATTRS = writable(model, [
|
|
'Name',
|
|
'Rules',
|
|
'Type',
|
|
'Local',
|
|
'Description',
|
|
'Policies',
|
|
'Roles',
|
|
// SecretID isn't writable but we need it to identify an
|
|
// update via the old API, see TokenAdapter dataForRequest
|
|
'SecretID',
|
|
'AccessorID',
|
|
]);
|
|
export default model;
|