ScoreSaberDatabaseDownloader.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. using Mobcast.Coffee.AssetSystem;
  2. using SongBrowser.DataAccess;
  3. using SongBrowser.DataAccess.Network;
  4. using System;
  5. using System.Collections;
  6. using UnityEngine;
  7. using UnityEngine.Networking;
  8. using Logger = SongBrowser.Logging.Logger;
  9. namespace SongBrowser.UI
  10. {
  11. public class ScoreSaberDatabaseDownloader : MonoBehaviour
  12. {
  13. public const String SCRAPED_SCORE_SABER_ALL_JSON_URL = "https://cdn.wes.cloud/beatstar/bssb/v2-all.json";
  14. public const String SCRAPED_SCORE_SABER_RANKED_JSON_URL = "https://cdn.wes.cloud/beatstar/bssb/v2-ranked.json";
  15. public static ScoreSaberDatabaseDownloader Instance;
  16. public static ScoreSaberDataFile ScoreSaberDataFile = null;
  17. public Action onScoreSaberDataDownloaded;
  18. private readonly byte[] _buffer = new byte[4 * 1048576];
  19. /// <summary>
  20. /// Awake.
  21. /// </summary>
  22. private void Awake()
  23. {
  24. Logger.Trace("Awake-ScoreSaberDatabaseDownloader()");
  25. if (Instance == null)
  26. {
  27. Instance = this;
  28. }
  29. }
  30. /// <summary>
  31. /// Acquire any UI elements from Beat saber that we need. Wait for the song list to be loaded.
  32. /// </summary>
  33. public void Start()
  34. {
  35. Logger.Trace("Start()");
  36. StartCoroutine(DownloadScoreSaberDatabases());
  37. }
  38. /// <summary>
  39. /// Helper to download both databases.
  40. /// </summary>
  41. /// <returns></returns>
  42. private IEnumerator DownloadScoreSaberDatabases()
  43. {
  44. ScoreSaberDataFile = null;
  45. yield return DownloadScoreSaberData(SCRAPED_SCORE_SABER_ALL_JSON_URL);
  46. yield return DownloadScoreSaberData(SCRAPED_SCORE_SABER_RANKED_JSON_URL);
  47. if (ScoreSaberDataFile != null)
  48. {
  49. SongBrowserApplication.MainProgressBar.ShowMessage("Success downloading BeatStar data...", 5.0f);
  50. onScoreSaberDataDownloaded?.Invoke();
  51. }
  52. }
  53. /// <summary>
  54. /// Wait for score saber related files to download.
  55. /// </summary>
  56. /// <returns></returns>
  57. private IEnumerator DownloadScoreSaberData(String url)
  58. {
  59. SongBrowserApplication.MainProgressBar.ShowMessage("Downloading BeatStar data...", 5.0f);
  60. Logger.Info("Attempting to download: {0}", url);
  61. using (UnityWebRequest www = UnityWebRequest.Get(url))
  62. {
  63. // Use 4MB cache, large enough for this file to grow for awhile.
  64. www.SetCacheable(new CacheableDownloadHandlerScoreSaberData(www, _buffer));
  65. yield return www.SendWebRequest();
  66. Logger.Debug("Returned from web request!...");
  67. try
  68. {
  69. // First time
  70. if (ScoreSaberDatabaseDownloader.ScoreSaberDataFile == null)
  71. {
  72. ScoreSaberDatabaseDownloader.ScoreSaberDataFile = (www.downloadHandler as CacheableDownloadHandlerScoreSaberData).ScoreSaberDataFile;
  73. }
  74. else
  75. {
  76. // Second time, update.
  77. var newScoreSaberData = (www.downloadHandler as CacheableDownloadHandlerScoreSaberData).ScoreSaberDataFile;
  78. foreach (var pair in newScoreSaberData.SongHashToScoreSaberData)
  79. {
  80. if (ScoreSaberDatabaseDownloader.ScoreSaberDataFile.SongHashToScoreSaberData.ContainsKey(pair.Key))
  81. {
  82. foreach (var diff in pair.Value.diffs)
  83. {
  84. var index = ScoreSaberDatabaseDownloader.ScoreSaberDataFile.SongHashToScoreSaberData[pair.Key].diffs.FindIndex(x => x.diff == diff.diff);
  85. if (index < 0)
  86. {
  87. ScoreSaberDatabaseDownloader.ScoreSaberDataFile.SongHashToScoreSaberData[pair.Key].diffs.Add(diff);
  88. }
  89. }
  90. }
  91. }
  92. }
  93. Logger.Info("Success downloading ScoreSaber data!");
  94. }
  95. catch (System.InvalidOperationException)
  96. {
  97. Logger.Error("Failed to download ScoreSaber data file...");
  98. }
  99. catch (Exception e)
  100. {
  101. Logger.Exception("Exception trying to download ScoreSaber data file...", e);
  102. }
  103. }
  104. }
  105. }
  106. }