OALicenseInfo_services.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430
  1. package services
  2. import (
  3. "archive/zip"
  4. "bytes"
  5. "fmt"
  6. "strings"
  7. "xugu_license/internal/api"
  8. "xugu_license/internal/global"
  9. "xugu_license/internal/models"
  10. "xugu_license/internal/module/email"
  11. "xugu_license/internal/module/license"
  12. "xugu_license/internal/utils"
  13. "github.com/pkg/errors"
  14. )
  15. func DistributeOALicenseServices(OperatorUniqueID, OaRequestId string, UserUniqueIDs, UserAccounts, UserNames, EmailArray []string) (error, []string) {
  16. // //检测OARequest是否以及分发过给用户
  17. // existUsers, err := checkDistributeToUser(OaRequestId, UserUniqueIDs, UserNames)
  18. // if err != nil {
  19. // global.Logger.Errorln("license分发请求检测是否已发放给用户失败 %s", err.Error())
  20. // return err, nil
  21. // }
  22. // //返回以及分发过的用户列表
  23. // if len(existUsers) != 0 {
  24. // return nil, existUsers
  25. // }
  26. // fmt.Println("DistributeOALicenseServices : ")
  27. // //获取一个申请单的多个license信息
  28. // LicInfos, _, err := models.GetOALicenseInfo(1, 1, "", "", "", OaRequestId)
  29. // if err != nil {
  30. // return err, nil
  31. // }
  32. // //将分发的lic信息插入lic分发用户表中
  33. // for _, licInfo := range *LicInfos {
  34. // for userIdx, userUID := range UserUniqueIDs {
  35. // //如果lic1为空则报错
  36. // if licInfo.GenrateInfo.Lic1.String == "" {
  37. // global.Logger.Errorln("DistributeOALicenseServices : license生成信息为空 ")
  38. // return errors.New("license生成信息为空"), nil
  39. // }
  40. // err = models.InsertlicenseRecordByUserRow(OaRequestId, licInfo.LicInfo.UniqueID.String, userUID, UserAccounts[userIdx], OperatorUniqueID)
  41. // if err != nil {
  42. // global.Logger.Errorln("DistributeOALicenseServices: 数据库插入失败: ", err.Error())
  43. // return err, nil
  44. // }
  45. // }
  46. // }
  47. // //发送邮件
  48. // //邮箱不空则发送
  49. // //将一个申请单的多个license信息用邮箱发送
  50. // if len(EmailArray) == 0 {
  51. // return nil, nil
  52. // }
  53. // //将licenses里的lic串们打包在zip里
  54. // // 1. 创建 ZIP 文件并存储在内存中
  55. // // var buffer bytes.Buffer
  56. // // zipWriter := zip.NewWriter(&buffer)
  57. // // for _, lic := range *LicInfos {
  58. // // // 将数据添加到 ZIP 中
  59. // // file1, err := zipWriter.Create("file1.txt")
  60. // // if err != nil {
  61. // // global.Logger.Errorln(err)
  62. // // }
  63. // // _, err = file1.Write(lic)
  64. // // if err != nil {
  65. // // global.Logger.Errorln(err)
  66. // // }
  67. // // }
  68. // // file2, err := zipWriter.Create("file2.txt")
  69. // // if err != nil {
  70. // // global.Logger.Errorln(err)
  71. // // }
  72. // // _, err = file2.Write(data2)
  73. // // if err != nil {
  74. // // global.Logger.Errorln(err)
  75. // // }
  76. // fmt.Println("EmailArray : ", EmailArray)
  77. // emails := strings.Join(EmailArray, ",")
  78. // if !strings.Contains(emails, "@") {
  79. // return nil, nil
  80. // }
  81. // for _, lic := range *LicInfos {
  82. // if lic.GenrateInfo.Lic1.String == "" {
  83. // global.Logger.Errorln("DistributeOALicenseServices : license生成信息为空 ")
  84. // return errors.New("license生成信息为空"), nil
  85. // }
  86. // //组装邮件
  87. // em, err := email.BuildEmail(&lic, EmailArray, lic.GenrateInfo.Lic1.String, lic.GenrateInfo.Lic2.String)
  88. // if err != nil {
  89. // global.Logger.Errorln("邮件生成失败", err.Error())
  90. // return err, nil
  91. // }
  92. // //发送邮件
  93. // err = email.SendEmail(em)
  94. // if err != nil {
  95. // global.Logger.Errorln("邮件发送失败", err.Error())
  96. // return err, nil
  97. // }
  98. // //将分发的lic信息插入lic分发邮箱表中
  99. // err = models.InsertlicenseRecordByEmailRow(OaRequestId, lic.LicInfo.UniqueID.String, emails, OperatorUniqueID)
  100. // if err != nil {
  101. // global.Logger.Errorln("数据库插入失败: ", err.Error())
  102. // return err, nil
  103. // }
  104. // }
  105. return nil, nil
  106. }
  107. func DistributeLicenseToUserServices(OperatorUniqueID string, OaRequestId int64, UserUniqueIDs, UserAccounts, UserNames []string) (error, []string) {
  108. //检测OARequest是否以及分发过给用户
  109. existUsers, err := checkDistributeToUser(OaRequestId, UserUniqueIDs, UserNames)
  110. if err != nil {
  111. global.Logger.Errorln("license分发请求检测是否已发放给用户失败 %s", err.Error())
  112. return err, nil
  113. }
  114. //返回以及分发过的用户列表
  115. if len(existUsers) != 0 {
  116. return nil, existUsers
  117. }
  118. fmt.Println("DistributeOALicenseServices : ")
  119. //获取一个申请单的多个license信息
  120. LicInfos, _, err := models.GetOALicenseInfo(1, 1, "", "", "", OaRequestId)
  121. if err != nil {
  122. return err, nil
  123. }
  124. //将分发的lic信息插入lic分发用户表中
  125. for _, licInfo := range *LicInfos {
  126. for userIdx, userUID := range UserUniqueIDs {
  127. //如果lic1为空则报错
  128. if licInfo.GenrateInfo.Lic1.String == "" {
  129. global.Logger.Errorln("DistributeOALicenseServices : license生成信息为空 ")
  130. return errors.New("license生成信息为空"), nil
  131. }
  132. err = models.InsertlicenseRecordByUserRow(OaRequestId, licInfo.LicInfo.UniqueID.String, userUID, UserAccounts[userIdx], OperatorUniqueID)
  133. if err != nil {
  134. global.Logger.Errorln("DistributeOALicenseServices: 数据库插入失败: ", err.Error())
  135. return err, nil
  136. }
  137. }
  138. }
  139. return nil, nil
  140. }
  141. func DistributeLicenseToEmailServices(OperatorUniqueID string, OaRequestId int64, UserUniqueIDs, UserAccounts, UserNames, EmailArray []string) (error, []string) {
  142. //发送邮件
  143. //邮箱不空则发送
  144. //将一个申请单的多个license信息用邮箱发送
  145. if len(EmailArray) == 0 {
  146. return nil, nil
  147. }
  148. //获取一个申请单的多个license信息
  149. LicInfos, _, err := models.GetOALicenseInfo(1, 1, "", "", "", OaRequestId)
  150. if err != nil {
  151. return err, nil
  152. }
  153. //将licenses里的lic串们打包在zip里
  154. //1. 创建 ZIP 文件并存储在内存中
  155. var buffer bytes.Buffer
  156. zipWriter := zip.NewWriter(&buffer)
  157. for i, lic := range *LicInfos {
  158. ii := i + 1
  159. num := 1
  160. filetestName := fmt.Sprintf("%d_%s_license_jdCount%d_%d", ii, lic.LicInfo.OAGLXMName.String, lic.LicInfo.OANodeCount.Int64, num)
  161. num++
  162. // 将数据添加到 ZIP 中
  163. file1, err := zipWriter.Create(fmt.Sprintf(filetestName+"_%s", lic.LicInfo.OAMainMAC.String))
  164. if err != nil {
  165. global.Logger.Errorln(err)
  166. }
  167. if lic.GenrateInfo.Lic1.Valid {
  168. _, err = file1.Write([]byte(lic.GenrateInfo.Lic1.String))
  169. if err != nil {
  170. global.Logger.Errorln(err)
  171. }
  172. }
  173. file2, err := zipWriter.Create(fmt.Sprintf(filetestName+"_%s", lic.LicInfo.OASecondMAC.String))
  174. if lic.GenrateInfo.Lic2.Valid {
  175. if err != nil {
  176. global.Logger.Errorln(err)
  177. }
  178. _, err = file2.Write([]byte(lic.GenrateInfo.Lic2.String))
  179. if err != nil {
  180. global.Logger.Errorln(err)
  181. }
  182. }
  183. }
  184. // 关闭 zip.Writer
  185. if err := zipWriter.Close(); err != nil {
  186. global.Logger.Errorln(err)
  187. }
  188. // 将 ZIP 内容转换为 []byte
  189. zipBytes := buffer.Bytes()
  190. fmt.Println("EmailArray : ", EmailArray)
  191. emails := strings.Join(EmailArray, ",")
  192. if !strings.Contains(emails, "@") {
  193. return nil, nil
  194. }
  195. // if lic.GenrateInfo.Lic1.String == "" {
  196. // global.Logger.Errorln("DistributeOALicenseServices : license生成信息为空 ")
  197. // return errors.New("license生成信息为空"), nil
  198. // }
  199. lic := &(*LicInfos)[0]
  200. //组装邮件
  201. em, err := email.BuildEmail(lic, EmailArray, zipBytes, "")
  202. if err != nil {
  203. global.Logger.Errorln("邮件生成失败", err.Error())
  204. return err, nil
  205. }
  206. //发送邮件
  207. err = email.SendEmail(em)
  208. if err != nil {
  209. global.Logger.Errorln("邮件发送失败", err.Error())
  210. return err, nil
  211. }
  212. for _, lic := range *LicInfos {
  213. //将分发的lic信息插入lic分发邮箱表中
  214. err = models.InsertlicenseRecordByEmailRow(OaRequestId, lic.LicInfo.UniqueID.String, emails, OperatorUniqueID)
  215. if err != nil {
  216. global.Logger.Errorln("数据库插入失败: ", err.Error())
  217. return err, nil
  218. }
  219. }
  220. // for _, lic := range *LicInfos {
  221. // if lic.GenrateInfo.Lic1.String == "" {
  222. // global.Logger.Errorln("DistributeOALicenseServices : license生成信息为空 ")
  223. // return errors.New("license生成信息为空"), nil
  224. // }
  225. // //组装邮件
  226. // em, err := email.BuildEmail(&lic, EmailArray, lic.GenrateInfo.Lic1.String, lic.GenrateInfo.Lic2.String)
  227. // if err != nil {
  228. // global.Logger.Errorln("邮件生成失败", err.Error())
  229. // return err, nil
  230. // }
  231. // //发送邮件
  232. // err = email.SendEmail(em)
  233. // if err != nil {
  234. // global.Logger.Errorln("邮件发送失败", err.Error())
  235. // return err, nil
  236. // }
  237. // //将分发的lic信息插入lic分发邮箱表中
  238. // err = models.InsertlicenseRecordByEmailRow(OaRequestId, lic.LicInfo.UniqueID.String, emails, OperatorUniqueID)
  239. // if err != nil {
  240. // global.Logger.Errorln("数据库插入失败: ", err.Error())
  241. // return err, nil
  242. // }
  243. // }
  244. return nil, nil
  245. }
  246. // 生成license
  247. func GenerateOALicenseStrServices(request api.GenerateLicenseStrRequest) (error, bool) {
  248. if request.OARequestId != 0 {
  249. //一个OARequestId会有多条数据UniqueID
  250. OALics, _, err := models.GetOALicenseInfo(0, 0, "", "", "", request.OARequestId)
  251. if err != nil || OALics == nil {
  252. global.Logger.Errorln("LicenseInfo数据查询失败: ", err.Error())
  253. return errors.Errorf("LicenseInfo数据查询失败 : %v", err.Error()), false
  254. }
  255. //校验license信息是否与oa一致
  256. var isCheck bool
  257. for _, license := range *OALics {
  258. //检测该数据是否与oa库数据库一致 //todo
  259. isCheckTmp, err := models.CheckLicenseInfoInOADB(&license.LicInfo)
  260. if err != nil {
  261. global.Logger.Errorln("LicenseInfo数据对比oa库 校验失败: ", err.Error())
  262. return errors.Errorf("LicenseInfo数据对比oa库 校验失败 %v", err.Error()), false
  263. }
  264. if isCheckTmp {
  265. global.Logger.Errorf("\nLicenseInfo数据对比oa库 不一致: %v\n", license.LicInfo.UniqueID)
  266. isCheck = isCheckTmp
  267. err = models.UpdatelicenseInfoRow(license)
  268. if err != nil {
  269. return err, false
  270. }
  271. }
  272. }
  273. //不一致则返回
  274. if isCheck {
  275. return nil, true
  276. }
  277. //生成license,已生成的不管
  278. for _, v := range *OALics {
  279. if v.GenrateInfo.LicenseFlage.String == "未生成" {
  280. err := generateLicenseStrSub(utils.ToString(v.LicInfo.UniqueID))
  281. if err != nil {
  282. global.Logger.Errorf("请联系管理员, LicenseInfo%v生成失败: %v\n", v.LicInfo.UniqueID, err.Error())
  283. return errors.Errorf("请联系管理员, LicenseInfo%v生成失败: %v\n", v.LicInfo.UniqueID, err.Error()), false
  284. }
  285. }
  286. }
  287. return nil, false
  288. }
  289. return errors.Errorf("License申请单为空"), false
  290. }
  291. func generateLicenseStrSub(UniqueID string) error {
  292. var applications *[]models.OALicenseInfo
  293. var err error
  294. if UniqueID != "" {
  295. applications, _, err = models.GetOALicenseInfo(0, 1, "", UniqueID, "", 0)
  296. if err != nil {
  297. global.Logger.Errorln("LicenseInfo数据查询失败: ", err.Error())
  298. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  299. return errors.Errorf("LicenseInfo数据查询失败: %v", err.Error())
  300. }
  301. }
  302. fmt.Printf("applications%#v\n", applications)
  303. //生成副主节点license
  304. if applications == nil {
  305. global.Logger.Errorln("LicenseInfo数据生成失败 ,数据查询为空 ")
  306. //c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("LicenseInfo数据生成失败 ,数据查询为空: ", err.Error())})
  307. return errors.Errorf("LicenseInfo数据生成失败 ,数据查询为空 ")
  308. }
  309. pj := license.ProjectInfo{
  310. ProjectName: utils.ToString((*applications)[0].LicInfo.OAProductName),
  311. UserName: utils.ToString((*applications)[0].LicInfo.OAProductVersion),
  312. UserAddr: "未填写",
  313. SerialNumber: "未填写",
  314. }
  315. ei := license.EnvironmentInfo{
  316. CpuSN: "未填写",
  317. BaseboardSN: "未填写",
  318. MacAddr: utils.ToString((*applications)[0].LicInfo.OAMainMAC),
  319. DiskID: "未填写",
  320. IPAddr: "未填写",
  321. }
  322. LicType := utils.SwitchLicenseType(utils.ToString((*applications)[0].LicInfo.OAProductVersion))
  323. lI := license.LicenseInfo{
  324. GenDate: "2024-07-15",
  325. ExpireDate: "9999-12-31",
  326. LicenseType: LicType,
  327. LicenseVersion: 1,
  328. HardType: 3,
  329. }
  330. //这里调用的是license模块中的生成license的方法
  331. res := false
  332. if res {
  333. if (*applications)[0].LicInfo.OASecondMAC.String != "" {
  334. // var licStr2 []byte
  335. // ei.MacAddr = applications[0].SecondaryMasterMacAddress
  336. // licStr2 = license.GenerateLicense(pj, ei, lI)
  337. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), []byte("b4j6z4rE2IfG1av0wIPT7YnvyGZFHxwIBikMGjgCLQILR0xsT1NHiuzoi+Dqq+bmiNDEiuPyitDVgdvlRmYbFAk+MAAGASlPTkdMbE9"), []byte("b4j6z4rE2IfG1av0wIPT7YnvyGZFHxwIBikMGjgCLQILR0xsT1NHiuzoi+Dqq+bmiNDEiuPyitDVgdvlRmYbFAk+MAAGASlPTkdMbE9"))
  338. if err != nil {
  339. global.Logger.Errorln("LicenseInfo生成插入失败: ", err.Error())
  340. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  341. return errors.Errorf("LicenseInfo生成插入失败:: ", err.Error())
  342. }
  343. } else {
  344. //fmt.Println("licStr licStr2", licStr, licStr2)
  345. //插入到数据库
  346. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), []byte("b4j6z4rE2IfG1av0wIPT7YnvyGZFHxwIBikMGjgCLQILR0xsT1NHiuzoi+Dqq+bmiNDEiuPyitDVgdvlRmYbFAk+MAAGASlPTkdMbE9"), nil)
  347. if err != nil {
  348. global.Logger.Errorln("LicenseInfo2生成插入失败: ", err.Error())
  349. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  350. return errors.Errorf("LicenseInfo2生成插入失败:: ", err.Error())
  351. }
  352. }
  353. } else {
  354. licStr := license.GenerateLicense(pj, ei, lI)
  355. //生成副主节点license
  356. if (*applications)[0].LicInfo.OASecondMAC.String != "" {
  357. var licStr2 []byte
  358. ei.MacAddr = (*applications)[0].LicInfo.OASecondMAC.String
  359. licStr2 = license.GenerateLicense(pj, ei, lI)
  360. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), licStr, licStr2)
  361. if err != nil {
  362. global.Logger.Errorln("LicenseInfo2生成插入失败: ", err.Error())
  363. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  364. return errors.Errorf("LicenseInfo2生成插入失败:: ", err.Error())
  365. }
  366. } else {
  367. //插入到数据库
  368. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), licStr, nil)
  369. if err != nil {
  370. global.Logger.Errorln("LicenseInfo生成插入失败: ", err.Error())
  371. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  372. return errors.Errorf("LicenseInfo生成插入失败:: ", err.Error())
  373. }
  374. }
  375. }
  376. //---------------------
  377. return nil
  378. }