mirror of
https://github.com/lensapp/lens.git
synced 2024-11-10 10:36:25 +03:00
Fix broken shell when workdir not exists (#3349)
Signed-off-by: devodev <abalexandrebarone@gmail.com>
This commit is contained in:
parent
acbca1ac1d
commit
8c5457cf89
@ -31,8 +31,11 @@ export class LocalShellSession extends ShellSession {
|
|||||||
return [helmCli.getBinaryDir()];
|
return [helmCli.getBinaryDir()];
|
||||||
}
|
}
|
||||||
|
|
||||||
public async open() {
|
protected get cwd(): string | undefined {
|
||||||
|
return this.cluster.preferences?.terminalCWD;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async open() {
|
||||||
const env = await this.getCachedShellEnv();
|
const env = await this.getCachedShellEnv();
|
||||||
const shell = env.PTYSHELL;
|
const shell = env.PTYSHELL;
|
||||||
const args = await this.getShellArgs(shell);
|
const args = await this.getShellArgs(shell);
|
||||||
|
@ -32,6 +32,10 @@ export class NodeShellSession extends ShellSession {
|
|||||||
protected podId = `node-shell-${uuid()}`;
|
protected podId = `node-shell-${uuid()}`;
|
||||||
protected kc: KubeConfig;
|
protected kc: KubeConfig;
|
||||||
|
|
||||||
|
protected get cwd(): string | undefined {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
constructor(socket: WebSocket, cluster: Cluster, protected nodeName: string) {
|
constructor(socket: WebSocket, cluster: Cluster, protected nodeName: string) {
|
||||||
super(socket, cluster);
|
super(socket, cluster);
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import fse from "fs-extra";
|
||||||
import type { Cluster } from "../cluster";
|
import type { Cluster } from "../cluster";
|
||||||
import { Kubectl } from "../kubectl";
|
import { Kubectl } from "../kubectl";
|
||||||
import type * as WebSocket from "ws";
|
import type * as WebSocket from "ws";
|
||||||
@ -50,9 +51,7 @@ export abstract class ShellSession {
|
|||||||
protected kubectlBinDirP: Promise<string>;
|
protected kubectlBinDirP: Promise<string>;
|
||||||
protected kubeconfigPathP: Promise<string>;
|
protected kubeconfigPathP: Promise<string>;
|
||||||
|
|
||||||
protected get cwd(): string | undefined {
|
protected abstract get cwd(): string | undefined;
|
||||||
return this.cluster.preferences?.terminalCWD;
|
|
||||||
}
|
|
||||||
|
|
||||||
constructor(protected websocket: WebSocket, protected cluster: Cluster) {
|
constructor(protected websocket: WebSocket, protected cluster: Cluster) {
|
||||||
this.kubectl = new Kubectl(cluster.version);
|
this.kubectl = new Kubectl(cluster.version);
|
||||||
@ -60,10 +59,14 @@ export abstract class ShellSession {
|
|||||||
this.kubectlBinDirP = this.kubectl.binDir();
|
this.kubectlBinDirP = this.kubectl.binDir();
|
||||||
}
|
}
|
||||||
|
|
||||||
open(shell: string, args: string[], env: Record<string, any>): void {
|
protected async open(shell: string, args: string[], env: Record<string, any>) {
|
||||||
|
const cwd = (this.cwd && await fse.pathExists(this.cwd))
|
||||||
|
? this.cwd
|
||||||
|
: env.HOME;
|
||||||
|
|
||||||
this.shellProcess = pty.spawn(shell, args, {
|
this.shellProcess = pty.spawn(shell, args, {
|
||||||
cols: 80,
|
cols: 80,
|
||||||
cwd: this.cwd || env.HOME,
|
cwd,
|
||||||
env,
|
env,
|
||||||
name: "xterm-256color",
|
name: "xterm-256color",
|
||||||
rows: 30,
|
rows: 30,
|
||||||
|
Loading…
Reference in New Issue
Block a user