[core] Properly handle Delta manifests (update base manifest)

Also removes the old workaround.
This commit is contained in:
derrod 2020-09-09 10:29:46 +02:00
parent 36d02fa5ce
commit dcbf8db54d

View file

@ -31,6 +31,7 @@ from legendary.models.manifest import Manifest, ManifestMeta
from legendary.models.chunk import Chunk from legendary.models.chunk import Chunk
from legendary.utils.game_workarounds import is_opt_enabled from legendary.utils.game_workarounds import is_opt_enabled
from legendary.utils.savegame_helper import SaveGameHelper from legendary.utils.savegame_helper import SaveGameHelper
from legendary.utils.manifests import combine_manifests
# ToDo: instead of true/false return values for success/failure actually raise an exception that the CLI/GUI # ToDo: instead of true/false return values for success/failure actually raise an exception that the CLI/GUI
@ -652,6 +653,9 @@ class LegendaryCore:
def get_delta_manifest(self, base_url, old_build_id, new_build_id): def get_delta_manifest(self, base_url, old_build_id, new_build_id):
"""Get optimized delta manifest (doesn't seem to exist for most games)""" """Get optimized delta manifest (doesn't seem to exist for most games)"""
if old_build_id == new_build_id:
return None
r = self.egs.unauth_session.get(f'{base_url}/Deltas/{new_build_id}/{old_build_id}.delta') r = self.egs.unauth_session.get(f'{base_url}/Deltas/{new_build_id}/{old_build_id}.delta')
if r.status_code == 200: if r.status_code == 200:
return r.content return r.content
@ -667,11 +671,10 @@ class LegendaryCore:
file_exclude_filter: list = None, file_install_tag: list = None, file_exclude_filter: list = None, file_install_tag: list = None,
dl_optimizations: bool = False, dl_timeout: int = 10, dl_optimizations: bool = False, dl_timeout: int = 10,
repair: bool = False, repair_use_latest: bool = False, repair: bool = False, repair_use_latest: bool = False,
disable_delta: bool = False, egl_guid: str = '' disable_delta: bool = False, override_delta_manifest: str = '',
) -> (DLManager, AnalysisResult, ManifestMeta): egl_guid: str = '') -> (DLManager, AnalysisResult, ManifestMeta):
# load old manifest # load old manifest
old_manifest = None old_manifest = None
delta_manifest_used = False
# load old manifest if we have one # load old manifest if we have one
if override_old_manifest: if override_old_manifest:
@ -710,19 +713,23 @@ class LegendaryCore:
# save manifest with version name as well for testing/downgrading/etc. # save manifest with version name as well for testing/downgrading/etc.
self.lgd.save_manifest(game.app_name, new_manifest_data, self.lgd.save_manifest(game.app_name, new_manifest_data,
version=new_manifest.meta.build_version) version=new_manifest.meta.build_version)
# also fetch optimized delta manifest (may not exist)
if old_manifest and new_manifest and not (override_old_manifest or override_manifest or disable_delta or # check if we should use a delta manifest or not
old_manifest.meta.build_id == new_manifest.meta.build_id): disable_delta = disable_delta or ((override_old_manifest or override_manifest) and not override_delta_manifest)
delta_manifest_data = self.get_delta_manifest(randchoice(base_urls), if old_manifest and new_manifest and not disable_delta:
old_manifest.meta.build_id, if override_delta_manifest:
new_manifest.meta.build_id) self.log.info(f'Overriding delta manifest with "{override_delta_manifest}"')
delta_manifest_data, _ = self.get_uri_manifest(override_delta_manifest)
else:
delta_manifest_data = self.get_delta_manifest(randchoice(base_urls),
old_manifest.meta.build_id,
new_manifest.meta.build_id)
if delta_manifest_data: if delta_manifest_data:
delta_manifest = self.load_manifest(delta_manifest_data) delta_manifest = self.load_manifest(delta_manifest_data)
self.log.info(f'Using optimized delta manifest to upgrade from build' self.log.info(f'Using optimized delta manifest to upgrade from build '
f'"{old_manifest.meta.build_id}" to' f'"{old_manifest.meta.build_id}" to '
f'"{new_manifest.meta.build_id}"...') f'"{new_manifest.meta.build_id}"...')
new_manifest = delta_manifest combine_manifests(new_manifest, delta_manifest)
delta_manifest_used = True
else: else:
self.log.debug(f'No Delta manifest received from CDN.') self.log.debug(f'No Delta manifest received from CDN.')
@ -794,8 +801,7 @@ class LegendaryCore:
file_prefix_filter=file_prefix_filter, file_prefix_filter=file_prefix_filter,
file_exclude_filter=file_exclude_filter, file_exclude_filter=file_exclude_filter,
file_install_tag=file_install_tag, file_install_tag=file_install_tag,
processing_optimization=process_opt, processing_optimization=process_opt)
delta_manifest_used=delta_manifest_used)
prereq = None prereq = None
if new_manifest.meta.prereq_ids: if new_manifest.meta.prereq_ids: