node-helm
was created for javascript developers who work with helm.sh package manager for Kubernetes.
The package is a wrapper that integrates with the helm.sh process.
npm install --save DaPulse/node-helm#master
Setup your helm.sh file location - for linux or windows
let helmBinary = '/usr/local/bin/helm';
if (process.platform === "win32") {
helmBinary = 'helm';
}
require Helm class
let Promise = require("bluebird");
const Helm = require("node-helm").Helm;
let helm = Promise.promisifyAll(new Helm({helmCommand: helmBinary}));
https://docs.helm.sh/helm/#helm-list
let options = {}; //No options available currently
let releases = await helm.listAsync(options);
https://docs.helm.sh/helm/#helm-get
let options = {
releaseName = 'service';
}
let history = await helm.getAsync(options);
https://docs.helm.sh/helm/#helm-install
let options = {
chartName: "CHARTNAME",
releaseName: "SERVICENAME",
namespace: "dev",
//custom values
values: {
"authKey":"20FD87EA-A679-4817-AFA4-E5CC17712456"
}
};
return installation = await helm.installAsync(options);
https://docs.helm.sh/helm/#helm-upgrade
return await helm.upgradeAsync({
reuseValues : shouldReuseValues, //boolean value
chartName: "./ChartFolder",
releaseName: SERVICENAME,
values: {
"authKey":"20FD87EA-A679-4817-AFA4-E5CC17712456"
}
});
https://docs.helm.sh/helm/#helm-delete
var options = {
shouldPurge : true,
releaseName: 'service'
}
return await helm.deleteAsync(options);
https://docs.helm.sh/helm/#helm-history
let options = {
releaseName = 'service';
}
let history = await helm.historyAsync(options);
https://docs.helm.sh/helm/#helm-test
let options = {
releaseName = 'service'
}
let test = await helm.testAsync(options);
https://docs.helm.sh/helm/#helm-rollback
let options = {
releaseName = 'service',
revision: 0
};
let rollback = await helm.rollbackAsync(options);
https://docs.helm.sh/helm/#helm-status
let options = {
releaseName = 'service';
}
let status = await helm.statusAsync(options);