Nomad Client for NodeJS.
Includes built-in paramater, querystring and body checking - helps in preventing fires.
Currently used in our Production. (This version may contain issues that are fixed internally, raise an issue if we haven't noticed the issue.)
- Install
npm install @chatsight/hostel
- Construct
const Hostel = require('@chatsight/hostel')
const fs = require('fs')
const main = async () => {
var nomadAPI = new Hostel({
connection:{
hostname: "...", //Don't include the protocol (i.e. https://) here.
port: "4646",
sslEnabled: true, //Use HTTPS
ssl:{
privateKey: fs.readFileSync('/secrets/...'),
cert: fs.readFileSync('/secrets/...'),
ca: fs.readFileSync('/secrets/...'),
},
/* WARNING: Use process.env.NOMAD_TOKEN instead for the secretID, this is left here for only versions <=1.0.2 */
secretID: "s.70697a7a61", // Secret ID. No, this is not an actual key.
/**/
ignoreSecretTLSWarning: false, // Prevent Client from sending SecretID if HTTP is accidently selected. Set to true to ignore.
ignoreTLSWarning: false // Ignore HTTPS Unauthorized warning by setting to true.
},
timeouts:{
request: 20000 // Timeout in MS for requests made to the Nomad Cluster.
}
})
}
main()
- Go!
...(async function)
await nomadAPI.jobs.list().then(k => {console.log(k)})
...
- As close to 1:1 binding with official REST API bindings.
- Currently supporting:
- Allocations
- List
- Read
- Stop
- Signal
- Restart
- Jobs
- List
- Read
- Create // Standard JSON Object (Stringification not required).
- Parse // Pass HCL/HCL2 file from fs.readFileSync(), then convert Buffer to string. Do not Stringify.
- Update
- Stop
- Revert
- Plan
- Nodes
- List
- Read
- Drain
- Purge
- Eligibility
- System
- Force GC
- Allocations
All commands follow a chainable hierarchy to their root node. Every function returns an async promise.
Hostel.prototype.<api>.<function>()
...
nomadAPI.jobs.list()
...
nomadAPI.allocations.read()
...
nomadAPI.nodes.drain()
URI Parameters, Body Properties, and Query String Parameters are flattened with this API. To ensure this isn't a problem, schema.js
that is included in this library ensures each variable is placed in the right location to make the request to your Nomad Cluster.
- Payload Body Properties retain the same Capitlization and spelling as displayed on the REST Documentation.
- URI Parameters now use a "camelCase" type setting. This means for example
node_id
becomesnodeId
,job_id
becomesjobId
,alloc_id
becomesallocId
. - Query String Parameters retain the same Capitlization and spelling as displayed on the REST Documentation.
... //Example
nomadAPI.nodes.eligibility({
nodeId: "00000-0000-0000-00000",
Eligibility: "eligible",
})
...
All functions (except .hostel chain functions (i.e. nomadAPI.hostel.supportedActions()
) return an array with two elements. A boolean success indicator, and the response from the Nomad Cluster as a preparsed Array containing Object(s).
... //Fetching Jobs from the Nomad Cluster
await nomadAPI.jobs.list().then(k => {console.log(k)})
... //Example Response
[
true,
[
{
ID: 'ice-cream-machine-magic',
ParentID: '',
Name: 'ice-cream-machine-magic',
Namespace: '',
Datacenters: [...],
Multiregion: null,
Type: 'service',
Priority: 100,
Periodic: false,
ParameterizedJob: false,
Stop: false,
Status: 'running',
StatusDescription: '',
JobSummary: {...},
CreateIndex: 57,
ModifyIndex: 65306,
JobModifyIndex: 65287,
SubmitTime: 1619192045653244200
},
...
]
]
...
Example: Parsing a HCL file to an Object.
...
var hclFile = (fs.readFileSync('./job.hcl')).toString()
await nomadAPI.jobs.parse({
JobHCL: hclFile,
Canonicalize: true
}).then(k => {
// k[1] contains the HCL file submitted, now parsed as JSON, represented by an Object
})
...
Example: Creating a Job with our HCL converted already to JSON from above.
...
var hclFile = (fs.readFileSync('./job.hcl')).toString()
await nomadAPI.jobs.parse({
JobHCL: hclFile,
Canonicalize: true
}).then(async k => {
var settings = {
name: "ice-cream-machine-job",
cpu: 1000,
memory: 1000,
container: '<some container>'
}
var nj = k[1]
nj.ID = settings.name
nj.Name = settings.name
nj.TaskGroups[0].Tasks[0].Resources.CPU = settings.cpu
nj.TaskGroups[0].Tasks[0].Resources.MemoryMB = settings.memory
nj.TaskGroups[0].Tasks[0].Config.image = settings.container
await nomadAPI.jobs.create({
Job: nj
}).then(k => {
console.log(k)
})
})
...
If you wish to add features we haven't gotten to yet, you can pretty easily do so by;
i) Fork the repo.
ii) Add the new feature chain to schema.js
iii) Add a new Function property to the API Chain within the Class.
iv) Merge back if you're feeling nice.