OALicenseInfo_services.go 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439
  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_%djd_%d", ii, lic.LicInfo.OAGLXMName.String, lic.LicInfo.OANodeCount.Int64, num)
  161. num++
  162. // 将数据添加到 ZIP 中
  163. file1, err := zipWriter.Create(fmt.Sprintf(filetestName+"_%s.dat", lic.LicInfo.OAMainMAC.String))
  164. if err != nil {
  165. global.Logger.Errorln(err)
  166. return err, nil
  167. }
  168. if lic.GenrateInfo.Lic1.Valid {
  169. _, err = file1.Write([]byte(lic.GenrateInfo.Lic1.String))
  170. if err != nil {
  171. global.Logger.Errorln(err)
  172. return err, nil
  173. }
  174. }
  175. if lic.GenrateInfo.Lic2.Valid {
  176. if err != nil {
  177. global.Logger.Errorln(err)
  178. return err, nil
  179. }
  180. file2, err := zipWriter.Create(fmt.Sprintf(filetestName+"_%s", lic.LicInfo.OASecondMAC.String))
  181. if err != nil {
  182. global.Logger.Errorln(err)
  183. return err, nil
  184. }
  185. _, err = file2.Write([]byte(lic.GenrateInfo.Lic2.String))
  186. if err != nil {
  187. global.Logger.Errorln(err)
  188. return err, nil
  189. }
  190. }
  191. }
  192. // 关闭 zip.Writer
  193. if err := zipWriter.Close(); err != nil {
  194. global.Logger.Errorln(err)
  195. }
  196. // 将 ZIP 内容转换为 []byte
  197. zipBytes := buffer.Bytes()
  198. fmt.Println("EmailArray : ", EmailArray)
  199. emails := strings.Join(EmailArray, ",")
  200. if !strings.Contains(emails, "@") {
  201. return nil, nil
  202. }
  203. // if lic.GenrateInfo.Lic1.String == "" {
  204. // global.Logger.Errorln("DistributeOALicenseServices : license生成信息为空 ")
  205. // return errors.New("license生成信息为空"), nil
  206. // }
  207. lic := &(*LicInfos)[0]
  208. //组装邮件
  209. em, err := email.BuildEmail(lic, EmailArray, zipBytes, "")
  210. if err != nil {
  211. global.Logger.Errorln("邮件生成失败", err.Error())
  212. return err, nil
  213. }
  214. //发送邮件
  215. err = email.SendEmail(em)
  216. if err != nil {
  217. global.Logger.Errorln("邮件发送失败", err.Error())
  218. return err, nil
  219. }
  220. for _, lic := range *LicInfos {
  221. //将分发的lic信息插入lic分发邮箱表中
  222. err = models.InsertlicenseRecordByEmailRow(OaRequestId, lic.LicInfo.UniqueID.String, emails, OperatorUniqueID)
  223. if err != nil {
  224. global.Logger.Errorln("数据库插入失败: ", err.Error())
  225. return err, nil
  226. }
  227. }
  228. // for _, lic := range *LicInfos {
  229. // if lic.GenrateInfo.Lic1.String == "" {
  230. // global.Logger.Errorln("DistributeOALicenseServices : license生成信息为空 ")
  231. // return errors.New("license生成信息为空"), nil
  232. // }
  233. // //组装邮件
  234. // em, err := email.BuildEmail(&lic, EmailArray, lic.GenrateInfo.Lic1.String, lic.GenrateInfo.Lic2.String)
  235. // if err != nil {
  236. // global.Logger.Errorln("邮件生成失败", err.Error())
  237. // return err, nil
  238. // }
  239. // //发送邮件
  240. // err = email.SendEmail(em)
  241. // if err != nil {
  242. // global.Logger.Errorln("邮件发送失败", err.Error())
  243. // return err, nil
  244. // }
  245. // //将分发的lic信息插入lic分发邮箱表中
  246. // err = models.InsertlicenseRecordByEmailRow(OaRequestId, lic.LicInfo.UniqueID.String, emails, OperatorUniqueID)
  247. // if err != nil {
  248. // global.Logger.Errorln("数据库插入失败: ", err.Error())
  249. // return err, nil
  250. // }
  251. // }
  252. return nil, nil
  253. }
  254. // 生成license
  255. func GenerateOALicenseStrServices(request api.GenerateLicenseStrRequest) (error, bool) {
  256. if request.OARequestId != 0 {
  257. //一个OARequestId会有多条数据UniqueID
  258. OALics, _, err := models.GetOALicenseInfo(0, 0, "", "", "", request.OARequestId)
  259. if err != nil || OALics == nil {
  260. global.Logger.Errorln("LicenseInfo数据查询失败: ", err.Error())
  261. return errors.Errorf("LicenseInfo数据查询失败 : %v", err.Error()), false
  262. }
  263. //校验license信息是否与oa一致
  264. var isCheck bool
  265. for _, license := range *OALics {
  266. //检测该数据是否与oa库数据库一致 //todo
  267. isCheckTmp, err := models.CheckLicenseInfoInOADB(&license.LicInfo)
  268. if err != nil {
  269. global.Logger.Errorln("LicenseInfo数据对比oa库 校验失败: ", err.Error())
  270. return errors.Errorf("LicenseInfo数据对比oa库 校验失败 %v", err.Error()), false
  271. }
  272. if isCheckTmp {
  273. global.Logger.Errorf("\nLicenseInfo数据对比oa库 不一致: %v\n", license.LicInfo.UniqueID)
  274. isCheck = isCheckTmp
  275. err = models.UpdatelicenseInfoRow(license)
  276. if err != nil {
  277. return err, false
  278. }
  279. }
  280. }
  281. //不一致则返回
  282. if isCheck {
  283. return nil, true
  284. }
  285. //生成license,已生成的不管
  286. for _, v := range *OALics {
  287. if v.GenrateInfo.LicenseFlage.String == "未生成" {
  288. err := generateLicenseStrSub(utils.ToString(v.LicInfo.UniqueID))
  289. if err != nil {
  290. global.Logger.Errorf("请联系管理员, LicenseInfo%v生成失败: %v\n", v.LicInfo.UniqueID, err.Error())
  291. return errors.Errorf("请联系管理员, LicenseInfo%v生成失败: %v\n", v.LicInfo.UniqueID, err.Error()), false
  292. }
  293. }
  294. }
  295. return nil, false
  296. }
  297. return errors.Errorf("License申请单为空"), false
  298. }
  299. func generateLicenseStrSub(UniqueID string) error {
  300. var applications *[]models.OALicenseInfo
  301. var err error
  302. if UniqueID != "" {
  303. applications, _, err = models.GetOALicenseInfo(0, 1, "", UniqueID, "", 0)
  304. if err != nil {
  305. global.Logger.Errorln("LicenseInfo数据查询失败: ", err.Error())
  306. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  307. return errors.Errorf("LicenseInfo数据查询失败: %v", err.Error())
  308. }
  309. }
  310. fmt.Printf("applications%#v\n", applications)
  311. //生成副主节点license
  312. if applications == nil {
  313. global.Logger.Errorln("LicenseInfo数据生成失败 ,数据查询为空 ")
  314. //c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("LicenseInfo数据生成失败 ,数据查询为空: ", err.Error())})
  315. return errors.Errorf("LicenseInfo数据生成失败 ,数据查询为空 ")
  316. }
  317. pj := license.ProjectInfo{
  318. ProjectName: utils.ToString((*applications)[0].LicInfo.OAProductName),
  319. UserName: utils.ToString((*applications)[0].LicInfo.OAProductVersion),
  320. UserAddr: "未填写",
  321. SerialNumber: "未填写",
  322. }
  323. ei := license.EnvironmentInfo{
  324. CpuSN: "未填写",
  325. BaseboardSN: "未填写",
  326. MacAddr: utils.ToString((*applications)[0].LicInfo.OAMainMAC),
  327. DiskID: "未填写",
  328. IPAddr: "未填写",
  329. }
  330. LicType := utils.SwitchLicenseType(utils.ToString((*applications)[0].LicInfo.OAProductVersion))
  331. lI := license.LicenseInfo{
  332. GenDate: "2024-07-15",
  333. ExpireDate: "9999-12-31",
  334. LicenseType: LicType,
  335. LicenseVersion: 1,
  336. HardType: 3,
  337. }
  338. //这里调用的是license模块中的生成license的方法
  339. res := false
  340. if res {
  341. if (*applications)[0].LicInfo.OASecondMAC.String != "" {
  342. // var licStr2 []byte
  343. // ei.MacAddr = applications[0].SecondaryMasterMacAddress
  344. // licStr2 = license.GenerateLicense(pj, ei, lI)
  345. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), []byte("b4j6z4rE2IfG1av0wIPT7YnvyGZFHxwIBikMGjgCLQILR0xsT1NHiuzoi+Dqq+bmiNDEiuPyitDVgdvlRmYbFAk+MAAGASlPTkdMbE9"), []byte("b4j6z4rE2IfG1av0wIPT7YnvyGZFHxwIBikMGjgCLQILR0xsT1NHiuzoi+Dqq+bmiNDEiuPyitDVgdvlRmYbFAk+MAAGASlPTkdMbE9"))
  346. if err != nil {
  347. global.Logger.Errorln("LicenseInfo生成插入失败: ", err.Error())
  348. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  349. return errors.Errorf("LicenseInfo生成插入失败:: ", err.Error())
  350. }
  351. } else {
  352. //fmt.Println("licStr licStr2", licStr, licStr2)
  353. //插入到数据库
  354. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), []byte("b4j6z4rE2IfG1av0wIPT7YnvyGZFHxwIBikMGjgCLQILR0xsT1NHiuzoi+Dqq+bmiNDEiuPyitDVgdvlRmYbFAk+MAAGASlPTkdMbE9"), nil)
  355. if err != nil {
  356. global.Logger.Errorln("LicenseInfo2生成插入失败: ", err.Error())
  357. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  358. return errors.Errorf("LicenseInfo2生成插入失败:: ", err.Error())
  359. }
  360. }
  361. } else {
  362. licStr := license.GenerateLicense(pj, ei, lI)
  363. //生成副主节点license
  364. if (*applications)[0].LicInfo.OASecondMAC.String != "" {
  365. var licStr2 []byte
  366. ei.MacAddr = (*applications)[0].LicInfo.OASecondMAC.String
  367. licStr2 = license.GenerateLicense(pj, ei, lI)
  368. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), licStr, licStr2)
  369. if err != nil {
  370. global.Logger.Errorln("LicenseInfo2生成插入失败: ", err.Error())
  371. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  372. return errors.Errorf("LicenseInfo2生成插入失败:: ", err.Error())
  373. }
  374. } else {
  375. //插入到数据库
  376. err = models.UpdateOALicenseStr(utils.ToString((*applications)[0].LicInfo.UniqueID), licStr, nil)
  377. if err != nil {
  378. global.Logger.Errorln("LicenseInfo生成插入失败: ", err.Error())
  379. // c.JSON(http.StatusBadRequest, gin.H{"error": fmt.Sprintf("数据查询失败: ", err.Error())})
  380. return errors.Errorf("LicenseInfo生成插入失败:: ", err.Error())
  381. }
  382. }
  383. }
  384. //---------------------
  385. return nil
  386. }