diff --git a/package.json b/package.json index e93f8c9..5ee7150 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@thinkdeep/k8s", - "version": "3.0.3", + "version": "3.0.4", "description": "K8s node client tag for processing yaml configurations in javascript code.", "main": "src/k8s-client.mjs", "repository": "git@github.com:ThinkDeepTech/k8s.git", diff --git a/src/k8s-client.mjs b/src/k8s-client.mjs index 31a917f..bd516cc 100644 --- a/src/k8s-client.mjs +++ b/src/k8s-client.mjs @@ -11,12 +11,39 @@ class K8sClient { this._api = new K8sApi(); } + /** + * Initialize the K8sClient for use. + * + * Usage: + * const client = await new K8sClient().init(); + * + * @returns Promise that resolves to the K8sClient instance. + */ async init() { await this._api.init(this._kubeConfig); return this; } + /** + * Determine if an object exists on the cluster. + * @param {String} kind The k8s kind (i.e, CronJob). + * @param {String} name The name of the object as seen in the k8s metadata name field. + * @param {String} namespace The k8s object's namespace. + * @returns True if the object exists. False otherwise. + */ + async exists(kind, name, namespace) { + return this._api.exists(kind, name, namespace); + } + + /** + * Create an array of objects on your k8s cluster. + * + * NOTE: If a specific order for the objects being created is required by kubernetes this function will fail unless the array is ordered as needed. + * + * @param {Array | Array} configurations Accepted configurations include either valid yaml strings of the same form accepted by kubectl or kubernetes javascript API objects (i.e, k8s.V1CronJob). Make sure the kind and apiVersion fields are populated. + * @returns Array of k8s javascript client objects of the associated form (i.e, k8s.V1CronJob for kind CronJob, etc). + */ async createAll(configurations) { const targets = []; @@ -27,6 +54,12 @@ class K8sClient { return targets; } + /** + * Create an object on your k8s cluster. + * + * @param {String | any} configuration Accepted configuration includes either a valid yaml string of the same form accepted by kubectl or a kubernetes javascript API object (i.e, k8s.V1CronJob). Make sure the kind and apiVersion fields are populated. + * @returns The k8s javascript client object returned from the API or the manifest as constructed by the configuration. The latter case is necessary in the event that creation actually doesn't occur because the object already exists. + */ async create (configuration) { const manifest = this._manifest(configuration); @@ -34,6 +67,12 @@ class K8sClient { return (await this._api.createAll([manifest]))[0] || manifest; } + /** + * Create or update an array of configurations. This command has similar meaning to kubectl apply -f <...>. If an object doesn't already exist on the cluster it's created. Otherwise, it's updated. + * + * @param {Array | Array} configurations Accepted configurations include either valid yaml strings of the same form accepted by kubectl or kubernetes javascript API objects (i.e, k8s.V1CronJob). Make sure the kind and apiVersion fields are populated. + * @returns Array of k8s javascript client objects of the associated form (i.e, k8s.V1CronJob for kind CronJob, etc). + */ async applyAll(configurations) { const targets = []; @@ -44,11 +83,17 @@ class K8sClient { return targets; } + /** + * Create or update a configuration. This command has similar meaning to kubectl apply -f <...>. If the object doesn't already exist on the cluster it's created. Otherwise, it's updated. + * + * @param {String | any} configuration Accepted configuration includes either a valid yaml string of the same form accepted by kubectl or a kubernetes javascript API object (i.e, k8s.V1CronJob). Make sure the kind and apiVersion fields are populated. + * @returns The k8s javascript client object returned from the API or the manifest as constructed by the configuration. + */ async apply(configuration) { const manifest = this._manifest(configuration); - const alreadyExists = await this._api.exists(manifest.kind, manifest.metadata.name, manifest.metadata.namespace); + const alreadyExists = await this.exists(manifest.kind, manifest.metadata.name, manifest.metadata.namespace); if (!alreadyExists) { return this.create(configuration); } @@ -58,10 +103,27 @@ class K8sClient { return modifiedManifests[0]; } + /** + * Get an object from the cluster. + * + * NOTE: If the object doesn't exist on the cluster a ErrorNotFound exception will be thrown. + * + * @param {String} kind The k8s kind (i.e, CronJob). + * @param {String} name The name of the object as seen in the k8s metadata name field. + * @param {String} namespace The k8s object's namespace. + * @returns A kubernetes javascript client representation of the object on the cluster. + */ async get(kind, name, namespace) { return this._api.read(kind, name, namespace); } + /** + * Get all objects of the specified kind in the associated namespace. + * + * @param {String} kind The k8s kind (i.e, CronJob). + * @param {String} namespace The k8s object's namespace. + * @returns Array of k8s javascript client objects of the specified kind from the specified namespace. + */ async getAll(kind, namespace) { const resources = await this._api.listAll(kind, namespace); @@ -76,8 +138,14 @@ class K8sClient { return targets; } + /** + * Delete an object from your cluster. + * + * @param {any} manifest The kubernetes javascript client representation of the object you want to delete. Remember to include a valid kind and apiVersion. + * @returns + */ async delete (manifest) { - return this._api.deleteAll([manifest]); + await this._api.deleteAll([manifest]); } _parse(yamlString) {