mirror of
https://github.com/kjanat/livedash-node.git
synced 2026-01-16 08:52:10 +01:00
Major code quality overhaul addressing 58% of all linting issues: • Type Safety Improvements: - Replace all any types with proper TypeScript interfaces - Fix Map component shadowing (renamed to CountryMap) - Add comprehensive custom error classes system - Enhance API route type safety • Accessibility Enhancements: - Add explicit button types to all interactive elements - Implement useId() hooks for form element accessibility - Add SVG title attributes for screen readers - Fix static element interactions with keyboard handlers • React Best Practices: - Resolve exhaustive dependencies warnings with useCallback - Extract nested component definitions to top level - Fix array index keys with proper unique identifiers - Improve component organization and prop typing • Code Organization: - Automatic import organization and type import optimization - Fix unused function parameters and variables - Enhanced error handling with structured error responses - Improve component reusability and maintainability Results: 248 → 104 total issues (58% reduction) - Fixed all critical type safety and security issues - Enhanced accessibility compliance significantly - Improved code maintainability and performance
55 lines
1.7 KiB
TypeScript
55 lines
1.7 KiB
TypeScript
// Custom Next.js server with configurable scheduler initialization
|
|
import { createServer } from "node:http";
|
|
import { parse } from "node:url";
|
|
import next from "next";
|
|
import { getSchedulerConfig, logEnvConfig, validateEnv } from "./lib/env.js";
|
|
import { startImportProcessingScheduler } from "./lib/importProcessor.js";
|
|
import { startProcessingScheduler } from "./lib/processingScheduler.js";
|
|
import { startCsvImportScheduler } from "./lib/scheduler.js";
|
|
|
|
const dev = process.env.NODE_ENV !== "production";
|
|
const hostname = "localhost";
|
|
const port = parseInt(process.env.PORT || "3000", 10);
|
|
|
|
// Initialize Next.js
|
|
const app = next({ dev, hostname, port });
|
|
const handle = app.getRequestHandler();
|
|
|
|
app.prepare().then(() => {
|
|
// Validate and log environment configuration
|
|
const envValidation = validateEnv();
|
|
if (!envValidation.valid) {
|
|
console.error("[Environment] Validation errors:", envValidation.errors);
|
|
}
|
|
|
|
logEnvConfig();
|
|
|
|
// Get scheduler configuration
|
|
const config = getSchedulerConfig();
|
|
|
|
// Initialize schedulers based on configuration
|
|
if (config.enabled) {
|
|
console.log("Initializing schedulers...");
|
|
startCsvImportScheduler();
|
|
startImportProcessingScheduler();
|
|
startProcessingScheduler();
|
|
console.log("All schedulers initialized successfully");
|
|
}
|
|
|
|
createServer(async (req, res) => {
|
|
try {
|
|
// Parse the URL
|
|
const parsedUrl = parse(req.url || "", true);
|
|
|
|
// Let Next.js handle the request
|
|
await handle(req, res, parsedUrl);
|
|
} catch (err) {
|
|
console.error("Error occurred handling", req.url, err);
|
|
res.statusCode = 500;
|
|
res.end("Internal Server Error");
|
|
}
|
|
}).listen(port, () => {
|
|
console.log(`> Ready on http://${hostname}:${port}`);
|
|
});
|
|
});
|