ui: Address some Admin Partition FIXMEs (#11057)

This commit addresses some left over admin partition FIXMEs

1. Adds Partition correctly to Service Instances
2. Converts non-important 'we can do this later' FIXMEs to TODOs
3. Removes some FIXMEs that I've double checked and addressed.

Most of the remaining FIXMEs I'm waiting on responses to questions from
the consul core folks for. I'll address those in a separate PR.
pull/11199/head
John Cowen 2021-10-01 11:07:58 +01:00 committed by GitHub
parent 887a23deb1
commit 8b002d086a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 27 additions and 14 deletions

View File

@ -2,7 +2,6 @@ import Adapter from './application';
// Blocking query support for partitions is currently disabled // Blocking query support for partitions is currently disabled
export default class PartitionAdapter extends Adapter { export default class PartitionAdapter extends Adapter {
// FIXME: Check overall hierarchy again
async requestForQuery(request, { ns, dc, index }) { async requestForQuery(request, { ns, dc, index }) {
const respond = await request` const respond = await request`
GET /v1/partitions?${{ dc }} GET /v1/partitions?${{ dc }}
@ -12,7 +11,7 @@ export default class PartitionAdapter extends Adapter {
await respond((headers, body) => delete headers['x-consul-index']); await respond((headers, body) => delete headers['x-consul-index']);
return respond; return respond;
} }
// TODO: Not used until we do Partition CRUD
async requestForQueryRecord(request, { ns, dc, index, id }) { async requestForQueryRecord(request, { ns, dc, index, id }) {
if (typeof id === 'undefined') { if (typeof id === 'undefined') {
throw new Error('You must specify an id'); throw new Error('You must specify an id');

View File

@ -4,7 +4,7 @@
focus=(action 'focus') focus=(action 'focus')
)}} )}}
<Guard @name="hasValue" @cond={{action 'hasValue'}} /> <Guard @name="hasValue" @cond={{action 'hasValue'}} />
{{!FIXME: Call this reset or similar }} {{!TODO: Call this reset or similar }}
<Action @name="clearError" @exec={{queue (action (mut error) undefined) (action (mut secret) undefined)}} /> <Action @name="clearError" @exec={{queue (action (mut error) undefined) (action (mut secret) undefined)}} />
<div class="auth-form" ...attributes> <div class="auth-form" ...attributes>
<State @matches="error"> <State @matches="error">

View File

@ -3,6 +3,7 @@ import { inject as service } from '@ember/service';
import { tracked } from '@glimmer/tracking'; import { tracked } from '@glimmer/tracking';
import { action, get } from '@ember/object'; import { action, get } from '@ember/object';
import { schedule } from '@ember/runloop'; import { schedule } from '@ember/runloop';
import { runInDebug } from '@ember/debug';
/** /**
* Utility function to set, but actually replace if we should replace * Utility function to set, but actually replace if we should replace
@ -89,7 +90,8 @@ export default class DataSource extends Component {
@action @action
disconnect() { disconnect() {
// FIXME? Should we be doing this here // TODO: Should we be doing this here? Fairly sure we should be so if this
// TODO gets old enough (6 months/ 1 year or so) feel free to remove
if ( if (
typeof this.data !== 'undefined' && typeof this.data !== 'undefined' &&
typeof this.data.length === 'undefined' && typeof this.data.length === 'undefined' &&
@ -182,7 +184,12 @@ export default class DataSource extends Component {
this.source.readyState = 2; this.source.readyState = 2;
this.disconnect(); this.disconnect();
schedule('afterRender', () => { schedule('afterRender', () => {
// FIXME: Lazy data-sources // TODO: Support lazy data-sources by keeping a reference to $el
runInDebug(_ =>
console.error(
`Invalidation is only supported for non-lazy data sources. If you want to use this you should fixup support for lazy data sources`
)
);
this.connect([]); this.connect([]);
}); });
} }

View File

@ -72,7 +72,6 @@
}} }}
@onchange={{action (mut this.partitions) value="data"}} @onchange={{action (mut this.partitions) value="data"}}
/> />
{{!FIXME: Do partitions do the same as namespace deletion? }}
{{#each (reject-by 'DeletedAt' this.partitions) as |item|}} {{#each (reject-by 'DeletedAt' this.partitions) as |item|}}
<MenuItem <MenuItem
class={{if (eq @partition item.Name) 'is-active'}} class={{if (eq @partition item.Name) 'is-active'}}

View File

@ -29,7 +29,7 @@ export default Component.extend({
}, },
}; };
}; };
// FIXME: We should probably put the component into idle state // TODO: We should probably put the component into idle state
this.onchange(e); this.onchange(e);
}, },
}, },

View File

@ -50,9 +50,7 @@ export default class ServiceInstance extends Model {
@alias('Service.Tags') Tags; @alias('Service.Tags') Tags;
@alias('Service.Meta') Meta; @alias('Service.Meta') Meta;
@alias('Service.Namespace') Namespace; @alias('Service.Namespace') Namespace;
@alias('Service.Partition') Partition;
// FIXME: Is parition top level or Service.Partition?
@attr('string') Partition;
@filter('Checks.@each.Kind', (item, i, arr) => item.Kind === 'service') ServiceChecks; @filter('Checks.@each.Kind', (item, i, arr) => item.Kind === 'service') ServiceChecks;
@filter('Checks.@each.Kind', (item, i, arr) => item.Kind === 'node') NodeChecks; @filter('Checks.@each.Kind', (item, i, arr) => item.Kind === 'node') NodeChecks;

View File

@ -84,7 +84,10 @@ export default class BaseRoute extends Route {
return value; return value;
} }
// FIXME: this is only required due to intention_id trying to do too much // TODO: this is only required due to intention_id trying to do too much
// therefore we need to change the route parameter intention_id to just
// intention or id or similar then we can revert to only returning a model if
// we have searchProps (or a child route overwrites model)
model() { model() {
const model = {}; const model = {};
if ( if (

View File

@ -11,6 +11,14 @@ export default class HttpService extends Service {
return setProperties(instance, data); return setProperties(instance, data);
} }
// TODO: Currently we don't use the other properties here So dc, nspace and
// partition, but confusingly they currently are in a different order to all
// our @dataSource uris @dataSource uses /:partition/:nspace/:dc/thing whilst
// here DataSink uses /:parition/:dc/:nspace/thing We should change DataSink
// to also use a @dataSink decorator and make sure the order of the parameters
// is the same throughout the app As it stands right now, if we do need to use
// those parameters for DataSink it will be very easy to introduce a bug due
// to this inconsistency
persist(sink, instance) { persist(sink, instance) {
const [, , , , model] = sink.split('/'); const [, , , , model] = sink.split('/');
const repo = this[model]; const repo = this[model];

View File

@ -18,10 +18,10 @@ export default class DcService extends RepositoryService {
const items = this.store.peekAll('dc'); const items = this.store.peekAll('dc');
const item = items.findBy('Name', params.name); const item = items.findBy('Name', params.name);
if (typeof item === 'undefined') { if (typeof item === 'undefined') {
// FIXME: HTTPError // TODO: We should use a HTTPError error here and remove all occurances of
// the custom shaped ember-data error throughout the app
const e = new Error('Page not found'); const e = new Error('Page not found');
e.status = '404'; e.status = '404';
// FIXME: EDError
throw { errors: [e] }; throw { errors: [e] };
} }
return item; return item;

View File

@ -56,7 +56,6 @@ as |route|>
@filter={{filters}} @filter={{filters}}
/> />
{{/if}} {{/if}}
{{!FIXME: Check param order }}
<DataWriter <DataWriter
@sink={{uri @sink={{uri
'/${partition}/${dc}/${nspace}/intention/' '/${partition}/${dc}/${nspace}/intention/'