UNPKG

@kui-shell/plugin-kubectl

Version:

Kubernetes visualization plugin for kubernetes

122 lines (121 loc) 4.69 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; exports.emitKubectlConfigChangeEvent = emitKubectlConfigChangeEvent; exports.offKubectlConfigChangeEvents = offKubectlConfigChangeEvents; exports.onKubectlConfigChangeEvents = onKubectlConfigChangeEvents; exports.register = register; var _core = require("@kui-shell/core"); var _flags = _interopRequireDefault(require("./flags")); var _exec = require("./exec"); var _options = require("./options"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /* * Copyright 2020 The Kubernetes Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ var __awaiter = void 0 && (void 0).__awaiter || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; const kubectlConfigChangeChannel = '/kubectl/config/change'; const mutators = ['delete-cluster', 'delete-context', 'rename-context', 'set', 'set-cluster', 'set-context', 'set-credentials', 'unset', 'use-context']; function emitKubectlConfigChangeEvent(type, namespace, context) { try { _core.Events.eventChannelUnsafe.emit(kubectlConfigChangeChannel, type, namespace, context); } catch (err) { console.error('Error in onKubectlConfigChangeEvent handler', err); } } function onKubectlConfigChangeEvents(handler) { _core.Events.eventChannelUnsafe.on(kubectlConfigChangeChannel, handler); } function offKubectlConfigChangeEvents(handler) { _core.Events.eventChannelUnsafe.off(kubectlConfigChangeChannel, handler); } /** * Here, we conservatively broadcoast that the kubectl config *may* * have changed. * */ function emitChangeEventIfNeeded(args) { const idx = args.argvNoOptions.indexOf('config'); const verb = args.argvNoOptions[idx + 1]; const change = verb === 'set' || verb === 'use-context' || verb === 'set-context' && !args.parsedOptions.current ? 'NewContext' : verb === 'set-context' || verb === 'set-cluster' || verb === 'set-credentials' || verb === 'rename-context' ? 'AlteredContext' : undefined; if (change) { emitKubectlConfigChangeEvent('SetNamespaceOrContext', (0, _options.getNamespaceAsExpressed)(args), verb === 'use-context' ? args.argvNoOptions[idx + 2] : undefined); } } /** Kui proxy-side handler; we just pass it through to the PTY, and then emit a config change event */ function doConfig(args) { return __awaiter(this, void 0, void 0, function* () { args.command = args.command.replace(/_config/, 'config'); args.argvNoOptions[1] = 'config'; args.argv[1] = 'config'; const response = yield (0, _exec.doExecWithPty)(args); emitChangeEventIfNeeded(args); return response; }); } /** Kui client-side handler; we pass it through to the proxy-side handler, but also emit a config change event */ function doConfigClient(cmd, verb, args) { return __awaiter(this, void 0, void 0, function* () { const command = args.command.replace(/config/, '_config'); const response = yield args.REPL.qexec(command); emitChangeEventIfNeeded(args); return response; }); } function register(registrar, cmd) { mutators.forEach(verb => { registrar.listen(`/${cmd}/_config/${verb}`, doConfig, Object.assign({}, _flags.default, { requiresLocal: true })); registrar.listen(`/${cmd}/config/${verb}`, doConfigClient.bind(undefined, cmd, verb), _flags.default); }); } /** * Register the commands * */ var _default = registrar => { register(registrar, 'kubectl'); register(registrar, 'k'); }; exports.default = _default;