mirror of
https://github.com/QYG2297248353/IYUUPlus-Windows.git
synced 2024-11-10 14:37:04 +08:00
131 lines
3.6 KiB
JavaScript
131 lines
3.6 KiB
JavaScript
const { spawn, exec, execFile } = require('child_process');
|
|
const os = require('os');
|
|
const path = require('path');
|
|
const log = require('electron-log')
|
|
|
|
function getPhpPath(resourcePath) {
|
|
const arch = os.arch();
|
|
if (arch === 'x64') {
|
|
return path.join(resourcePath, 'run', 'php-8.3.8-x64');
|
|
} else if (arch === 'ia32') {
|
|
return path.join(resourcePath, 'run', 'php-8.3.8-x86');
|
|
} else {
|
|
log.info("Unsupported architecture:", arch);
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
let serverProcess = null;
|
|
|
|
function startServer() {
|
|
let resourcePath = process.resourcesPath;
|
|
if (resourcePath.includes('node_modules')) {
|
|
resourcePath = process.cwd();
|
|
}
|
|
|
|
const env = { ...process.env };
|
|
const phpDir = getPhpPath(resourcePath);
|
|
env.Path = `${phpDir};${env.Path}`;
|
|
|
|
const workingDir = path.resolve(path.join(resourcePath, 'iyuu'));
|
|
const batFile = path.join('windows.bat');
|
|
// batFile 父目录
|
|
|
|
|
|
log.info(`[IYUU] 工作目录: ${workingDir}`);
|
|
|
|
// serverProcess = exec(`cmd /c ${batPath}`, {
|
|
// cwd: workingDirectory,
|
|
// env: env,
|
|
// windowsHide: true
|
|
// }, (error, stdout, stderr) => {
|
|
// if (error) {
|
|
// log.error(`[IYUU] 服务启动错误: ${error.message}`);
|
|
// return;
|
|
// }
|
|
// if (stderr) {
|
|
// log.error(`[IYUU] 服务启动 stderr: ${stderr}`);
|
|
// return;
|
|
// }
|
|
// log.info(`[IYUU] 服务启动成功: ${stdout}`);
|
|
// });
|
|
|
|
|
|
// serverProcess = execFile('cmd', ['/c', batPath], {
|
|
// cwd: workingDirectory,
|
|
// env: env,
|
|
// killSignal: 'SIGTERM',
|
|
// windowsHide: true,
|
|
// }, (error, stdout, stderr) => {
|
|
// if (error) {
|
|
// log.error(`[IYUU] 服务启动错误: ${error.message}`);
|
|
// } else {
|
|
// log.error(`[IYUU] 服务启动 stderr: ${stderr}`);
|
|
// log.info(`[IYUU] 服务启动成功: ${stdout}`);
|
|
// }
|
|
// });
|
|
|
|
serverProcess = spawn('cmd', ['/k', 'windows.bat'], {
|
|
cwd: workingDir,
|
|
stdio: 'pipe',
|
|
env: env,
|
|
detached: true,
|
|
windowsHide: false
|
|
});
|
|
|
|
serverProcess.unref();
|
|
|
|
if (serverProcess.stdout) {
|
|
serverProcess.stdout.on('data', (data) => {
|
|
log.info(`[IYUU] ${data}`);
|
|
});
|
|
|
|
serverProcess.stderr.on('data', (data) => {
|
|
log.error(`[IYUU] ${data}`);
|
|
});
|
|
|
|
|
|
}
|
|
|
|
serverProcess.on('error', (err) => {
|
|
log.error(`[IYUU] 服务启动错误: ${err.message}`);
|
|
});
|
|
|
|
serverProcess.on("close", function (code) {
|
|
log.info("[IYUU] 服务退出:" + code);
|
|
restartServer();
|
|
});
|
|
}
|
|
|
|
function stopServer() {
|
|
if (serverProcess) {
|
|
log.info("Killing server process with PID:", serverProcess.pid);
|
|
|
|
try {
|
|
process.kill(-serverProcess.pid, 'SIGTERM');
|
|
log.info("后台服务已关闭...");
|
|
serverProcess = null;
|
|
} catch (err) {
|
|
log.error('Error using process.kill:', err);
|
|
exec(`taskkill /PID ${serverProcess.pid} /T /F`, (err, stdout, stderr) => {
|
|
if (err) {
|
|
log.error('Error using taskkill:', err);
|
|
} else {
|
|
log.info("后台服务已关闭...");
|
|
serverProcess = null;
|
|
}
|
|
});
|
|
}
|
|
} else {
|
|
log.info("No server process to kill.");
|
|
}
|
|
}
|
|
|
|
function restartServer() {
|
|
stopServer();
|
|
setTimeout(() => {
|
|
startServer();
|
|
}, 1000);
|
|
}
|
|
|
|
module.exports = { startServer, stopServer, restartServer }; |