import { useQuery } from '@tanstack/react-query'; import { config } from '../../config'; import { useAuthStore } from '../../auth/auth-store'; import { useRefreshInterval } from './use-refresh-interval'; export interface CatalogRoute { routeId: string; exchangeCount: number; lastSeen: string | null; fromEndpointUri: string | null; routeState: string | null; } export interface CatalogAgent { instanceId: string; displayName: string; state: string; tps: number; } export interface DeploymentSummary { status: string; replicas: string; version: number; } export interface CatalogApp { slug: string; displayName: string; managed: boolean; environmentSlug: string; health: 'live' | 'stale' | 'dead' | 'offline'; agentCount: number; routes: CatalogRoute[]; agents: CatalogAgent[]; exchangeCount: number; deployment: DeploymentSummary | null; } export function useCatalog(environment?: string) { const refetchInterval = useRefreshInterval(15_000); return useQuery({ queryKey: ['catalog', environment], queryFn: async () => { const token = useAuthStore.getState().accessToken; const params = new URLSearchParams(); if (environment) params.set('environment', environment); const qs = params.toString(); const res = await fetch(`${config.apiBaseUrl}/catalog${qs ? `?${qs}` : ''}`, { headers: { Authorization: `Bearer ${token}`, 'X-Cameleer-Protocol-Version': '1', }, }); if (!res.ok) throw new Error('Failed to load catalog'); return res.json() as Promise; }, placeholderData: (prev) => prev, refetchInterval, }); } export function useRouteMetrics(from?: string, to?: string, appId?: string) { const refetchInterval = useRefreshInterval(30_000); return useQuery({ queryKey: ['routes', 'metrics', from, to, appId], queryFn: async () => { const token = useAuthStore.getState().accessToken; const params = new URLSearchParams(); if (from) params.set('from', from); if (to) params.set('to', to); if (appId) params.set('appId', appId); const res = await fetch(`${config.apiBaseUrl}/routes/metrics?${params}`, { headers: { Authorization: `Bearer ${token}`, 'X-Cameleer-Protocol-Version': '1', }, }); if (!res.ok) throw new Error('Failed to load route metrics'); return res.json(); }, placeholderData: (prev: unknown) => prev, refetchInterval, }); }