mirror of
https://github.com/an-anime-team/an-anime-game-launcher.git
synced 2024-12-21 01:11:46 +03:00
Merge branch 'marie/integrity' into 'main'
Add file integrity/verification See merge request KRypt0n_/an-anime-game-launcher!45
This commit is contained in:
commit
0f3693d849
17 changed files with 214 additions and 2 deletions
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Spiel wird entpackt...
|
unpacking: Spiel wird entpackt...
|
||||||
applying_changes: Änderungen werden angewandt...
|
applying_changes: Änderungen werden angewandt...
|
||||||
deleting_outdated: Lösche veraltete dateien...
|
deleting_outdated: Lösche veraltete dateien...
|
||||||
|
integrity_check: Verifiziere Dateien...
|
||||||
|
download_mismatch_files: Lade nicht übereinstimmenden Dateien herunter...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Starten
|
launch: Starten
|
||||||
predownload: Update vorinstallieren
|
predownload: Update vorinstallieren
|
||||||
|
integrity: Dateien verifizieren und reparieren
|
||||||
|
|
||||||
# Einstellungs Fenster
|
# Einstellungs Fenster
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Unpacking game...
|
unpacking: Unpacking game...
|
||||||
applying_changes: Applying changes...
|
applying_changes: Applying changes...
|
||||||
deleting_outdated: Deleting outdated files...
|
deleting_outdated: Deleting outdated files...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Launch
|
launch: Launch
|
||||||
predownload: Pre-download update
|
predownload: Pre-download update
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Descomprimiendo el juego...
|
unpacking: Descomprimiendo el juego...
|
||||||
applying_changes: Applying changes...
|
applying_changes: Applying changes...
|
||||||
deleting_outdated: Borrando archivos viejos...
|
deleting_outdated: Borrando archivos viejos...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Instalación de paquetes de voz
|
# Instalación de paquetes de voz
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Jugar
|
launch: Jugar
|
||||||
predownload: Pre-descargar actualización
|
predownload: Pre-descargar actualización
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Ventana de opciones
|
# Ventana de opciones
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Décompression du jeu...
|
unpacking: Décompression du jeu...
|
||||||
applying_changes: Application des changements...
|
applying_changes: Application des changements...
|
||||||
deleting_outdated: Suppression des fichiers non à jour...
|
deleting_outdated: Suppression des fichiers non à jour...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -73,6 +75,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Lancer
|
launch: Lancer
|
||||||
predownload: Pre-téléchargement de mise à jour
|
predownload: Pre-téléchargement de mise à jour
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Játék kibontása folyamatban...
|
unpacking: Játék kibontása folyamatban...
|
||||||
applying_changes: Változások alkalmazása...
|
applying_changes: Változások alkalmazása...
|
||||||
deleting_outdated: Lejárt fájlok kitörlése...
|
deleting_outdated: Lejárt fájlok kitörlése...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Indítás
|
launch: Indítás
|
||||||
predownload: Frissítés előtöltése
|
predownload: Frissítés előtöltése
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Membongkar game...
|
unpacking: Membongkar game...
|
||||||
applying_changes: Applying changes...
|
applying_changes: Applying changes...
|
||||||
deleting_outdated: Menghapus file lama...
|
deleting_outdated: Menghapus file lama...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Luncurkan
|
launch: Luncurkan
|
||||||
predownload: Pembaruan pra-unduh
|
predownload: Pembaruan pra-unduh
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Decomprimendo il gioco...
|
unpacking: Decomprimendo il gioco...
|
||||||
applying_changes: Applicando i cambiamenti...
|
applying_changes: Applicando i cambiamenti...
|
||||||
deleting_outdated: Cancellando file vecchi...
|
deleting_outdated: Cancellando file vecchi...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Avvia
|
launch: Avvia
|
||||||
predownload: Pre-scarica aggiornamento
|
predownload: Pre-scarica aggiornamento
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Pakker ut spill...
|
unpacking: Pakker ut spill...
|
||||||
applying_changes: Applying changes...
|
applying_changes: Applying changes...
|
||||||
deleting_outdated: Fjerner utdaterte filer...
|
deleting_outdated: Fjerner utdaterte filer...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Start
|
launch: Start
|
||||||
predownload: Forhånds-nedlast oppdatering
|
predownload: Forhånds-nedlast oppdatering
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: Распаковка игры...
|
unpacking: Распаковка игры...
|
||||||
applying_changes: Применение изменений...
|
applying_changes: Применение изменений...
|
||||||
deleting_outdated: Удаление устаревших файлов...
|
deleting_outdated: Удаление устаревших файлов...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Установка звуковых пакетов
|
# Установка звуковых пакетов
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: Запустить
|
launch: Запустить
|
||||||
predownload: Предзагрузить обновление
|
predownload: Предзагрузить обновление
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Окно настроек
|
# Окно настроек
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -25,6 +25,8 @@ launcher:
|
||||||
unpacking: unpacking g-game (o^▽^o)
|
unpacking: unpacking g-game (o^▽^o)
|
||||||
applying_changes: appwying changes...
|
applying_changes: appwying changes...
|
||||||
deleting_outdated: deweting outdated fiwes...
|
deleting_outdated: deweting outdated fiwes...
|
||||||
|
integrity_check: vewifying fiwes...
|
||||||
|
download_mismatch_files: downwoading mismatched fiwes...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -70,6 +72,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: launch (◕▿◕✿)
|
launch: launch (◕▿◕✿)
|
||||||
predownload: pwe-downwoad update
|
predownload: pwe-downwoad update
|
||||||
|
integrity: vewify files & wepaiw
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -24,6 +24,8 @@ launcher:
|
||||||
unpacking: 解压游戏中...
|
unpacking: 解压游戏中...
|
||||||
applying_changes: 应用更改...
|
applying_changes: 应用更改...
|
||||||
deleting_outdated: 删除过期文件...
|
deleting_outdated: 删除过期文件...
|
||||||
|
integrity_check: Verifying Files...
|
||||||
|
download_mismatch_files: Downloading mismatched files...
|
||||||
|
|
||||||
# Voice packages installation
|
# Voice packages installation
|
||||||
voice:
|
voice:
|
||||||
|
@ -69,6 +71,7 @@ launcher:
|
||||||
ready:
|
ready:
|
||||||
launch: 启动
|
launch: 启动
|
||||||
predownload: 预下载更新
|
predownload: 预下载更新
|
||||||
|
integrity: Verify Files & Repair
|
||||||
|
|
||||||
# Settings window
|
# Settings window
|
||||||
settings:
|
settings:
|
||||||
|
|
BIN
src/assets/images/integrity.png
Normal file
BIN
src/assets/images/integrity.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 10 KiB |
|
@ -16,6 +16,7 @@
|
||||||
import Gear from './assets/images/gear.png';
|
import Gear from './assets/images/gear.png';
|
||||||
import GearActive from './assets/images/gear-active.png';
|
import GearActive from './assets/images/gear-active.png';
|
||||||
import Download from './assets/images/cloud-download.png';
|
import Download from './assets/images/cloud-download.png';
|
||||||
|
import Integrity from './assets/images/integrity.png';
|
||||||
|
|
||||||
const launcher = new Launcher(onMount);
|
const launcher = new Launcher(onMount);
|
||||||
|
|
||||||
|
@ -145,6 +146,10 @@
|
||||||
<img src={GearActive} class="active" alt="Settings">
|
<img src={GearActive} class="active" alt="Settings">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<button class="button hint--left hint--small" aria-label="{typeof $locale === 'string' ? $_('launcher.states.ready.integrity') : ''}" id="integrity">
|
||||||
|
<img src={Integrity} alt="Integrity" />
|
||||||
|
</button>
|
||||||
|
|
||||||
<button class="button hint--left hint--small" aria-label="{typeof $locale === 'string' ? $_('launcher.states.ready.predownload') : ''}" id="predownload">
|
<button class="button hint--left hint--small" aria-label="{typeof $locale === 'string' ? $_('launcher.states.ready.predownload') : ''}" id="predownload">
|
||||||
<img src={Download} alt="Download" />
|
<img src={Download} alt="Download" />
|
||||||
</button>
|
</button>
|
||||||
|
|
|
@ -70,6 +70,22 @@ img.background
|
||||||
width: 60%
|
width: 60%
|
||||||
margin: auto
|
margin: auto
|
||||||
|
|
||||||
|
#integrity
|
||||||
|
position: absolute
|
||||||
|
display: none
|
||||||
|
|
||||||
|
width: 52px
|
||||||
|
height: 52px
|
||||||
|
|
||||||
|
right: 386px
|
||||||
|
bottom: 54px
|
||||||
|
|
||||||
|
border-radius: 8px
|
||||||
|
|
||||||
|
img
|
||||||
|
width: 80%
|
||||||
|
margin: auto
|
||||||
|
|
||||||
#settings
|
#settings
|
||||||
width: 76px
|
width: 76px
|
||||||
height: 76px
|
height: 76px
|
||||||
|
@ -152,4 +168,4 @@ img.background
|
||||||
|
|
||||||
#downloader
|
#downloader
|
||||||
background-color: rgba(0,0,0,.3)
|
background-color: rgba(0,0,0,.3)
|
||||||
border: 1px solid rgba(0,0,0,.4)
|
border: 1px solid rgba(0,0,0,.4)
|
||||||
|
|
|
@ -22,7 +22,7 @@ class Stream extends AbstractInstaller
|
||||||
|
|
||||||
export default class Voice
|
export default class Voice
|
||||||
{
|
{
|
||||||
protected static readonly langs = {
|
public static readonly langs = {
|
||||||
'en-us': 'English(US)',
|
'en-us': 'English(US)',
|
||||||
'ja-jp': 'Japanese',
|
'ja-jp': 'Japanese',
|
||||||
'ko-kr': 'Korean',
|
'ko-kr': 'Korean',
|
||||||
|
|
|
@ -27,6 +27,7 @@ export default class State
|
||||||
public launchButton: HTMLElement;
|
public launchButton: HTMLElement;
|
||||||
public pauseButton: HTMLElement;
|
public pauseButton: HTMLElement;
|
||||||
public predownloadButton: HTMLElement;
|
public predownloadButton: HTMLElement;
|
||||||
|
public integrityButton: HTMLElement;
|
||||||
public settingsButton: HTMLElement;
|
public settingsButton: HTMLElement;
|
||||||
|
|
||||||
protected _state: LauncherState = 'game-launch-available';
|
protected _state: LauncherState = 'game-launch-available';
|
||||||
|
@ -56,6 +57,7 @@ export default class State
|
||||||
this.launchButton = <HTMLElement>document.getElementById('launch');
|
this.launchButton = <HTMLElement>document.getElementById('launch');
|
||||||
this.pauseButton = <HTMLElement>document.getElementById('pause');
|
this.pauseButton = <HTMLElement>document.getElementById('pause');
|
||||||
this.predownloadButton = <HTMLElement>document.getElementById('predownload');
|
this.predownloadButton = <HTMLElement>document.getElementById('predownload');
|
||||||
|
this.integrityButton = <HTMLElement>document.getElementById('integrity');
|
||||||
this.settingsButton = <HTMLElement>document.getElementById('settings');
|
this.settingsButton = <HTMLElement>document.getElementById('settings');
|
||||||
|
|
||||||
this.launchButton.onclick = () => {
|
this.launchButton.onclick = () => {
|
||||||
|
@ -96,6 +98,21 @@ export default class State
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
this.integrityButton.onclick = () => {
|
||||||
|
this.launchButton.style['display'] = 'none';
|
||||||
|
this.integrityButton.style['display'] = 'none';
|
||||||
|
this.settingsButton.style['display'] = 'none';
|
||||||
|
|
||||||
|
import('./states/CheckIntegrity').then((module) => {
|
||||||
|
module.default(this.launcher).then(() => {
|
||||||
|
this.update().then(() => {
|
||||||
|
this.launchButton.style['display'] = 'block';
|
||||||
|
this.settingsButton.style['display'] = 'block';
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
this.update().then(async () => {
|
this.update().then(async () => {
|
||||||
// Close splash screen
|
// Close splash screen
|
||||||
IPC.write('launcher-loaded');
|
IPC.write('launcher-loaded');
|
||||||
|
@ -239,6 +256,7 @@ export default class State
|
||||||
|
|
||||||
this.launcher.progressBar!.hide();
|
this.launcher.progressBar!.hide();
|
||||||
this.predownloadButton.style['display'] = 'none';
|
this.predownloadButton.style['display'] = 'none';
|
||||||
|
this.integrityButton.style['display'] = 'none';
|
||||||
|
|
||||||
this.launchButton.classList.remove('button-blue');
|
this.launchButton.classList.remove('button-blue');
|
||||||
this.launchButton.setAttribute('aria-label', '');
|
this.launchButton.setAttribute('aria-label', '');
|
||||||
|
@ -272,6 +290,8 @@ export default class State
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'game-launch-available':
|
case 'game-launch-available':
|
||||||
|
this.integrityButton.style['display'] = 'block';
|
||||||
|
|
||||||
this.launchButton.textContent = dictionary['ready']['launch'];
|
this.launchButton.textContent = dictionary['ready']['launch'];
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
138
src/ts/launcher/states/CheckIntegrity.ts
Normal file
138
src/ts/launcher/states/CheckIntegrity.ts
Normal file
|
@ -0,0 +1,138 @@
|
||||||
|
import type Launcher from '../../Launcher';
|
||||||
|
|
||||||
|
import { Debug, fs, path, Cache, Downloader } from '../../../empathize';
|
||||||
|
|
||||||
|
import constants from '../../Constants';
|
||||||
|
import Patch from "../../Patch";
|
||||||
|
import Locales from '../Locales';
|
||||||
|
import Voice from "../../Voice";
|
||||||
|
|
||||||
|
declare const Neutralino;
|
||||||
|
|
||||||
|
async function download(fileInfo): Promise<boolean>
|
||||||
|
{
|
||||||
|
return new Promise(async (resolve) => {
|
||||||
|
const gameDir = await constants.paths.gameDir;
|
||||||
|
const cache = await Cache.get('Game.getLatestData.ServerResponse');
|
||||||
|
|
||||||
|
let uri = `${cache!.value['game']['latest']['decompressed_path']}/${fileInfo.remoteName}`;
|
||||||
|
|
||||||
|
Downloader.download(uri, `${gameDir}/${fileInfo.remoteName}.new`).then((stream) => {
|
||||||
|
stream.finish(async () => {
|
||||||
|
const process = await Neutralino.os.execCommand(`md5sum "${path.addSlashes(`${gameDir}/${fileInfo.remoteName}.new`)}"`);
|
||||||
|
const fileHash = (process.stdOut || process.stdErr).split(' ')[0];
|
||||||
|
|
||||||
|
if (fileHash == fileInfo.md5)
|
||||||
|
{
|
||||||
|
await fs.remove(`${gameDir}/${fileInfo.remoteName}`);
|
||||||
|
await fs.move(`${gameDir}/${fileInfo.remoteName}.new`, `${gameDir}/${fileInfo.remoteName}`);
|
||||||
|
resolve(true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
await fs.remove(`${gameDir}/${fileInfo.remoteName}.new`);
|
||||||
|
resolve(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export default (launcher: Launcher): Promise<void> => {
|
||||||
|
return new Promise(async (resolve) => {
|
||||||
|
const gameDir = await constants.paths.gameDir;
|
||||||
|
|
||||||
|
Neutralino.filesystem.readFile(`${gameDir}/pkg_version`)
|
||||||
|
.then(async (files) => {
|
||||||
|
// Check Game and Voice Pack Integrity
|
||||||
|
|
||||||
|
let mismatchedFiles = new Array();
|
||||||
|
|
||||||
|
files = files.split(/\r\n|\r|\n/).filter((file) => file != '');
|
||||||
|
|
||||||
|
const InstalledVoices = await Voice.installed;
|
||||||
|
|
||||||
|
for (const voice of InstalledVoices)
|
||||||
|
{
|
||||||
|
Neutralino.filesystem.readFile(`${gameDir}/Audio_${Voice.langs[voice.lang]}_pkg_version`)
|
||||||
|
.then(async (vfiles) => {
|
||||||
|
vfiles = vfiles.split(/\r\n|\r|\n/).filter((file) => file != '');
|
||||||
|
files.push(...vfiles);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if (files.length > 0)
|
||||||
|
{
|
||||||
|
const patch = await Patch.latest;
|
||||||
|
|
||||||
|
launcher.progressBar?.init({
|
||||||
|
label: Locales.translate('launcher.progress.game.integrity_check') as string,
|
||||||
|
showSpeed: false,
|
||||||
|
showEta: true,
|
||||||
|
showPercents: true,
|
||||||
|
showTotals: false
|
||||||
|
});
|
||||||
|
|
||||||
|
launcher.progressBar?.show();
|
||||||
|
|
||||||
|
let current = 0, total = files.length;
|
||||||
|
|
||||||
|
for (const file of files)
|
||||||
|
{
|
||||||
|
// {"remoteName": "AnAnimeGame_Data/StreamingAssets/AssetBundles/blocks/00/16567284.blk", "md5": "79ab71cfff894edeaaef025ef1152b77", "fileSize": 3232361}
|
||||||
|
const fileCheckInfo = JSON.parse(file) as { remoteName: string, md5: string, fileSize: number };
|
||||||
|
|
||||||
|
// If the file exists and it's not UnityPlayer.dll
|
||||||
|
// or if it's UnityPlayer.dll but the patch wasn't applied
|
||||||
|
if (await fs.exists(`${gameDir}/${fileCheckInfo.remoteName}`) &&
|
||||||
|
(!fileCheckInfo.remoteName.includes('UnityPlayer.dll') || !patch.applied))
|
||||||
|
{
|
||||||
|
const process = await Neutralino.os.execCommand(`md5sum "${path.addSlashes(`${gameDir}/${fileCheckInfo.remoteName}`)}"`);
|
||||||
|
const fileHash = (process.stdOut || process.stdErr).split(' ')[0];
|
||||||
|
|
||||||
|
if (fileHash != fileCheckInfo.md5)
|
||||||
|
mismatchedFiles.push(fileCheckInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
launcher.progressBar?.update(++current, total, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
Debug.log({
|
||||||
|
function: 'Launcher/States/Integrity',
|
||||||
|
message: mismatchedFiles.length == 0 ?
|
||||||
|
`Checked ${total} files with ${mismatchedFiles.length} mismatches` :
|
||||||
|
[
|
||||||
|
`Checked ${total} files with ${mismatchedFiles.length} mismatch(es):`,
|
||||||
|
...mismatchedFiles.map(e => `[${e.md5}] ${e.remoteName}`)
|
||||||
|
]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
launcher.progressBar?.hide();
|
||||||
|
|
||||||
|
// Replace mismatched files
|
||||||
|
|
||||||
|
mismatchedFiles.forEach(async (fileInfo: { remoteName: string, md5: string, fileSize: number }) =>
|
||||||
|
{
|
||||||
|
launcher.progressBar?.init({
|
||||||
|
label: Locales.translate('launcher.progress.game.download_mismatch_files') as string,
|
||||||
|
showSpeed: false,
|
||||||
|
showEta: false,
|
||||||
|
showPercents: false,
|
||||||
|
showTotals: false
|
||||||
|
});
|
||||||
|
|
||||||
|
download(fileInfo).then(async (success) => {
|
||||||
|
if (!success)
|
||||||
|
Debug.log({
|
||||||
|
function: 'Launcher/States/Integrity',
|
||||||
|
message: `Download of ${fileInfo.remoteName} failed`
|
||||||
|
});
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
resolve();
|
||||||
|
})
|
||||||
|
.catch(() => resolve());
|
||||||
|
})
|
||||||
|
}
|
Loading…
Reference in a new issue