163 lines
6.8 KiB
TypeScript
163 lines
6.8 KiB
TypeScript
import { Request, Response } from 'express';
|
|
import { getAllRooms, createRoom, deleteRoom, deleteAllRooms } from '../services/roomService';
|
|
import { deleteAllRecordings, getAllRecordings } from '../services/recordingService';
|
|
|
|
export const getHome = async (_req: Request, res: Response) => {
|
|
try {
|
|
console.log('Fetching rooms from:', `${process.env.MEET_API_URL || 'http://localhost:6080/api/v1'}/rooms`);
|
|
console.log('Using API key:', process.env.MEET_API_KEY || 'meet-api-key');
|
|
|
|
const { rooms } = await getAllRooms();
|
|
|
|
// Sort rooms by newest first
|
|
rooms.sort((a, b) => {
|
|
const dateA = new Date(a.creationDate);
|
|
const dateB = new Date(b.creationDate);
|
|
return dateB.getTime() - dateA.getTime();
|
|
});
|
|
|
|
console.log(`Rooms fetched successfully: ${rooms.length}`);
|
|
res.render('index', { rooms });
|
|
} catch (error) {
|
|
console.error('Error fetching rooms:', error);
|
|
console.error('Error details:', {
|
|
message: error instanceof Error ? error.message : 'Unknown error',
|
|
stack: error instanceof Error ? error.stack : 'No stack trace',
|
|
apiUrl: process.env.MEET_API_URL || 'http://localhost:6080/api/v1',
|
|
apiKey: process.env.MEET_API_KEY || 'meet-api-key'
|
|
});
|
|
res.status(500).send('Internal Server Error - Failed to fetch rooms: ' + (error instanceof Error ? error.message : 'Unknown error'));
|
|
return;
|
|
}
|
|
};
|
|
|
|
export const postCreateRoom = async (req: Request, res: Response) => {
|
|
try {
|
|
console.log('Creating room with body:', JSON.stringify(req.body, null, 2));
|
|
const { roomIdPrefix, autoDeletionDate } = req.body;
|
|
const preferences = processFormPreferences(req.body);
|
|
|
|
console.log('Processed preferences:', JSON.stringify(preferences, null, 2));
|
|
console.log('Room creation parameters:', { roomIdPrefix, autoDeletionDate });
|
|
|
|
const result = await createRoom({ roomIdPrefix, autoDeletionDate, preferences });
|
|
console.log('Room created successfully:', result);
|
|
res.redirect('/');
|
|
} catch (error) {
|
|
console.error('Error creating room:', error);
|
|
console.error('Error details:', {
|
|
message: error instanceof Error ? error.message : 'Unknown error',
|
|
stack: error instanceof Error ? error.stack : 'No stack trace',
|
|
requestBody: req.body
|
|
});
|
|
res.status(500).send('Internal Server Error - Failed to create room: ' + (error instanceof Error ? error.message : 'Unknown error'));
|
|
return;
|
|
}
|
|
};
|
|
|
|
export const deleteRoomCtrl = async (req: Request, res: Response) => {
|
|
try {
|
|
console.log('Deleting room with body:', JSON.stringify(req.body, null, 2));
|
|
const { roomId } = req.body;
|
|
|
|
if (!roomId) {
|
|
console.error('No roomId provided for deletion');
|
|
res.status(400).send('Bad Request - roomId is required');
|
|
return;
|
|
}
|
|
|
|
console.log(`Attempting to delete room: ${roomId}`);
|
|
await deleteRoom(roomId);
|
|
console.log(`Room ${roomId} deleted successfully`);
|
|
res.redirect('/');
|
|
} catch (error) {
|
|
console.error('Error deleting room:', error);
|
|
console.error('Error details:', {
|
|
message: error instanceof Error ? error.message : 'Unknown error',
|
|
stack: error instanceof Error ? error.stack : 'No stack trace',
|
|
requestBody: req.body
|
|
});
|
|
res.status(500).send('Internal Server Error - Failed to delete room: ' + (error instanceof Error ? error.message : 'Unknown error'));
|
|
return;
|
|
}
|
|
};
|
|
|
|
export const deleteAllRoomsCtrl = async (_req: Request, res: Response) => {
|
|
try {
|
|
console.log('Deleting all rooms...');
|
|
const allRooms = await getAllRooms();
|
|
console.log(`Found ${allRooms.rooms.length} rooms to delete`);
|
|
|
|
if (allRooms.rooms.length === 0) {
|
|
console.log('No rooms to delete');
|
|
res.render('index', { rooms: [] });
|
|
return;
|
|
}
|
|
|
|
const roomIds = allRooms.rooms.map((room) => room.roomId);
|
|
console.log(`Deleting ${roomIds.length} rooms:`, roomIds);
|
|
await deleteAllRooms(roomIds);
|
|
console.log('All rooms deleted successfully');
|
|
res.render('index', { rooms: [] });
|
|
} catch (error) {
|
|
console.error('Error deleting all rooms:', error);
|
|
console.error('Error details:', {
|
|
message: error instanceof Error ? error.message : 'Unknown error',
|
|
stack: error instanceof Error ? error.stack : 'No stack trace'
|
|
});
|
|
res.status(500).send('Internal Server Error - Failed to delete all rooms: ' + (error instanceof Error ? error.message : 'Unknown error'));
|
|
return;
|
|
}
|
|
};
|
|
|
|
export const deleteAllRecordingsCtrl = async (_req: Request, res: Response) => {
|
|
try {
|
|
console.log('Deleting all recordings...');
|
|
const [{ recordings }, { rooms }] = await Promise.all([getAllRecordings(), getAllRooms()]);
|
|
console.log(`Found ${recordings.length} recordings to delete`);
|
|
|
|
if (recordings.length === 0) {
|
|
console.log('No recordings to delete');
|
|
res.render('index', { rooms });
|
|
return;
|
|
}
|
|
|
|
const recordingIds = recordings.map((recording) => recording.recordingId);
|
|
console.log(`Deleting ${recordingIds.length} recordings:`, recordingIds);
|
|
await deleteAllRecordings(recordingIds);
|
|
console.log('All recordings deleted successfully');
|
|
res.render('index', { rooms });
|
|
} catch (error) {
|
|
console.error('Error deleting all recordings:', error);
|
|
console.error('Error details:', {
|
|
message: error instanceof Error ? error.message : 'Unknown error',
|
|
stack: error instanceof Error ? error.stack : 'No stack trace'
|
|
});
|
|
res.status(500).send('Internal Server Error - Failed to delete all recordings: ' + (error instanceof Error ? error.message : 'Unknown error'));
|
|
return;
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Converts flat form data to nested MeetRoomPreferences object
|
|
*/
|
|
const processFormPreferences = (body: any): any => {
|
|
const preferences = {
|
|
chatPreferences: {
|
|
enabled: body['preferences.chatPreferences.enabled'] === 'on'
|
|
},
|
|
recordingPreferences: {
|
|
enabled: body['preferences.recordingPreferences.enabled'] === 'on',
|
|
// Only include allowAccessTo if recording is enabled
|
|
...(body['preferences.recordingPreferences.enabled'] === 'on' && {
|
|
allowAccessTo: body['preferences.recordingPreferences.allowAccessTo'] || 'admin-moderator-publisher'
|
|
})
|
|
},
|
|
virtualBackgroundPreferences: {
|
|
enabled: body['preferences.virtualBackgroundPreferences.enabled'] === 'on'
|
|
}
|
|
};
|
|
|
|
return preferences;
|
|
};
|