77 lines
1.5 KiB
TypeScript
77 lines
1.5 KiB
TypeScript
import { Hono } from "hono"
|
|
import { type BeszelContext, beszelAuth } from "./beszel/middleware"
|
|
|
|
const beszel = new Hono<BeszelContext>()
|
|
|
|
// Apply middleware to all beszel routes
|
|
beszel.use("*", beszelAuth())
|
|
|
|
interface BeszelSystemInfo {
|
|
name: string
|
|
info: {
|
|
cpu: number
|
|
ram: number
|
|
disk: number
|
|
}
|
|
}
|
|
|
|
interface BeszelApiSystem {
|
|
name: string
|
|
info: {
|
|
cpu: number
|
|
mp: number // memory percentage
|
|
dp: number // disk percentage
|
|
}
|
|
}
|
|
|
|
beszel.get("/systems", async (c) => {
|
|
try {
|
|
const beszelHost = process.env.BESZEL_HOST
|
|
const token = c.get("beszelToken")
|
|
|
|
if (!beszelHost) {
|
|
return c.json({ error: "BESZEL_HOST environment variable not set" }, 500)
|
|
}
|
|
|
|
const response = await fetch(`http://${beszelHost}/api/collections/systems/records`, {
|
|
headers: {
|
|
Authorization: token,
|
|
},
|
|
})
|
|
|
|
if (!response.ok) {
|
|
return new Response(
|
|
JSON.stringify({
|
|
error: "Failed to fetch Beszel data",
|
|
status: response.status,
|
|
}),
|
|
{
|
|
status: response.status,
|
|
headers: { "Content-Type": "application/json" },
|
|
},
|
|
)
|
|
}
|
|
|
|
const data = (await response.json()) as { items: BeszelApiSystem[] }
|
|
|
|
const systems: BeszelSystemInfo[] = data.items.map((system) => ({
|
|
name: system.name,
|
|
info: {
|
|
cpu: system.info.cpu,
|
|
ram: system.info.mp,
|
|
disk: system.info.dp,
|
|
},
|
|
}))
|
|
|
|
return c.json({
|
|
lastUpdated: new Date().toISOString(),
|
|
systems,
|
|
totalSystems: systems.length,
|
|
})
|
|
} catch (error) {
|
|
return c.json({ error: "Internal server error", message: String(error) }, 500)
|
|
}
|
|
})
|
|
|
|
export default beszel
|