import { CoreV1Api } from "@kubernetes/client-node"; import getKubeConfig from "../../../../utils/config/kubernetes"; import createLogger from "../../../../utils/logger"; const logger = createLogger("kubernetesStatusService"); export default async function handler(req, res) { const APP_LABEL = "app.kubernetes.io/name"; const { service, podSelector } = req.query; const [namespace, appName] = service; if (!namespace && !appName) { res.status(400).send({ error: "kubernetes query parameters are required", }); return; } const labelSelector = podSelector !== undefined ? podSelector : `${APP_LABEL}=${appName}`; logger.info("labelSelector %s/%s = %s", namespace, appName, labelSelector); try { const kc = getKubeConfig(); if (!kc) { res.status(500).send({ error: "No kubernetes configuration" }); return; } const coreApi = kc.makeApiClient(CoreV1Api); const podsResponse = await coreApi.listNamespacedPod(namespace, null, null, null, null, labelSelector) .then((response) => response.body) .catch((err) => { logger.error("Error getting pods: %d %s %s", err.statusCode, err.body, err.response); return null; }); if (!podsResponse) { res.status(500).send({ error: "Error communicating with kubernetes" }); return; } const pods = podsResponse.items; if (pods.length === 0) { res.status(404).send({ error: "not found", }); return; } const someReady = pods.find(pod => pod.status.phase === "Running"); const allReady = pods.every((pod) => pod.status.phase === "Running"); let status = "down"; if (allReady) { status = "running"; } else if (someReady) { status = "partial"; } res.status(200).json({ status }); } catch (e) { logger.error(e); res.status(500).send({ error: "unknown error", }); } }