2022-03-01 10:44:12 +08:00
|
|
|
|
using System.Collections;
|
|
|
|
|
|
using System.Collections.Generic;
|
2022-05-02 23:15:09 +08:00
|
|
|
|
using System.IO;
|
2022-03-01 10:44:12 +08:00
|
|
|
|
using UnityEngine;
|
|
|
|
|
|
|
|
|
|
|
|
namespace YooAsset
|
|
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 初始化操作
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public abstract class InitializationOperation : AsyncOperationBase
|
|
|
|
|
|
{
|
2022-11-04 13:10:08 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 初始化内部加载的包裹版本
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public string InitializedPackageVersion;
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-05-05 21:12:44 +08:00
|
|
|
|
/// 编辑器下模拟模式的初始化操作
|
2022-03-01 10:44:12 +08:00
|
|
|
|
/// </summary>
|
2022-05-05 21:12:44 +08:00
|
|
|
|
internal sealed class EditorSimulateModeInitializationOperation : InitializationOperation
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
2022-05-02 23:15:09 +08:00
|
|
|
|
private enum ESteps
|
|
|
|
|
|
{
|
|
|
|
|
|
None,
|
2022-12-17 18:08:23 +08:00
|
|
|
|
LoadManifestFileData,
|
|
|
|
|
|
CheckDeserializeManifest,
|
2022-05-02 23:15:09 +08:00
|
|
|
|
Done,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-05-05 21:12:44 +08:00
|
|
|
|
private readonly EditorSimulateModeImpl _impl;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
private readonly string _simulatePatchManifestPath;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
private DeserializeManifestOperation _deserializer;
|
2022-05-02 23:15:09 +08:00
|
|
|
|
private ESteps _steps = ESteps.None;
|
|
|
|
|
|
|
2022-05-07 19:20:52 +08:00
|
|
|
|
internal EditorSimulateModeInitializationOperation(EditorSimulateModeImpl impl, string simulatePatchManifestPath)
|
2022-05-02 23:15:09 +08:00
|
|
|
|
{
|
|
|
|
|
|
_impl = impl;
|
2022-05-07 19:20:52 +08:00
|
|
|
|
_simulatePatchManifestPath = simulatePatchManifestPath;
|
2022-05-02 23:15:09 +08:00
|
|
|
|
}
|
2022-03-01 10:44:12 +08:00
|
|
|
|
internal override void Start()
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.LoadManifestFileData;
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
internal override void Update()
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.LoadManifestFileData)
|
2022-05-07 19:20:52 +08:00
|
|
|
|
{
|
|
|
|
|
|
if (File.Exists(_simulatePatchManifestPath) == false)
|
2022-05-02 23:15:09 +08:00
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Failed;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
Error = $"Not found simulation manifest file : {_simulatePatchManifestPath}";
|
2022-05-02 23:15:09 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
YooLogger.Log($"Load simulation manifest file : {_simulatePatchManifestPath}");
|
|
|
|
|
|
byte[] bytesData = FileUtility.ReadAllBytes(_simulatePatchManifestPath);
|
|
|
|
|
|
_deserializer = new DeserializeManifestOperation(bytesData);
|
|
|
|
|
|
OperationSystem.StartOperation(_deserializer);
|
|
|
|
|
|
_steps = ESteps.CheckDeserializeManifest;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (_steps == ESteps.CheckDeserializeManifest)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (_deserializer.IsDone)
|
2022-10-31 16:45:21 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_deserializer.Status == EOperationStatus.Succeed)
|
|
|
|
|
|
{
|
|
|
|
|
|
var manifest = _deserializer.Manifest;
|
|
|
|
|
|
InitializedPackageVersion = manifest.PackageVersion;
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_impl.ActivePatchManifest = manifest;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Succeed;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Failed;
|
|
|
|
|
|
Error = _deserializer.Error;
|
|
|
|
|
|
}
|
2022-10-31 16:45:21 +08:00
|
|
|
|
}
|
2022-05-02 23:15:09 +08:00
|
|
|
|
}
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-05-05 21:12:44 +08:00
|
|
|
|
/// 离线运行模式的初始化操作
|
2022-03-01 10:44:12 +08:00
|
|
|
|
/// </summary>
|
2022-04-21 16:16:40 +08:00
|
|
|
|
internal sealed class OfflinePlayModeInitializationOperation : InitializationOperation
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
|
|
|
|
|
private enum ESteps
|
|
|
|
|
|
{
|
2022-03-03 18:07:20 +08:00
|
|
|
|
None,
|
2022-12-17 18:08:23 +08:00
|
|
|
|
QueryBuildinPackageVersion,
|
|
|
|
|
|
LoadBuildinManifest,
|
2022-12-14 21:53:09 +08:00
|
|
|
|
StartVerifyOperation,
|
|
|
|
|
|
CheckVerifyOperation,
|
2022-03-01 10:44:12 +08:00
|
|
|
|
Done,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-04-12 19:15:44 +08:00
|
|
|
|
private readonly OfflinePlayModeImpl _impl;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
private readonly string _packageName;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
private readonly BuildinPackageVersionQuerier _buildinPackageVersionQuerier;
|
|
|
|
|
|
private BuildinManifestLoader _buildinManifestLoader;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
private CacheFilesVerifyOperation _verifyOperation;
|
2022-03-03 18:07:20 +08:00
|
|
|
|
private ESteps _steps = ESteps.None;
|
2022-10-18 10:19:17 +08:00
|
|
|
|
private float _verifyTime;
|
2022-03-01 10:44:12 +08:00
|
|
|
|
|
2022-10-27 14:20:05 +08:00
|
|
|
|
internal OfflinePlayModeInitializationOperation(OfflinePlayModeImpl impl, string packageName)
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
|
|
|
|
|
_impl = impl;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
_packageName = packageName;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinPackageVersionQuerier = new BuildinPackageVersionQuerier(packageName);
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
internal override void Start()
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.QueryBuildinPackageVersion;
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
internal override void Update()
|
|
|
|
|
|
{
|
2022-03-03 18:07:20 +08:00
|
|
|
|
if (_steps == ESteps.None || _steps == ESteps.Done)
|
2022-03-01 10:44:12 +08:00
|
|
|
|
return;
|
2022-05-02 15:03:36 +08:00
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.QueryBuildinPackageVersion)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinPackageVersionQuerier.Update();
|
|
|
|
|
|
if (_buildinPackageVersionQuerier.IsDone == false)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
string error = _buildinPackageVersionQuerier.Error;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (string.IsNullOrEmpty(error) == false)
|
|
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Failed;
|
|
|
|
|
|
Error = error;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinManifestLoader = new BuildinManifestLoader(_packageName, _buildinPackageVersionQuerier.Version);
|
|
|
|
|
|
_steps = ESteps.LoadBuildinManifest;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.LoadBuildinManifest)
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinManifestLoader.Update();
|
|
|
|
|
|
Progress = _buildinManifestLoader.Progress;
|
|
|
|
|
|
if (_buildinManifestLoader.IsDone == false)
|
2022-03-01 10:44:12 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
var manifest = _buildinManifestLoader.Manifest;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
if (manifest == null)
|
2022-05-02 15:03:36 +08:00
|
|
|
|
{
|
2022-03-01 10:44:12 +08:00
|
|
|
|
_steps = ESteps.Done;
|
2022-03-03 18:07:20 +08:00
|
|
|
|
Status = EOperationStatus.Failed;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
Error = _buildinManifestLoader.Error;
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
|
|
|
|
|
else
|
2022-10-18 10:19:17 +08:00
|
|
|
|
{
|
2022-11-04 13:10:08 +08:00
|
|
|
|
InitializedPackageVersion = manifest.PackageVersion;
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_impl.ActivePatchManifest = manifest;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
_steps = ESteps.StartVerifyOperation;
|
2022-10-18 10:19:17 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-14 21:53:09 +08:00
|
|
|
|
if (_steps == ESteps.StartVerifyOperation)
|
2022-10-18 10:19:17 +08:00
|
|
|
|
{
|
2022-12-14 21:53:09 +08:00
|
|
|
|
#if UNITY_WEBGL
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_verifyOperation = new CacheFilesVerifyWithoutThreadOperation(_impl.ActivePatchManifest, _impl);
|
2022-12-14 21:53:09 +08:00
|
|
|
|
#else
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_verifyOperation = new CacheFilesVerifyWithThreadOperation(_impl.ActivePatchManifest, _impl);
|
2022-12-14 21:53:09 +08:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
OperationSystem.StartOperation(_verifyOperation);
|
2022-10-18 10:19:17 +08:00
|
|
|
|
_verifyTime = UnityEngine.Time.realtimeSinceStartup;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
_steps = ESteps.CheckVerifyOperation;
|
2022-10-18 10:19:17 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-14 21:53:09 +08:00
|
|
|
|
if (_steps == ESteps.CheckVerifyOperation)
|
2022-10-18 10:19:17 +08:00
|
|
|
|
{
|
2022-12-14 21:53:09 +08:00
|
|
|
|
Progress = _verifyOperation.Progress;
|
|
|
|
|
|
if (_verifyOperation.IsDone)
|
2022-04-12 19:15:44 +08:00
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Succeed;
|
2022-10-18 10:19:17 +08:00
|
|
|
|
float costTime = UnityEngine.Time.realtimeSinceStartup - _verifyTime;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
YooLogger.Log($"Verify result : Success {_verifyOperation.VerifySuccessList.Count}, Fail {_verifyOperation.VerifyFailList.Count}, Elapsed time {costTime} seconds");
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-08-03 15:46:45 +08:00
|
|
|
|
/// 联机运行模式的初始化操作
|
2022-10-31 16:45:21 +08:00
|
|
|
|
/// 注意:优先从沙盒里加载清单,如果沙盒里不存在就尝试把内置清单拷贝到沙盒并加载该清单。
|
2022-03-01 10:44:12 +08:00
|
|
|
|
/// </summary>
|
2022-04-21 16:16:40 +08:00
|
|
|
|
internal sealed class HostPlayModeInitializationOperation : InitializationOperation
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
private enum ESteps
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
None,
|
2022-12-13 11:29:22 +08:00
|
|
|
|
CheckAppFootPrint,
|
2022-10-31 16:45:21 +08:00
|
|
|
|
TryLoadCacheManifest,
|
2022-12-17 18:08:23 +08:00
|
|
|
|
QueryBuildinPackageVersion,
|
|
|
|
|
|
CopyBuildinManifest,
|
|
|
|
|
|
LoadBuildinManifest,
|
2022-12-14 21:53:09 +08:00
|
|
|
|
StartVerifyOperation,
|
|
|
|
|
|
CheckVerifyOperation,
|
2022-10-27 14:20:05 +08:00
|
|
|
|
Done,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private readonly HostPlayModeImpl _impl;
|
|
|
|
|
|
private readonly string _packageName;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
private readonly BuildinPackageVersionQuerier _buildinPackageVersionQuerier;
|
|
|
|
|
|
private BuildinManifestCopyer _buildinManifestCopyer;
|
|
|
|
|
|
private BuildinManifestLoader _buildinManifestLoader;
|
|
|
|
|
|
private CacheManifestLoader _cacheManifestLoader;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
private CacheFilesVerifyOperation _verifyOperation;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
private ESteps _steps = ESteps.None;
|
|
|
|
|
|
private float _verifyTime;
|
|
|
|
|
|
|
|
|
|
|
|
internal HostPlayModeInitializationOperation(HostPlayModeImpl impl, string packageName)
|
|
|
|
|
|
{
|
|
|
|
|
|
_impl = impl;
|
|
|
|
|
|
_packageName = packageName;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinPackageVersionQuerier = new BuildinPackageVersionQuerier(packageName);
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
internal override void Start()
|
|
|
|
|
|
{
|
2022-12-13 11:29:22 +08:00
|
|
|
|
_steps = ESteps.CheckAppFootPrint;
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
internal override void Update()
|
|
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (_steps == ESteps.None || _steps == ESteps.Done)
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
2022-12-13 11:29:22 +08:00
|
|
|
|
if (_steps == ESteps.CheckAppFootPrint)
|
|
|
|
|
|
{
|
|
|
|
|
|
var appFootPrint = new AppFootPrint();
|
|
|
|
|
|
appFootPrint.Load();
|
|
|
|
|
|
|
|
|
|
|
|
// 如果水印发生变化,则说明覆盖安装后首次打开游戏
|
|
|
|
|
|
if (appFootPrint.IsDirty())
|
|
|
|
|
|
{
|
|
|
|
|
|
PersistentHelper.DeleteManifestFolder();
|
|
|
|
|
|
appFootPrint.Coverage();
|
|
|
|
|
|
YooLogger.Log("Delete manifest files when application foot print dirty !");
|
|
|
|
|
|
}
|
|
|
|
|
|
_steps = ESteps.TryLoadCacheManifest;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-10-31 16:45:21 +08:00
|
|
|
|
if (_steps == ESteps.TryLoadCacheManifest)
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_cacheManifestLoader == null)
|
|
|
|
|
|
_cacheManifestLoader = new CacheManifestLoader(_packageName);
|
|
|
|
|
|
|
|
|
|
|
|
_cacheManifestLoader.Update();
|
|
|
|
|
|
if (_cacheManifestLoader.IsDone)
|
2022-10-31 16:45:21 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
var manifest = _cacheManifestLoader.Manifest;
|
|
|
|
|
|
if (manifest != null)
|
2022-10-31 16:45:21 +08:00
|
|
|
|
{
|
2022-11-04 13:10:08 +08:00
|
|
|
|
InitializedPackageVersion = manifest.PackageVersion;
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_impl.ActivePatchManifest = manifest;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
_steps = ESteps.StartVerifyOperation;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
}
|
2022-12-17 18:08:23 +08:00
|
|
|
|
else
|
2022-10-31 16:45:21 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.QueryBuildinPackageVersion;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.QueryBuildinPackageVersion)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinPackageVersionQuerier.Update();
|
|
|
|
|
|
if (_buildinPackageVersionQuerier.IsDone == false)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
// 注意:为了兼容MOD模式,初始化动态新增的包裹的时候,如果内置清单不存在也不需要报错!
|
2022-12-17 18:08:23 +08:00
|
|
|
|
string error = _buildinPackageVersionQuerier.Error;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (string.IsNullOrEmpty(error) == false)
|
|
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Succeed;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
YooLogger.Log($"Failed to load buildin package version file : {error}");
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinManifestCopyer = new BuildinManifestCopyer(_packageName, _buildinPackageVersionQuerier.Version);
|
|
|
|
|
|
_buildinManifestLoader = new BuildinManifestLoader(_packageName, _buildinPackageVersionQuerier.Version);
|
|
|
|
|
|
_steps = ESteps.CopyBuildinManifest;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.CopyBuildinManifest)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinManifestCopyer.Update();
|
|
|
|
|
|
Progress = _buildinManifestCopyer.Progress;
|
|
|
|
|
|
if (_buildinManifestCopyer.IsDone == false)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
string error = _buildinManifestCopyer.Error;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
if (string.IsNullOrEmpty(error) == false)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Failed;
|
|
|
|
|
|
Error = error;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.LoadBuildinManifest;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.LoadBuildinManifest)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_buildinManifestLoader.Update();
|
|
|
|
|
|
Progress = _buildinManifestLoader.Progress;
|
|
|
|
|
|
if (_buildinManifestLoader.IsDone == false)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
var manifest = _buildinManifestLoader.Manifest;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
if (manifest == null)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Failed;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
Error = _buildinManifestLoader.Error;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
2022-11-04 13:10:08 +08:00
|
|
|
|
InitializedPackageVersion = manifest.PackageVersion;
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_impl.ActivePatchManifest = manifest;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
_steps = ESteps.StartVerifyOperation;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-14 21:53:09 +08:00
|
|
|
|
if (_steps == ESteps.StartVerifyOperation)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
2022-12-14 21:53:09 +08:00
|
|
|
|
#if UNITY_WEBGL
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_verifyOperation = new CacheFilesVerifyWithoutThreadOperation(_impl.ActivePatchManifest, _impl);
|
2022-12-14 21:53:09 +08:00
|
|
|
|
#else
|
2022-12-17 22:37:39 +08:00
|
|
|
|
_verifyOperation = new CacheFilesVerifyWithThreadOperation(_impl.ActivePatchManifest, _impl);
|
2022-12-14 21:53:09 +08:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
OperationSystem.StartOperation(_verifyOperation);
|
2022-10-27 14:20:05 +08:00
|
|
|
|
_verifyTime = UnityEngine.Time.realtimeSinceStartup;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
_steps = ESteps.CheckVerifyOperation;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-14 21:53:09 +08:00
|
|
|
|
if (_steps == ESteps.CheckVerifyOperation)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
2022-12-14 21:53:09 +08:00
|
|
|
|
Progress = _verifyOperation.Progress;
|
|
|
|
|
|
if (_verifyOperation.IsDone)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Status = EOperationStatus.Succeed;
|
|
|
|
|
|
float costTime = UnityEngine.Time.realtimeSinceStartup - _verifyTime;
|
2022-12-14 21:53:09 +08:00
|
|
|
|
YooLogger.Log($"Verify result : Success {_verifyOperation.VerifySuccessList.Count}, Fail {_verifyOperation.VerifyFailList.Count}, Elapsed time {costTime} seconds");
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-03-01 10:44:12 +08:00
|
|
|
|
|
2022-05-02 23:15:09 +08:00
|
|
|
|
|
2022-12-13 11:29:22 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 应用程序水印
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
internal class AppFootPrint
|
|
|
|
|
|
{
|
|
|
|
|
|
private string _footPrint;
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 读取应用程序水印
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public void Load()
|
|
|
|
|
|
{
|
|
|
|
|
|
string footPrintFilePath = PersistentHelper.GetAppFootPrintFilePath();
|
|
|
|
|
|
if (File.Exists(footPrintFilePath))
|
|
|
|
|
|
{
|
|
|
|
|
|
_footPrint = FileUtility.ReadAllText(footPrintFilePath);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
Coverage();
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 检测水印是否发生变化
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public bool IsDirty()
|
|
|
|
|
|
{
|
|
|
|
|
|
#if UNITY_EDITOR
|
|
|
|
|
|
return _footPrint != Application.version;
|
|
|
|
|
|
#else
|
|
|
|
|
|
return _footPrint != Application.buildGUID;
|
|
|
|
|
|
#endif
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 覆盖掉水印
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public void Coverage()
|
|
|
|
|
|
{
|
|
|
|
|
|
#if UNITY_EDITOR
|
|
|
|
|
|
_footPrint = Application.version;
|
|
|
|
|
|
#else
|
|
|
|
|
|
_footPrint = Application.buildGUID;
|
|
|
|
|
|
#endif
|
|
|
|
|
|
string footPrintFilePath = PersistentHelper.GetAppFootPrintFilePath();
|
|
|
|
|
|
FileUtility.CreateFile(footPrintFilePath, _footPrint);
|
|
|
|
|
|
YooLogger.Log($"Save application foot print : {_footPrint}");
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-10-31 16:45:21 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 内置补丁清单版本查询器
|
|
|
|
|
|
/// </summary>
|
2022-12-17 18:08:23 +08:00
|
|
|
|
internal class BuildinPackageVersionQuerier
|
2022-04-12 19:15:44 +08:00
|
|
|
|
{
|
|
|
|
|
|
private enum ESteps
|
|
|
|
|
|
{
|
|
|
|
|
|
LoadStaticVersion,
|
|
|
|
|
|
CheckStaticVersion,
|
2022-06-29 11:59:39 +08:00
|
|
|
|
Done,
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-10-26 21:02:25 +08:00
|
|
|
|
private readonly string _buildinPackageName;
|
2022-04-12 19:15:44 +08:00
|
|
|
|
private ESteps _steps = ESteps.LoadStaticVersion;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
private UnityWebDataRequester _downloader;
|
2022-04-12 19:15:44 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-10-27 14:20:05 +08:00
|
|
|
|
/// 内置包裹版本
|
2022-04-12 19:15:44 +08:00
|
|
|
|
/// </summary>
|
2022-10-27 14:20:05 +08:00
|
|
|
|
public string Version { private set; get; }
|
2022-04-12 19:15:44 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-10-27 14:20:05 +08:00
|
|
|
|
/// 错误日志
|
2022-04-12 19:15:44 +08:00
|
|
|
|
/// </summary>
|
2022-10-27 14:20:05 +08:00
|
|
|
|
public string Error { private set; get; }
|
2022-06-29 11:59:39 +08:00
|
|
|
|
|
2022-04-12 19:15:44 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 是否已经完成
|
|
|
|
|
|
/// </summary>
|
2022-10-27 14:20:05 +08:00
|
|
|
|
public bool IsDone
|
2022-04-12 19:15:44 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
get
|
|
|
|
|
|
{
|
|
|
|
|
|
return _steps == ESteps.Done;
|
|
|
|
|
|
}
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-10-27 14:20:05 +08:00
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
public BuildinPackageVersionQuerier(string buildinPackageName)
|
2022-05-07 20:30:16 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
_buildinPackageName = buildinPackageName;
|
2022-05-07 20:30:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-06-29 11:59:39 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 更新流程
|
|
|
|
|
|
/// </summary>
|
2022-04-12 19:15:44 +08:00
|
|
|
|
public void Update()
|
|
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (IsDone)
|
2022-04-12 19:15:44 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
if (_steps == ESteps.LoadStaticVersion)
|
|
|
|
|
|
{
|
2022-10-26 21:02:25 +08:00
|
|
|
|
string fileName = YooAssetSettingsData.GetPatchManifestVersionFileName(_buildinPackageName);
|
2022-09-27 21:11:55 +08:00
|
|
|
|
string filePath = PathHelper.MakeStreamingLoadPath(fileName);
|
2022-04-12 19:15:44 +08:00
|
|
|
|
string url = PathHelper.ConvertToWWWPath(filePath);
|
2022-10-27 14:20:05 +08:00
|
|
|
|
_downloader = new UnityWebDataRequester();
|
|
|
|
|
|
_downloader.SendRequest(url);
|
2022-04-12 19:15:44 +08:00
|
|
|
|
_steps = ESteps.CheckStaticVersion;
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-04-12 19:15:44 +08:00
|
|
|
|
if (_steps == ESteps.CheckStaticVersion)
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (_downloader.IsDone() == false)
|
2022-04-12 19:15:44 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (_downloader.HasError())
|
2022-03-01 10:44:12 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
Error = _downloader.GetError();
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
2022-04-12 19:15:44 +08:00
|
|
|
|
else
|
|
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
Version = _downloader.GetText();
|
|
|
|
|
|
if (string.IsNullOrEmpty(Version))
|
2022-10-31 16:45:21 +08:00
|
|
|
|
Error = $"Buildin package version file content is empty !";
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
2022-10-27 14:20:05 +08:00
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
_downloader.Dispose();
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
2022-10-27 14:20:05 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-10-31 16:45:21 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 内置补丁清单加载器
|
|
|
|
|
|
/// </summary>
|
2022-12-17 18:08:23 +08:00
|
|
|
|
internal class BuildinManifestLoader
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
|
|
|
|
|
private enum ESteps
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
LoadBuildinManifest,
|
|
|
|
|
|
CheckLoadBuildinManifest,
|
|
|
|
|
|
CheckDeserializeManifest,
|
2022-10-27 14:20:05 +08:00
|
|
|
|
Done,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private readonly string _buildinPackageName;
|
|
|
|
|
|
private readonly string _buildinPackageVersion;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
private ESteps _steps = ESteps.LoadBuildinManifest;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
private UnityWebDataRequester _downloader;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
private DeserializeManifestOperation _deserializer;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 加载结果
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public PatchManifest Manifest { private set; get; }
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 加载进度
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public float Progress { private set; get; }
|
|
|
|
|
|
|
2022-10-27 14:20:05 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 错误日志
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public string Error { private set; get; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 是否已经完成
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public bool IsDone
|
|
|
|
|
|
{
|
|
|
|
|
|
get
|
|
|
|
|
|
{
|
|
|
|
|
|
return _steps == ESteps.Done;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
public BuildinManifestLoader(string buildinPackageName, string buildinPackageVersion)
|
2022-10-27 14:20:05 +08:00
|
|
|
|
{
|
|
|
|
|
|
_buildinPackageName = buildinPackageName;
|
|
|
|
|
|
_buildinPackageVersion = buildinPackageVersion;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 更新流程
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public void Update()
|
|
|
|
|
|
{
|
|
|
|
|
|
if (IsDone)
|
|
|
|
|
|
return;
|
2022-04-12 19:15:44 +08:00
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.LoadBuildinManifest)
|
2022-04-12 19:15:44 +08:00
|
|
|
|
{
|
2022-12-03 18:48:51 +08:00
|
|
|
|
string fileName = YooAssetSettingsData.GetPatchManifestBinaryFileName(_buildinPackageName, _buildinPackageVersion);
|
2022-09-27 21:11:55 +08:00
|
|
|
|
string filePath = PathHelper.MakeStreamingLoadPath(fileName);
|
2022-04-12 19:15:44 +08:00
|
|
|
|
string url = PathHelper.ConvertToWWWPath(filePath);
|
2022-10-27 14:20:05 +08:00
|
|
|
|
_downloader = new UnityWebDataRequester();
|
|
|
|
|
|
_downloader.SendRequest(url);
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.CheckLoadBuildinManifest;
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
2022-03-01 10:44:12 +08:00
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.CheckLoadBuildinManifest)
|
2022-04-12 19:15:44 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (_downloader.IsDone() == false)
|
2022-04-12 19:15:44 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (_downloader.HasError())
|
2022-04-12 19:15:44 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
Error = _downloader.GetError();
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.Done;
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
// 解析APP里的补丁清单
|
2022-12-17 18:08:23 +08:00
|
|
|
|
byte[] bytesData = _downloader.GetData();
|
|
|
|
|
|
_deserializer = new DeserializeManifestOperation(bytesData);
|
|
|
|
|
|
OperationSystem.StartOperation(_deserializer);
|
|
|
|
|
|
_steps = ESteps.CheckDeserializeManifest;
|
|
|
|
|
|
}
|
|
|
|
|
|
_downloader.Dispose();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (_steps == ESteps.CheckDeserializeManifest)
|
|
|
|
|
|
{
|
|
|
|
|
|
Progress = _deserializer.Progress;
|
|
|
|
|
|
if (_deserializer.IsDone)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (_deserializer.Status == EOperationStatus.Succeed)
|
2022-10-31 16:45:21 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
Manifest = _deserializer.Manifest;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
}
|
2022-12-17 18:08:23 +08:00
|
|
|
|
else
|
2022-10-31 16:45:21 +08:00
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
Error = _deserializer.Error;
|
2022-10-31 16:45:21 +08:00
|
|
|
|
}
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.Done;
|
2022-04-12 19:15:44 +08:00
|
|
|
|
}
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-06-29 11:59:39 +08:00
|
|
|
|
|
2022-10-31 16:45:21 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 内置补丁清单复制器
|
|
|
|
|
|
/// </summary>
|
2022-12-17 18:08:23 +08:00
|
|
|
|
internal class BuildinManifestCopyer
|
2022-06-29 11:59:39 +08:00
|
|
|
|
{
|
|
|
|
|
|
private enum ESteps
|
|
|
|
|
|
{
|
2022-12-17 18:08:23 +08:00
|
|
|
|
CopyBuildinManifest,
|
|
|
|
|
|
CheckCopyBuildinManifest,
|
2022-06-29 11:59:39 +08:00
|
|
|
|
Done,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-10-27 14:20:05 +08:00
|
|
|
|
private readonly string _buildinPackageName;
|
|
|
|
|
|
private readonly string _buildinPackageVersion;
|
2022-12-17 18:08:23 +08:00
|
|
|
|
private ESteps _steps = ESteps.CopyBuildinManifest;
|
2022-10-27 14:20:05 +08:00
|
|
|
|
private UnityWebFileRequester _downloader;
|
2022-06-29 11:59:39 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 错误日志
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public string Error { private set; get; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-10-27 14:20:05 +08:00
|
|
|
|
/// 是否已经完成
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public bool IsDone
|
|
|
|
|
|
{
|
|
|
|
|
|
get
|
|
|
|
|
|
{
|
|
|
|
|
|
return _steps == ESteps.Done;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 加载进度
|
2022-06-29 11:59:39 +08:00
|
|
|
|
/// </summary>
|
2022-10-27 14:20:05 +08:00
|
|
|
|
public float Progress
|
|
|
|
|
|
{
|
|
|
|
|
|
get
|
|
|
|
|
|
{
|
|
|
|
|
|
if (_downloader == null)
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
return _downloader.Progress();
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-06-29 11:59:39 +08:00
|
|
|
|
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
public BuildinManifestCopyer(string buildinPackageName, string buildinPackageVersion)
|
2022-06-29 11:59:39 +08:00
|
|
|
|
{
|
2022-09-27 21:11:55 +08:00
|
|
|
|
_buildinPackageName = buildinPackageName;
|
2022-10-26 21:02:25 +08:00
|
|
|
|
_buildinPackageVersion = buildinPackageVersion;
|
2022-06-29 11:59:39 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 更新流程
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public void Update()
|
|
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (IsDone)
|
2022-06-29 11:59:39 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.CopyBuildinManifest)
|
2022-06-29 11:59:39 +08:00
|
|
|
|
{
|
2022-10-31 16:45:21 +08:00
|
|
|
|
string savePath = PersistentHelper.GetCacheManifestFilePath(_buildinPackageName);
|
2022-12-03 18:48:51 +08:00
|
|
|
|
string fileName = YooAssetSettingsData.GetPatchManifestBinaryFileName(_buildinPackageName, _buildinPackageVersion);
|
2022-10-31 16:45:21 +08:00
|
|
|
|
string filePath = PathHelper.MakeStreamingLoadPath(fileName);
|
|
|
|
|
|
string url = PathHelper.ConvertToWWWPath(filePath);
|
|
|
|
|
|
_downloader = new UnityWebFileRequester();
|
|
|
|
|
|
_downloader.SendRequest(url, savePath);
|
2022-12-17 18:08:23 +08:00
|
|
|
|
_steps = ESteps.CheckCopyBuildinManifest;
|
2022-06-29 11:59:39 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-12-17 18:08:23 +08:00
|
|
|
|
if (_steps == ESteps.CheckCopyBuildinManifest)
|
2022-06-29 11:59:39 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (_downloader.IsDone() == false)
|
2022-06-29 11:59:39 +08:00
|
|
|
|
return;
|
|
|
|
|
|
|
2022-10-27 14:20:05 +08:00
|
|
|
|
if (_downloader.HasError())
|
2022-06-29 11:59:39 +08:00
|
|
|
|
{
|
2022-10-27 14:20:05 +08:00
|
|
|
|
Error = _downloader.GetError();
|
2022-06-29 11:59:39 +08:00
|
|
|
|
}
|
2022-10-27 14:20:05 +08:00
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
_downloader.Dispose();
|
2022-06-29 11:59:39 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-12-17 18:08:23 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 沙盒补丁清单加载器
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
internal class CacheManifestLoader
|
|
|
|
|
|
{
|
|
|
|
|
|
private enum ESteps
|
|
|
|
|
|
{
|
|
|
|
|
|
LoadCacheManifestFile,
|
|
|
|
|
|
CheckDeserializeManifest,
|
|
|
|
|
|
Done,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private readonly string _packageName;
|
|
|
|
|
|
private ESteps _steps = ESteps.LoadCacheManifestFile;
|
|
|
|
|
|
private DeserializeManifestOperation _deserializer;
|
|
|
|
|
|
private string _manifestFilePath;
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 加载结果
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public PatchManifest Manifest { private set; get; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 加载进度
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public float Progress { private set; get; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 错误日志
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public string Error { private set; get; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 是否已经完成
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public bool IsDone
|
|
|
|
|
|
{
|
|
|
|
|
|
get
|
|
|
|
|
|
{
|
|
|
|
|
|
return _steps == ESteps.Done;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public CacheManifestLoader(string packageName)
|
|
|
|
|
|
{
|
|
|
|
|
|
_packageName = packageName;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 更新流程
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public void Update()
|
|
|
|
|
|
{
|
|
|
|
|
|
if (IsDone)
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
if (_steps == ESteps.LoadCacheManifestFile)
|
|
|
|
|
|
{
|
|
|
|
|
|
_manifestFilePath = PersistentHelper.GetCacheManifestFilePath(_packageName);
|
|
|
|
|
|
if (File.Exists(_manifestFilePath) == false)
|
|
|
|
|
|
{
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
Error = $"Manifest file not found : {_manifestFilePath}";
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
byte[] bytesData = File.ReadAllBytes(_manifestFilePath);
|
|
|
|
|
|
_deserializer = new DeserializeManifestOperation(bytesData);
|
|
|
|
|
|
OperationSystem.StartOperation(_deserializer);
|
|
|
|
|
|
_steps = ESteps.CheckDeserializeManifest;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (_steps == ESteps.CheckDeserializeManifest)
|
|
|
|
|
|
{
|
|
|
|
|
|
Progress = _deserializer.Progress;
|
|
|
|
|
|
if (_deserializer.IsDone)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (_deserializer.Status == EOperationStatus.Succeed)
|
|
|
|
|
|
{
|
|
|
|
|
|
Manifest = _deserializer.Manifest;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
Error = _deserializer.Error;
|
|
|
|
|
|
|
|
|
|
|
|
// 注意:如果加载沙盒内的清单报错,为了避免流程被卡住,我们主动把损坏的文件删除。
|
|
|
|
|
|
if (File.Exists(_manifestFilePath))
|
|
|
|
|
|
{
|
|
|
|
|
|
YooLogger.Warning($"Failed to load cache manifest file : {Error}");
|
|
|
|
|
|
YooLogger.Warning($"Invalid cache manifest file have been removed : {_manifestFilePath}");
|
|
|
|
|
|
File.Delete(_manifestFilePath);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
_steps = ESteps.Done;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-03-01 10:44:12 +08:00
|
|
|
|
}
|