From 8b8192afc9f043da9d9413971292ba90b5127352 Mon Sep 17 00:00:00 2001 From: xLuxy <67131061+xLuxy@users.noreply.github.com> Date: Wed, 25 Oct 2023 14:09:28 +0200 Subject: [PATCH] Make downloading js-module configurable via config commit b7e0c27a4da4a38df1c13f5d528520223823e9ee Author: xLuxy <67131061+xLuxy@users.noreply.github.com> Date: Wed Oct 25 14:07:14 2023 +0200 Bump version to 2.6.0 commit 50c6ea393bdc6704778eee28f8c53d18d21cb2c5 Author: xLuxy <67131061+xLuxy@users.noreply.github.com> Date: Wed Oct 25 14:06:48 2023 +0200 Update README.md commit 50d5af3f596ae04c3b52aae38eec67d58331eb70 Author: xLuxy <67131061+xLuxy@users.noreply.github.com> Date: Wed Oct 25 14:03:05 2023 +0200 Make downloading js-module optional via config --- README.md | 11 +++++++---- bin/altv-pkg.js | 50 +++++++++++++++++++++++++++++++------------------ package.json | 2 +- 3 files changed, 40 insertions(+), 23 deletions(-) diff --git a/README.md b/README.md index 6ed15ab..6814cee 100644 --- a/README.md +++ b/README.md @@ -30,11 +30,14 @@ Create a `.altvpkgrc.json` file in your root directory and add the following JSO **Note:** The `loadVoiceServer` configuration allows you to include [external voice server](https://docs.altv.mp/articles/external_voice_server.html) when downloading binaries. +Below you'll find all available options for the `.altvpkgrc.json` file with their default values: + ``` { - "loadBytecodeModule": true, - "loadCSharpModule": true, - "loadJSV2Module": true, - "loadVoiceServer": true + "loadJSModule": true, + "loadBytecodeModule": false, + "loadCSharpModule": false, + "loadJSV2Module": false, + "loadVoiceServer": false } ``` diff --git a/bin/altv-pkg.js b/bin/altv-pkg.js index 730c8b8..cc08f89 100644 --- a/bin/altv-pkg.js +++ b/bin/altv-pkg.js @@ -16,7 +16,7 @@ const rootPath = process.cwd(); let platform = process.platform == 'win32' ? 'x64_win32' : 'x64_linux'; let branch = null; -const { loadBytecodeModule, loadCSharpModule, loadJSV2Module, loadVoiceServer } = loadRuntimeConfig(); +const { loadJSModule, loadBytecodeModule, loadCSharpModule, loadJSV2Module, loadVoiceServer } = loadRuntimeConfig(); function authorizeDiscord() { console.log(chalk.greenBright('===== Authorizing via Discord =====')); @@ -128,8 +128,6 @@ async function start() { const linuxFiles = { ...sharedFiles, - 'modules/libjs-module.so': `https://${CDN_ADDRESS}/js-module/${branch}/${platform}/modules/js-module/libjs-module.so`, - 'libnode.so.108': `https://${CDN_ADDRESS}/js-module/${branch}/${platform}/modules/js-module/libnode.so.108`, 'start.sh': `https://${CDN_ADDRESS}/others/start.sh`, }; @@ -138,11 +136,7 @@ async function start() { linuxFiles[file] = `https://${SERVER_CDN_ADDRESS}/server/${serverBranch}/x64_linux/${file}`; } - const windowsFiles = { - ...sharedFiles, - 'modules/js-module.dll': `https://${CDN_ADDRESS}/js-module/${branch}/${platform}/modules/js-module/js-module.dll`, - 'libnode.dll': `https://${CDN_ADDRESS}/js-module/${branch}/${platform}/modules/js-module/libnode.dll`, - }; + const windowsFiles = { ...sharedFiles }; res = await axios.get(`https://${SERVER_CDN_ADDRESS}/server/${serverBranch}/x64_win32/update.json`, { responseType: 'json', headers }); for ([file, hash] of Object.entries(res.data.hashList)) { @@ -155,16 +149,29 @@ async function start() { const linuxUpdates = [ ...sharedUpdates, - `https://${SERVER_CDN_ADDRESS}/server/${serverBranch}/x64_linux/update.json`, - `https://${CDN_ADDRESS}/js-module/${branch}/x64_linux/update.json`, + `https://${SERVER_CDN_ADDRESS}/server/${serverBranch}/x64_linux/update.json` ]; const windowsUpdates = [ ...sharedUpdates, - `https://${SERVER_CDN_ADDRESS}/server/${serverBranch}/x64_win32/update.json`, - `https://${CDN_ADDRESS}/js-module/${branch}/x64_win32/update.json`, + `https://${SERVER_CDN_ADDRESS}/server/${serverBranch}/x64_win32/update.json` ]; + if (loadJSModule) { + res = await axios.get(`https://${CDN_ADDRESS}/js-module/${branch}/x64_linux/update.json`, { responseType: 'json', headers }); + for ([file, hash] of Object.entries(res.data.hashList)) { + linuxFiles[file] = `https://${CDN_ADDRESS}/js-module/${branch}/x64_linux/${file}`; + } + + res = await axios.get(`https://${CDN_ADDRESS}/js-module/${branch}/x64_win32/update.json`, { responseType: 'json', headers }); + for ([file, hash] of Object.entries(res.data.hashList)) { + windowsFiles[file] = `https://${CDN_ADDRESS}/js-module/${branch}/x64_win32/${file}`; + } + + linuxUpdates.push(`https://${CDN_ADDRESS}/js-module/${branch}/x64_linux/update.json`) + windowsUpdates.push(`https://${CDN_ADDRESS}/js-module/${branch}/x64_win32/update.json`); + } + if (loadBytecodeModule) { res = await axios.get(`https://${CDN_ADDRESS}/js-bytecode-module/${branch}/x64_linux/update.json`, { responseType: 'json', headers }); for ([file, hash] of Object.entries(res.data.hashList)) { @@ -247,23 +254,25 @@ async function start() { let promises = []; let anyHashRejected = false; + + console.log(filesToUse[file]) for (const url of filesUpdate) { const promise = new Promise((resolve, reject) => { axios.get(url, { responseType: 'json', headers }).then(({ data: { hashList } }) => { for (let [file, hash] of Object.entries(hashList)) { - file = correctPathIfNecessary(file); + const correctedFileName = correctPathIfNecessary(file); - if (getLocalFileHash(file) === hash) { - console.log(chalk.cyanBright('✓'), chalk.whiteBright(file)); + if (getLocalFileHash(correctedFileName) === hash) { + console.log(chalk.cyanBright('✓'), chalk.whiteBright(correctedFileName)); continue; } - console.log(chalk.redBright('x'), chalk.whiteBright(file)); + console.log(chalk.redBright('x'), chalk.whiteBright(correctedFileName)); if (anyHashRejected) return; - filesToDownload[file] = filesToUse[file]; + filesToDownload[correctedFileName] = filesToUse[file]; } resolve(); @@ -344,6 +353,8 @@ function correctPathIfNecessary(file) { } function loadRuntimeConfig() { + let loadJSModule = true; + let loadBytecodeModule = false; let loadCSharpModule = false; let loadJSV2Module = false; @@ -353,6 +364,9 @@ function loadRuntimeConfig() { const data = fs.readFileSync(`./${RC_FILE_NAME}`, { encoding: 'utf8' }); const parsedData = JSON.parse(data); + if (typeof parsedData.loadJSModule !== 'undefined') + loadJSModule = !!parsedData.loadJSModule; + loadBytecodeModule = !!parsedData.loadBytecodeModule; loadCSharpModule = !!parsedData.loadCSharpModule; loadJSV2Module = !!parsedData.loadJSV2Module; @@ -361,7 +375,7 @@ function loadRuntimeConfig() { console.log(chalk.gray(`Configuration file '${RC_FILE_NAME}' could not be read. Continuing without...`)); } - return { loadBytecodeModule, loadCSharpModule, loadJSV2Module, loadVoiceServer }; + return { loadJSModule, loadBytecodeModule, loadCSharpModule, loadJSV2Module, loadVoiceServer }; } start(); diff --git a/package.json b/package.json index 2ff2c63..ae1e17d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "altv-pkg", - "version": "2.5.0", + "version": "2.6.0", "description": "Install alt:V Binaries Quickly", "main": "bin/index.js", "author": "stuyk",