mirror of
https://github.com/an-anime-team/an-anime-game-launcher.git
synced 2025-01-04 16:07:19 +03:00
2.1.2
- added `latest.log` file generation, changed log files naming From previous commits: - fixed chinese voice data installation (!33) - don't attempt to edit /etc/hosts or use pkexec when running as flatpak (!31) From beta-1: - fixed compatibility issues with patch repos
This commit is contained in:
parent
b30c2276ef
commit
a4a1d3501e
8 changed files with 35 additions and 18 deletions
|
@ -135,8 +135,8 @@ This is our current roadmap goals. You can find older ones [here](repository/pag
|
||||||
* <s>Move launcher on [Empathize](https://github.com/empathizejs/framework)</s> *(2.1.0)*
|
* <s>Move launcher on [Empathize](https://github.com/empathizejs/framework)</s> *(2.1.0)*
|
||||||
* <s>Make notifications translations</s> *(2.1.0)*
|
* <s>Make notifications translations</s> *(2.1.0)*
|
||||||
* <s>ToS Violation Window</s> *(2.1.0)*
|
* <s>ToS Violation Window</s> *(2.1.0)*
|
||||||
|
* <s>Add `latest.log` file generation</s> *(2.1.2)*
|
||||||
* Add Chinese game's version support (due to changes in the Krock's patch)
|
* Add Chinese game's version support (due to changes in the Krock's patch)
|
||||||
* Add `latest.log` file generation
|
|
||||||
* Implement manual config flushing functionality from the Empathize's API
|
* Implement manual config flushing functionality from the Empathize's API
|
||||||
* Add analytics window
|
* Add analytics window
|
||||||
* Add an option to show terminal with the wine's log of the game
|
* Add an option to show terminal with the wine's log of the game
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"applicationId": "com.gitlab.KRypt0n_.an-anime-game-launcher",
|
"applicationId": "com.gitlab.KRypt0n_.an-anime-game-launcher",
|
||||||
"version": "2.1.2-beta1",
|
"version": "2.1.2",
|
||||||
"defaultMode": "window",
|
"defaultMode": "window",
|
||||||
"port": 0,
|
"port": 0,
|
||||||
"documentRoot": "/bundle/",
|
"documentRoot": "/bundle/",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "an-anime-game-launcher",
|
"name": "an-anime-game-launcher",
|
||||||
"version": "2.1.2-beta1",
|
"version": "2.1.2",
|
||||||
"license": "GPL-3.0",
|
"license": "GPL-3.0",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
|
|
@ -39,7 +39,7 @@ const bundler = new Bundler({
|
||||||
output: path.join(__dirname, '../dist/An Anime Game Launcher.AppImage'),
|
output: path.join(__dirname, '../dist/An Anime Game Launcher.AppImage'),
|
||||||
|
|
||||||
// Application version
|
// Application version
|
||||||
version: '2.1.2-beta1'
|
version: '2.1.2'
|
||||||
});
|
});
|
||||||
|
|
||||||
// Bundle project
|
// Bundle project
|
||||||
|
|
|
@ -19,6 +19,22 @@
|
||||||
|
|
||||||
const launcher = new Launcher(onMount);
|
const launcher = new Launcher(onMount);
|
||||||
|
|
||||||
|
const getLogFilename = (date: Date = Debug.startedAt) => {
|
||||||
|
const prefixZero = (num: number) => num < 10 ? `0${num}` : num;
|
||||||
|
|
||||||
|
return `${date.getFullYear()}-${prefixZero(date.getMonth() + 1)}-${prefixZero(date.getDate())}-${prefixZero(date.getHours())}-${prefixZero(date.getMinutes())}-${prefixZero(date.getSeconds())}.log`;
|
||||||
|
};
|
||||||
|
|
||||||
|
constants.paths.launcherDir.then((launcherDir) => {
|
||||||
|
Neutralino.filesystem.getStats(`${launcherDir}/logs/latest.log`)
|
||||||
|
.then(async () => {
|
||||||
|
const created_at = (await Neutralino.os.execCommand(`stat -c '%W' "${path.addSlashes(`${launcherDir}/logs/latest.log`)}"`)).stdOut;
|
||||||
|
|
||||||
|
Neutralino.filesystem.moveFile(`${launcherDir}/logs/latest.log`, `${launcherDir}/logs/${getLogFilename(new Date(created_at * 1000))}`);
|
||||||
|
})
|
||||||
|
.catch(() => {});
|
||||||
|
});
|
||||||
|
|
||||||
Neutralino.events.on('windowClose', async () => {
|
Neutralino.events.on('windowClose', async () => {
|
||||||
Downloader.closeStreams(true);
|
Downloader.closeStreams(true);
|
||||||
Archive.closeStreams(true);
|
Archive.closeStreams(true);
|
||||||
|
@ -46,7 +62,7 @@
|
||||||
const log = Debug.get().join('\r\n');
|
const log = Debug.get().join('\r\n');
|
||||||
|
|
||||||
if (log != '')
|
if (log != '')
|
||||||
await Neutralino.filesystem.writeFile(`${launcherDir}/logs/${Debug.startedAt.getDate()}-${Debug.startedAt.getMonth() + 1}-${Debug.startedAt.getFullYear()}-${Debug.startedAt.getHours()}-${Debug.startedAt.getMinutes()}-${Debug.startedAt.getSeconds()}.log`, log);
|
await Neutralino.filesystem.writeFile(`${launcherDir}/logs/latest.log`, log);
|
||||||
|
|
||||||
// And close the launcher when they was saved
|
// And close the launcher when they was saved
|
||||||
Neutralino.app.exit();
|
Neutralino.app.exit();
|
||||||
|
@ -64,7 +80,7 @@
|
||||||
const log = `=== Log can be incomplete ===\r\n\r\n${Debug.get().join('\r\n')}`;
|
const log = `=== Log can be incomplete ===\r\n\r\n${Debug.get().join('\r\n')}`;
|
||||||
|
|
||||||
if (log != '')
|
if (log != '')
|
||||||
await Neutralino.filesystem.writeFile(`${await constants.paths.launcherDir}/logs/${Debug.startedAt.getDate()}-${Debug.startedAt.getMonth() + 1}-${Debug.startedAt.getFullYear()}-${Debug.startedAt.getHours()}-${Debug.startedAt.getMinutes()}-${Debug.startedAt.getSeconds()}.log`, log);
|
await Neutralino.filesystem.writeFile(`${await constants.paths.launcherDir}/logs/latest.log`, log);
|
||||||
|
|
||||||
logSavingStarted = false;
|
logSavingStarted = false;
|
||||||
}, 5000);
|
}, 5000);
|
||||||
|
@ -77,7 +93,7 @@
|
||||||
* Update launcher's title
|
* Update launcher's title
|
||||||
*/
|
*/
|
||||||
Game.latest.then((game) => {
|
Game.latest.then((game) => {
|
||||||
Windows.current.setTitle(`An Anime Game Launcher - ${game.version} (beta revision)`);
|
Windows.current.setTitle(`An Anime Game Launcher - ${game.version}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -100,7 +100,7 @@ class Paths
|
||||||
/**
|
/**
|
||||||
* Cache file
|
* Cache file
|
||||||
*
|
*
|
||||||
* @default "~/.local/share/anime-game-launcher/cache.json"
|
* @default "~/.local/share/anime-game-launcher/.cache.json"
|
||||||
*/
|
*/
|
||||||
public static get cache(): Promise<string>
|
public static get cache(): Promise<string>
|
||||||
{
|
{
|
||||||
|
|
|
@ -187,12 +187,15 @@ export default class Launcher
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async isFlatpak(): Promise<boolean> {
|
/**
|
||||||
try {
|
* Check if the launcher is running under flatpak
|
||||||
const stats = await Neutralino.filesystem.getStats("/.flatpak-info");
|
*/
|
||||||
return stats.isFile;
|
public static isFlatpak(): Promise<boolean>
|
||||||
} catch (error) {
|
{
|
||||||
return false;
|
return new Promise((resolve) => {
|
||||||
}
|
Neutralino.filesystem.getStats('/.flatpak-info')
|
||||||
|
.then((stats) => resolve(stats.isFile))
|
||||||
|
.catch(() => resolve(false));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -305,8 +305,6 @@ export default class Patch
|
||||||
|
|
||||||
const originalPlayer = /if \[ "\${sum}" == "([a-z0-9]{32})" \]; then/mg.exec(response);
|
const originalPlayer = /if \[ "\${sum}" == "([a-z0-9]{32})" \]; then/mg.exec(response);
|
||||||
|
|
||||||
console.log(originalPlayer);
|
|
||||||
|
|
||||||
// If we could get original UnityPlayer.dll hash - then we can
|
// If we could get original UnityPlayer.dll hash - then we can
|
||||||
// compare it with actual UnityPlayer.dll hash and say whether the patch
|
// compare it with actual UnityPlayer.dll hash and say whether the patch
|
||||||
// was applied or not
|
// was applied or not
|
||||||
|
|
Loading…
Reference in a new issue