4394c5b9ff
This extracts some common API-idiosyncracy-handling patterns from model serialisers into properties that are processed by the application serialiser: * arrayNullOverrides converts a null property value to an empty array * mapToArray converts a map to an array of maps, using the original map keys as Name properties on the array maps * separateNanos splits nanosecond-containing timestamps into millisecond timestamps and separate nanosecond properties
25 lines
688 B
JavaScript
25 lines
688 B
JavaScript
import { inject as service } from '@ember/service';
|
|
import { get } from '@ember/object';
|
|
import ApplicationSerializer from './application';
|
|
import classic from 'ember-classic-decorator';
|
|
|
|
@classic
|
|
export default class Evaluation extends ApplicationSerializer {
|
|
@service system;
|
|
|
|
mapToArray = ['FailedTGAllocs'];
|
|
separateNanos = ['CreateTime', 'ModifyTime'];
|
|
|
|
normalize(typeHash, hash) {
|
|
hash.PlainJobId = hash.JobID;
|
|
hash.Namespace =
|
|
hash.Namespace ||
|
|
get(hash, 'Job.Namespace') ||
|
|
this.get('system.activeNamespace.id') ||
|
|
'default';
|
|
hash.JobID = JSON.stringify([hash.JobID, hash.Namespace]);
|
|
|
|
return super.normalize(typeHash, hash);
|
|
}
|
|
}
|