mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Remove lens-pod-menu intree extension
Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
5596088f86
commit
a4b96e5cd8
@ -1,20 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
||||||
*/
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
"overrides": [
|
|
||||||
{
|
|
||||||
files: [
|
|
||||||
"**/*.ts",
|
|
||||||
"**/*.tsx",
|
|
||||||
],
|
|
||||||
rules: {
|
|
||||||
"import/no-unresolved": ["error", {
|
|
||||||
ignore: ["@k8slens/extensions"],
|
|
||||||
}],
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
};
|
|
||||||
1
extensions/.gitignore
vendored
1
extensions/.gitignore
vendored
@ -1 +0,0 @@
|
|||||||
*/*.tgz
|
|
||||||
@ -1,22 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "lens-pod-menu",
|
|
||||||
"version": "6.1.0",
|
|
||||||
"description": "Lens pod menu",
|
|
||||||
"renderer": "dist/renderer.js",
|
|
||||||
"lens": {
|
|
||||||
"metadata": {},
|
|
||||||
"styles": []
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"build": "npx webpack",
|
|
||||||
"dev": "npx webpack -- --watch",
|
|
||||||
"test": "npx jest --passWithNoTests --env=jsdom src $@"
|
|
||||||
},
|
|
||||||
"files": [
|
|
||||||
"dist/**/*"
|
|
||||||
],
|
|
||||||
"dependencies": {},
|
|
||||||
"devDependencies": {
|
|
||||||
"@k8slens/extensions": "file:../../src/extensions/npm/extensions"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,39 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import { Renderer } from "@k8slens/extensions";
|
|
||||||
import type { PodAttachMenuProps } from "./src/attach-menu";
|
|
||||||
import { PodAttachMenu } from "./src/attach-menu";
|
|
||||||
import type { PodShellMenuProps } from "./src/shell-menu";
|
|
||||||
import { PodShellMenu } from "./src/shell-menu";
|
|
||||||
import type { PodLogsMenuProps } from "./src/logs-menu";
|
|
||||||
import { PodLogsMenu } from "./src/logs-menu";
|
|
||||||
import React from "react";
|
|
||||||
|
|
||||||
export default class PodMenuRendererExtension extends Renderer.LensExtension {
|
|
||||||
kubeObjectMenuItems = [
|
|
||||||
{
|
|
||||||
kind: "Pod",
|
|
||||||
apiVersions: ["v1"],
|
|
||||||
components: {
|
|
||||||
MenuItem: (props: PodAttachMenuProps) => <PodAttachMenu {...props} />,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
kind: "Pod",
|
|
||||||
apiVersions: ["v1"],
|
|
||||||
components: {
|
|
||||||
MenuItem: (props: PodShellMenuProps) => <PodShellMenu {...props} />,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
kind: "Pod",
|
|
||||||
apiVersions: ["v1"],
|
|
||||||
components: {
|
|
||||||
MenuItem: (props: PodLogsMenuProps) => <PodLogsMenu {...props} />,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
];
|
|
||||||
}
|
|
||||||
@ -1,106 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import React from "react";
|
|
||||||
import { Renderer, Common } from "@k8slens/extensions";
|
|
||||||
|
|
||||||
type Pod = Renderer.K8sApi.Pod;
|
|
||||||
|
|
||||||
const {
|
|
||||||
Component: {
|
|
||||||
createTerminalTab,
|
|
||||||
terminalStore,
|
|
||||||
MenuItem,
|
|
||||||
Icon,
|
|
||||||
SubMenu,
|
|
||||||
StatusBrick,
|
|
||||||
},
|
|
||||||
Navigation,
|
|
||||||
} = Renderer;
|
|
||||||
const {
|
|
||||||
Util,
|
|
||||||
App,
|
|
||||||
} = Common;
|
|
||||||
|
|
||||||
export interface PodAttachMenuProps extends Renderer.Component.KubeObjectMenuProps<Pod> {
|
|
||||||
}
|
|
||||||
|
|
||||||
export class PodAttachMenu extends React.Component<PodAttachMenuProps> {
|
|
||||||
async attachToPod(container?: string) {
|
|
||||||
const { object: pod } = this.props;
|
|
||||||
|
|
||||||
const kubectlPath = App.Preferences.getKubectlPath() || "kubectl";
|
|
||||||
const commandParts = [
|
|
||||||
kubectlPath,
|
|
||||||
"attach",
|
|
||||||
"-i",
|
|
||||||
"-t",
|
|
||||||
"-n", pod.getNs(),
|
|
||||||
pod.getName(),
|
|
||||||
];
|
|
||||||
|
|
||||||
if (window.navigator.platform !== "Win32") {
|
|
||||||
commandParts.unshift("exec");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (container) {
|
|
||||||
commandParts.push("-c", container);
|
|
||||||
}
|
|
||||||
|
|
||||||
const shell = createTerminalTab({
|
|
||||||
title: `Pod: ${pod.getName()} (namespace: ${pod.getNs()}) [Attached]`,
|
|
||||||
});
|
|
||||||
|
|
||||||
terminalStore.sendCommand(commandParts.join(" "), {
|
|
||||||
enter: true,
|
|
||||||
tabId: shell.id,
|
|
||||||
});
|
|
||||||
|
|
||||||
Navigation.hideDetails();
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
|
||||||
const { object, toolbar } = this.props;
|
|
||||||
const containers = object.getRunningContainers();
|
|
||||||
|
|
||||||
if (!containers.length) return null;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<MenuItem onClick={Util.prevDefault(() => this.attachToPod(containers[0].name))}>
|
|
||||||
<Icon
|
|
||||||
material="pageview"
|
|
||||||
interactive={toolbar}
|
|
||||||
tooltip={toolbar && "Attach to Pod"}
|
|
||||||
/>
|
|
||||||
<span className="title">Attach Pod</span>
|
|
||||||
{containers.length > 1 && (
|
|
||||||
<>
|
|
||||||
<Icon className="arrow" material="keyboard_arrow_right"/>
|
|
||||||
<SubMenu>
|
|
||||||
{
|
|
||||||
containers.map(container => {
|
|
||||||
const { name } = container;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<MenuItem
|
|
||||||
key={name}
|
|
||||||
onClick={Util.prevDefault(() => this.attachToPod(name))}
|
|
||||||
className="flex align-center"
|
|
||||||
>
|
|
||||||
<StatusBrick/>
|
|
||||||
<span>{name}</span>
|
|
||||||
</MenuItem>
|
|
||||||
);
|
|
||||||
})
|
|
||||||
}
|
|
||||||
</SubMenu>
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
</MenuItem>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,87 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import React from "react";
|
|
||||||
import { Renderer, Common } from "@k8slens/extensions";
|
|
||||||
|
|
||||||
type Pod = Renderer.K8sApi.Pod;
|
|
||||||
type IPodContainer = Renderer.K8sApi.IPodContainer;
|
|
||||||
|
|
||||||
const {
|
|
||||||
Component: {
|
|
||||||
logTabStore,
|
|
||||||
MenuItem,
|
|
||||||
Icon,
|
|
||||||
SubMenu,
|
|
||||||
StatusBrick,
|
|
||||||
},
|
|
||||||
Navigation,
|
|
||||||
} = Renderer;
|
|
||||||
const {
|
|
||||||
Util,
|
|
||||||
} = Common;
|
|
||||||
|
|
||||||
export interface PodLogsMenuProps extends Renderer.Component.KubeObjectMenuProps<Pod> {
|
|
||||||
}
|
|
||||||
|
|
||||||
export class PodLogsMenu extends React.Component<PodLogsMenuProps> {
|
|
||||||
showLogs(container: IPodContainer) {
|
|
||||||
Navigation.hideDetails();
|
|
||||||
const pod = this.props.object;
|
|
||||||
|
|
||||||
logTabStore.createPodTab({
|
|
||||||
selectedPod: pod,
|
|
||||||
selectedContainer: container,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
|
||||||
const { object: pod, toolbar } = this.props;
|
|
||||||
const containers = pod.getAllContainers();
|
|
||||||
const statuses = pod.getContainerStatuses();
|
|
||||||
|
|
||||||
if (!containers.length) return null;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<MenuItem onClick={Util.prevDefault(() => this.showLogs(containers[0]))}>
|
|
||||||
<Icon
|
|
||||||
material="subject"
|
|
||||||
interactive={toolbar}
|
|
||||||
tooltip={toolbar && "Pod Logs"}
|
|
||||||
/>
|
|
||||||
<span className="title">Logs</span>
|
|
||||||
{containers.length > 1 && (
|
|
||||||
<>
|
|
||||||
<Icon className="arrow" material="keyboard_arrow_right"/>
|
|
||||||
<SubMenu>
|
|
||||||
{
|
|
||||||
containers.map(container => {
|
|
||||||
const { name } = container;
|
|
||||||
const status = statuses.find(status => status.name === name);
|
|
||||||
const brick = status ? (
|
|
||||||
<StatusBrick
|
|
||||||
className={Util.cssNames(Object.keys(status.state)[0], { ready: status.ready })}
|
|
||||||
/>
|
|
||||||
) : null;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<MenuItem
|
|
||||||
key={name}
|
|
||||||
onClick={Util.prevDefault(() => this.showLogs(container))}
|
|
||||||
className="flex align-center"
|
|
||||||
>
|
|
||||||
{brick}
|
|
||||||
<span>{name}</span>
|
|
||||||
</MenuItem>
|
|
||||||
);
|
|
||||||
})
|
|
||||||
}
|
|
||||||
</SubMenu>
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
</MenuItem>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,114 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import React from "react";
|
|
||||||
import { Renderer, Common } from "@k8slens/extensions";
|
|
||||||
|
|
||||||
type Pod = Renderer.K8sApi.Pod;
|
|
||||||
|
|
||||||
const {
|
|
||||||
Component: {
|
|
||||||
createTerminalTab,
|
|
||||||
terminalStore,
|
|
||||||
MenuItem,
|
|
||||||
Icon,
|
|
||||||
SubMenu,
|
|
||||||
StatusBrick,
|
|
||||||
},
|
|
||||||
Navigation,
|
|
||||||
} = Renderer;
|
|
||||||
const {
|
|
||||||
Util,
|
|
||||||
App,
|
|
||||||
} = Common;
|
|
||||||
|
|
||||||
export interface PodShellMenuProps extends Renderer.Component.KubeObjectMenuProps<Pod> {
|
|
||||||
}
|
|
||||||
|
|
||||||
export class PodShellMenu extends React.Component<PodShellMenuProps> {
|
|
||||||
async execShell(container?: string) {
|
|
||||||
const { object: pod } = this.props;
|
|
||||||
|
|
||||||
const kubectlPath = App.Preferences.getKubectlPath() || "kubectl";
|
|
||||||
const commandParts = [
|
|
||||||
kubectlPath,
|
|
||||||
"exec",
|
|
||||||
"-i",
|
|
||||||
"-t",
|
|
||||||
"-n", pod.getNs(),
|
|
||||||
pod.getName(),
|
|
||||||
];
|
|
||||||
|
|
||||||
if (window.navigator.platform !== "Win32") {
|
|
||||||
commandParts.unshift("exec");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (container) {
|
|
||||||
commandParts.push("-c", container);
|
|
||||||
}
|
|
||||||
|
|
||||||
commandParts.push("--");
|
|
||||||
|
|
||||||
if (pod.getSelectedNodeOs() === "windows") {
|
|
||||||
commandParts.push("powershell");
|
|
||||||
} else {
|
|
||||||
commandParts.push('sh -c "clear; (bash || ash || sh)"');
|
|
||||||
}
|
|
||||||
|
|
||||||
const shell = createTerminalTab({
|
|
||||||
title: `Pod: ${pod.getName()} (namespace: ${pod.getNs()})`,
|
|
||||||
});
|
|
||||||
|
|
||||||
terminalStore.sendCommand(commandParts.join(" "), {
|
|
||||||
enter: true,
|
|
||||||
tabId: shell.id,
|
|
||||||
});
|
|
||||||
|
|
||||||
Navigation.hideDetails();
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
|
||||||
const { object, toolbar } = this.props;
|
|
||||||
const containers = object.getRunningContainers();
|
|
||||||
|
|
||||||
if (!containers.length) return null;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<MenuItem onClick={Util.prevDefault(() => this.execShell(containers[0].name))}>
|
|
||||||
<Icon
|
|
||||||
svg="ssh"
|
|
||||||
interactive={toolbar}
|
|
||||||
tooltip={toolbar && "Pod Shell"}
|
|
||||||
/>
|
|
||||||
<span className="title">Shell</span>
|
|
||||||
{containers.length > 1 && (
|
|
||||||
<>
|
|
||||||
<Icon className="arrow" material="keyboard_arrow_right"/>
|
|
||||||
<SubMenu>
|
|
||||||
{
|
|
||||||
containers.map(container => {
|
|
||||||
const { name } = container;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<MenuItem
|
|
||||||
key={name}
|
|
||||||
onClick={Util.prevDefault(() => this.execShell(name))}
|
|
||||||
className="flex align-center"
|
|
||||||
>
|
|
||||||
<StatusBrick/>
|
|
||||||
<span>{name}</span>
|
|
||||||
</MenuItem>
|
|
||||||
);
|
|
||||||
})
|
|
||||||
}
|
|
||||||
</SubMenu>
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
</MenuItem>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,27 +0,0 @@
|
|||||||
{
|
|
||||||
"compilerOptions": {
|
|
||||||
"outDir": "dist",
|
|
||||||
"module": "CommonJS",
|
|
||||||
"target": "ES2017",
|
|
||||||
"lib": ["ESNext", "DOM", "DOM.Iterable"],
|
|
||||||
"moduleResolution": "Node",
|
|
||||||
"sourceMap": false,
|
|
||||||
"declaration": false,
|
|
||||||
"strict": false,
|
|
||||||
"noImplicitAny": true,
|
|
||||||
"skipLibCheck": true,
|
|
||||||
"esModuleInterop": true,
|
|
||||||
"allowSyntheticDefaultImports": true,
|
|
||||||
"experimentalDecorators": true,
|
|
||||||
"useDefineForClassFields": true,
|
|
||||||
"jsx": "react"
|
|
||||||
},
|
|
||||||
"include": [
|
|
||||||
"./*.ts",
|
|
||||||
"./*.tsx"
|
|
||||||
],
|
|
||||||
"exclude": [
|
|
||||||
"node_modules",
|
|
||||||
"*.js"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
@ -1,44 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
||||||
*/
|
|
||||||
const path = require("path");
|
|
||||||
|
|
||||||
module.exports = [
|
|
||||||
{
|
|
||||||
entry: "./renderer.tsx",
|
|
||||||
context: __dirname,
|
|
||||||
target: "electron-renderer",
|
|
||||||
mode: "production",
|
|
||||||
optimization: {
|
|
||||||
minimize: false,
|
|
||||||
},
|
|
||||||
module: {
|
|
||||||
rules: [
|
|
||||||
{
|
|
||||||
test: /\.tsx?$/,
|
|
||||||
use: "ts-loader",
|
|
||||||
exclude: /node_modules/,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
externals: [
|
|
||||||
{
|
|
||||||
"@k8slens/extensions": "var global.LensExtensions",
|
|
||||||
"react": "var global.React",
|
|
||||||
"react-dom": "var global.ReactDOM",
|
|
||||||
"mobx": "var global.Mobx",
|
|
||||||
"mobx-react": "var global.MobxReact",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
resolve: {
|
|
||||||
extensions: [ ".tsx", ".ts", ".js" ],
|
|
||||||
},
|
|
||||||
output: {
|
|
||||||
libraryTarget: "commonjs2",
|
|
||||||
globalObject: "this",
|
|
||||||
filename: "renderer.js",
|
|
||||||
path: path.resolve(__dirname, "dist"),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
];
|
|
||||||
@ -59,9 +59,7 @@
|
|||||||
"sentryDsn": "",
|
"sentryDsn": "",
|
||||||
"contentSecurityPolicy": "script-src 'unsafe-eval' 'self'; frame-src http://*.localhost:*/; img-src * data:",
|
"contentSecurityPolicy": "script-src 'unsafe-eval' 'self'; frame-src http://*.localhost:*/; img-src * data:",
|
||||||
"welcomeRoute": "/welcome",
|
"welcomeRoute": "/welcome",
|
||||||
"extensions": [
|
"extensions": []
|
||||||
"pod-menu"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=16 <17"
|
"node": ">=16 <17"
|
||||||
@ -231,7 +229,6 @@
|
|||||||
"joi": "^17.7.0",
|
"joi": "^17.7.0",
|
||||||
"js-yaml": "^4.1.0",
|
"js-yaml": "^4.1.0",
|
||||||
"jsdom": "^16.7.0",
|
"jsdom": "^16.7.0",
|
||||||
"lens-pod-menu": "file:./extensions/pod-menu",
|
|
||||||
"lodash": "^4.17.15",
|
"lodash": "^4.17.15",
|
||||||
"marked": "^4.2.4",
|
"marked": "^4.2.4",
|
||||||
"md5-file": "^5.0.0",
|
"md5-file": "^5.0.0",
|
||||||
@ -249,7 +246,6 @@
|
|||||||
"npm": "^8.19.3",
|
"npm": "^8.19.3",
|
||||||
"p-limit": "^3.1.0",
|
"p-limit": "^3.1.0",
|
||||||
"path-to-regexp": "^6.2.0",
|
"path-to-regexp": "^6.2.0",
|
||||||
"pod-menu": "file:./extensions/pod-menu",
|
|
||||||
"proper-lockfile": "^4.1.2",
|
"proper-lockfile": "^4.1.2",
|
||||||
"react": "^17.0.2",
|
"react": "^17.0.2",
|
||||||
"react-dom": "^17.0.2",
|
"react-dom": "^17.0.2",
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user