import React from "react"; import { Component, K8sApi, Util, Navigation } from "@k8slens/extensions"; interface Props extends Component.KubeObjectMenuProps { } export class PodShellMenu extends React.Component { async execShell(container?: string) { Navigation.hideDetails(); const { object: pod } = this.props const containerParam = container ? `-c ${container}` : "" let command = `kubectl exec -i -t -n ${pod.getNs()} ${pod.getName()} ${containerParam} "--"` if (window.navigator.platform !== "Win32") { command = `exec ${command}` } if (pod.getSelectedNodeOs() === "windows") { command = `${command} powershell` } else { command = `${command} sh -c "clear; (bash || ash || sh)"` } const shell = Component.createTerminalTab({ title: `Pod: ${pod.getName()} (namespace: ${pod.getNs()})` }); Component.terminalStore.sendCommand(command, { enter: true, tabId: shell.id }); } render() { const { object, toolbar } = this.props const containers = object.getRunningContainers(); if (!containers.length) return; return ( this.execShell(containers[0].name))}> Shell {containers.length > 1 && ( <> { containers.map(container => { const { name } = container; return ( this.execShell(name))} className="flex align-center"> {name} ) }) } )} ) } }