mirror of
https://github.com/kjanat/livedash-node.git
synced 2026-01-16 13:32:08 +01:00
- Added MessageViewer component to display parsed messages in a chat-like format. - Introduced new Message table in the database to store individual messages with timestamps, roles, and content. - Updated Session model to include a relation to parsed messages. - Created transcript parsing logic to convert raw transcripts into structured messages. - Enhanced processing scheduler to handle sessions with parsed messages. - Updated API endpoints to return parsed messages alongside session details. - Added manual trigger commands for session refresh, transcript parsing, and processing. - Improved user experience with color-coded message roles and timestamps in the UI. - Documented the new scheduler workflow and transcript parsing implementation.
39 lines
1.2 KiB
TypeScript
39 lines
1.2 KiB
TypeScript
// Custom Next.js server with scheduler initialization
|
|
import { createServer } from 'http';
|
|
import { parse } from 'url';
|
|
import next from 'next';
|
|
import { startScheduler } from './lib/scheduler.js';
|
|
import { startProcessingScheduler } from './lib/processingScheduler.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(() => {
|
|
// Initialize schedulers when the server starts
|
|
console.log('Starting schedulers...');
|
|
startScheduler();
|
|
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}`);
|
|
});
|
|
});
|