@hashgraph/solo
Version:
An opinionated CLI tool to deploy and manage private Hedera Networks.
91 lines • 5.29 kB
JavaScript
// SPDX-License-Identifier: Apache-2.0
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __param = (this && this.__param) || function (paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
};
var KubectlDependencyManager_1;
import * as constants from '../constants.js';
import * as version from '../../../version.js';
import { inject, injectable } from 'tsyringe-neo';
import { patchInject } from '../dependency-injection/container-helper.js';
import { InjectTokens } from '../dependency-injection/inject-tokens.js';
import { BaseDependencyManager } from './base-dependency-manager.js';
import { PackageDownloader } from '../package-downloader.js';
import { format } from 'node:util';
import { SoloError } from '../errors/solo-error.js';
import { OperatingSystem } from '../../business/utils/operating-system.js';
const KUBECTL_RELEASE_BASE_URL = 'https://dl.k8s.io/release';
const KUBECTL_ARTIFACT_TEMPLATE = '%s/bin/%s/%s/kubectl';
const KUBECTL_WINDOWS_ARTIFACT_TEMPLATE = '%s/bin/%s/%s/kubectl.exe';
let KubectlDependencyManager = KubectlDependencyManager_1 = class KubectlDependencyManager extends BaseDependencyManager {
constructor(downloader, installationDirectory, osArch, kubectlVersion) {
// Call the base constructor with the Kubectl-specific parameters
super(patchInject(downloader, InjectTokens.PackageDownloader, KubectlDependencyManager_1.name), patchInject(installationDirectory, InjectTokens.KubectlInstallationDirectory, KubectlDependencyManager_1.name), patchInject(osArch, InjectTokens.OsArch, KubectlDependencyManager_1.name), patchInject(kubectlVersion, InjectTokens.KubectlVersion, KubectlDependencyManager_1.name) ||
version.KUBECTL_VERSION, constants.KUBECTL, KUBECTL_RELEASE_BASE_URL);
}
/**
* Get the Kubectl artifact name based on version, OS, and architecture
*/
getArtifactName() {
return format(OperatingSystem.isWin32() ? KUBECTL_WINDOWS_ARTIFACT_TEMPLATE : KUBECTL_ARTIFACT_TEMPLATE, this.getRequiredVersion(), OperatingSystem.getFormattedPlatform(), this.osArch);
}
async getVersion(executableWithPath) {
try {
// Override KUBECONFIG to prevent loading kubeconfig and triggering authentication
// plugins (e.g., Teleport exec credentials) which can hang in non-interactive environments.
// Using the null device ensures kubectl only reports the client version without any
// server or credential-related operations.
const nullDevice = OperatingSystem.isWin32() ? 'nul' : '/dev/null';
const output = await this.run(`"${executableWithPath}" version --client`, [], false, false, { KUBECONFIG: nullDevice }, 30_000);
this.logger.debug(`Raw kubectl version output: ${output.join('\n')}`);
if (output.length > 0) {
for (const line of output) {
if (line.trim().startsWith('Client Version')) {
const match = line.trim().match(/(\d+\.\d+\.\d+)/);
if (match) {
const detectedVersion = match[1];
this.logger.info(`Kubectl version: ${detectedVersion}`);
return detectedVersion;
}
}
}
}
}
catch (error) {
throw new SoloError('Failed to check kubectl version', error);
}
throw new SoloError('Failed to get kubectl version');
}
getDownloadURL() {
return `${this.downloadBaseUrl}/${this.artifactName}`;
}
/**
* Handle any post-download processing before copying to destination
* Child classes can override this for custom extraction or processing
*/
async processDownloadedPackage(packageFilePath) {
// For kubectl, the downloaded file is the executable itself, so we can return it directly
return [packageFilePath];
}
getChecksumURL() {
return `${this.downloadURL}.sha256`;
}
};
KubectlDependencyManager = KubectlDependencyManager_1 = __decorate([
injectable(),
__param(0, inject(InjectTokens.PackageDownloader)),
__param(1, inject(InjectTokens.KubectlInstallationDirectory)),
__param(2, inject(InjectTokens.OsArch)),
__param(3, inject(InjectTokens.KubectlVersion)),
__metadata("design:paramtypes", [PackageDownloader, String, String, String])
], KubectlDependencyManager);
export { KubectlDependencyManager };
//# sourceMappingURL=kubectl-dependency-manager.js.map