/** * @module api * Data Layer - Kommunikation mit der API * Verantwortlich für den Abruf der Laufzeitdaten. */ /** * Führt einen API-Request zu /api/data aus. * * @async * @function fetchRunData * @param {Object} [filters={}] - Optionales Filterobjekt für den Request. * @param {string|number} [filters.run] - Run-Nummer zur Filterung. * @param {string} [filters.policy_hash] - Policy-Hash zur Filterung. * @param {boolean} [filters.filter_pinned] - Optional, ob nur pinned Runs berücksichtigt werden. * @returns {Promise} Promise, das ein Array von Laufdatenobjekten zurückgibt. * * Jedes Laufdatenobjekt hat die Form: * { run_id, policy_hash, pinned_status, delta_t, warn_rate, unknown_rate } */ export async function fetchRunData(filters = {}) { const params = new URLSearchParams(); if (filters.run) params.append('run', filters.run); if (filters.policy_hash) params.append('policy_hash', filters.policy_hash); if (typeof filters.filter_pinned === 'boolean') { params.append('filter_pinned', filters.filter_pinned ? 'true' : 'false'); } const queryString = params.toString(); const endpoint = '/api/data' + (queryString ? `?${queryString}` : ''); try { const response = await fetch(endpoint, { method: 'GET', headers: { 'Accept': 'application/json' } }); if (!response.ok) { throw new Error(`API request failed with status ${response.status}`); } const data = await response.json(); // Defensive: Sicherstellen, dass es sich um ein Array handelt if (!Array.isArray(data)) { console.warn('API returned non-array response', data); return []; } return data; } catch (error) { console.error('Error fetching run data:', error); return []; } }