81f209d71e
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)
59 lines
1.6 KiB
JavaScript
59 lines
1.6 KiB
JavaScript
import RepositoryService from 'consul-ui/services/repository';
|
|
import { get } from '@ember/object';
|
|
import { Promise } from 'rsvp';
|
|
import { PRIMARY_KEY, SLUG_KEY } from 'consul-ui/models/token';
|
|
import statusFactory from 'consul-ui/utils/acls-status';
|
|
import isValidServerErrorFactory from 'consul-ui/utils/http/acl/is-valid-server-error';
|
|
|
|
const isValidServerError = isValidServerErrorFactory();
|
|
const status = statusFactory(isValidServerError, Promise);
|
|
const MODEL_NAME = 'token';
|
|
|
|
export default RepositoryService.extend({
|
|
getModelName: function() {
|
|
return MODEL_NAME;
|
|
},
|
|
getPrimaryKey: function() {
|
|
return PRIMARY_KEY;
|
|
},
|
|
getSlugKey: function() {
|
|
return SLUG_KEY;
|
|
},
|
|
status: function(obj) {
|
|
return status(obj);
|
|
},
|
|
self: function(secret, dc) {
|
|
return get(this, 'store')
|
|
.self(this.getModelName(), {
|
|
secret: secret,
|
|
dc: dc,
|
|
})
|
|
.catch(e => {
|
|
// If we get this 500 RPC error, it means we are a legacy ACL cluster
|
|
// set AccessorID to null - which for the frontend means legacy mode
|
|
if (isValidServerError(e)) {
|
|
return {
|
|
AccessorID: null,
|
|
SecretID: secret,
|
|
};
|
|
}
|
|
return Promise.reject(e);
|
|
});
|
|
},
|
|
clone: function(item) {
|
|
return get(this, 'store').clone(this.getModelName(), get(item, PRIMARY_KEY));
|
|
},
|
|
findByPolicy: function(id, dc) {
|
|
return get(this, 'store').query(this.getModelName(), {
|
|
policy: id,
|
|
dc: dc,
|
|
});
|
|
},
|
|
findByRole: function(id, dc) {
|
|
return get(this, 'store').query(this.getModelName(), {
|
|
role: id,
|
|
dc: dc,
|
|
});
|
|
},
|
|
});
|