Add visualization_tool/js/api.js
This commit is contained in:
parent
58df668499
commit
7dd2ee785a
1 changed files with 58 additions and 0 deletions
58
visualization_tool/js/api.js
Normal file
58
visualization_tool/js/api.js
Normal file
|
|
@ -0,0 +1,58 @@
|
|||
/**
|
||||
* @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<Array>} 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 [];
|
||||
}
|
||||
}
|
||||
Loading…
Reference in a new issue