462c6653ac
* Allow running jobs from a namespace-limited token * qpNamespace cleanup * Looks like parse can deal with a * namespace * A little diff cleanup * Defensive destructuring * Removing accidental friendly-fire on can-scale * Testfix: Job run buttons from jobs index * Testfix: activeRegion job adapter string * Testfix: unit tests for job abilities correctly reflect the any-namespace rule * Testfix: job editor test looks for requests with namespace applied on plan
110 lines
2.6 KiB
JavaScript
110 lines
2.6 KiB
JavaScript
import WatchableNamespaceIDs from './watchable-namespace-ids';
|
|
import addToPath from 'nomad-ui/utils/add-to-path';
|
|
import { base64EncodeString } from 'nomad-ui/utils/encode';
|
|
import classic from 'ember-classic-decorator';
|
|
|
|
@classic
|
|
export default class JobAdapter extends WatchableNamespaceIDs {
|
|
relationshipFallbackLinks = {
|
|
summary: '/summary',
|
|
};
|
|
|
|
fetchRawDefinition(job) {
|
|
const url = this.urlForFindRecord(job.get('id'), 'job');
|
|
return this.ajax(url, 'GET');
|
|
}
|
|
|
|
forcePeriodic(job) {
|
|
if (job.get('periodic')) {
|
|
const url = addToPath(
|
|
this.urlForFindRecord(job.get('id'), 'job'),
|
|
'/periodic/force'
|
|
);
|
|
return this.ajax(url, 'POST');
|
|
}
|
|
}
|
|
|
|
stop(job) {
|
|
const url = this.urlForFindRecord(job.get('id'), 'job');
|
|
return this.ajax(url, 'DELETE');
|
|
}
|
|
|
|
parse(spec) {
|
|
const url = addToPath(this.urlForFindAll('job'), '/parse?namespace=*');
|
|
return this.ajax(url, 'POST', {
|
|
data: {
|
|
JobHCL: spec,
|
|
Canonicalize: true,
|
|
},
|
|
});
|
|
}
|
|
|
|
plan(job) {
|
|
const jobId = job.get('id') || job.get('_idBeforeSaving');
|
|
const store = this.store;
|
|
const url = addToPath(this.urlForFindRecord(jobId, 'job'), '/plan');
|
|
|
|
return this.ajax(url, 'POST', {
|
|
data: {
|
|
Job: job.get('_newDefinitionJSON'),
|
|
Diff: true,
|
|
},
|
|
}).then((json) => {
|
|
json.ID = jobId;
|
|
store.pushPayload('job-plan', { jobPlans: [json] });
|
|
return store.peekRecord('job-plan', jobId);
|
|
});
|
|
}
|
|
|
|
// Running a job doesn't follow REST create semantics so it's easier to
|
|
// treat it as an action.
|
|
run(job) {
|
|
return this.ajax(this.urlForCreateRecord('job'), 'POST', {
|
|
data: {
|
|
Job: job.get('_newDefinitionJSON'),
|
|
},
|
|
});
|
|
}
|
|
|
|
update(job) {
|
|
const jobId = job.get('id') || job.get('_idBeforeSaving');
|
|
return this.ajax(this.urlForUpdateRecord(jobId, 'job'), 'POST', {
|
|
data: {
|
|
Job: job.get('_newDefinitionJSON'),
|
|
},
|
|
});
|
|
}
|
|
|
|
scale(job, group, count, message) {
|
|
const url = addToPath(
|
|
this.urlForFindRecord(job.get('id'), 'job'),
|
|
'/scale'
|
|
);
|
|
return this.ajax(url, 'POST', {
|
|
data: {
|
|
Count: count,
|
|
Message: message,
|
|
Target: {
|
|
Group: group,
|
|
},
|
|
Meta: {
|
|
Source: 'nomad-ui',
|
|
},
|
|
},
|
|
});
|
|
}
|
|
|
|
dispatch(job, meta, payload) {
|
|
const url = addToPath(
|
|
this.urlForFindRecord(job.get('id'), 'job'),
|
|
'/dispatch'
|
|
);
|
|
return this.ajax(url, 'POST', {
|
|
data: {
|
|
Payload: base64EncodeString(payload),
|
|
Meta: meta,
|
|
},
|
|
});
|
|
}
|
|
}
|