heartbeat-monitor/node_modules/next/dist/esm/server/load-manifest.js
Matt Bruce bed1169443 Initial commit: Heartbeat Monitor dashboard
- Full-featured monitoring dashboard for local web apps
- Real-time status tracking with uptime percentages
- Visual sparklines for status history
- Add/Edit/Delete apps dynamically
- Categories and color coding
- Auto-refresh every 30 seconds
- API endpoints for apps and status management
2026-02-18 11:16:01 -06:00

44 lines
1.4 KiB
JavaScript

import { readFileSync } from 'fs';
import { runInNewContext } from 'vm';
import { deepFreeze } from '../shared/lib/deep-freeze';
const sharedCache = new Map();
export function loadManifest(path, shouldCache = true, cache = sharedCache) {
const cached = shouldCache && cache.get(path);
if (cached) {
return cached;
}
let manifest = JSON.parse(readFileSync(path, 'utf8'));
// Freeze the manifest so it cannot be modified if we're caching it.
if (shouldCache) {
manifest = deepFreeze(manifest);
}
if (shouldCache) {
cache.set(path, manifest);
}
return manifest;
}
export function evalManifest(path, shouldCache = true, cache = sharedCache) {
const cached = shouldCache && cache.get(path);
if (cached) {
return cached;
}
const content = readFileSync(path, 'utf8');
if (content.length === 0) {
throw new Error('Manifest file is empty');
}
let contextObject = {};
runInNewContext(content, contextObject);
// Freeze the context object so it cannot be modified if we're caching it.
if (shouldCache) {
contextObject = deepFreeze(contextObject);
}
if (shouldCache) {
cache.set(path, contextObject);
}
return contextObject;
}
export function clearManifestCache(path, cache = sharedCache) {
return cache.delete(path);
}
//# sourceMappingURL=load-manifest.js.map