PageUpdateInfoService.cs 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. using Attribute;
  2. using Dto;
  3. using Vo;
  4. using Model;
  5. using Model.Base;
  6. using Repository;
  7. using Service;
  8. using Microsoft.AspNetCore.Mvc;
  9. using Aliyun.OSS;
  10. using Common;
  11. using System.Text.RegularExpressions;
  12. using Infrastructure.Model;
  13. using Base;
  14. using Mapster;
  15. namespace Services
  16. {
  17. /// <summary>
  18. /// 页面模板更新信息Service业务层处理
  19. /// </summary>
  20. [AppService(ServiceType = typeof(IPageUpdateInfoService), ServiceLifetime = LifeTime.Transient)]
  21. public class PageUpdateInfoService : BaseService<PageUpdateInfo>, IPageUpdateInfoService
  22. {
  23. /// <summary>
  24. /// 页面模板更新信息-列表
  25. /// </summary>
  26. /// <param name="parm">请求参数</param>
  27. /// <returns>页面模板更新信息列表</returns>
  28. public PagedInfo<PageUpdateInfoListVo> List([FromQuery] PageUpdateInfoListDto parm, [FromQuery] PagerInfo page)
  29. {
  30. //开始拼装查询条件
  31. var predicate = Expressionable.Create<PageUpdateInfo>();
  32. predicate = predicate.And(m => m.appVersion == parm.appVersion);
  33. predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.kind), m => m.kind.Contains(parm.kind));
  34. predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.title), m => m.title.Contains(parm.title));
  35. predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.modulePath), m => m.modulePath.Contains(parm.modulePath));
  36. var response = Queryable()
  37. .Where(predicate.ToExpression())
  38. .OrderBy(m => m.id)
  39. .ToPage<PageUpdateInfo, PageUpdateInfoListVo>(page);
  40. return response;
  41. }
  42. /// <summary>
  43. /// 页面模板更新信息-刷新文件
  44. /// </summary>
  45. /// <param name="parm">请求参数</param>
  46. /// <returns>页面模板更新信息刷新文件</returns>
  47. public void UpdateTemplate([FromQuery] PageUpdateInfoUpdateTemplateDto parm)
  48. {
  49. OssConfigs ossConfigs = new();
  50. AppSettings.Bind("OssConfigs", ossConfigs);
  51. string kind = parm.kind;
  52. if(!string.IsNullOrEmpty(parm.appVersion))
  53. {
  54. kind += "/" + parm.appVersion;
  55. }
  56. GetSystemFiles(ossConfigs, kind);
  57. foreach (string filename in SystemFiles)
  58. {
  59. string template = filename.Substring(filename.LastIndexOf("/") + 1);
  60. if (template.EndsWith(".html"))
  61. {
  62. PageUpdateInfo check = GetFirst(m => m.modulePath == template && m.kind == parm.kind && m.appVersion == parm.appVersion);
  63. if (check == null)
  64. {
  65. string ModuleContent = Function.GetNetFileContent(ossConfigs.Host + "template/app/" + kind + "/" + template);
  66. if (!string.IsNullOrEmpty(ModuleContent))
  67. {
  68. string admintitle = "";
  69. string title = "";
  70. Match match = Regex.Match(ModuleContent, "<title>.*?</title>", RegexOptions.IgnoreCase);
  71. if (match.Success)
  72. {
  73. admintitle = match.Value.Replace("<title>", "").Replace("</title>", "");
  74. // if (admintitle.Contains("-"))
  75. // {
  76. // title = admintitle.Substring(admintitle.LastIndexOf("-") + 1);
  77. // }
  78. // else
  79. // {
  80. title = admintitle;
  81. // }
  82. }
  83. var item = GetFirst(m => m.modulePath == template && kind == parm.kind && m.appVersion == parm.appVersion);
  84. if(item == null)
  85. {
  86. Add(new PageUpdateInfo()
  87. {
  88. createDate = DateTime.Now,
  89. updateDate = DateTime.Now,
  90. kind = parm.kind,
  91. leftAction1 = "{\"Url\":\"GoBack#{\\\"Level\\\":\\\"1\\\"}\",\"Jump\":\"1\",\"Kind\":\"2\"}",
  92. leftBtn1 = "static/images/left.png",
  93. skidFlag = true,
  94. showScrollBar = false,
  95. title = title,
  96. showTitle = true,
  97. statusBarStyle = "default",
  98. textColor = "333333",
  99. backgroudColor = "FFFFFF",
  100. modulePath = template,
  101. moduleVersion = 1,
  102. mustUpdate = true,
  103. appVersion = Function.CheckNull(parm.appVersion),
  104. });
  105. }
  106. else
  107. {
  108. item.updateDate = DateTime.Now;
  109. item.title = title;
  110. Update(item, true);
  111. }
  112. }
  113. }
  114. }
  115. }
  116. }
  117. List<string> SystemFiles;
  118. private void GetSystemFiles(OssConfigs ossConfigs, string Kind = "default")
  119. {
  120. SystemFiles = new List<string>();
  121. var client = new OssClient(ossConfigs.Endpoint, ossConfigs.Key, ossConfigs.Secret);
  122. var listObjectsRequest = new ListObjectsRequest(ossConfigs.BucketName);
  123. listObjectsRequest.MaxKeys = 1000;
  124. listObjectsRequest.Prefix = "template/app/" + Kind + "/";
  125. var result = client.ListObjects(listObjectsRequest);
  126. foreach (var summary in result.ObjectSummaries)
  127. {
  128. SystemFiles.Add(summary.Key);
  129. }
  130. }
  131. /// <summary>
  132. /// 生成APP配置文件
  133. /// </summary>
  134. /// <param name="parm">请求参数</param>
  135. /// <returns>生成APP配置文件</returns>
  136. public string makeAppInitData(AppSourceSet set, string kind, string appVersion, string EncryptType = "des")
  137. {
  138. // OssConfigs ossConfigs = new();
  139. // AppSettings.Bind("OssConfigs", ossConfigs);
  140. string GotoPages = "{";
  141. string PageInfoList = "{";
  142. string LibFile = "{";
  143. List<PageUpdateInfo> newpages = GetList(m => m.kind == kind && m.appVersion == appVersion);
  144. if(!string.IsNullOrEmpty(appVersion))
  145. {
  146. kind += "/" + appVersion;
  147. }
  148. foreach (PageUpdateInfo page in newpages)
  149. {
  150. string FileName = page.modulePath.Split('.')[0];
  151. var pageinfo = page.Adapt<AppPageInfoVo>();
  152. pageinfo.dataId = Function.MD5_16(pageinfo.id.ToString() + "123890");
  153. PageInfoList += "\"page" + FileName + "\":" + Newtonsoft.Json.JsonConvert.SerializeObject(pageinfo) + ",";
  154. // string PagePath = "template/app/" + kind + "/" + page.modulePath;
  155. // string pageContent = Function.GetNetFileContent(ossConfigs.Host + PagePath);
  156. string pageContent = Function.GetNetFileContent(set.host + "/" + set.path + "/" + appVersion + "/" + page.modulePath);
  157. if(EncryptType == "des")
  158. {
  159. pageContent = Dbconn.Encrypt3DES(pageContent, "*ga34|^7");
  160. }
  161. else
  162. {
  163. pageContent = Dbconn.AesEncrypt(pageContent, "CBTU1dD4Kd5pyiGWTsI10jRQ3SvKusSV", "DYgjCEIMVrj2W9xN");
  164. }
  165. LibFile += "\"page" + FileName + "\":\"" + pageContent + "\",";
  166. }
  167. PageInfoList = PageInfoList.TrimEnd(',');
  168. PageInfoList += "}";
  169. GotoPages = GotoPages.TrimEnd(',');
  170. GotoPages += "}";
  171. LibFile = LibFile.TrimEnd(',');
  172. LibFile += "}";
  173. if(EncryptType == "des") return Dbconn.Encrypt3DES(PageInfoList, "*ga34|^7") + "#cut#" + GotoPages + "#cut#" + Dbconn.Encrypt3DES(LibFile, "*ga34|^7");
  174. return Dbconn.AesEncrypt(PageInfoList, "CBTU1dD4Kd5pyiGWTsI10jRQ3SvKusSV", "DYgjCEIMVrj2W9xN") + "#cut#" + GotoPages + "#cut#" + Dbconn.AesEncrypt(LibFile, "CBTU1dD4Kd5pyiGWTsI10jRQ3SvKusSV", "DYgjCEIMVrj2W9xN");
  175. }
  176. /// <summary>
  177. /// 页面模板复制
  178. /// </summary>
  179. /// <param name="parm">请求参数</param>
  180. /// <returns>页面模板复制</returns>
  181. public void Copy([FromQuery] CopyDto parm)
  182. {
  183. var predicate = Expressionable.Create<PageUpdateInfo>();
  184. predicate = predicate.And(m => m.appVersion == parm.sourceVersion);
  185. var list = Queryable()
  186. .Where(predicate.ToExpression())
  187. .OrderBy(m => m.id)
  188. .ToList();
  189. foreach(var sub in list)
  190. {
  191. sub.appVersion = parm.addVersion;
  192. Add(sub);
  193. }
  194. }
  195. /// <summary>
  196. /// 复制前删除
  197. /// </summary>
  198. /// <param name="parm">请求参数</param>
  199. /// <returns>复制前删除</returns>
  200. public void DeleteForCopy([FromQuery] CopyDto parm)
  201. {
  202. var predicate = Expressionable.Create<PageUpdateInfo>();
  203. predicate = predicate.And(m => m.appVersion == parm.addVersion);
  204. var list = Queryable()
  205. .Where(predicate.ToExpression())
  206. .OrderBy(m => m.id)
  207. .ToList();
  208. foreach(var sub in list)
  209. {
  210. Delete(sub);
  211. }
  212. }
  213. }
  214. }