35d65c7c7e
Fixes #14617 Dynamic Node Metadata allows Nomad users, and their jobs, to update Node metadata through an API. Currently Node metadata is only reloaded when a Client agent is restarted. Includes new UI for editing metadata as well. --------- Co-authored-by: Phil Renaud <phil.renaud@hashicorp.com>
72 lines
1.5 KiB
JavaScript
72 lines
1.5 KiB
JavaScript
import Watchable from './watchable';
|
|
import addToPath from 'nomad-ui/utils/add-to-path';
|
|
import classic from 'ember-classic-decorator';
|
|
|
|
@classic
|
|
export default class NodeAdapter extends Watchable {
|
|
setEligible(node) {
|
|
return this.setEligibility(node, true);
|
|
}
|
|
|
|
setIneligible(node) {
|
|
return this.setEligibility(node, false);
|
|
}
|
|
|
|
setEligibility(node, isEligible) {
|
|
const url = addToPath(
|
|
this.urlForFindRecord(node.id, 'node'),
|
|
'/eligibility'
|
|
);
|
|
return this.ajax(url, 'POST', {
|
|
data: {
|
|
NodeID: node.id,
|
|
Eligibility: isEligible ? 'eligible' : 'ineligible',
|
|
},
|
|
});
|
|
}
|
|
|
|
// Force: -1s deadline
|
|
// No Deadline: 0 deadline
|
|
drain(node, drainSpec) {
|
|
const url = addToPath(this.urlForFindRecord(node.id, 'node'), '/drain');
|
|
return this.ajax(url, 'POST', {
|
|
data: {
|
|
NodeID: node.id,
|
|
DrainSpec: Object.assign(
|
|
{
|
|
Deadline: 0,
|
|
IgnoreSystemJobs: true,
|
|
},
|
|
drainSpec
|
|
),
|
|
},
|
|
});
|
|
}
|
|
|
|
forceDrain(node, drainSpec) {
|
|
return this.drain(
|
|
node,
|
|
Object.assign({}, drainSpec, {
|
|
Deadline: -1,
|
|
})
|
|
);
|
|
}
|
|
|
|
cancelDrain(node) {
|
|
const url = addToPath(this.urlForFindRecord(node.id, 'node'), '/drain');
|
|
return this.ajax(url, 'POST', {
|
|
data: {
|
|
NodeID: node.id,
|
|
DrainSpec: null,
|
|
},
|
|
});
|
|
}
|
|
|
|
addMeta(node, newMeta) {
|
|
const url = `/v1/client/metadata?node_id=${node.id}`;
|
|
return this.ajax(url, 'POST', {
|
|
data: { Meta: newMeta },
|
|
});
|
|
}
|
|
}
|