2023-01-31 22:00:30 -05:00
|
|
|
import * as toml from 'toml';
|
2023-02-02 21:19:55 -05:00
|
|
|
import IConfig from './IConfig.js';
|
2024-04-24 03:50:17 -04:00
|
|
|
import * as fs from 'fs';
|
2023-02-02 21:19:55 -05:00
|
|
|
import WSServer from './WSServer.js';
|
2024-04-23 09:57:02 -04:00
|
|
|
|
|
|
|
|
import { QemuVM, QemuVmDefinition } from '@cvmts/qemu';
|
|
|
|
|
|
|
|
|
|
import * as Shared from '@cvmts/shared';
|
2024-04-05 09:10:47 -04:00
|
|
|
import AuthManager from './AuthManager.js';
|
2023-02-24 22:54:28 -05:00
|
|
|
|
2024-04-24 03:50:17 -04:00
|
|
|
let logger = new Shared.Logger('CVMTS.Init');
|
2024-04-23 09:57:02 -04:00
|
|
|
|
2024-04-24 03:50:17 -04:00
|
|
|
logger.Info('CollabVM Server starting up');
|
2023-01-31 22:00:30 -05:00
|
|
|
|
|
|
|
|
// Parse the config file
|
|
|
|
|
|
2024-04-24 03:50:17 -04:00
|
|
|
let Config: IConfig;
|
2023-01-31 22:00:30 -05:00
|
|
|
|
2024-04-24 03:50:17 -04:00
|
|
|
if (!fs.existsSync('config.toml')) {
|
|
|
|
|
logger.Error('Fatal error: Config.toml not found. Please copy config.example.toml and fill out fields');
|
|
|
|
|
process.exit(1);
|
2023-01-31 22:00:30 -05:00
|
|
|
}
|
|
|
|
|
try {
|
2024-04-24 03:50:17 -04:00
|
|
|
var configRaw = fs.readFileSync('config.toml').toString();
|
|
|
|
|
Config = toml.parse(configRaw);
|
2023-01-31 22:00:30 -05:00
|
|
|
} catch (e) {
|
2024-04-24 03:50:17 -04:00
|
|
|
logger.Error('Fatal error: Failed to read or parse the config file: {0}', (e as Error).message);
|
|
|
|
|
process.exit(1);
|
2023-01-31 22:00:30 -05:00
|
|
|
}
|
|
|
|
|
|
2023-02-02 21:19:55 -05:00
|
|
|
async function start() {
|
2024-04-24 03:50:17 -04:00
|
|
|
// Print a warning if qmpSockDir is set
|
|
|
|
|
// and the host OS is Windows, as this
|
|
|
|
|
// configuration will very likely not work.
|
|
|
|
|
if (process.platform === 'win32' && Config.vm.qmpSockDir) {
|
|
|
|
|
logger.Warning("You appear to have the option 'qmpSockDir' enabled in the config.");
|
|
|
|
|
logger.Warning('This is not supported on Windows, and you will likely run into issues.');
|
|
|
|
|
logger.Warning('To remove this warning, use the qmpHost and qmpPort options instead.');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Init the auth manager if enabled
|
|
|
|
|
let auth = Config.auth.enabled ? new AuthManager(Config.auth.apiEndpoint, Config.auth.secretKey) : null;
|
|
|
|
|
|
|
|
|
|
// Fire up the VM
|
|
|
|
|
let def: QemuVmDefinition = {
|
|
|
|
|
id: Config.collabvm.node,
|
|
|
|
|
command: Config.vm.qemuArgs
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var VM = new QemuVM(def);
|
|
|
|
|
await VM.Start();
|
|
|
|
|
|
|
|
|
|
// Start up the websocket server
|
|
|
|
|
var WS = new WSServer(Config, VM, auth);
|
|
|
|
|
WS.listen();
|
2023-02-02 21:19:55 -05:00
|
|
|
}
|
2024-04-24 03:50:17 -04:00
|
|
|
start();
|