API improvements

- now pre-downloaded game will be automatically unpacked
This commit is contained in:
Observer KRypt0n_ 2021-12-29 19:32:09 +02:00
parent 77969868e3
commit 2a4dcc03e3
No known key found for this signature in database
GPG key ID: DC5D4EC1303465DA
3 changed files with 108 additions and 59 deletions

View file

@ -18,9 +18,9 @@ declare const Neutralino;
class Stream extends AbstractInstaller class Stream extends AbstractInstaller
{ {
public constructor(uri: string) public constructor(uri: string, predownloaded: boolean = false)
{ {
super(uri, constants.paths.gameDir); super(uri, constants.paths.gameDir, predownloaded);
} }
} }
@ -170,9 +170,24 @@ export default class Game
}); });
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
this.isUpdatePredownloaded().then(async (predownloaded) => {
if (predownloaded)
{
Debug.log({
function: 'Game.update',
message: 'Update is already pre-downloaded. Unpacking started'
});
resolve(new Stream(`${await constants.paths.launcherDir}/game-predownloaded.zip`, true));
}
else
{
(version === null ? this.latest : this.getDiff(version)) (version === null ? this.latest : this.getDiff(version))
.then((data: Latest|Diff|null) => resolve(data === null ? null : new Stream(data.path))) .then((data: Latest|Diff|null) => resolve(data === null ? null : new Stream(data.path)))
.catch((error) => reject(error)); .catch((error) => reject(error));
}
});
}); });
} }

View file

@ -12,9 +12,9 @@ declare const Neutralino;
class Stream extends AbstractInstaller class Stream extends AbstractInstaller
{ {
public constructor(uri: string) public constructor(uri: string, predownloaded: boolean = false)
{ {
super(uri, constants.paths.gameDir); super(uri, constants.paths.gameDir, predownloaded);
} }
} }
@ -129,6 +129,19 @@ export default class Voice
}); });
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
this.isUpdatePredownloaded(lang).then(async (predownloaded) => {
if (predownloaded)
{
Debug.log({
function: 'Voice.update',
message: 'Voice package update is already pre-downloaded. Unpacking started'
});
resolve(new Stream(`${await constants.paths.launcherDir}/voice-${lang}-predownloaded.zip`, true));
}
else
{
(version === null ? this.latest : this.getDiff(version)) (version === null ? this.latest : this.getDiff(version))
.then((data: VoicePack[]|null) => { .then((data: VoicePack[]|null) => {
if (data === null) if (data === null)
@ -142,6 +155,8 @@ export default class Voice
} }
}) })
.catch((error) => reject(error)); .catch((error) => reject(error));
}
});
}); });
} }

View file

@ -32,42 +32,35 @@ export default abstract class Installer
protected downloadFinished: boolean = false; protected downloadFinished: boolean = false;
protected unpackFinished: boolean = false; protected unpackFinished: boolean = false;
public constructor(uri: string, unpackDir: string|Promise<string>) /**
* @param uri URI to the archive we need to download
* @param unpackDir path to unpack this archive to
*
* @param alreadyDownloaded specifies whether the archive was already downloaded
* If true, then URI will be used as a path to the archive. Otherwise stream will download it
*/
public constructor(uri: string, unpackDir: string|Promise<string>, alreadyDownloaded: boolean = false)
{ {
const shouldResolve = typeof unpackDir !== 'string';
const debugThread = new DebugThread('AbstractInstaller', { const debugThread = new DebugThread('AbstractInstaller', {
message: { message: {
'uri': uri, 'uri': uri,
'unpack dir': typeof unpackDir === 'string' ? unpackDir : '<promise>' 'unpack dir': shouldResolve ? '<promise>' : unpackDir,
'already downloaded': alreadyDownloaded ? 'true' : 'false'
} }
}); });
constants.paths.launcherDir.then((launcherDir) => { constants.paths.launcherDir.then((launcherDir) => {
const archivePath = `${launcherDir}/${Downloader.fileFromUri(uri)}`; const archivePath = alreadyDownloaded ? uri : `${launcherDir}/${Downloader.fileFromUri(uri)}`;
// Download archive
Downloader.download(uri, archivePath).then((stream) => {
stream.progressInterval = this.downloadProgressInterval;
stream.start(() => {
this.downloadStarted = true;
if (this.onDownloadStart)
this.onDownloadStart();
});
stream.progress((current, total, difference) => {
if (this.onDownloadProgress)
this.onDownloadProgress(current, total, difference);
});
stream.finish(() => {
this.downloadFinished = true;
if (this.onDownloadFinish)
this.onDownloadFinish();
// And then unpack it // And then unpack it
const unpackArchive = (unpackDir: string) => { const unpackArchive = () => {
Promise.resolve(unpackDir)
.then((unpackDir) => {
if (shouldResolve)
debugThread.log(`Resolved unpack dir: ${unpackDir}`);
Archive.unpack(archivePath, unpackDir).then((stream) => { Archive.unpack(archivePath, unpackDir).then((stream) => {
stream.progressInterval = this.unpackProgressInterval; stream.progressInterval = this.unpackProgressInterval;
@ -94,19 +87,45 @@ export default abstract class Installer
this.onUnpackFinish(); this.onUnpackFinish();
}); });
}); });
});
}; };
const shouldResolve = typeof unpackDir !== 'string'; // Download archive
if (!alreadyDownloaded)
{
Downloader.download(uri, archivePath).then((stream) => {
stream.progressInterval = this.downloadProgressInterval;
stream.start(() => {
this.downloadStarted = true;
if (this.onDownloadStart)
this.onDownloadStart();
});
stream.progress((current, total, difference) => {
if (this.onDownloadProgress)
this.onDownloadProgress(current, total, difference);
});
stream.finish(() => {
this.downloadFinished = true;
if (this.onDownloadFinish)
this.onDownloadFinish();
Promise.resolve(unpackDir) Promise.resolve(unpackDir)
.then((unpackDir) => { .then((unpackDir) => {
if (shouldResolve) if (shouldResolve)
debugThread.log(`Resolved unpack dir: ${unpackDir}`); debugThread.log(`Resolved unpack dir: ${unpackDir}`);
unpackArchive(unpackDir); unpackArchive();
}); });
}); });
}); });
}
else unpackArchive();
}); });
} }