mirror of
https://github.com/status-im/consul.git
synced 2025-01-23 12:11:05 +00:00
53b30dda4d
* ui: Use `X-Range` header/meta to decide whether to reconcile or not Previously we used a `shouldReconcile` method in order to decide whether a response should trigger a reconciliation of the frontend ember-data 'source of truth' or not. It's a lot nicer/clearer if this 'flag' can be set alongside the HTTP request information, moreover we almost have the same functionality in `If-Range`/`Partial Content` HTTP functionality. Here we partly follow this HTTP semantics but use a custom `X-Range` header instead.
92 lines
2.8 KiB
JavaScript
92 lines
2.8 KiB
JavaScript
import Service, { inject as service } from '@ember/service';
|
|
import { assert } from '@ember/debug';
|
|
import { typeOf } from '@ember/utils';
|
|
import { get } from '@ember/object';
|
|
|
|
export default Service.extend({
|
|
getModelName: function() {
|
|
assert('RepositoryService.getModelName should be overridden', false);
|
|
},
|
|
getPrimaryKey: function() {
|
|
assert('RepositoryService.getPrimaryKey should be overridden', false);
|
|
},
|
|
getSlugKey: function() {
|
|
assert('RepositoryService.getSlugKey should be overridden', false);
|
|
},
|
|
//
|
|
store: service('store'),
|
|
reconcile: function(meta = {}) {
|
|
// unload anything older than our current sync date/time
|
|
if (typeof meta.date !== 'undefined') {
|
|
const checkNspace = meta.nspace !== '';
|
|
this.store.peekAll(this.getModelName()).forEach(item => {
|
|
const dc = get(item, 'Datacenter');
|
|
if (dc === meta.dc) {
|
|
if (checkNspace) {
|
|
const nspace = get(item, 'Namespace');
|
|
if (nspace !== meta.namespace) {
|
|
return;
|
|
}
|
|
}
|
|
const date = get(item, 'SyncTime');
|
|
if (!item.isDeleted && typeof date !== 'undefined' && date != meta.date) {
|
|
this.store.unloadRecord(item);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
},
|
|
peekOne: function(id) {
|
|
return this.store.peekRecord(this.getModelName(), id);
|
|
},
|
|
findAllByDatacenter: function(dc, nspace, configuration = {}) {
|
|
const query = {
|
|
dc: dc,
|
|
ns: nspace,
|
|
};
|
|
if (typeof configuration.cursor !== 'undefined') {
|
|
query.index = configuration.cursor;
|
|
query.uri = configuration.uri;
|
|
}
|
|
return this.store.query(this.getModelName(), query);
|
|
},
|
|
findBySlug: function(slug, dc, nspace, configuration = {}) {
|
|
const query = {
|
|
dc: dc,
|
|
ns: nspace,
|
|
id: slug,
|
|
};
|
|
if (typeof configuration.cursor !== 'undefined') {
|
|
query.index = configuration.cursor;
|
|
query.uri = configuration.uri;
|
|
}
|
|
return this.store.queryRecord(this.getModelName(), query);
|
|
},
|
|
create: function(obj) {
|
|
// TODO: This should probably return a Promise
|
|
return this.store.createRecord(this.getModelName(), obj);
|
|
},
|
|
persist: function(item) {
|
|
return item.save();
|
|
},
|
|
remove: function(obj) {
|
|
let item = obj;
|
|
if (typeof obj.destroyRecord === 'undefined') {
|
|
item = obj.get('data');
|
|
}
|
|
// TODO: Change this to use vanilla JS
|
|
// I think this was originally looking for a plain object
|
|
// as opposed to an ember one
|
|
if (typeOf(item) === 'object') {
|
|
item = this.store.peekRecord(this.getModelName(), item[this.getPrimaryKey()]);
|
|
}
|
|
return item.destroyRecord().then(item => {
|
|
return this.store.unloadRecord(item);
|
|
});
|
|
},
|
|
invalidate: function() {
|
|
// TODO: This should probably return a Promise
|
|
this.store.unloadAll(this.getModelName());
|
|
},
|
|
});
|