report.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611
  1. package controllers
  2. import (
  3. "eta/eta_mini_bridge/models"
  4. "eta/eta_mini_bridge/models/response"
  5. "eta/eta_mini_bridge/services"
  6. "eta/eta_mini_bridge/utils"
  7. "html"
  8. "strconv"
  9. "time"
  10. "github.com/rdlucklib/rdluck_tools/paging"
  11. )
  12. type ReportController struct {
  13. BaseAuthController
  14. }
  15. // @Title List
  16. // @Description create users
  17. // @Param ChartPermissionId query int true "品种ID"
  18. // @Param Level query int true "品种层级"
  19. // @Param PageSize query int true "每页数据条数"
  20. // @Param CurrentIndex query int true "当前页页码,从1开始"
  21. // @Param RangeType query string true "范围类型,1-一天内,2-一周内,3-半年内"
  22. // @Param ClassifyId query int true "分类id"
  23. // @Success 200 {object} response.ReportListResp
  24. // @router /list [get]
  25. func (this *ReportController) List() {
  26. br := new(models.BaseResponse).Init()
  27. defer func() {
  28. this.Data["json"] = br
  29. this.ServeJSON()
  30. }()
  31. pageSize, _ := this.GetInt("PageSize")
  32. currentIndex, _ := this.GetInt("CurrentIndex")
  33. chartPermissionId, _ := this.GetInt("ChartPermissionId")
  34. level, _ := this.GetInt("Level")
  35. rangeType, _ := this.GetInt("RangeType")
  36. classifyId, _ := this.GetInt("ClassifyId")
  37. if chartPermissionId <= 0 {
  38. br.Msg = "品种参数错误"
  39. return
  40. }
  41. var condition string
  42. switch rangeType {
  43. case 1:
  44. condition += ` AND DATE(a.modify_time)=DATE(NOW()) `
  45. case 2:
  46. condition += ` AND DATE(a.modify_time) BETWEEN DATE_SUB(NOW(),INTERVAL 1 WEEK) AND NOW() `
  47. case 3:
  48. condition += ` AND DATE(a.modify_time) BETWEEN DATE_SUB(NOW(),INTERVAL 6 MONTH) AND NOW() `
  49. }
  50. var startSize int
  51. if pageSize <= 0 {
  52. pageSize = utils.PageSize20
  53. }
  54. if currentIndex <= 0 {
  55. currentIndex = 1
  56. }
  57. startSize = utils.StartIndex(currentIndex, pageSize)
  58. var total int
  59. var reportList []*models.ReportList
  60. switch level {
  61. case 2:
  62. classifyIds, err := models.GetClassifyIdsListById(chartPermissionId)
  63. if err != nil {
  64. br.Msg = "获取报告列表失败"
  65. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  66. return
  67. }
  68. if len(classifyIds) == 0 {
  69. br.Msg = "该品种下没有绑定分类"
  70. br.ErrMsg = "获取数据失败,品种id:" + strconv.Itoa(chartPermissionId)
  71. return
  72. }
  73. // 根据分类筛选报告
  74. var selectedClassifyId []int
  75. if classifyId > 0 {
  76. for _, v := range classifyIds {
  77. if v == classifyId {
  78. selectedClassifyId = append(selectedClassifyId, v)
  79. break
  80. }
  81. }
  82. } else {
  83. selectedClassifyId = classifyIds
  84. }
  85. tmptotal, err := models.GetReportCountByClassifyIds(selectedClassifyId, condition)
  86. if err != nil {
  87. br.Msg = "获取数据失败"
  88. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  89. return
  90. }
  91. total = tmptotal
  92. tmpReportList, err := models.GetReportListByClassifyIds(selectedClassifyId, condition, startSize, pageSize)
  93. if err != nil {
  94. br.Msg = "获取报告列表失败"
  95. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  96. return
  97. }
  98. reportList = tmpReportList
  99. case 1:
  100. chartPermissionIds, err := models.GetChildChartPermissionIdsById(chartPermissionId)
  101. if err != nil {
  102. br.Msg = "获取报告列表失败"
  103. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  104. return
  105. }
  106. if len(chartPermissionIds) == 0 {
  107. br.Msg = "该品种下没有绑定分类"
  108. br.ErrMsg = "获取数据失败,品种id:" + strconv.Itoa(chartPermissionId)
  109. return
  110. }
  111. classifyIds, err := models.GetClassifyIdsListByIds(chartPermissionIds)
  112. if err != nil {
  113. br.Msg = "获取报告列表失败"
  114. br.ErrMsg = "获取报告列表失败,Err:" + err.Error()
  115. return
  116. }
  117. if len(classifyIds) == 0 {
  118. br.Msg = "该品种下没有绑定分类"
  119. return
  120. }
  121. // 根据分类筛选报告
  122. var selectedClassifyId []int
  123. if classifyId > 0 {
  124. for _, v := range classifyIds {
  125. if v == classifyId {
  126. selectedClassifyId = append(selectedClassifyId, v)
  127. break
  128. }
  129. }
  130. } else {
  131. selectedClassifyId = classifyIds
  132. }
  133. tmptotal, err := models.GetReportCountByClassifyIds(selectedClassifyId, condition)
  134. if err != nil {
  135. br.Msg = "获取数据失败"
  136. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  137. return
  138. }
  139. total = tmptotal
  140. tmpReportList, err := models.GetReportListByClassifyIds(selectedClassifyId, condition, startSize, pageSize)
  141. if err != nil {
  142. br.Msg = "获取报告列表失败"
  143. br.ErrMsg = "获取报告列表失败,Err:" + err.Error()
  144. return
  145. }
  146. reportList = tmpReportList
  147. default:
  148. br.Msg = "层级参数错误"
  149. return
  150. }
  151. page := paging.GetPaging(currentIndex, pageSize, total)
  152. resp := new(response.ReportListResp)
  153. resp.Paging = page
  154. resp.List = reportList
  155. br.Ret = 200
  156. br.Success = true
  157. br.Msg = "获取成功"
  158. br.Data = resp
  159. }
  160. // @Title 研报详情
  161. // @Description 研报详情接口
  162. // @Param ReportId query int true "报告id"
  163. // @Param UserId query int true "用户id"
  164. // @Success 200 {object} response.ReportDetailResp
  165. // @router /detail [get]
  166. func (this *ReportController) Detail() {
  167. br := new(models.BaseResponse).Init()
  168. defer func() {
  169. this.Data["json"] = br
  170. this.ServeJSON()
  171. }()
  172. reportId, err := this.GetInt("ReportId")
  173. userId, err := this.GetInt("UserId")
  174. if err != nil {
  175. br.Msg = "参数获取失败"
  176. br.ErrMsg = "参数获取失败,Err:" + err.Error()
  177. return
  178. }
  179. if reportId <= 0 {
  180. br.Msg = "参数错误"
  181. br.ErrMsg = "参数错误,报告id小于等于0"
  182. return
  183. }
  184. if userId <= 0 {
  185. br.Msg = "参数错误"
  186. br.ErrMsg = "参数错误,用户id小于等于0"
  187. return
  188. }
  189. user, err := models.GetUserById(userId)
  190. if err != nil {
  191. br.Msg = "用户不存在"
  192. br.ErrMsg = "用户不存在,系统异常,Err:" + err.Error()
  193. return
  194. }
  195. // 有效期是否到期
  196. var vailStatus int
  197. if user.Status == utils.UserStatusFormal || user.Status == utils.UserStatusNo {
  198. if user.ValidEndTime.After(time.Now()) && user.ValidStartTime.Before(time.Now()) {
  199. vailStatus = 2
  200. } else {
  201. // 不在有效期时间则设置为过期, 将用户状态禁用
  202. vailStatus = 1
  203. user.Status = utils.UserStatusNo
  204. }
  205. }
  206. report, err := models.GetReportById(reportId)
  207. if err != nil {
  208. if err.Error() == utils.ErrNoRow() {
  209. br.Ret = 200
  210. br.Data = new(response.ReportDetailResp)
  211. br.Success = true
  212. br.Msg = "该报告已删除或不存在"
  213. return
  214. }
  215. br.Msg = "该报告已删除"
  216. br.ErrMsg = "获取报告详情失败,Err:" + err.Error()
  217. return
  218. }
  219. report.ContentSub = html.UnescapeString(report.ContentSub)
  220. report.Content = html.UnescapeString(report.Content)
  221. if report == nil {
  222. br.Msg = "报告不存在"
  223. return
  224. }
  225. reportChartPermissionIds, err := models.GetChartPermissionIdsListByClassifyId(report.ClassifyIdSecond)
  226. if err != nil {
  227. br.Msg = "获取研报权限失败"
  228. br.ErrMsg = "获取研报权限失败,Err:" + err.Error()
  229. return
  230. }
  231. chartPermissionList, err := models.GetChartPermissionListByStrIds(reportChartPermissionIds)
  232. if err != nil {
  233. br.Msg = "获取研报权限失败"
  234. br.ErrMsg = "获取研报权限失败,Err:" + err.Error()
  235. return
  236. }
  237. var IsHas bool
  238. var IsPublic bool
  239. for _, v := range chartPermissionList {
  240. if v.IsPublic == 1 {
  241. IsPublic = true
  242. break
  243. }
  244. }
  245. resp := new(response.ReportDetailResp)
  246. if !IsPublic {
  247. // 如果是私有报告,用户权限过期直接返回有效期已过
  248. if vailStatus == 1 {
  249. resp.Report = report
  250. resp.Status = utils.ReportPermissionStatusExpired
  251. report.Content = ""
  252. br.Ret = 200
  253. br.Data = resp
  254. br.Msg = "用户权限不足"
  255. return
  256. }
  257. // 如果被禁用或是潜在用户,直接返回无阅读报告权限
  258. if user.Status == utils.UserStatusNo || user.Status == utils.UserStatusPotential {
  259. resp.Report = report
  260. resp.Status = utils.ReportPermissionStatusNo
  261. report.Content = ""
  262. br.Ret = 200
  263. br.Data = resp
  264. br.Msg = "用户权限不足"
  265. return
  266. }
  267. chartPermissionIds, err := models.GetChartPermissionIdByUserId(userId)
  268. if err != nil {
  269. br.Msg = "获取用户权限失败"
  270. br.ErrMsg = "获取用户权限失败,Err:" + err.Error()
  271. return
  272. }
  273. if len(chartPermissionIds) <= 0 {
  274. resp.Report = report
  275. resp.Status = utils.ReportPermissionStatusNo
  276. report.Content = ""
  277. br.Ret = 200
  278. br.Data = resp
  279. br.Msg = "用户权限不足"
  280. return
  281. }
  282. classifyIds, err := models.GetClassifyIdsListByIds(chartPermissionIds)
  283. if err != nil {
  284. br.Msg = "获取用户权限失败"
  285. br.ErrMsg = "获取用户分类权限失败,Err:" + err.Error()
  286. return
  287. }
  288. if len(classifyIds) <= 0 {
  289. resp.Report = report
  290. resp.Status = utils.ReportPermissionStatusNoPermission
  291. report.Content = ""
  292. br.Ret = 200
  293. br.Data = resp
  294. br.Msg = "用户权限不足"
  295. return
  296. }
  297. for _, v := range classifyIds {
  298. if v == report.ClassifyIdSecond {
  299. IsHas = true
  300. }
  301. }
  302. if !IsHas {
  303. resp.Report = report
  304. resp.Status = utils.ReportPermissionStatusNoPermission
  305. report.Content = ""
  306. br.Ret = 200
  307. br.Data = resp
  308. br.Msg = "用户权限不足"
  309. return
  310. }
  311. } else {
  312. report.IsPublic = IsPublic
  313. }
  314. resp.Report = report
  315. resp.Status = utils.ReportPermissionStatusHas
  316. br.Data = resp
  317. br.Ret = 200
  318. br.Success = true
  319. br.Msg = "获取成功"
  320. }
  321. // @Title 研报详情
  322. // @Description 研报详情接口
  323. // @Param ReportId query int true "报告id"
  324. // @Success 200 {object} response.ReportDetailResp
  325. // @router /detail/noUser [get]
  326. func (this *ReportController) DetailNoUser() {
  327. br := new(models.BaseResponse).Init()
  328. defer func() {
  329. this.Data["json"] = br
  330. this.ServeJSON()
  331. }()
  332. reportId, err := this.GetInt("ReportId")
  333. if err != nil {
  334. br.Msg = "参数获取失败"
  335. br.ErrMsg = "参数获取失败,Err:" + err.Error()
  336. return
  337. }
  338. if reportId <= 0 {
  339. br.Msg = "参数错误"
  340. br.ErrMsg = "参数错误,报告id小于等于0"
  341. return
  342. }
  343. report, err := models.GetReportById(reportId)
  344. if err != nil {
  345. if err.Error() == utils.ErrNoRow() {
  346. br.Ret = 200
  347. br.Data = new(response.ReportDetailResp)
  348. br.Success = true
  349. br.Msg = "该报告已删除或不存在"
  350. return
  351. }
  352. br.Msg = "该报告已删除"
  353. br.ErrMsg = "获取报告详情失败,Err:" + err.Error()
  354. return
  355. }
  356. report.ContentSub = html.UnescapeString(report.ContentSub)
  357. report.Content = ""
  358. if report == nil {
  359. br.Msg = "报告不存在"
  360. return
  361. }
  362. resp := new(response.ReportDetailResp)
  363. resp.Report = report
  364. resp.Status = utils.ReportPermissionStatusNoUser
  365. br.Data = resp
  366. br.Ret = 200
  367. br.Success = true
  368. br.Msg = "获取成功"
  369. }
  370. // @Title 今日研报列表
  371. // @Description 今日研报列表
  372. // @Success 200 {object} response.ReportListResp
  373. // @router /daily/list [get]
  374. func (this *ReportController) Today() {
  375. br := new(models.BaseResponse).Init()
  376. defer func() {
  377. this.Data["json"] = br
  378. this.ServeJSON()
  379. }()
  380. total, err := models.GetReportDailyListCount()
  381. if err != nil {
  382. br.Msg = "获取数据失败"
  383. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  384. return
  385. }
  386. list, err := models.GetReportDailyList(0, total)
  387. if err != nil {
  388. br.Msg = "获取失败"
  389. br.ErrMsg = "获取失败,Err:" + err.Error()
  390. return
  391. }
  392. classifyIds := make([]string, 0)
  393. for _, v := range list {
  394. classifyIds = append(classifyIds, strconv.Itoa(v.ClassifyIdSecond))
  395. }
  396. classifyIds = utils.Unique(classifyIds)
  397. // 获取二级分类和二级品种权限的映射
  398. chartPermissionMapping, err := models.GetChartPermissionListByClassifyStrIds(classifyIds)
  399. if err != nil {
  400. br.Msg = "获取研报权限失败"
  401. br.ErrMsg = "获取研报权限失败,Err:" + err.Error()
  402. return
  403. }
  404. classifyToPermissionMap2 := make(map[int][]int)
  405. chartPermissionIds := make([]string, 0)
  406. for _, v := range chartPermissionMapping {
  407. classifyToPermissionMap2[v.ClassifyId] = append(classifyToPermissionMap2[v.ClassifyId], v.ChartPermissionId)
  408. chartPermissionIds = append(chartPermissionIds, strconv.Itoa(v.ChartPermissionId))
  409. }
  410. // 获取二级品种的权限,并建立映射
  411. chartPermissionList2, err := models.GetChartPermissionListByStrIds(chartPermissionIds)
  412. if err != nil {
  413. br.Msg = "获取研报二级品种权限失败"
  414. br.ErrMsg = "获取研报二级品种权限失败,Err:" + err.Error()
  415. return
  416. }
  417. chartPermissionViewMap2 := make(map[int]*models.ChartPermission)
  418. for _, v := range chartPermissionList2 {
  419. chartPermissionViewMap2[v.ChartPermissionId] = v
  420. }
  421. // 获取一级品种的权限,并建立映射
  422. chartPermissionList1, err := models.GetChildChartPermissionListById(0)
  423. if err != nil {
  424. br.Msg = "获取研报一级品种权限失败"
  425. br.ErrMsg = "获取研报一级品种权限失败,Err:" + err.Error()
  426. return
  427. }
  428. chartPermissionMap1 := make(map[int]*models.ChartPermission)
  429. for _, v := range chartPermissionList1 {
  430. chartPermissionMap1[v.ChartPermissionId] = v
  431. }
  432. // 组合数据
  433. for _, v := range list {
  434. var permissionNames []string
  435. for _, vv := range classifyToPermissionMap2[v.ClassifyIdSecond] {
  436. parent2 := chartPermissionViewMap2[vv].ParentId
  437. permissionNames = append(permissionNames, chartPermissionMap1[parent2].PermissionName)
  438. }
  439. v.PermissionNames = utils.Unique(permissionNames)
  440. }
  441. resp := new(response.ReportListResp)
  442. resp.List = list
  443. br.Ret = 200
  444. br.Success = true
  445. br.Msg = "获取成功"
  446. br.Data = resp
  447. }
  448. // @Title 最新研报列表
  449. // @Description 最新研报列表
  450. // @Param PageSize query int true "每页数据条数"
  451. // @Param CurrentIndex query int true "当前页页码,从1开始"
  452. // @Success 200 {object} response.ReportListResp
  453. // @router /recent/list [get]
  454. func (this *ReportController) RecentList() {
  455. br := new(models.BaseResponse).Init()
  456. defer func() {
  457. this.Data["json"] = br
  458. this.ServeJSON()
  459. }()
  460. pageSize, _ := this.GetInt("PageSize")
  461. currentIndex, _ := this.GetInt("CurrentIndex")
  462. var startSize int
  463. if pageSize <= 0 {
  464. pageSize = utils.PageSize30
  465. }
  466. if currentIndex <= 0 {
  467. currentIndex = 1
  468. }
  469. startSize = utils.StartIndex(currentIndex, pageSize)
  470. total, err := models.GetReportRecentListCount()
  471. if err != nil {
  472. br.Msg = "获取数据失败"
  473. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  474. return
  475. }
  476. list, err := models.GetReportRecentList(startSize, pageSize)
  477. if err != nil {
  478. br.Msg = "获取失败"
  479. br.ErrMsg = "获取失败,Err:" + err.Error()
  480. return
  481. }
  482. classifyIds := make([]string, 0)
  483. for _, v := range list {
  484. classifyIds = append(classifyIds, strconv.Itoa(v.ClassifyIdSecond))
  485. }
  486. classifyIds = utils.Unique(classifyIds)
  487. // 获取二级分类和二级品种权限的映射
  488. chartPermissionMapping, err := models.GetChartPermissionListByClassifyStrIds(classifyIds)
  489. if err != nil {
  490. br.Msg = "获取研报权限失败"
  491. br.ErrMsg = "获取研报权限失败,Err:" + err.Error()
  492. return
  493. }
  494. classifyToPermissionMap2 := make(map[int][]int)
  495. chartPermissionIds := make([]string, 0)
  496. for _, v := range chartPermissionMapping {
  497. classifyToPermissionMap2[v.ClassifyId] = append(classifyToPermissionMap2[v.ClassifyId], v.ChartPermissionId)
  498. chartPermissionIds = append(chartPermissionIds, strconv.Itoa(v.ChartPermissionId))
  499. }
  500. // 获取二级品种的权限,并建立映射
  501. chartPermissionList2, err := models.GetChartPermissionListByStrIds(chartPermissionIds)
  502. if err != nil {
  503. br.Msg = "获取研报二级品种权限失败"
  504. br.ErrMsg = "获取研报二级品种权限失败,Err:" + err.Error()
  505. return
  506. }
  507. chartPermissionViewMap2 := make(map[int]*models.ChartPermission)
  508. for _, v := range chartPermissionList2 {
  509. chartPermissionViewMap2[v.ChartPermissionId] = v
  510. }
  511. // 获取一级品种的权限,并建立映射
  512. chartPermissionList1, err := models.GetChildChartPermissionListById(0)
  513. if err != nil {
  514. br.Msg = "获取研报一级品种权限失败"
  515. br.ErrMsg = "获取研报一级品种权限失败,Err:" + err.Error()
  516. return
  517. }
  518. chartPermissionMap1 := make(map[int]*models.ChartPermission)
  519. for _, v := range chartPermissionList1 {
  520. chartPermissionMap1[v.ChartPermissionId] = v
  521. }
  522. // 组合数据
  523. for _, v := range list {
  524. var permissionNames []string
  525. for _, vv := range classifyToPermissionMap2[v.ClassifyIdSecond] {
  526. parent2 := chartPermissionViewMap2[vv].ParentId
  527. permissionNames = append(permissionNames, chartPermissionMap1[parent2].PermissionName)
  528. }
  529. v.PermissionNames = utils.Unique(permissionNames)
  530. }
  531. page := paging.GetPaging(currentIndex, pageSize, total)
  532. resp := new(response.ReportListResp)
  533. resp.Paging = page
  534. resp.List = list
  535. br.Ret = 200
  536. br.Success = true
  537. br.Msg = "获取成功"
  538. br.Data = resp
  539. }
  540. // @Title 研报搜索
  541. // @Description 研报搜索
  542. // @Param PageSize query int true "每页数据条数"
  543. // @Param CurrentIndex query int true "当前页页码,从1开始"
  544. // @Param KeyWord query string true "关键字"
  545. // @Success 200 {object} response.ReportSearchResp
  546. // @router /search [get]
  547. func (this *ReportController) Search() {
  548. br := new(models.BaseResponse).Init()
  549. defer func() {
  550. this.Data["json"] = br
  551. this.ServeJSON()
  552. }()
  553. keyWord := this.GetString("KeyWord")
  554. pageSize, _ := this.GetInt("PageSize")
  555. currentIndex, _ := this.GetInt("CurrentIndex")
  556. if pageSize <= 0 {
  557. pageSize = utils.PageSize30
  558. }
  559. if currentIndex <= 0 {
  560. currentIndex = 1
  561. }
  562. if keyWord == "" {
  563. br.Msg = "请输入关键字"
  564. return
  565. }
  566. reportList, err, errMsg := services.SearchReport(keyWord, currentIndex, pageSize)
  567. if err != nil {
  568. br.Msg = "研报搜索失败"
  569. br.ErrMsg = errMsg + ",Err:" + err.Error()
  570. return
  571. }
  572. br.Data = reportList
  573. br.Msg = "查询成功"
  574. br.Ret = 200
  575. br.Success = true
  576. }