Some curseforge mods disallow 3rd party downloads, log those to the console for manual action.

This commit is contained in:
Daniel Scalzi
2023-07-02 17:09:32 -04:00
parent 9f6220b508
commit 5da3d6cf5f
3 changed files with 571 additions and 215 deletions

700
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -30,28 +30,28 @@
"homepage": "https://github.com/dscalzi/Nebula#readme",
"devDependencies": {
"@types/fs-extra": "^11.0.1",
"@types/luxon": "^3.2.0",
"@types/node": "^18.15.3",
"@types/luxon": "^3.3.0",
"@types/node": "^18.16.9",
"@types/triple-beam": "^1.3.2",
"@types/yargs": "^17.0.22",
"@typescript-eslint/eslint-plugin": "^5.55.0",
"@typescript-eslint/parser": "^5.55.0",
"eslint": "^8.36.0",
"rimraf": "^4.4.0",
"typescript": "^5.0.2"
"@types/yargs": "^17.0.24",
"@typescript-eslint/eslint-plugin": "^5.60.1",
"@typescript-eslint/parser": "^5.60.1",
"eslint": "^8.44.0",
"rimraf": "^5.0.1",
"typescript": "^5.1.6"
},
"dependencies": {
"dotenv": "^16.0.3",
"fs-extra": "^11.1.0",
"got": "^12.6.0",
"dotenv": "^16.3.1",
"fs-extra": "^11.1.1",
"got": "^13.0.0",
"helios-distribution-types": "^1.2.0",
"luxon": "^3.3.0",
"minimatch": "^7.4.2",
"minimatch": "^9.0.2",
"node-stream-zip": "^1.15.0",
"toml": "^3.0.0",
"triple-beam": "^1.3.0",
"ts-json-schema-generator": "^1.2.0",
"winston": "^3.8.2",
"yargs": "^17.7.1"
"winston": "^3.9.0",
"yargs": "^17.7.2"
}
}

View File

@@ -32,6 +32,16 @@ export interface CurseForgeManifest {
overrides: string
}
export interface CurseForgeModResponse {
data: {
id: number
gameId: number
name: string
slug: string
// There are more fields that we don't use right now.
}
}
export interface CurseForgeModFileResponse {
data: {
id: number
@@ -94,14 +104,16 @@ export class CurseForgeParser {
const requiredPath = resolve(createServerResult.forgeModContainer, ToggleableNamespace.REQUIRED)
const optionalPath = resolve(createServerResult.forgeModContainer, ToggleableNamespace.OPTIONAL_ON)
const disallowedFiles: { name: string, fileName: string, url: string }[] = []
// Download mods
for(const file of manifest.files) {
log.debug(`Processing - Mod: ${file.projectID}, File: ${file.fileID}`)
const modInfo = (await CurseForgeParser.cfClient.get<CurseForgeModFileResponse>(`mods/${file.projectID}/files/${file.fileID}`)).body
log.debug(`Downloading ${modInfo.data.fileName}`)
const fileInfo = (await CurseForgeParser.cfClient.get<CurseForgeModFileResponse>(`mods/${file.projectID}/files/${file.fileID}`)).body
log.debug(`Downloading ${fileInfo.data.fileName}`)
let dir: string
const fileNameLower = modInfo.data.fileName.toLowerCase()
const fileNameLower = fileInfo.data.fileName.toLowerCase()
if(fileNameLower.endsWith('jar')) {
dir = file.required ? requiredPath : optionalPath
}
@@ -114,11 +126,45 @@ export class CurseForgeParser {
dir = createServerResult.miscFileContainer
}
const downloadStream = got.stream(modInfo.data.downloadUrl)
const fileWriterStream = createWriteStream(join(dir, modInfo.data.fileName))
const thirdPartyDisallowed = fileInfo.data.downloadUrl == null
if(thirdPartyDisallowed) {
await pipeline(downloadStream, fileWriterStream)
log.warn(`${fileInfo.data.fileName} is not available for 3rd-party download through the curseforge API!`)
const modInfo = (await CurseForgeParser.cfClient.get<CurseForgeModResponse>(`mods/${file.projectID}`)).body
disallowedFiles.push({
name: modInfo.data.name,
fileName: fileInfo.data.fileName,
url: `https://www.curseforge.com/minecraft/mc-mods/${modInfo.data.slug}/download/${file.fileID}`
})
} else {
const downloadStream = got.stream(fileInfo.data.downloadUrl)
const fileWriterStream = createWriteStream(join(dir, fileInfo.data.fileName))
await pipeline(downloadStream, fileWriterStream)
}
}
if(disallowedFiles.length > 0) {
log.error('============================================')
log.error('\x1b[41mWARNING\x1b[0m')
log.error(`${disallowedFiles.length} files declared by this modpack do not permit 3rd-party downloads.`)
log.error('They MUST be downloaded manually.')
log.error('The mods and their download urls will be listed below.')
log.error('============================================')
for(const file of disallowedFiles) {
log.error(`${file.name} (${file.fileName}) - \x1b[32m${file.url}\x1b[0m`)
}
log.error('============================================')
log.error('YOUR MODPACK IS NOT FULLY GENERATED!')
log.error('MANUAL ACTION REQUIRED! SCROLL UP AND READ THE WARNING!')
log.error('============================================')
}
}
}