report.go 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913
  1. package report
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "fmt"
  6. report_chapter_type_cache "hongze/hongze_yb/cache/report_chapter_type"
  7. "hongze/hongze_yb/global"
  8. "hongze/hongze_yb/models/response"
  9. "hongze/hongze_yb/models/response/purchase"
  10. "hongze/hongze_yb/models/tables/chart_permission"
  11. "hongze/hongze_yb/models/tables/chart_permission_chapter_mapping"
  12. "hongze/hongze_yb/models/tables/chart_permission_search_key_word_mapping"
  13. "hongze/hongze_yb/models/tables/daily_base_column"
  14. "hongze/hongze_yb/models/tables/rddp/classify"
  15. "hongze/hongze_yb/models/tables/rddp/report"
  16. "hongze/hongze_yb/models/tables/rddp/report_chapter"
  17. "hongze/hongze_yb/models/tables/rddp/report_chapter_ticker"
  18. "hongze/hongze_yb/models/tables/report_chapter_type"
  19. "hongze/hongze_yb/models/tables/report_chapter_type_permission"
  20. "hongze/hongze_yb/services/company"
  21. elasticService "hongze/hongze_yb/services/elastic"
  22. "hongze/hongze_yb/services/user"
  23. "hongze/hongze_yb/task"
  24. "hongze/hongze_yb/utils"
  25. "html"
  26. "sort"
  27. "strconv"
  28. "time"
  29. )
  30. // GetLatestClassReport 已购列表最新报告
  31. func GetLatestClassReport(permissionIds []int, userId uint64) (purchaseList []*purchase.PurchaseListItem, err error) {
  32. var errMsg string
  33. defer func() {
  34. if sysErr := recover(); sysErr != nil {
  35. err = errors.New("系统错误")
  36. global.LOG.Critical(fmt.Sprintf("GetLatestClassReport: userId=%d, err:%s,sysErr:%s", userId, err.Error(), sysErr))
  37. }
  38. if err != nil {
  39. global.LOG.Critical(fmt.Sprintf("GetLatestClassReport: userId=%d, err:%s, errMsg:%s", userId, err.Error(), errMsg))
  40. }
  41. }()
  42. //获取所有分类信息
  43. classifys, err := classify.GetSimpleAll()
  44. if err != nil {
  45. errMsg = err.Error()
  46. err = errors.New("分类查询出错")
  47. return
  48. }
  49. classifyFirstIconMap := make(map[int]string)
  50. classifySecondNameMap := make(map[string]int)
  51. for _, v := range classifys{
  52. if v.ParentId == 0 {
  53. classifyFirstIconMap[v.Id] = v.YbIconUrl
  54. }else{
  55. classifySecondNameMap[v.ClassifyName] = v.Id
  56. }
  57. }
  58. //获取最新的晨报
  59. dayReport, err := report.GetLatestDay()
  60. if err != nil {
  61. errMsg = err.Error()
  62. err = errors.New("晨报查询出错")
  63. return
  64. }
  65. //获取最新的有权限的周报
  66. //typeIds, err := report_chapter_type.GetEffectTypeID()
  67. typeIds, err := report_chapter_type_cache.GetEffectTypeID()
  68. if err != nil {
  69. errMsg = err.Error()
  70. err = errors.New("晨报查询出错")
  71. return
  72. }
  73. weekReport, err := GetLatestWeek(permissionIds, typeIds)
  74. if err != nil {
  75. errMsg = err.Error()
  76. err = errors.New("周报查询出错")
  77. return
  78. }
  79. // 有权限的二级分类
  80. var reports []*report.Report
  81. var classifyIdSeconds []int
  82. classifyIdSecondMap := make(map[int]bool)
  83. // 获取晨报和周报以外的其他报告
  84. // 获取有权限的二级分类
  85. chartPermissions, err := chart_permission_search_key_word_mapping.GetChartPermissionByFrom("rddp")
  86. if err != nil {
  87. errMsg = err.Error()
  88. err = errors.New("分类权限查询出错")
  89. return
  90. }
  91. if len(chartPermissions) > 0 {
  92. for _, v := range chartPermissions {
  93. for _, myPerId := range permissionIds {
  94. if v.ChartPermissionId == myPerId {
  95. if classifyIdSecond, ok := classifySecondNameMap[v.KeyWord]; ok {
  96. if _, ok2 := classifyIdSecondMap[classifyIdSecond]; !ok2 {
  97. classifyIdSeconds = append(classifyIdSeconds, classifyIdSecond)
  98. classifyIdSecondMap[classifyIdSecond] = true
  99. }
  100. }
  101. break
  102. }
  103. }
  104. }
  105. }
  106. reports, err = report.GetLatestClassReportsByClassifyIdSeconds(classifyIdSeconds)
  107. if err != nil {
  108. errMsg = err.Error()
  109. err = errors.New("二级分类最新报告查询出错")
  110. return
  111. }
  112. if dayReport.Id > 0 {
  113. reports = append(reports, dayReport)
  114. }
  115. if weekReport != nil {
  116. reports = append(reports, weekReport)
  117. }
  118. //获取未读数
  119. unReadItem, tErr := GetUnRead(classifyIdSeconds, userId)
  120. if tErr != nil {
  121. err = tErr
  122. return
  123. }
  124. if len(reports) > 0 {
  125. otherLatestItem := new(purchase.PurchaseListItem)
  126. // 处理其他报告()
  127. for _, v := range reports {
  128. temp := new(purchase.PurchaseListItem)
  129. temp.ReportId = v.Id
  130. temp.ClassifyIdFirst = v.ClassifyIdFirst
  131. temp.ClassifyNameFirst = v.ClassifyNameFirst
  132. temp.Stage = v.Stage
  133. temp.Title = v.Title
  134. temp.ClassifyIdSecond = v.ClassifyIdSecond
  135. temp.ClassifyNameSecond = v.ClassifyNameSecond
  136. temp.Time = v.PublishTime
  137. if temp.ClassifyNameFirst == "大事点评" || temp.ClassifyNameFirst == "会议纪要" || temp.ClassifyNameFirst == "年报合集"{
  138. if otherLatestItem.Time.Format(utils.FormatDateTime) > v.PublishTime.Format(utils.FormatDateTime) {
  139. continue
  140. }
  141. temp.Unread = unReadItem["大事点评"] + unReadItem["会议纪要"] + unReadItem["年报合集"]
  142. temp.Content = fmt.Sprintf("【第%d期|FICC】%s", temp.Stage, temp.ClassifyNameFirst)
  143. otherLatestItem = temp
  144. }
  145. }
  146. for _, v := range reports {
  147. temp := new(purchase.PurchaseListItem)
  148. temp.ReportId = v.Id
  149. temp.ClassifyIdFirst = v.ClassifyIdFirst
  150. temp.ClassifyNameFirst = v.ClassifyNameFirst
  151. temp.Stage = v.Stage
  152. temp.Title = v.Title
  153. temp.ClassifyIdSecond = v.ClassifyIdSecond
  154. temp.ClassifyNameSecond = v.ClassifyNameSecond
  155. temp.Time = v.PublishTime
  156. temp.Unread = unReadItem[temp.ClassifyNameFirst]
  157. if imgUrl, ok := classifyFirstIconMap[temp.ClassifyIdFirst]; ok {
  158. temp.ImgUrl = imgUrl
  159. }
  160. if temp.ClassifyNameFirst == "晨报" || temp.ClassifyNameFirst == "周报" { //晨报或者周报,查询最新的章节信息
  161. temp.Content = fmt.Sprintf("【第%d期|FICC】%s", temp.Stage, temp.Title)
  162. }else if temp.ClassifyNameFirst == "大事点评" || temp.ClassifyNameFirst == "会议纪要" || temp.ClassifyNameFirst == "年报合集"{
  163. continue
  164. }else{
  165. if temp.ClassifyNameFirst != temp.ClassifyNameSecond { //包含二级分类
  166. temp.Content = fmt.Sprintf("【第%d期|FICC| %s】%s", temp.Stage, temp.ClassifyNameSecond, temp.ClassifyNameFirst)
  167. } else { //无二级分类
  168. temp.Content = fmt.Sprintf("【第%d期|FICC】%s", temp.Stage, temp.ClassifyNameFirst)
  169. }
  170. }
  171. purchaseList = append(purchaseList, temp)
  172. }
  173. purchaseList = append(purchaseList, otherLatestItem)
  174. }
  175. return
  176. }
  177. // GetPurchaseDetail 已购详情页面
  178. func GetPurchaseDetail(permissionIds []int, userId uint64, classifyIdFirst int, pageIndex, pageSize int) (ret *purchase.DetailResp, err error) {
  179. var errMsg string
  180. defer func() {
  181. if err != nil {
  182. global.LOG.Critical(fmt.Sprintf("GetPurchaseDetail: userId=%d, err:%s, errMsg:%s", userId, err.Error(), errMsg))
  183. }
  184. }()
  185. var reports []*report.Report
  186. var weekReportIds []int
  187. classifyInfo, err := classify.GetByClassifyId(classifyIdFirst)
  188. if err != nil {
  189. errMsg = err.Error()
  190. err = errors.New("分类查询出错")
  191. return
  192. }
  193. if classifyInfo.Id == 0 {
  194. err = errors.New("分类不存在")
  195. return
  196. }
  197. classifyNameFirst := classifyInfo.ClassifyName
  198. offset := (pageIndex - 1) * pageSize
  199. var total int64
  200. var classifyIdSeconds []int
  201. if classifyNameFirst == "晨报" {
  202. //分类获取
  203. reports, err = report.GetListByClassifyIdFirst(classifyIdFirst, offset, pageSize)
  204. if err != nil {
  205. errMsg = err.Error()
  206. err = errors.New("晨报查询出错")
  207. return
  208. }
  209. total, err = report.GetListCountByClassifyIdFirst(classifyIdFirst)
  210. if err != nil {
  211. errMsg = err.Error()
  212. err = errors.New("查询报告总数出错")
  213. return
  214. }
  215. }else {
  216. if classifyNameFirst == "周报" {
  217. newTypeIds, tErr := GetWeekTypeIdsByPermissionIds(permissionIds,[]int{})
  218. if tErr != nil {
  219. return
  220. }
  221. weekReportIds, err = report_chapter.GetReportIdsByTypeIdsAndClass(newTypeIds, classifyNameFirst)
  222. //分类获取
  223. reports, err = report.GetListByIDsAndClassifyIdFirst(weekReportIds, classifyIdFirst, offset, pageSize)
  224. if err != nil {
  225. return
  226. }
  227. total, err = report.GetListCountByIDsAndClassifyIdFirst(weekReportIds, classifyIdFirst)
  228. if err != nil {
  229. errMsg = err.Error()
  230. err = errors.New("查询报告总数出错")
  231. return
  232. }
  233. }else{
  234. //获取有权限的二级分类
  235. var classifyNameSeconds []string
  236. chartPermissions, tErr := chart_permission_search_key_word_mapping.GetChartPermissionByFrom("rddp")
  237. if tErr != nil {
  238. errMsg = tErr.Error()
  239. err = errors.New("分类权限查询出错")
  240. return
  241. }
  242. if len(chartPermissions) > 0 {
  243. for _, v := range chartPermissions {
  244. for _, myPerId := range permissionIds {
  245. if v.ChartPermissionId == myPerId {
  246. if classifyNameFirst == "大事点评" || classifyNameFirst == "会议纪要" || classifyNameFirst == "年报合集" {
  247. if v.KeyWord == "大事点评" || v.KeyWord == "会议纪要" || v.KeyWord == "年报合集" { //筛选出用户有权限的二级分类ID
  248. classifyNameSeconds = append(classifyNameSeconds, v.KeyWord)
  249. }
  250. }else{
  251. classifyNameSeconds = append(classifyNameSeconds, v.KeyWord)
  252. }
  253. break
  254. }
  255. }
  256. }
  257. }
  258. //获取所有二级分类的id
  259. if classifyNameFirst == "大事点评" || classifyNameFirst == "会议纪要" || classifyNameFirst == "年报合集" {
  260. classifyIdSeconds, tErr = classify.GetOtherIdsByClassifyNames(classifyNameSeconds)
  261. }else{
  262. classifyIdSeconds, tErr = classify.GetIdsByClassifyNameAndParentId(classifyNameSeconds, classifyIdFirst)
  263. }
  264. if tErr != nil {
  265. errMsg = tErr.Error()
  266. err = errors.New("二级分类查询出错")
  267. return
  268. }
  269. if len(classifyIdSeconds) > 0 {
  270. //分类获取
  271. reports, err = report.GetListByClassifyIdSeconds(classifyIdSeconds, offset, pageSize)
  272. if err != nil {
  273. return
  274. }
  275. total, err = report.GetListCountByClassifyIdSeconds(classifyIdSeconds)
  276. if err != nil {
  277. errMsg = err.Error()
  278. err = errors.New("查询报告总数出错")
  279. return
  280. }
  281. }
  282. }
  283. }
  284. var list []*purchase.Detail
  285. ret = new(purchase.DetailResp)
  286. if len(reports) > 0 {
  287. var viewReportIds []int
  288. for _, v := range reports {
  289. viewReportIds = append(viewReportIds, v.Id)
  290. temp := new(purchase.Detail)
  291. temp.ReportId = v.Id
  292. temp.ClassifyIdFirst = v.ClassifyIdFirst
  293. temp.ClassifyNameFirst = v.ClassifyNameFirst
  294. temp.Title = v.Title
  295. temp.ClassifyIdSecond = v.ClassifyIdSecond
  296. temp.ClassifyNameSecond = v.ClassifyNameSecond
  297. temp.Stage = v.Stage
  298. temp.ImgUrl = classifyInfo.YbBgUrl
  299. if temp.ClassifyNameFirst == "晨报" || temp.ClassifyNameFirst == "周报" { //晨报或者周报,查询最新的章节信息
  300. temp.Content = fmt.Sprintf("【第%d期|FICC】%s", temp.Stage, temp.Title)
  301. temp.TopName = temp.Title
  302. }else{
  303. if temp.ClassifyNameFirst != temp.ClassifyNameSecond { //包含二级分类
  304. temp.Content = fmt.Sprintf("【第%d期|FICC| %s】%s", temp.Stage, temp.ClassifyNameSecond, temp.ClassifyNameFirst)
  305. temp.TopName = temp.ClassifyNameSecond
  306. } else {
  307. temp.Content = fmt.Sprintf("【第%d期|FICC】%s", temp.Stage, temp.ClassifyNameFirst)
  308. temp.TopName = temp.ClassifyNameFirst
  309. }
  310. }
  311. temp.Time = v.PublishTime
  312. list = append(list, temp)
  313. }
  314. }
  315. ret.List = list
  316. ret.Paging = response.GetPaging(pageIndex, pageSize, int(total))
  317. // 执行一个协程任务,新增用户浏览记录
  318. //_, tErr := BatchInsertReportView(weekReportIds, userId, classifyNameFirst, classifyIdSeconds)
  319. task.Task(BatchInsertReportView, weekReportIds, userId, classifyNameFirst, classifyIdSeconds)
  320. /*if tErr != nil {
  321. err = tErr
  322. return
  323. }*/
  324. return
  325. }
  326. // 获取报告详情
  327. func GetReportDetail(userinfo user.UserInfo, reportId int) (reportDetail response.ReportDetail, err error) {
  328. var errMsg string
  329. defer func() {
  330. if err != nil {
  331. global.LOG.Critical(fmt.Sprintf("GetReportDetail: userId=%d, err:%s, errMsg:%s", userinfo.UserID, err.Error(), errMsg))
  332. }
  333. }()
  334. reportInfo, err := report.GetByReportId(reportId)
  335. if err != nil {
  336. errMsg = err.Error()
  337. err = errors.New("报告查询出错")
  338. return
  339. }
  340. if reportInfo.Id == 0 {
  341. err = errors.New("报告不存在")
  342. return
  343. }
  344. //判断权限
  345. var authOk bool
  346. var permissionCheckInfo response.PermissionCheckInfo
  347. var vaildWeekTypeIds []int
  348. if reportInfo.ClassifyNameFirst == "晨报"{
  349. authOk, permissionCheckInfo, err = CheckDayReportPermission(userinfo)
  350. }else if reportInfo.ClassifyNameFirst == "周报"{
  351. authOk, permissionCheckInfo, vaildWeekTypeIds, err = CheckWeekReportPermission(userinfo)
  352. }else{
  353. authOk, permissionCheckInfo, err = CheckReportPermission(userinfo, reportId)
  354. }
  355. if err != nil {
  356. return
  357. }
  358. reportItem := new(response.ReportItem)
  359. reportItem.ReportId = reportInfo.Id
  360. reportItem.Title = reportInfo.Title
  361. reportItem.PublishTime = reportInfo.PublishTime
  362. reportItem.ClassifyNameFirst = reportInfo.ClassifyNameFirst
  363. reportItem.ClassifyNameSecond = reportInfo.ClassifyNameSecond
  364. reportItem.Stage = reportInfo.Stage
  365. reportItem.Abstract = reportInfo.Abstract
  366. reportItem.ContentSub = html.UnescapeString(reportInfo.ContentSub)
  367. reportItem.Frequency = reportInfo.Frequency
  368. reportItem.VideoName = reportInfo.VideoName
  369. reportItem.VideoPlaySeconds = reportInfo.VideoPlaySeconds
  370. reportItem.Author = reportInfo.Author
  371. var reportTypeList []*response.ReportChapterListItem
  372. if (reportInfo.ClassifyNameFirst == "晨报" || reportInfo.ClassifyNameFirst == "周报") {
  373. //(晨报和周报的banner图)
  374. if reportInfo.ClassifyNameFirst == "晨报" {
  375. reportItem.BannerUrl = utils.ALIYUN_YBIMG_HOST + "report_banner_day.jpg"
  376. } else {
  377. reportItem.BannerUrl = utils.ALIYUN_YBIMG_HOST + "report_banner_week.jpg"
  378. }
  379. if authOk {
  380. reportTypeList, err = GetChapterListByReport(reportInfo.ClassifyNameFirst, reportInfo.Id, vaildWeekTypeIds)
  381. if err != nil {
  382. return
  383. }
  384. }
  385. }
  386. //如果有权限则展示content
  387. if authOk {
  388. task.Task(AddViewRecord, userinfo, reportInfo.Id, reportInfo.ClassifyNameFirst, 0)
  389. reportItem.Content = html.UnescapeString(reportInfo.Content)
  390. reportItem.VideoUrl = reportInfo.VideoUrl
  391. }
  392. reportDetail.ReportInfo = reportItem
  393. reportDetail.ReportChapterList = reportTypeList
  394. reportDetail.PermissionCheck = &permissionCheckInfo
  395. reportDetail.AuthOk = authOk
  396. return
  397. }
  398. // CheckReportPermission 验证用户查看报告的权限
  399. func CheckReportPermission(userInfo user.UserInfo, reportId int) (authOk bool, permissionCheckInfo response.PermissionCheckInfo, err error) {
  400. permissionIds, err := chart_permission_chapter_mapping.GetPermissionIdsByReportId(reportId, "rddp")
  401. if err != nil && err != utils.ErrNoRow {
  402. return
  403. }
  404. authOk, permissionCheckInfo,_, err = company.GetCheckPermission(userInfo.CompanyID, int(userInfo.UserID), permissionIds)
  405. return
  406. }
  407. // GetReportList 获取报告列表
  408. func GetReportList(user user.UserInfo, keyWord string, classifyIdFirst, classifyIdSecond, pageIndex, pageSize int) (ret *response.ReportList, err error) {
  409. var errMsg string
  410. defer func() {
  411. if err != nil {
  412. global.LOG.Critical(fmt.Sprintf("GetReportList: userId=%d, err:%s, errMsg:%s", user.UserID, err.Error(), errMsg))
  413. }
  414. }()
  415. var condition string
  416. pars := make([]interface{}, 0)
  417. classifyParent, err := classify.GetByClassifyId(classifyIdFirst)
  418. if err != nil {
  419. errMsg = err.Error()
  420. err = errors.New("分类查询出错")
  421. return
  422. }
  423. if classifyParent.Id == 0 {
  424. err = errors.New("该分类不存在")
  425. return
  426. }
  427. condition = `classify_id_first = ? and state = 2`
  428. pars = append(pars, classifyIdFirst)
  429. permissionMap := make(map[string][]int)
  430. checkPermissionMap := make(map[string]bool)
  431. permissionImageMap := make(map[string]string)
  432. chartPermissionImageMap := make(map[int]string)
  433. var classifyIdSeconds []int
  434. var reportImgUrl string
  435. chartPermissionList, err := chart_permission.GetFiccListExceptTacticByProductId()
  436. if err != nil {
  437. errMsg = err.Error()
  438. err = errors.New("分类查询出错")
  439. return
  440. }
  441. if len(chartPermissionList) > 0 {
  442. for _, v := range chartPermissionList {
  443. chartPermissionImageMap[int(v.ChartPermissionID)] = v.YbImgUrl
  444. }
  445. }
  446. if classifyIdSecond > 0 && keyWord == "" {
  447. classifyInfo, tErr := classify.GetByClassifyId(classifyIdSecond)
  448. if tErr != nil {
  449. errMsg = tErr.Error()
  450. err = errors.New("分类查询出错")
  451. return
  452. }
  453. if classifyInfo.Id == 0 {
  454. err = errors.New("该二级分类不存在")
  455. return
  456. }
  457. condition += " AND classify_id_second = ?"
  458. pars = append(pars, classifyIdSecond)
  459. //查询二级分类对应的权限
  460. permissionIds, tErr := chart_permission_search_key_word_mapping.GetChartPermissionIdsByKeyWord(classifyInfo.ClassifyName)
  461. if tErr != nil {
  462. errMsg = tErr.Error()
  463. err = errors.New("分类权限查询出错")
  464. return
  465. }
  466. permissionMap[classifyInfo.ClassifyName] = permissionIds
  467. if len(permissionIds) > 0{
  468. for _, v := range permissionIds {
  469. reportImgUrl = chartPermissionImageMap[v]
  470. }
  471. }
  472. }else{
  473. if classifyParent.ClassifyName == "晨报" || classifyParent.ClassifyName == "周报"{
  474. reportImgUrl = chartPermissionImageMap[1]
  475. classifyIdSeconds = append(classifyIdSeconds,0)
  476. }
  477. chartPermissions, tErr := chart_permission_search_key_word_mapping.GetChartPermissionByFrom("rddp")
  478. if tErr != nil {
  479. errMsg = tErr.Error()
  480. err = errors.New("分类权限查询出错")
  481. return
  482. }
  483. if len(chartPermissions) > 0 {
  484. for _, v := range chartPermissions {
  485. permissionMap[v.KeyWord] = append(permissionMap[v.KeyWord], v.ChartPermissionId)
  486. permissionImageMap[v.KeyWord] = chartPermissionImageMap[v.ChartPermissionId]
  487. }
  488. }
  489. //获取二级分类的所有头像
  490. classifyList, tErr := classify.GetListByPid(classifyIdFirst)
  491. if tErr != nil {
  492. errMsg = tErr.Error()
  493. err = errors.New("二级分类查询出错")
  494. return
  495. }
  496. for _, v := range classifyList {
  497. classifyIdSeconds = append(classifyIdSeconds, v.Id)
  498. }
  499. if len(classifyIdSeconds) == 0 && classifyParent.ClassifyName != "晨报" && classifyParent.ClassifyName != "周报" {
  500. ret = new(response.ReportList)
  501. ret.Paging = response.GetPaging(pageIndex, pageSize, 0)
  502. return
  503. }
  504. condition += ` AND classify_id_second IN ? `
  505. pars = append(pars, classifyIdSeconds)
  506. }
  507. // 获取有效的权限id列表
  508. validPermissionIdList, err := company.GetValidPermissionIdListByCompany2ProductId(user.CompanyID, 1)
  509. if err != nil && err != utils.ErrNoRow {
  510. errMsg = err.Error()
  511. err = errors.New("查询分类出错")
  512. return
  513. }
  514. if len(validPermissionIdList) > 0 {
  515. for classifyName, perIds := range permissionMap {
  516. checkLoop:
  517. for _, checkId := range perIds{
  518. for _, validPerid := range validPermissionIdList {
  519. if checkId == validPerid {
  520. checkPermissionMap[classifyName] = true
  521. break checkLoop
  522. }
  523. }
  524. }
  525. }
  526. }
  527. var total int64
  528. var list []*report.Report
  529. if keyWord == "" {
  530. offset := (pageIndex - 1) * pageSize
  531. list, err = report.GetReportList(condition, pars, offset, pageSize)
  532. if err != nil {
  533. errMsg = err.Error()
  534. err = errors.New("报告查询出错")
  535. return
  536. }
  537. total, err = report.GetReportListCount(condition, pars)
  538. if err != nil {
  539. errMsg = err.Error()
  540. err = errors.New("查询报告总数出错")
  541. return
  542. }
  543. }else{
  544. if classifyIdSecond > 0 {
  545. classifyIdSeconds = append(classifyIdSeconds, classifyIdSecond)
  546. }
  547. if classifyParent.ClassifyName == "晨报" || classifyParent.ClassifyName == "周报" {
  548. classifyIdSeconds = append(classifyIdSeconds,0)
  549. }
  550. searchResp, total1, tErr := elasticService.ReportListSearch(keyWord, classifyIdFirst, classifyIdSeconds, pageIndex, pageSize)
  551. if tErr != nil {
  552. errMsg = tErr.Error()
  553. err = errors.New("查询失败")
  554. return
  555. }
  556. total = int64(total1)
  557. if searchResp.Hits != nil {
  558. for _, v := range searchResp.Hits.Hits {
  559. temp := new(report.Report)
  560. itemJson, tmpErr := v.Source.MarshalJSON()
  561. if tmpErr != nil {
  562. errMsg = tmpErr.Error()
  563. err = errors.New("解析出错")
  564. return
  565. }
  566. reportItem := new(response.EsReportItem)
  567. tmpErr = json.Unmarshal(itemJson, &reportItem)
  568. if tmpErr != nil {
  569. errMsg = tmpErr.Error()
  570. err = errors.New("解析json出错")
  571. return
  572. }
  573. temp.Id = reportItem.ReportId
  574. temp.ClassifyIdFirst = reportItem.ClassifyIdFirst
  575. temp.ClassifyNameFirst = reportItem.ClassifyNameFirst
  576. temp.ClassifyIdSecond = reportItem.ClassifyIdSecond
  577. temp.ClassifyNameSecond = reportItem.ClassifyNameSecond
  578. temp.Abstract = reportItem.Abstract
  579. temp.StageStr = reportItem.StageStr
  580. temp.Title = reportItem.Title
  581. temp.PublishTime, err = time.Parse("2006-01-02 15:04:05", reportItem.PublishTime)
  582. if len(v.Highlight["Title"]) > 0 {
  583. temp.Title = v.Highlight["Title"][0]
  584. }
  585. if len(v.Highlight["Abstract"]) > 0 {
  586. temp.Title = v.Highlight["Abstract"][0]
  587. }
  588. if len(v.Highlight["StageStr"]) > 0 {
  589. temp.Title = v.Highlight["StageStr"][0]
  590. }
  591. list = append(list, temp)
  592. }
  593. }
  594. }
  595. var reportList []*response.ReportListItem
  596. if len(list) > 0 {
  597. for _, reportInfo := range list {
  598. reportItem := new(response.ReportListItem)
  599. reportItem.ReportId = reportInfo.Id
  600. reportItem.Title = reportInfo.Title
  601. reportItem.PublishTime = reportInfo.PublishTime
  602. reportItem.ClassifyNameFirst = reportInfo.ClassifyNameFirst
  603. reportItem.ClassifyNameSecond = reportInfo.ClassifyNameSecond
  604. reportItem.ClassifyIdFirst = reportInfo.ClassifyIdFirst
  605. reportItem.ClassifyIdSecond = reportInfo.ClassifyIdSecond
  606. reportItem.Stage = reportInfo.Stage
  607. reportItem.Abstract = reportInfo.Abstract
  608. reportItem.Author = reportInfo.Author
  609. stageStr := reportInfo.StageStr
  610. if stageStr == "" {
  611. stageStr = strconv.Itoa(reportInfo.Stage)
  612. }
  613. reportItem.TitleInfo = fmt.Sprintf("【第%s期|FICC|%s】%s", stageStr, reportItem.ClassifyNameSecond, reportItem.Title)
  614. if reportInfo.ClassifyNameFirst == "晨报" || reportInfo.ClassifyNameFirst == "周报" || classifyIdSecond > 0{
  615. reportItem.ReportImgUrl = utils.ALIYUN_YBIMG_HOST + reportImgUrl
  616. reportItem.TitleInfo = fmt.Sprintf("【第%s期|FICC|%s】%s", stageStr, reportItem.ClassifyNameFirst, reportItem.Title)
  617. } else if url,ok := permissionImageMap[reportInfo.ClassifyNameSecond]; ok {
  618. reportItem.ReportImgUrl = utils.ALIYUN_YBIMG_HOST + url
  619. }
  620. if authOk,ok := checkPermissionMap[reportInfo.ClassifyNameSecond]; ok && authOk {
  621. reportItem.VideoUrl = reportInfo.VideoUrl
  622. reportItem.AuthOk = authOk
  623. }
  624. reportList = append(reportList, reportItem)
  625. }
  626. }
  627. ret = new(response.ReportList)
  628. ret.List = reportList
  629. ret.Paging = response.GetPaging(pageIndex, pageSize, int(total))
  630. return
  631. }
  632. // GetCollectReportList 首页展示报告汇总列表
  633. func GetCollectReportList(user user.UserInfo, chartPermissionId, pageIndex, pageSize int) (ret *response.ReportCollectResp, err error) {
  634. var errMsg string
  635. defer func() {
  636. if err != nil {
  637. global.LOG.Critical(fmt.Sprintf("GetCollectReportList: userId=%d, err:%s, errMsg:%s", user.UserID, err.Error(), errMsg))
  638. }
  639. }()
  640. // 查询权限的基本信息
  641. permissionInfo, err := chart_permission.GetByChartPermissionId(chartPermissionId)
  642. if err != nil {
  643. errMsg = err.Error()
  644. err = errors.New("查询权限出错")
  645. return
  646. }
  647. if permissionInfo.ChartPermissionID == 0 {
  648. err = errors.New("权限不存在")
  649. return
  650. }
  651. // 除了晨报和周报以外的其他报告
  652. classifyNames, err := chart_permission_search_key_word_mapping.GetKeyWordsByChartPermissionId(chartPermissionId, "rddp")
  653. if err != nil {
  654. errMsg = err.Error()
  655. err = errors.New("查询权限对应的分类出错")
  656. return
  657. }
  658. var classifySecondIds []int
  659. if len(classifyNames) > 0 {
  660. classifySecondIds, err = classify.GetSecondIdsByClassifyNames(classifyNames)
  661. if err != nil {
  662. errMsg = err.Error()
  663. err = errors.New("查询分类出错")
  664. return
  665. }
  666. }
  667. // 查询晨报和周报相对应的章节ID
  668. reportChapterTypeIds, err := report_chapter_type_permission.GetTypeIdsByChartPermissionId(chartPermissionId)
  669. if err != nil {
  670. errMsg = err.Error()
  671. err = errors.New("查询权限对应的章节出错")
  672. return
  673. }
  674. var reportList []*response.ReportCollectListItem
  675. list := response.ReportCollectListResp{}
  676. var total int64
  677. if len(reportChapterTypeIds) > 0 || len(classifySecondIds) > 0 {
  678. offset := (pageIndex - 1) * pageSize
  679. reportList, err = report.GetReportCollectListByPermission(classifySecondIds, reportChapterTypeIds, offset, pageSize)
  680. if err != nil {
  681. errMsg = err.Error()
  682. err = errors.New("查询报告信息出错")
  683. return
  684. }
  685. listMap := make(map[string]*response.ReportCollectList)
  686. for _, v := range reportList {
  687. v.ContentSub = html.UnescapeString(v.ContentSub)
  688. if _, ok := listMap[v.PublishTime.Format("2006-01-02")]; !ok {
  689. temp := new(response.ReportCollectList)
  690. temp.Date = v.PublishTime.Format("2006-01-02")
  691. listMap[v.PublishTime.Format("2006-01-02")] = temp
  692. }
  693. listMap[v.PublishTime.Format("2006-01-02")].SubList = append(listMap[v.PublishTime.Format("2006-01-02")].SubList, v)
  694. }
  695. for _, v := range listMap {
  696. list = append(list, v)
  697. }
  698. total, err = report.GetReportCollectCountByPermission(classifySecondIds, reportChapterTypeIds)
  699. if err != nil {
  700. errMsg = err.Error()
  701. err = errors.New("查询报告总数出错")
  702. return
  703. }
  704. if len(list) > 0 {
  705. sort.Sort(list)
  706. }
  707. }
  708. ret = new(response.ReportCollectResp)
  709. ret.List = list
  710. ret.Paging = response.GetPaging(pageIndex, pageSize, int(total))
  711. return
  712. }
  713. func SearchReport(user user.UserInfo, keyWord string, pageIndex, pageSize int)(ret *response.ReportSearchResp, err error) {
  714. var errMsg string
  715. defer func() {
  716. if err != nil {
  717. global.LOG.Critical(fmt.Sprintf("SearchReport: userId=%d, err:%s, errMsg:%s", user.UserID, err.Error(), errMsg))
  718. }
  719. }()
  720. //查询正常状态的分类
  721. classifys, err := classify.GetSimpleAll()
  722. if err != nil {
  723. errMsg = err.Error()
  724. err = errors.New("分类查询出错")
  725. return
  726. }
  727. var classifyIdFirsts []int
  728. classifyIdSeconds := []int{0}
  729. for _, v := range classifys{
  730. if v.ParentId == 0 {
  731. classifyIdFirsts = append(classifyIdFirsts, v.Id)
  732. }else{
  733. classifyIdSeconds = append(classifyIdSeconds, v.Id)
  734. }
  735. }
  736. searchResp, total, err := elasticService.SearchReport(keyWord, classifyIdFirsts, classifyIdSeconds, pageIndex, pageSize)
  737. if err != nil {
  738. errMsg = err.Error()
  739. err = errors.New("查询失败")
  740. return
  741. }
  742. var reportList []*response.ReportCollectListItem
  743. if searchResp.Hits != nil {
  744. for _, v := range searchResp.Hits.Hits {
  745. temp := new(response.ReportCollectListItem)
  746. itemJson, tmpErr := v.Source.MarshalJSON()
  747. if tmpErr != nil {
  748. errMsg = tmpErr.Error()
  749. err = errors.New("解析出错")
  750. return
  751. }
  752. reportItem := new(response.EsReportItem)
  753. tmpErr = json.Unmarshal(itemJson, &reportItem)
  754. if tmpErr != nil {
  755. errMsg = tmpErr.Error()
  756. err = errors.New("解析json出错")
  757. return
  758. }
  759. temp.ReportId = reportItem.ReportId
  760. temp.ClassifyIdFirst = reportItem.ClassifyIdFirst
  761. temp.ClassifyNameFirst = reportItem.ClassifyNameFirst
  762. temp.ClassifyIdSecond = reportItem.ClassifyIdSecond
  763. temp.ClassifyNameSecond = reportItem.ClassifyNameSecond
  764. temp.Title = reportItem.Title
  765. temp.ContentSub = html.UnescapeString(html.UnescapeString(reportItem.BodyContent))
  766. temp.PublishTime, err = time.Parse("2006-01-02 15:04:05", reportItem.PublishTime)
  767. fmt.Println(*reportItem)
  768. if len(v.Highlight["Title"]) > 0 {
  769. temp.Title = v.Highlight["Title"][0]
  770. }
  771. if len(v.Highlight["BodyContent"]) > 0 {
  772. temp.ContentSub = html.UnescapeString(html.UnescapeString(v.Highlight["BodyContent"][0]))
  773. }
  774. if len(v.Highlight["Categories"]) > 0 {
  775. if temp.ClassifyNameSecond != "" {
  776. temp.ClassifyNameSecond = "<span style=\"color:#efefef\">"+temp.ClassifyNameSecond+"</span>"
  777. }
  778. if temp.ClassifyNameFirst != "" {
  779. temp.ClassifyNameFirst = "<span style=\"color:#efefef\">"+temp.ClassifyNameFirst+"</span>"
  780. }
  781. }
  782. reportList = append(reportList, temp)
  783. }
  784. }
  785. ret = new(response.ReportSearchResp)
  786. ret.List = reportList
  787. ret.Paging = response.GetPaging(pageIndex, pageSize, int(total))
  788. return
  789. }
  790. // GetTickerData 获取指标数据
  791. func GetTickerData(user user.UserInfo, reportChapterId int) (ret response.TickerData, err error) {
  792. var errMsg string
  793. defer func() {
  794. if err != nil {
  795. global.LOG.Critical(fmt.Sprintf("GetTickerData: userId=%d, err:%s, errMsg:%s", user.UserID, err.Error(), errMsg))
  796. }
  797. }()
  798. //查询章节类型
  799. chapter, err := report_chapter.GetTypeIdById(reportChapterId)
  800. if err != nil {
  801. errMsg = err.Error()
  802. err = errors.New("查询章节失败")
  803. return
  804. }
  805. if chapter.ReportChapterId == 0 {
  806. err = errors.New("章节不存在或者未发布")
  807. return
  808. }
  809. tickers, err := report_chapter_ticker.GetTickerByChapterId(reportChapterId)
  810. if err != nil {
  811. errMsg = err.Error()
  812. err = errors.New("查询章节指标失败")
  813. return
  814. }
  815. var list []*response.TickerDataItem
  816. if len(tickers) > 0 {
  817. var tickerNames []string
  818. for _, v := range tickers {
  819. tickerNames = append(tickerNames, v.Ticker)
  820. }
  821. var dataList []*response.TickerDataItem
  822. if chapter.TypeId == 17 {
  823. dataList, err = daily_base_column.GetDataByBaseColumnTickers17(tickerNames)
  824. }else{
  825. dataList, err = daily_base_column.GetDataByBaseColumnTickers(tickerNames)
  826. }
  827. if err != nil {
  828. errMsg = err.Error()
  829. err = errors.New("查询指标数据失败")
  830. return
  831. }
  832. chapterTypeInfo, tErr := report_chapter_type.GetTickerTitleByTypeId(chapter.TypeId)
  833. if tErr != nil {
  834. errMsg = tErr.Error()
  835. err = errors.New("查询章节类型失败")
  836. return
  837. }
  838. if len(dataList) >= 0 {
  839. for _, v := range dataList {
  840. temp := new(response.TickerDataItem)
  841. temp.BaseColumnName = v.BaseColumnName
  842. temp.Ticker = v.Ticker
  843. temp.Date = v.Date
  844. temp.TickerValue, _ = strconv.ParseFloat(fmt.Sprintf("%.2f",v.TickerValue), 2)
  845. temp.LastValue, _ = strconv.ParseFloat(fmt.Sprintf("%.2f",v.LastValue), 2)
  846. temp.MmValue, _ = strconv.ParseFloat(fmt.Sprintf("%.2f", v.MmValue), 2)
  847. temp.DdValue, _ = strconv.ParseFloat(fmt.Sprintf("%.2f", v.DdValue), 2)
  848. temp.WwValue, _ = strconv.ParseFloat(fmt.Sprintf("%.2f", v.WwValue), 2)
  849. list = append(list, temp)
  850. }
  851. }
  852. tickerTitle := new(response.TickerTitleData)
  853. tickerTitle.TickerTitle = chapterTypeInfo.TickerTitle
  854. tickerTitle.ReportChapterTypeId = int(chapterTypeInfo.ReportChapterTypeId)
  855. tickerTitle.ReportChapterTypeName = chapterTypeInfo.ReportChapterTypeName
  856. tickerTitle.DataTableImage = fmt.Sprintf("http://hongze.oss-cn-shanghai.aliyuncs.com/data_table/%s.png", chapterTypeInfo.ReportChapterTypeKey)
  857. ret.List = list
  858. ret.TickerTitle = tickerTitle
  859. }
  860. return
  861. }