report_v2.go 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/models"
  5. "eta/eta_api/models/report"
  6. "eta/eta_api/models/report_approve"
  7. "eta/eta_api/models/smart_report"
  8. "eta/eta_api/models/system"
  9. "eta/eta_api/services"
  10. "eta/eta_api/services/alarm_msg"
  11. "eta/eta_api/utils"
  12. "fmt"
  13. "github.com/rdlucklib/rdluck_tools/paging"
  14. "html"
  15. "strconv"
  16. "time"
  17. )
  18. // ListReport
  19. // @Title 获取报告列表接口
  20. // @Description 获取报告列表
  21. // @Param PageSize query int true "每页数据条数"
  22. // @Param CurrentIndex query int true "当前页页码,从1开始"
  23. // @Param TimeType query string true "筛选的时间类别:publish_time(发布时间),modify_time(更新时间);approve_time(审批时间)"
  24. // @Param StartDate query string true "开始时间"
  25. // @Param EndDate query string true "结束时间"
  26. // @Param Frequency query string true "频度"
  27. // @Param ClassifyIdFirst query int true "一级分类id"
  28. // @Param ClassifyIdSecond query int true "二级分类id"
  29. // @Param ClassifyIdThird query int true "三级分类id"
  30. // @Param State query int true "状态"
  31. // @Param KeyWord query string true "搜索关键词"
  32. // @Param PublishSort query string true "desc:降序,asc 升序(预留)"
  33. // @Param FilterReportType query string true "筛选报告类型,1:公共研报,2:共享研报,3:我的研报"
  34. // @Success 200 {object} models.ReportListResp
  35. // @router /list [get]
  36. func (this *ReportController) ListReport() {
  37. br := new(models.BaseResponse).Init()
  38. defer func() {
  39. this.Data["json"] = br
  40. this.ServeJSON()
  41. }()
  42. pageSize, _ := this.GetInt("PageSize")
  43. currentIndex, _ := this.GetInt("CurrentIndex")
  44. timeType := this.GetString("TimeType")
  45. startDate := this.GetString("StartDate")
  46. endDate := this.GetString("EndDate")
  47. frequency := this.GetString("Frequency")
  48. classifyIdFirst, _ := this.GetInt("ClassifyIdFirst", 0)
  49. classifyIdSecond, _ := this.GetInt("ClassifyIdSecond", 0)
  50. classifyIdThird, _ := this.GetInt("ClassifyIdThird", 0)
  51. state, _ := this.GetInt("State")
  52. keyWord := this.GetString("KeyWord")
  53. msgIsSend, _ := this.GetInt("MsgIsSend")
  54. filterReportType, _ := this.GetInt("FilterReportType", 1)
  55. var startSize int
  56. if pageSize <= 0 {
  57. pageSize = utils.PageSize20
  58. }
  59. if currentIndex <= 0 {
  60. currentIndex = 1
  61. }
  62. startSize = utils.StartIndex(currentIndex, pageSize)
  63. if timeType == "" {
  64. timeType = "publish_time"
  65. }
  66. if timeType != "publish_time" && timeType != "modify_time" && timeType != "approve_time" {
  67. br.Msg = "请选择正确的时间"
  68. br.ErrMsg = "请选择正确的时间"
  69. return
  70. }
  71. var condition string
  72. var pars []interface{}
  73. if keyWord != "" {
  74. condition += ` AND (a.title LIKE ? OR a.admin_real_name LIKE ? ) `
  75. pars = utils.GetLikeKeywordPars(pars, keyWord, 2)
  76. }
  77. if startDate != "" {
  78. condition += ` AND a.` + timeType + ` >= ? `
  79. pars = append(pars, startDate)
  80. }
  81. if endDate != "" {
  82. condition += ` AND a.` + timeType + ` <= ? `
  83. pars = append(pars, endDate)
  84. }
  85. if frequency != "" {
  86. condition += ` AND a.frequency = ? `
  87. pars = append(pars, frequency)
  88. }
  89. if classifyIdFirst > 0 {
  90. condition += ` AND a.classify_id_first = ? `
  91. pars = append(pars, classifyIdFirst)
  92. }
  93. if classifyIdSecond > 0 {
  94. condition += ` AND a.classify_id_second = ? `
  95. pars = append(pars, classifyIdSecond)
  96. }
  97. if classifyIdThird > 0 {
  98. condition += ` AND a.classify_id_third = ? `
  99. pars = append(pars, classifyIdSecond)
  100. }
  101. if state > 0 {
  102. condition += ` AND a.state = ? `
  103. pars = append(pars, state)
  104. }
  105. // 消息是否已推送 1-未推送; 2-已推送
  106. if msgIsSend == 1 {
  107. condition += ` AND (a.msg_is_send = 0 OR a.ths_msg_is_send = 0) `
  108. }
  109. if msgIsSend == 2 {
  110. condition += ` AND a.msg_is_send = 1 AND a.ths_msg_is_send = 1 `
  111. }
  112. var err error
  113. var total int
  114. var list []*models.ReportList
  115. switch filterReportType {
  116. // 筛选报告类型,1:公共研报,2:共享研报,3:我的研报
  117. case 1:
  118. //condition += ` AND a.is_public_publish = ? `
  119. condition += ` AND a.state in (2,6) `
  120. pars = append(pars, 1)
  121. case 3:
  122. condition += ` AND a.admin_id = ? `
  123. pars = append(pars, this.SysUser.AdminId)
  124. case 2:
  125. condition += ` AND (a.admin_id = ? or b.admin_id = ?) `
  126. pars = append(pars, this.SysUser.AdminId, this.SysUser.AdminId)
  127. }
  128. // 共享报告需要连表查询,所以需要单独写
  129. if filterReportType == 2 {
  130. total, err = models.GetReportListCountByGrant(condition, pars)
  131. if err != nil {
  132. br.Msg = "获取失败"
  133. br.ErrMsg = "获取失败,Err:" + err.Error()
  134. return
  135. }
  136. list, err = models.GetReportListByGrant(condition, pars, startSize, pageSize)
  137. if err != nil {
  138. br.Msg = "获取失败"
  139. br.ErrMsg = "获取失败,Err:" + err.Error()
  140. return
  141. }
  142. } else {
  143. total, err = models.GetReportListCountV1(condition, pars)
  144. if err != nil {
  145. br.Msg = "获取失败"
  146. br.ErrMsg = "获取失败,Err:" + err.Error()
  147. return
  148. }
  149. list, err = models.GetReportListV1(condition, pars, startSize, pageSize)
  150. if err != nil {
  151. br.Msg = "获取失败"
  152. br.ErrMsg = "获取失败,Err:" + err.Error()
  153. return
  154. }
  155. }
  156. listLen := len(list)
  157. if listLen > 0 {
  158. pvMap := make(map[int]int)
  159. uvMap := make(map[int]int)
  160. reportIdArr := make([]string, 0)
  161. syncReportIdArr := make([]string, 0) // 同步过来的报告IDs
  162. oldAndNewReportIdMap := make(map[int]int) // 旧报告和新报告的id对应关系
  163. for i := 0; i < listLen; i++ {
  164. reportIdArr = append(reportIdArr, strconv.Itoa(list[i].Id))
  165. if list[i].OldReportId > 0 {
  166. syncReportIdArr = append(syncReportIdArr, strconv.Itoa(list[i].OldReportId))
  167. oldAndNewReportIdMap[list[i].OldReportId] = list[i].Id
  168. }
  169. pvMap[list[i].Id] = list[i].Pv
  170. uvMap[list[i].Id] = list[i].Uv
  171. }
  172. // 当下报告的pv,uv
  173. if len(reportIdArr) > 0 {
  174. pvList, e := models.GetReportPvUvByReportIdList(reportIdArr)
  175. if e != nil {
  176. br.Msg = "获取失败"
  177. br.ErrMsg = "获取同步报告对应的PV、UV失败, Err: " + e.Error()
  178. return
  179. }
  180. for _, v := range pvList {
  181. pv := pvMap[v.ReportId]
  182. uv := uvMap[v.ReportId]
  183. pvMap[v.ReportId] = v.PvTotal + pv
  184. uvMap[v.ReportId] = v.UvTotal + uv
  185. }
  186. }
  187. //reportIds := strings.Join(reportIdArr, ",")
  188. //syncReportIds := strings.Join(syncReportIdArr, ",")
  189. // 查询同步过来的报告对应的老报告PV+UV
  190. if len(syncReportIdArr) > 0 {
  191. puvList, e := models.GetPUVByResearchReportIds(syncReportIdArr)
  192. if e != nil {
  193. br.Msg = "获取失败"
  194. br.ErrMsg = "获取同步报告对应的PV、UV失败, Err: " + e.Error()
  195. return
  196. }
  197. puvLen := len(puvList)
  198. for i := 0; i < puvLen; i++ {
  199. newReportId, ok := oldAndNewReportIdMap[puvList[i].ResearchReportId]
  200. if ok {
  201. pv := pvMap[newReportId]
  202. uv := uvMap[newReportId]
  203. pvMap[newReportId] = puvList[i].Pv + pv
  204. uvMap[newReportId] = puvList[i].Uv + uv
  205. }
  206. }
  207. }
  208. // 晨周报音频列表
  209. videoList, err := models.GetReportChapterVideoListByReportIds(reportIdArr)
  210. if err != nil {
  211. br.Msg = "获取失败"
  212. br.ErrMsg = "获取报告音频文件失败,Err:" + err.Error()
  213. return
  214. }
  215. for i := 0; i < listLen; i++ {
  216. list[i].Content = html.UnescapeString(list[i].Content)
  217. list[i].ContentSub = html.UnescapeString(list[i].ContentSub)
  218. // 除周报外其余报告均可推送客群
  219. list[i].NeedThsMsg = 1
  220. //if list[i].HasChapter == 1 && list[i].ChapterType == utils.REPORT_TYPE_WEEK {
  221. // list[i].NeedThsMsg = 0
  222. //}
  223. chapterList := make([]*models.ReportChapterVideoList, 0)
  224. for ii := 0; ii < len(videoList); ii++ {
  225. if list[i].Id == videoList[ii].ReportId {
  226. chapterList = append(chapterList, videoList[ii])
  227. }
  228. }
  229. list[i].ChapterVideoList = chapterList
  230. list[i].Pv += pvMap[list[i].Id]
  231. list[i].Uv += uvMap[list[i].Id]
  232. }
  233. }
  234. for _, item := range list {
  235. /*key := fmt.Sprint(`crm:report:edit:`, item.Id)
  236. opUserId, _ := utils.Rc.RedisInt(key)
  237. //如果当前没有人操作,获取当前操作人是本人,那么编辑按钮可用
  238. if opUserId <= 0 || (opUserId == this.SysUser.AdminId) || item.ClassifyNameFirst == "周报" || item.ClassifyNameFirst == "晨报" {
  239. item.CanEdit = true
  240. } else {
  241. adminInfo, errAdmin := system.GetSysUserById(opUserId)
  242. if errAdmin != nil {
  243. br.Msg = "获取失败"
  244. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  245. return
  246. }
  247. item.Editor = adminInfo.RealName
  248. }*/
  249. if item.HasChapter == 1 {
  250. item.CanEdit = true
  251. continue
  252. }
  253. markStatus, err := services.UpdateReportEditMark(item.Id, 0, this.SysUser.AdminId, 2, this.SysUser.RealName, this.Lang)
  254. if err != nil {
  255. br.Msg = "查询标记状态失败"
  256. br.ErrMsg = "查询标记状态失败,Err:" + err.Error()
  257. return
  258. }
  259. if markStatus.Status == 0 {
  260. item.CanEdit = true
  261. } else {
  262. item.Editor = markStatus.Editor
  263. }
  264. }
  265. page := paging.GetPaging(currentIndex, pageSize, total)
  266. resp := new(models.ReportListResp)
  267. resp.Paging = page
  268. resp.List = list
  269. br.Ret = 200
  270. br.Success = true
  271. br.Msg = "获取成功"
  272. br.Data = resp
  273. }
  274. // Add
  275. // @Title 新增报告接口
  276. // @Description 新增报告(不区分报告类型)
  277. // @Param request body models.AddReq true "type json string"
  278. // @Success 200 {object} models.AddResp
  279. // @router /add [post]
  280. func (this *ReportController) Add() {
  281. br := new(models.BaseResponse).Init()
  282. defer func() {
  283. this.Data["json"] = br
  284. this.ServeJSON()
  285. }()
  286. sysUser := this.SysUser
  287. if sysUser == nil {
  288. br.Msg = "请登录"
  289. br.ErrMsg = "请登录,SysUser Is Empty"
  290. br.Ret = 408
  291. return
  292. }
  293. var req models.AddReq
  294. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  295. if err != nil {
  296. br.Msg = "参数解析异常!"
  297. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  298. return
  299. }
  300. if req.Title == `` {
  301. br.Msg = "标题不能为空"
  302. br.ErrMsg = "标题不能为空"
  303. br.IsSendEmail = false
  304. return
  305. }
  306. if req.ClassifyIdFirst <= 0 {
  307. br.Msg = "分类必填"
  308. br.ErrMsg = "分类必填"
  309. br.IsSendEmail = false
  310. return
  311. }
  312. var contentSub string
  313. if req.Content != "" {
  314. e := utils.ContentXssCheck(req.Content)
  315. if e != nil {
  316. br.Msg = "存在非法标签"
  317. br.ErrMsg = "存在非法标签, Err: " + e.Error()
  318. return
  319. }
  320. content, e := services.FilterReportContentBr(req.Content)
  321. if e != nil {
  322. br.Msg = "内容去除前后空格失败"
  323. br.ErrMsg = "内容去除前后空格失败, Err: " + e.Error()
  324. return
  325. }
  326. req.Content = content
  327. contentSub, err = services.GetReportContentSub(req.Content)
  328. if err != nil {
  329. go alarm_msg.SendAlarmMsg("ContentSub 失败,Err:"+err.Error(), 3)
  330. //utils.SendEmail(utils.APPNAME+"失败提醒", "解析 ContentSub 失败,Err:"+err.Error(), utils.EmailSendToUsers)
  331. }
  332. }
  333. // 报告期数
  334. maxStage, err := models.GetReportStage(req.ClassifyIdFirst, req.ClassifyIdSecond, req.ClassifyIdThird)
  335. if err != nil {
  336. br.Msg = "期数获取失败!"
  337. br.ErrMsg = "期数获取失败,Err:" + err.Error()
  338. return
  339. }
  340. // 根据审批开关及审批流判断当前报告状态
  341. state, e := services.CheckReportCurrState(report_approve.FlowReportTypeChinese, req.ClassifyIdFirst, req.ClassifyIdSecond, req.ClassifyIdThird, models.ReportOperateAdd)
  342. if e != nil {
  343. br.Msg = "操作失败"
  344. br.ErrMsg = "校验报告当前状态失败, Err: " + e.Error()
  345. return
  346. }
  347. // 协作方式,1:个人,2:多人协作。默认:1
  348. if req.CollaborateType == 0 {
  349. req.CollaborateType = 1
  350. }
  351. // 报告布局,1:常规布局,2:智能布局。默认:1
  352. if req.ReportLayout == 0 {
  353. req.ReportLayout = 1
  354. }
  355. // 是否公开发布,1:是,2:否
  356. if req.IsPublicPublish == 0 {
  357. req.IsPublicPublish = 1
  358. }
  359. item := new(models.Report)
  360. item.AddType = req.AddType
  361. item.ReportVersion = 2
  362. item.ClassifyIdFirst = req.ClassifyIdFirst
  363. item.ClassifyNameFirst = req.ClassifyNameFirst
  364. item.ClassifyIdSecond = req.ClassifyIdSecond
  365. item.ClassifyNameSecond = req.ClassifyNameSecond
  366. item.Title = req.Title
  367. item.Abstract = req.Abstract
  368. item.Author = req.Author
  369. item.Frequency = req.Frequency
  370. item.State = state
  371. item.Content = html.EscapeString(req.Content)
  372. item.Stage = maxStage + 1
  373. item.ContentSub = html.EscapeString(contentSub)
  374. item.CreateTime = req.CreateTime
  375. item.ModifyTime = time.Now()
  376. item.ReportVersion = req.ReportVersion
  377. item.AdminId = sysUser.AdminId
  378. item.AdminRealName = sysUser.RealName
  379. item.ClassifyIdThird = req.ClassifyIdThird
  380. item.ClassifyNameThird = req.ClassifyNameThird
  381. // 产品要求,如果是多人协作,那么就是章节类型的报告
  382. if req.CollaborateType == 2 {
  383. item.HasChapter = 1
  384. item.ChapterType = ""
  385. }
  386. item.LastModifyAdminId = sysUser.AdminId
  387. item.LastModifyAdminName = sysUser.RealName
  388. item.ContentModifyTime = time.Now()
  389. item.NeedSplice = 1
  390. item.ContentStruct = html.EscapeString(req.ContentStruct)
  391. item.HeadImg = req.HeadImg
  392. item.EndImg = req.EndImg
  393. item.CanvasColor = req.CanvasColor
  394. item.HeadResourceId = req.HeadResourceId
  395. item.EndResourceId = req.EndResourceId
  396. item.CollaborateType = req.CollaborateType
  397. item.ReportLayout = req.ReportLayout
  398. item.IsPublicPublish = req.IsPublicPublish
  399. item.ReportCreateTime = time.Now()
  400. err, errMsg := services.AddReportAndChapter(item, req.InheritReportId, req.GrantAdminIdList)
  401. if err != nil {
  402. br.Msg = "保存失败"
  403. if errMsg != "" {
  404. br.Msg = errMsg
  405. }
  406. br.ErrMsg = "保存失败,Err:" + err.Error()
  407. return
  408. }
  409. recordItem := &models.ReportStateRecord{
  410. ReportId: item.Id,
  411. ReportType: 1,
  412. State: 1,
  413. AdminId: this.SysUser.AdminId,
  414. AdminName: this.SysUser.AdminName,
  415. CreateTime: time.Now(),
  416. }
  417. go func() {
  418. _, _ = models.AddReportStateRecord(recordItem)
  419. }()
  420. resp := new(models.AddResp)
  421. resp.ReportId = int64(item.Id)
  422. resp.ReportCode = item.ReportCode
  423. br.Ret = 200
  424. br.Success = true
  425. br.Msg = "保存成功"
  426. br.Data = resp
  427. }
  428. // Edit
  429. // @Title 编辑报告基础信息接口
  430. // @Description 编辑报告基础信息(不区分报告类型)
  431. // @Param request body models.EditReq true "type json string"
  432. // @Success 200 {object} models.EditResp
  433. // @router /edit [post]
  434. func (this *ReportController) Edit() {
  435. br := new(models.BaseResponse).Init()
  436. defer func() {
  437. this.Data["json"] = br
  438. this.ServeJSON()
  439. }()
  440. sysUser := this.SysUser
  441. if sysUser == nil {
  442. br.Msg = "请登录"
  443. br.ErrMsg = "请登录,SysUser Is Empty"
  444. br.Ret = 408
  445. return
  446. }
  447. var req models.EditReq
  448. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  449. if err != nil {
  450. br.Msg = "参数解析异常!"
  451. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  452. return
  453. }
  454. //if req.Content == "" {
  455. // br.Msg = "报告内容不能为空"
  456. // return
  457. //}
  458. //更新标记key
  459. markStatus, err := services.UpdateReportEditMark(int(req.ReportId), 0, sysUser.AdminId, 1, sysUser.RealName, this.Lang)
  460. if err != nil {
  461. br.Msg = err.Error()
  462. return
  463. }
  464. if markStatus.Status == 1 {
  465. br.Msg = markStatus.Msg
  466. //br.Ret = 202 //202 服务器已接受请求,但尚未处理。
  467. return
  468. }
  469. reportInfo, e := models.GetReportByReportId(int(req.ReportId))
  470. if e != nil {
  471. if e.Error() == utils.ErrNoRow() {
  472. br.Msg = "报告已被删除, 请刷新页面"
  473. return
  474. }
  475. br.Msg = "操作失败"
  476. br.ErrMsg = "获取报告失败, Err: " + e.Error()
  477. return
  478. }
  479. if reportInfo.State == models.ReportStatePublished || reportInfo.State == models.ReportStatePass {
  480. br.Msg = "该报告已发布,不允许编辑"
  481. br.ErrMsg = "该报告已发布,不允许编辑"
  482. return
  483. }
  484. // 编辑报告信息
  485. err, errMsg := services.EditReport(reportInfo, req, sysUser)
  486. if err != nil {
  487. br.Msg = "保存失败"
  488. if errMsg != "" {
  489. br.Msg = errMsg
  490. }
  491. br.ErrMsg = "保存失败,Err:" + err.Error()
  492. return
  493. }
  494. reportCode := utils.MD5(strconv.Itoa(int(req.ReportId)))
  495. resp := new(models.EditResp)
  496. resp.ReportId = req.ReportId
  497. resp.ReportCode = reportCode
  498. br.Ret = 200
  499. br.Success = true
  500. br.Msg = "保存成功"
  501. br.Data = resp
  502. }
  503. // Detail
  504. // @Title 获取报告详情接口
  505. // @Description 获取报告详情
  506. // @Param request body models.ReportDetailReq true "type json string"
  507. // @Success 200 {object} models.Report
  508. // @router /detail [get]
  509. func (this *ReportController) Detail() {
  510. br := new(models.BaseResponse).Init()
  511. defer func() {
  512. this.Data["json"] = br
  513. this.ServeJSON()
  514. }()
  515. /*var req models.ReportDetailReq
  516. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  517. if err != nil {
  518. br.Msg = "参数解析异常!"
  519. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  520. return
  521. }
  522. if req.ReportId <= 0 {
  523. br.Msg = "参数错误"
  524. return
  525. }*/
  526. reportId, err := this.GetInt("ReportId")
  527. if err != nil {
  528. br.Msg = "获取参数失败!"
  529. br.ErrMsg = "获取参数失败,Err:" + err.Error()
  530. return
  531. }
  532. if reportId <= 0 {
  533. br.Msg = "参数错误"
  534. return
  535. }
  536. item, err := models.GetReportById(reportId)
  537. if err != nil {
  538. if err.Error() == utils.ErrNoRow() {
  539. br.Msg = "报告已被删除"
  540. return
  541. }
  542. br.Msg = "获取失败"
  543. br.ErrMsg = "获取失败,Err:" + err.Error()
  544. return
  545. }
  546. chapterList := make([]*models.ReportChapter, 0)
  547. if item.HasChapter == 1 {
  548. // 获取章节内容
  549. tmpChapterList, err := models.GetPublishedChapterListByReportId(item.Id)
  550. if err != nil {
  551. br.Msg = "获取失败"
  552. br.ErrMsg = "获取晨/周报章节列表失败, Err: " + err.Error()
  553. return
  554. }
  555. if len(tmpChapterList) > 0 {
  556. // 章节类型的字段赋值
  557. for _, item := range tmpChapterList {
  558. item.Content = html.UnescapeString(item.Content)
  559. item.ContentSub = html.UnescapeString(item.ContentSub)
  560. chapterList = append(chapterList, item)
  561. }
  562. }
  563. //item.Abstract = item.Title
  564. }
  565. item.Content = html.UnescapeString(item.Content)
  566. item.ContentSub = html.UnescapeString(item.ContentSub)
  567. item.ContentStruct = html.UnescapeString(item.ContentStruct)
  568. if item.HeadResourceId > 0 {
  569. headResource, err := smart_report.GetResourceItemById(item.HeadResourceId)
  570. if err != nil {
  571. br.Msg = "操作失败"
  572. br.ErrMsg = "获取资源库版头失败, Err: " + err.Error()
  573. return
  574. }
  575. item.HeadImg = headResource.ImgUrl
  576. item.HeadStyle = headResource.Style
  577. }
  578. if item.EndResourceId > 0 {
  579. endResource, err := smart_report.GetResourceItemById(item.EndResourceId)
  580. if err != nil {
  581. br.Msg = "操作失败"
  582. br.ErrMsg = "获取资源库版头失败, Err: " + err.Error()
  583. return
  584. }
  585. item.EndImg = endResource.ImgUrl
  586. item.EndStyle = endResource.Style
  587. }
  588. resp := &models.ReportDetailView{
  589. ReportDetail: item,
  590. ChapterList: chapterList,
  591. }
  592. br.Ret = 200
  593. br.Success = true
  594. br.Msg = "获取成功"
  595. br.Data = resp
  596. }
  597. // SaveReportContent
  598. // @Title 保存草稿
  599. // @Description 保存草稿
  600. // @Param request body models.SaveReportContent true "type json string"
  601. // @Success 200 {object} models.ReportAuthorResp
  602. // @router /saveReportContent [post]
  603. func (this *ReportController) SaveReportContent() {
  604. br := new(models.BaseResponse).Init()
  605. br.IsSendEmail = false
  606. defer func() {
  607. this.Data["json"] = br
  608. this.ServeJSON()
  609. }()
  610. sysUser := this.SysUser
  611. if sysUser == nil {
  612. br.Msg = "请登录"
  613. br.ErrMsg = "请登录,SysUser Is Empty"
  614. br.Ret = 408
  615. return
  616. }
  617. var req models.SaveReportContent
  618. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  619. if err != nil {
  620. br.Msg = "参数解析异常!"
  621. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  622. return
  623. }
  624. reportId := req.ReportId
  625. noChangeFlag := req.NoChange
  626. if reportId <= 0 {
  627. resp := new(models.SaveReportContentResp)
  628. resp.ReportId = reportId
  629. br.Ret = 200
  630. br.Success = true
  631. br.Msg = "保存成功"
  632. br.Data = resp
  633. return
  634. }
  635. // 获取报告详情
  636. reportInfo, _ := models.GetReportByReportId(int(req.ReportId))
  637. if reportInfo != nil && reportInfo.State == 2 {
  638. br.Msg = "该报告已发布,不允许编辑"
  639. br.ErrMsg = "该报告已发布,不允许编辑"
  640. return
  641. }
  642. // 标记更新中
  643. {
  644. markStatus, err := services.UpdateReportEditMark(int(req.ReportId), 0, sysUser.AdminId, 1, sysUser.RealName, this.Lang)
  645. if err != nil {
  646. br.Msg = err.Error()
  647. return
  648. }
  649. if markStatus.Status == 1 {
  650. br.Msg = markStatus.Msg
  651. return
  652. }
  653. }
  654. // 内容有过修改的话,那么逻辑处理
  655. if noChangeFlag != 1 {
  656. content := req.Content
  657. if content == "" {
  658. content = this.GetString("Content")
  659. }
  660. if content != "" {
  661. e := utils.ContentXssCheck(req.Content)
  662. if e != nil {
  663. br.Msg = "存在非法标签"
  664. br.ErrMsg = "存在非法标签, Err: " + e.Error()
  665. return
  666. }
  667. contentClean, e := services.FilterReportContentBr(req.Content)
  668. if e != nil {
  669. br.Msg = "内容去除前后空格失败"
  670. br.ErrMsg = "内容去除前后空格失败, Err: " + e.Error()
  671. return
  672. }
  673. content = contentClean
  674. contentSub, err := services.GetReportContentSub(content)
  675. if err != nil {
  676. go alarm_msg.SendAlarmMsg("解析 ContentSub 失败,Err:"+err.Error(), 3)
  677. //utils.SendEmail(utils.APPNAME+"失败提醒", "解析 ContentSub 失败,Err:"+err.Error(), utils.EmailSendToUsers)
  678. }
  679. reportInfo.Content = html.EscapeString(content)
  680. reportInfo.ContentSub = html.EscapeString(contentSub)
  681. reportInfo.ContentStruct = html.EscapeString(req.ContentStruct)
  682. reportInfo.HeadImg = req.HeadImg
  683. reportInfo.EndImg = req.EndImg
  684. reportInfo.CanvasColor = req.CanvasColor
  685. reportInfo.HeadResourceId = req.HeadResourceId
  686. reportInfo.EndResourceId = req.EndResourceId
  687. reportInfo.ModifyTime = time.Now()
  688. reportInfo.ContentModifyTime = time.Now()
  689. updateCols := []string{"Content", "ContentSub", "ContentStruct", "HeadImg", "EndImg", "CanvasColor", "HeadResourceId", "EndResourceId", "ModifyTime", "ContentModifyTime"}
  690. err = reportInfo.UpdateReport(updateCols)
  691. if err != nil {
  692. br.Msg = "保存失败"
  693. br.ErrMsg = "保存失败,Err:" + err.Error()
  694. return
  695. }
  696. go models.AddReportSaveLog(reportId, this.SysUser.AdminId, reportInfo.Content, reportInfo.ContentSub, reportInfo.ContentStruct, reportInfo.CanvasColor, this.SysUser.AdminName, reportInfo.HeadResourceId, reportInfo.EndResourceId)
  697. }
  698. }
  699. resp := new(models.SaveReportContentResp)
  700. resp.ReportId = reportId
  701. br.Ret = 200
  702. br.Success = true
  703. br.Msg = "保存成功"
  704. br.Data = resp
  705. }
  706. // AuthorizedListReport
  707. // @Title 获取有权限的报告列表接口
  708. // @Description 获取有权限的报告列表接口
  709. // @Param PageSize query int true "每页数据条数"
  710. // @Param CurrentIndex query int true "当前页页码,从1开始"
  711. // @Param Keyword query string true "搜索关键词"
  712. // @Param ClassifyIdFirst query int true "一级分类id"
  713. // @Param ClassifyIdSecond query int true "二级分类id"
  714. // @Param ClassifyIdThird query int true "三级分类id"
  715. // @Success 200 {object} models.ReportListResp
  716. // @router /list/authorized [get]
  717. func (this *ReportController) AuthorizedListReport() {
  718. br := new(models.BaseResponse).Init()
  719. defer func() {
  720. this.Data["json"] = br
  721. this.ServeJSON()
  722. }()
  723. pageSize, _ := this.GetInt("PageSize")
  724. currentIndex, _ := this.GetInt("CurrentIndex")
  725. keyword := this.GetString("Keyword")
  726. classifyIdFirst, _ := this.GetInt("ClassifyIdFirst", 0)
  727. classifyIdSecond, _ := this.GetInt("ClassifyIdSecond", 0)
  728. classifyIdThird, _ := this.GetInt("ClassifyIdThird", 0)
  729. var startSize int
  730. if pageSize <= 0 {
  731. pageSize = utils.PageSize20
  732. }
  733. if currentIndex <= 0 {
  734. currentIndex = 1
  735. }
  736. startSize = utils.StartIndex(currentIndex, pageSize)
  737. var list []*models.ReportList
  738. // 没有输入信息,那就不展示
  739. if keyword == `` && classifyIdFirst <= 0 {
  740. page := paging.GetPaging(currentIndex, pageSize, 0)
  741. resp := new(models.ReportListResp)
  742. resp.Paging = page
  743. resp.List = list
  744. br.Ret = 200
  745. br.Success = true
  746. br.Msg = "获取成功"
  747. br.Data = resp
  748. return
  749. }
  750. // 当前用户有权限的报告id列表
  751. grantReportIdList := make([]int, 0)
  752. {
  753. obj := report.ReportGrant{}
  754. grantList, err := obj.GetGrantListByAdminId(this.SysUser.AdminId)
  755. if err != nil {
  756. br.Msg = "获取失败"
  757. br.ErrMsg = "获取授权报告id失败,Err:" + err.Error()
  758. return
  759. }
  760. for _, v := range grantList {
  761. grantReportIdList = append(grantReportIdList, v.ReportId)
  762. }
  763. }
  764. var condition string
  765. var pars []interface{}
  766. if classifyIdFirst > 0 {
  767. condition += ` AND a.classify_id_first = ? `
  768. pars = append(pars, classifyIdFirst)
  769. }
  770. if classifyIdSecond > 0 {
  771. condition += ` AND a.classify_id_second = ? `
  772. pars = append(pars, classifyIdSecond)
  773. }
  774. if classifyIdThird > 0 {
  775. condition += ` AND a.classify_id_third = ? `
  776. pars = append(pars, classifyIdSecond)
  777. }
  778. if keyword != `` {
  779. condition += ` AND a.title LIKE ? `
  780. pars = utils.GetLikeKeywordPars(pars, keyword, 1)
  781. }
  782. var err error
  783. var total int
  784. orCondition := `AND ( (a.is_public_publish = ? AND a.state in (2,6)) or a.admin_id = ? `
  785. pars = append(pars, 1, this.SysUser.AdminId)
  786. // 当前用户有权限的报告id列表
  787. num := len(grantReportIdList)
  788. if num > 0 {
  789. orCondition += ` OR a.id in (` + utils.GetOrmInReplace(num) + `)`
  790. pars = append(pars, grantReportIdList)
  791. }
  792. orCondition += ` ) `
  793. condition += orCondition
  794. total, err = models.GetReportListCountByAuthorized(condition, pars)
  795. if err != nil {
  796. br.Msg = "获取失败"
  797. br.ErrMsg = "获取失败,Err:" + err.Error()
  798. return
  799. }
  800. list, err = models.GetReportListByAuthorized(condition, pars, startSize, pageSize)
  801. if err != nil {
  802. br.Msg = "获取失败"
  803. br.ErrMsg = "获取失败,Err:" + err.Error()
  804. return
  805. }
  806. //for _, item := range list {
  807. // if item.HasChapter == 1 {
  808. // item.CanEdit = true
  809. // } else {
  810. // markStatus, err := services.UpdateReportEditMark(item.Id, this.SysUser.AdminId, 2, this.SysUser.RealName, this.Lang)
  811. // if err != nil {
  812. // br.Msg = "查询标记状态失败"
  813. // br.ErrMsg = "查询标记状态失败,Err:" + err.Error()
  814. // return
  815. // }
  816. // if markStatus.Status == 0 {
  817. // item.CanEdit = true
  818. // } else {
  819. // item.Editor = markStatus.Editor
  820. // }
  821. // }
  822. //}
  823. page := paging.GetPaging(currentIndex, pageSize, total)
  824. resp := new(models.ReportListResp)
  825. resp.Paging = page
  826. resp.List = list
  827. br.Ret = 200
  828. br.Success = true
  829. br.Msg = "获取成功"
  830. br.Data = resp
  831. }
  832. // BaseDetail
  833. // @Title 获取报告基础信息详情接口
  834. // @Description 获取报告基础信息详情接口
  835. // @Param request body models.ReportDetailReq true "type json string"
  836. // @Success 200 {object} models.Report
  837. // @router /detail/base [get]
  838. func (this *ReportController) BaseDetail() {
  839. br := new(models.BaseResponse).Init()
  840. defer func() {
  841. this.Data["json"] = br
  842. this.ServeJSON()
  843. }()
  844. /*var req models.ReportDetailReq
  845. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  846. if err != nil {
  847. br.Msg = "参数解析异常!"
  848. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  849. return
  850. }
  851. if req.ReportId <= 0 {
  852. br.Msg = "参数错误"
  853. return
  854. }*/
  855. reportId, err := this.GetInt("ReportId")
  856. if err != nil {
  857. br.Msg = "获取参数失败!"
  858. br.ErrMsg = "获取参数失败,Err:" + err.Error()
  859. return
  860. }
  861. if reportId <= 0 {
  862. br.Msg = "参数错误"
  863. return
  864. }
  865. reportInfo, err := models.GetReportById(reportId)
  866. if err != nil {
  867. if err.Error() == utils.ErrNoRow() {
  868. br.Msg = "报告已被删除"
  869. return
  870. }
  871. br.Msg = "获取失败"
  872. br.ErrMsg = "获取失败,Err:" + err.Error()
  873. return
  874. }
  875. // 基础信息就不获取章节信息了
  876. chapterList := make([]*models.ReportChapter, 0)
  877. reportInfo.Content = html.UnescapeString(reportInfo.Content)
  878. reportInfo.ContentSub = html.UnescapeString(reportInfo.ContentSub)
  879. grandAdminList := make([]models.ReportDetailViewAdmin, 0)
  880. permissionList := make([]models.ReportDetailViewPermission, 0)
  881. // 处理报告授权用户列表
  882. {
  883. obj := report.ReportGrant{}
  884. grantList, tmpErr := obj.GetGrantListById(reportId)
  885. if tmpErr != nil {
  886. br.Msg = "获取章节id授权用户列表失败"
  887. br.ErrMsg = "获取章节id授权用户列表失败, Err: " + tmpErr.Error()
  888. return
  889. }
  890. if len(grantList) > 0 {
  891. grandAdminIdList := make([]int, 0)
  892. for _, v := range grantList {
  893. grandAdminIdList = append(grandAdminIdList, v.AdminId)
  894. }
  895. adminList, tmpErr := system.GetAdminListByIdList(grandAdminIdList)
  896. if tmpErr != nil {
  897. br.Msg = "获取章节id授权用户列表失败"
  898. br.ErrMsg = "获取章节id授权用户列表失败, Err: " + tmpErr.Error()
  899. return
  900. }
  901. for _, v := range adminList {
  902. grandAdminList = append(grandAdminList, models.ReportDetailViewAdmin{
  903. AdminId: v.AdminId,
  904. AdminName: v.RealName,
  905. })
  906. }
  907. }
  908. }
  909. // 处理章节id关联品种id列表
  910. {
  911. minClassifyId := reportInfo.ClassifyIdThird
  912. if minClassifyId <= 0 {
  913. minClassifyId = reportInfo.ClassifyIdSecond
  914. }
  915. if minClassifyId <= 0 {
  916. minClassifyId = reportInfo.ClassifyIdFirst
  917. }
  918. if minClassifyId <= 0 {
  919. br.Msg = "分类异常"
  920. br.ErrMsg = "分类异常"
  921. return
  922. }
  923. // 获取分类关联的品种id
  924. classifyPermissionList, tmpErr := models.GetPermission(minClassifyId)
  925. if tmpErr != nil {
  926. br.Msg = "获取分类信息失败"
  927. br.ErrMsg = "获取失败,Err:" + tmpErr.Error()
  928. return
  929. }
  930. if len(classifyPermissionList) > 0 {
  931. permissionIdList := make([]int, 0)
  932. for _, v := range classifyPermissionList {
  933. permissionIdList = append(permissionIdList, v.ChartPermissionId)
  934. }
  935. adminList, tmpErr := models.GetChartPermissionByIdList(permissionIdList)
  936. if tmpErr != nil {
  937. br.Msg = "获取章节id授权用户列表失败"
  938. br.ErrMsg = "获取章节id授权用户列表失败, Err: " + tmpErr.Error()
  939. return
  940. }
  941. for _, v := range adminList {
  942. permissionList = append(permissionList, models.ReportDetailViewPermission{
  943. PermissionId: v.ChartPermissionId,
  944. PermissionName: v.ChartPermissionName,
  945. })
  946. }
  947. }
  948. }
  949. resp := &models.ReportDetailView{
  950. ReportDetail: reportInfo,
  951. ChapterList: chapterList,
  952. GrandAdminList: grandAdminList,
  953. PermissionList: permissionList,
  954. }
  955. br.Ret = 200
  956. br.Success = true
  957. br.Msg = "获取成功"
  958. br.Data = resp
  959. }
  960. // EditLayoutImg
  961. // @Title 版图设置接口
  962. // @Description 版图设置接口
  963. // @Param request body models.EditLayoutImgReq true "type json string"
  964. // @Success 200 {object} models.EditResp
  965. // @router /layout_img/edit [post]
  966. func (this *ReportController) EditLayoutImg() {
  967. br := new(models.BaseResponse).Init()
  968. defer func() {
  969. this.Data["json"] = br
  970. this.ServeJSON()
  971. }()
  972. sysUser := this.SysUser
  973. if sysUser == nil {
  974. br.Msg = "请登录"
  975. br.ErrMsg = "请登录,SysUser Is Empty"
  976. br.Ret = 408
  977. return
  978. }
  979. var req models.EditLayoutImgReq
  980. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  981. if err != nil {
  982. br.Msg = "参数解析异常!"
  983. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  984. return
  985. }
  986. //if req.Content == "" {
  987. // br.Msg = "报告内容不能为空"
  988. // return
  989. //}
  990. //更新标记key
  991. markStatus, err := services.UpdateReportEditMark(int(req.ReportId), 0, sysUser.AdminId, 1, sysUser.RealName, this.Lang)
  992. if err != nil {
  993. br.Msg = err.Error()
  994. return
  995. }
  996. if markStatus.Status == 1 {
  997. br.Msg = markStatus.Msg
  998. //br.Ret = 202 //202 服务器已接受请求,但尚未处理。
  999. return
  1000. }
  1001. reportInfo, e := models.GetReportByReportId(int(req.ReportId))
  1002. if e != nil {
  1003. if e.Error() == utils.ErrNoRow() {
  1004. br.Msg = "报告已被删除, 请刷新页面"
  1005. return
  1006. }
  1007. br.Msg = "操作失败"
  1008. br.ErrMsg = "获取报告失败, Err: " + e.Error()
  1009. return
  1010. }
  1011. if reportInfo.State == models.ReportStatePublished || reportInfo.State == models.ReportStatePass {
  1012. br.Msg = "该报告已发布,不允许编辑"
  1013. br.ErrMsg = "该报告已发布,不允许编辑"
  1014. return
  1015. }
  1016. // 编辑报告信息
  1017. err, errMsg := services.EditReportLayoutImg(reportInfo, req, sysUser)
  1018. if err != nil {
  1019. br.Msg = "保存失败"
  1020. if errMsg != "" {
  1021. br.Msg = errMsg
  1022. }
  1023. br.ErrMsg = "保存失败,Err:" + err.Error()
  1024. return
  1025. }
  1026. reportCode := utils.MD5(strconv.Itoa(int(req.ReportId)))
  1027. resp := new(models.EditResp)
  1028. resp.ReportId = req.ReportId
  1029. resp.ReportCode = reportCode
  1030. br.Ret = 200
  1031. br.Success = true
  1032. br.Msg = "保存成功"
  1033. br.Data = resp
  1034. }
  1035. // init
  1036. // @Description: 修复历史报告数据
  1037. // @author: Roc
  1038. // @datetime 2024-06-21 09:19:05
  1039. func init() {
  1040. //fixApproveRecord()
  1041. //fixChapterPermission()
  1042. //fixReportEs()
  1043. }
  1044. // 修复研报审批数据
  1045. func fixApproveRecord() {
  1046. recordOb := new(report_approve.ReportApproveRecord)
  1047. recordCond := fmt.Sprintf(` AND %s = ? AND %s in (?,?)`, report_approve.ReportApproveRecordCols.NodeType, report_approve.ReportApproveRecordCols.State)
  1048. recordPars := make([]interface{}, 0)
  1049. recordPars = append(recordPars, 0, report_approve.ReportApproveStatePass, report_approve.ReportApproveStateRefuse)
  1050. list, e := recordOb.GetItemsByCondition(recordCond, recordPars, []string{}, "")
  1051. if e != nil {
  1052. fmt.Println("查找审批记录失败,Err:", e.Error())
  1053. return
  1054. }
  1055. for _, recordItem := range list {
  1056. //fmt.Println(recordItem)
  1057. recordItem.NodeState = report_approve.ReportApproveStatePass
  1058. recordItem.NodeApproveUserId = recordItem.ApproveUserId
  1059. recordItem.NodeApproveUserName = recordItem.ApproveUserName
  1060. recordItem.NodeApproveTime = recordItem.ApproveTime
  1061. // 如果不是或签,那么只需要修复自己就好了
  1062. if recordItem.ApproveType != report_approve.NodeApproveTypeAny {
  1063. recordCols := []string{"State", "ApproveTime", "ModifyTime", "NodeState", "NodeApproveUserId", "NodeApproveUserName", "NodeApproveTime"}
  1064. if e = recordItem.Update(recordCols); e != nil {
  1065. fmt.Println("更新审批记录状态失败,Err:", e.Error())
  1066. }
  1067. continue
  1068. }
  1069. // 或签
  1070. // 需要将该审批的同一个节点的记录标记为已审批
  1071. if e := recordItem.UpdateNodeState(recordItem.ReportApproveId, recordItem.NodeId, recordItem.NodeState, recordItem.NodeApproveUserId, recordItem.NodeApproveUserName, recordItem.NodeApproveTime); e != nil {
  1072. fmt.Println("更新同一节点的其他审批记录状态失败,Err:", e.Error())
  1073. }
  1074. }
  1075. fmt.Println("审批数据修复完成")
  1076. }
  1077. // fixChapterPermission
  1078. // @Description: 修复章节关联的品种权限
  1079. // @author: Roc
  1080. // @datetime 2024-06-20 18:08:34
  1081. func fixChapterPermission() {
  1082. allChapterTypePermissionList, err := models.GetAllChapterTypePermission()
  1083. if err != nil {
  1084. fmt.Println("获取所有章节类型ID获取章节类型权限列表失败,Err:", err.Error())
  1085. return
  1086. }
  1087. currChapterTypePermissionIdListMap := make(map[int][]int)
  1088. hasPermissionMap := make(map[string]bool)
  1089. for _, v := range allChapterTypePermissionList {
  1090. tmpChapterTypePermissionList, ok := currChapterTypePermissionIdListMap[v.ReportChapterTypeId]
  1091. if !ok {
  1092. tmpChapterTypePermissionList = make([]int, 0)
  1093. }
  1094. key := fmt.Sprint(v.ReportChapterTypeId, "-", v.ChartPermissionId)
  1095. if _, has := hasPermissionMap[key]; !has {
  1096. hasPermissionMap[key] = true
  1097. currChapterTypePermissionIdListMap[v.ReportChapterTypeId] = append(tmpChapterTypePermissionList, v.ChartPermissionId)
  1098. }
  1099. }
  1100. notIdList := []int{9675, 9675, 9740, 9749, 9768, 9773, 9791, 9792, 9793, 9850, 9851, 9852, 9852, 9852, 9853, 9854, 9856, 9857, 9857, 9858, 9859, 9860, 9861, 9862, 9862, 9863, 9866}
  1101. allReportChapterList, err := models.GetAllReportChapter()
  1102. if err != nil {
  1103. fmt.Println("获取所有章节失败,Err:", err.Error())
  1104. return
  1105. }
  1106. addList := make([]*report.ReportChapterPermissionMapping, 0)
  1107. for _, v := range allReportChapterList {
  1108. // 如果是上面的章节id,那么就过滤掉,因为已经入库了
  1109. if utils.InArrayByInt(notIdList, v.ReportChapterId) {
  1110. continue
  1111. }
  1112. permissionIdList, ok := currChapterTypePermissionIdListMap[v.TypeId]
  1113. if !ok {
  1114. continue
  1115. }
  1116. for _, permissionId := range permissionIdList {
  1117. addList = append(addList, &report.ReportChapterPermissionMapping{
  1118. ReportChapterPermissionMappingId: 0,
  1119. ReportChapterId: v.ReportChapterId,
  1120. ChartPermissionId: permissionId,
  1121. CreateTime: v.ModifyTime,
  1122. })
  1123. }
  1124. }
  1125. obj := report.ReportChapterPermissionMapping{}
  1126. err = obj.MultiAdd(addList)
  1127. if err != nil {
  1128. fmt.Println("批量添加报章节的品种权限失败,Err:", err.Error())
  1129. }
  1130. return
  1131. }
  1132. // fixReportEs
  1133. // @Description: 修复报告es数据
  1134. // @author: Roc
  1135. // @datetime 2024-06-20 18:08:34
  1136. func fixReportEs() {
  1137. //reportInfo, err := models.GetReportByReportId(3941)
  1138. //if err != nil {
  1139. // fmt.Println("查询信息失败,", err)
  1140. // return
  1141. //}
  1142. //content := utils.TrimHtml(html.UnescapeString(reportInfo.Content))
  1143. //fmt.Println(content)
  1144. //
  1145. //fmt.Println("=========================")
  1146. //
  1147. //chapterInfo, err := models.GetReportChapterInfoById(9637)
  1148. //if err != nil {
  1149. // fmt.Println("查询信息失败2,", err)
  1150. // return
  1151. //}
  1152. //
  1153. //content = utils.TrimHtml(html.UnescapeString(chapterInfo.Content))
  1154. //fmt.Println(content)
  1155. //
  1156. //services.UpdateReportChapterEs(9637)
  1157. //return
  1158. var condition string
  1159. var pars []interface{}
  1160. condition += " AND state in (2,6) "
  1161. list, err := models.GetReportListV1(condition, pars, 0, 100000)
  1162. if err != nil {
  1163. fmt.Println("查询信息失败,", err)
  1164. return
  1165. }
  1166. num := len(list)
  1167. fmt.Println(num, "条待修复报告es数据")
  1168. for k, v := range list {
  1169. fmt.Println("剩余", num-k, "条")
  1170. services.UpdateReportEs(v.Id, 2)
  1171. }
  1172. fmt.Println("报告ES数据修复完成")
  1173. return
  1174. }