mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 21:35:52 +00:00
bce724baf1
* ui: Don't show the CRD menu for read-only intentions The UI bug here manifests itself only when a user/token is configured to have read-only access to intentions. Instead of only letting folks click to see a read only page of the intention, we would show an additional message saying that the intention was read-only due to it being 'Managed by [a kubernetes] CRD'. Whilst the intention was still read only, this extra message was still confusing for users. This PR fixes up the conditional logic and further moves the logic to use ember-can - looking at the history of the files in question, this bug snuck itself in partly due to it being 'permission-y type stuff' previous to using ember-can and when something being editable or not was nothing to do with ACLs. Then we moved to start using ember-can without completely realising what IsEditable previously meant. So overall the code here is a tiny bit clearer/cleaner by adding a proper can view CRD intention instead of overloading the idea of 'editability'.
45 lines
1.5 KiB
JavaScript
45 lines
1.5 KiB
JavaScript
import Model, { attr } from '@ember-data/model';
|
|
import { computed } from '@ember/object';
|
|
import { fragmentArray } from 'ember-data-model-fragments/attributes';
|
|
import { nullValue } from 'consul-ui/decorators/replace';
|
|
|
|
export const PRIMARY_KEY = 'uid';
|
|
export const SLUG_KEY = 'ID';
|
|
|
|
export default class Intention extends Model {
|
|
@attr('string') uid;
|
|
@attr('string') ID;
|
|
|
|
@attr('string') Datacenter;
|
|
@attr('string') Description;
|
|
|
|
@attr('string', { defaultValue: () => '*' }) SourceName;
|
|
@attr('string', { defaultValue: () => '*' }) DestinationName;
|
|
@attr('string', { defaultValue: () => 'default' }) SourceNS;
|
|
@attr('string', { defaultValue: () => 'default' }) DestinationNS;
|
|
@attr('string', { defaultValue: () => 'default' }) SourcePartition;
|
|
@attr('string', { defaultValue: () => 'default' }) DestinationPartition;
|
|
|
|
@attr('number') Precedence;
|
|
@attr('string', { defaultValue: () => 'consul' }) SourceType;
|
|
@nullValue(undefined) @attr('string') Action;
|
|
@attr('string') LegacyID;
|
|
@attr('boolean', { defaultValue: () => true }) Legacy;
|
|
@attr('number') SyncTime;
|
|
@attr('date') CreatedAt;
|
|
@attr('date') UpdatedAt;
|
|
@attr('number') CreateIndex;
|
|
@attr('number') ModifyIndex;
|
|
@attr() Meta; // {}
|
|
@attr({ defaultValue: () => [] }) Resources; // []
|
|
@fragmentArray('intention-permission') Permissions;
|
|
|
|
@computed('Meta')
|
|
get IsManagedByCRD() {
|
|
const meta = Object.entries(this.Meta || {}).find(
|
|
([key, value]) => key === 'external-source' && value === 'kubernetes'
|
|
);
|
|
return typeof meta !== 'undefined';
|
|
}
|
|
}
|