CMSCollection.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. using KdanCommon.CMSCollection.Data;
  2. using KdanCommon.Helpers;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Net.NetworkInformation;
  7. using System.Text;
  8. using System.Threading;
  9. using System.Threading.Tasks;
  10. using Windows.Data.Json;
  11. using Windows.Globalization;
  12. using Windows.Networking.Connectivity;
  13. using Windows.UI.Popups;
  14. using Windows.Web.Http;
  15. using Windows.Web.Http.Filters;
  16. namespace KdanCommon.CMSCollection
  17. {
  18. public class CMSCollection
  19. {
  20. public static string CMSDomain = "https://cms.kdanmobile.com";
  21. private List<ISetting> _settingList = null;
  22. private HttpClient _httpClient = null;
  23. private Uri _windowsCardsUri = null;
  24. private Uri _pdfViewerEventBarSettingUri = null;
  25. private Uri _pdfOtherSettingUri = null;
  26. private string _appType = null;
  27. private bool _loadCardsOnly = false;
  28. private SemaphoreSlim _loadSettingSS = new SemaphoreSlim(1);
  29. private bool _isLoaded = false;
  30. private object settingLock = new object();
  31. public CMSCollection(string appType, bool loadCardOnly = true)
  32. {
  33. var filter = new HttpBaseProtocolFilter();
  34. filter.CacheControl.ReadBehavior = HttpCacheReadBehavior.MostRecent;
  35. _httpClient = new HttpClient(filter);
  36. _windowsCardsUri = new Uri($"{CMSDomain}/items/windows_cards");
  37. _pdfViewerEventBarSettingUri = new Uri($"{CMSDomain}/items/pdf_remote_config");
  38. _pdfOtherSettingUri = new Uri($"{CMSDomain}/items/PDF_UWP_RemoteConfig");
  39. _appType = appType;
  40. _loadCardsOnly = loadCardOnly;
  41. _settingList = new List<ISetting>();
  42. Windows.Networking.Connectivity.NetworkInformation.NetworkStatusChanged += NetworkInformation_NetworkStatusChanged;
  43. }
  44. ~CMSCollection()
  45. {
  46. _httpClient.Dispose();
  47. Windows.Networking.Connectivity.NetworkInformation.NetworkStatusChanged -= NetworkInformation_NetworkStatusChanged;
  48. }
  49. private async void NetworkInformation_NetworkStatusChanged(object sender)
  50. {
  51. if (IsInternetAvailable())
  52. await LoadSettings();
  53. }
  54. #region Public Method
  55. public async Task<ISetting> GetSetting(string settingId)
  56. {
  57. await LoadSettings();
  58. lock (settingLock)
  59. return _settingList.FirstOrDefault(s => s.SettingName == settingId);
  60. }
  61. public async Task<List<WindowsCardSetting>> GetCardSettings()
  62. {
  63. await LoadSettings();
  64. lock (settingLock)
  65. return _settingList.Where(s => s is WindowsCardSetting).Select(s => s as WindowsCardSetting).OrderByDescending(w => w.Weight).ToList();
  66. }
  67. #endregion
  68. #region Private Method
  69. private async Task LoadSettings()
  70. {
  71. try
  72. {
  73. await _loadSettingSS.WaitAsync();
  74. if (!_isLoaded)
  75. {
  76. lock (settingLock)
  77. _settingList.Clear();
  78. if (!IsInternetAvailable())
  79. return;
  80. var allTask = new List<Task>();
  81. allTask.Add(GetWindowsCards());
  82. if (!_loadCardsOnly)
  83. {
  84. allTask.Add(GetViewerEventBarSetting());
  85. allTask.Add(GetOtherSetting());
  86. }
  87. await Task.WhenAll(allTask);
  88. _isLoaded = true;
  89. }
  90. }
  91. catch
  92. {
  93. }
  94. finally
  95. {
  96. _loadSettingSS.Release();
  97. }
  98. }
  99. private async Task GetViewerEventBarSetting()
  100. {
  101. var region = GetSystemRegion();
  102. var appLang = GetAppLanguage();
  103. var querys = new List<KeyValuePair<string, string>>();
  104. querys.Add(new KeyValuePair<string, string>("deep[evnet_bar_text_translations][_filter][languages_code][_eq]", appLang));
  105. querys.Add(new KeyValuePair<string, string>("deep[dialog_text_translations][_filter][languages_code][_eq]", appLang));
  106. querys.Add(new KeyValuePair<string, string>("deep[dialog_button][dialog_button_translations][_filter][languages_code][_eq]", appLang));
  107. querys.Add(new KeyValuePair<string, string>("deep[do_not_show_translations][_filter][languages_code][_eq]", appLang));
  108. querys.Add(new KeyValuePair<string, string>("filter[platform][_eq]", "windows"));
  109. querys.Add(new KeyValuePair<string, string>("filter[regions][_contains]", region));
  110. querys.Add(new KeyValuePair<string, string>("fields", "*,do_not_show_translations.*,evnet_bar_text_translations.*,dialog_text_translations.*,dialog_button.*,dialog_button.dialog_button_translations.*"));
  111. var result = await _httpClient.GetRequest(_pdfViewerEventBarSettingUri, querys);
  112. if (result.StatusCode == HttpStatusCode.Ok)
  113. {
  114. var jsonString = await result.Content.ReadAsStringAsync();
  115. var response = JsonTool.DeserializeJSON<ViewerEventBarSettingResponse>(jsonString);
  116. if (response != null && response.Data != null && response.Data.Length > 0)
  117. {
  118. lock (settingLock)
  119. _settingList.Add(response.Data[0]);
  120. }
  121. }
  122. }
  123. private async Task GetOtherSetting()
  124. {
  125. var querys = new List<KeyValuePair<string, string>>();
  126. querys.Add(new KeyValuePair<string, string>("filter[status][_eq]", "published"));
  127. querys.Add(new KeyValuePair<string, string>("filter[appTypes][_contains]", _appType));
  128. querys.Add(new KeyValuePair<string, string>("fields", "*"));
  129. var result = await _httpClient.GetRequest(_pdfOtherSettingUri, querys);
  130. if (result.StatusCode == HttpStatusCode.Ok)
  131. {
  132. var jsonString = await result.Content.ReadAsStringAsync();
  133. dynamic dyna = DynamicJsonHelper.ToDynamicJson(jsonString);
  134. if (dyna == null)
  135. return;
  136. List<dynamic> settings = DynamicJsonHelper.GetArraySafety(dyna.data);
  137. if (settings == null)
  138. return;
  139. foreach (var setting in settings)
  140. {
  141. string configName = DynamicJsonHelper.GetValueSafety<string>(setting.config_name, null);
  142. if (!string.IsNullOrEmpty(configName) && setting.json_data != null)
  143. {
  144. lock (settingLock)
  145. _settingList.Add(new JsonSetting(configName, setting.json_data));
  146. }
  147. }
  148. }
  149. }
  150. private async Task GetWindowsCards()
  151. {
  152. string region = GetSystemRegion();
  153. string lang = GetAppLanguage();
  154. var querys = new List<KeyValuePair<string, string>>();
  155. querys.Add(new KeyValuePair<string, string>("deep[Information][_filter][languages_code][_eq]", lang));
  156. querys.Add(new KeyValuePair<string, string>("filter[_or][0][include_regions][_eq]", "true"));
  157. querys.Add(new KeyValuePair<string, string>("filter[_or][0][regions][_contains]", region));
  158. querys.Add(new KeyValuePair<string, string>("filter[_or][1][include_regions][_eq]", "false"));
  159. querys.Add(new KeyValuePair<string, string>("filter[_or][1][regions][_ncontains]", region));
  160. querys.Add(new KeyValuePair<string, string>("filter[appTypes][_contains]", _appType));
  161. querys.Add(new KeyValuePair<string, string>("filter[status][_eq]", "published"));
  162. querys.Add(new KeyValuePair<string, string>("fields", "*,Information.*"));
  163. var result = await _httpClient.GetRequest(_windowsCardsUri, querys);
  164. if (result.StatusCode == HttpStatusCode.Ok)
  165. {
  166. var jsonString = await result.Content.ReadAsStringAsync();
  167. var response = JsonTool.DeserializeJSON<WindowsCardsResponse>(jsonString);
  168. if (response != null && response.Data != null && response.Data.Length > 0)
  169. {
  170. foreach (var card in response.Data)
  171. {
  172. lock (settingLock)
  173. _settingList.Add(card);
  174. }
  175. }
  176. }
  177. }
  178. private string GetSystemRegion()
  179. {
  180. var geographyCountryCode = new GeographicRegion().CodeTwoLetter;
  181. switch (geographyCountryCode)
  182. {
  183. case "GB":
  184. case "US":
  185. case "TW":
  186. case "CN":
  187. case "JP":
  188. case "ES":
  189. case "IT":
  190. case "FR":
  191. case "DE":
  192. case "RU":
  193. case "PT":
  194. case "KR":
  195. return geographyCountryCode;
  196. default:
  197. return "OTHER";
  198. }
  199. }
  200. private string GetAppLanguage()
  201. {
  202. try
  203. {
  204. var currentLang = Windows.ApplicationModel.Resources.Core.ResourceContext.GetForCurrentView().Languages[0];
  205. switch (currentLang)
  206. {
  207. case "de-DE":
  208. case "de":
  209. return "de";
  210. case "es-ES":
  211. case "es":
  212. return "es";
  213. case "fr-FR":
  214. case "fr":
  215. return "fr";
  216. case "it-IT":
  217. case "it":
  218. return "it";
  219. case "ja-JP":
  220. case "ja":
  221. return "ja";
  222. case "zh-Hans-CN":
  223. case "zh-Hans":
  224. case "zh-CN":
  225. return "zh-cn";
  226. case "zh-Hant-TW":
  227. case "zh-Hant":
  228. case "zh-TW":
  229. return "zh-tw";
  230. case "ru-RU":
  231. case "ru":
  232. return "ru";
  233. case "ko-KR":
  234. case "ko":
  235. return "ko";
  236. case "pt-PT":
  237. case "pt":
  238. return "pt";
  239. default:
  240. return "en";
  241. }
  242. }
  243. catch
  244. {
  245. return "en";
  246. }
  247. }
  248. private bool IsInternetAvailable()
  249. {
  250. ConnectionProfile connections = NetworkInformation.GetInternetConnectionProfile();
  251. bool isInternetAvailable = connections != null && connections.GetNetworkConnectivityLevel() == NetworkConnectivityLevel.InternetAccess;
  252. return isInternetAvailable;
  253. }
  254. #endregion
  255. }
  256. }