mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
poll for pods and services disappearing to remove dead port-forwards
Signed-off-by: Jim Ehrismann <jehrismann@mirantis.com>
This commit is contained in:
parent
a3765211de
commit
5c5658c602
@ -29,9 +29,8 @@ import { Wizard, WizardStep } from "../components/wizard";
|
||||
import { Input } from "../components/input";
|
||||
import { Notifications } from "../components/notifications";
|
||||
import { cssNames } from "../utils";
|
||||
import { addPortForward, modifyPortForward } from "./port-forward.store";
|
||||
import { addPortForward, modifyPortForward, openPortForward } from "./port-forward.store";
|
||||
import type { ForwardedPort } from "./port-forward-item";
|
||||
import { openPortForward } from ".";
|
||||
|
||||
interface Props extends Partial<DialogProps> {
|
||||
}
|
||||
|
||||
@ -28,6 +28,7 @@ import { apiBase } from "../api";
|
||||
import { waitUntilFree } from "tcp-port-used";
|
||||
import { Notifications } from "../components/notifications";
|
||||
import logger from "../../common/logger";
|
||||
import { podsApi, serviceApi } from "../../common/k8s-api/endpoints";
|
||||
|
||||
export class PortForwardStore extends ItemStore<PortForwardItem> {
|
||||
private storage = createStorage<ForwardedPort[] | undefined>("port_forwards", undefined);
|
||||
@ -56,9 +57,16 @@ export class PortForwardStore extends ItemStore<PortForwardItem> {
|
||||
watch() {
|
||||
return disposer(
|
||||
reaction(() => this.portForwards, () => this.loadAll()),
|
||||
this.reaper(),
|
||||
);
|
||||
}
|
||||
|
||||
reaper() {
|
||||
const interval = setInterval(async () => await Promise.all(this.portForwards.map(reapPortForward)), 30 * 1000); // every 30 seconds
|
||||
|
||||
return () => clearInterval(interval);
|
||||
}
|
||||
|
||||
loadAll() {
|
||||
return this.loadItems(async () => {
|
||||
let portForwards = await getPortForwards();
|
||||
@ -146,7 +154,7 @@ export async function removePortForward(portForward: ForwardedPort) {
|
||||
portForwardStore.reset();
|
||||
}
|
||||
|
||||
export async function getPortForwards(): Promise<ForwardedPort[]> {
|
||||
async function getPortForwards(): Promise<ForwardedPort[]> {
|
||||
try {
|
||||
const response = await apiBase.get<PortForwardsResult>(`/pods/port-forwards`);
|
||||
|
||||
@ -158,6 +166,20 @@ export async function getPortForwards(): Promise<ForwardedPort[]> {
|
||||
}
|
||||
}
|
||||
|
||||
async function reapPortForward(portForward: ForwardedPort): Promise<void> {
|
||||
const api = {
|
||||
"service": serviceApi,
|
||||
"pod": podsApi
|
||||
}[portForward.kind];
|
||||
|
||||
try {
|
||||
await api.get({name: portForward.name, namespace: portForward.namespace});
|
||||
} catch(error) {
|
||||
logger.debug(`port-forward resource ${portForward.name} not found, removing`, portForward);
|
||||
removePortForward(portForward);
|
||||
}
|
||||
}
|
||||
|
||||
export function openPortForward(portForward: ForwardedPort) {
|
||||
const browseTo = `http://localhost:${portForward.forwardPort}`;
|
||||
|
||||
|
||||
Loading…
Reference in New Issue
Block a user