h_exam.go 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. package handler
  2. import (
  3. webServerEntity "cicv-data-closedloop/amd64/web_server/entity"
  4. "cicv-data-closedloop/common/config/c_db"
  5. "cicv-data-closedloop/common/config/c_log"
  6. commonEntity "cicv-data-closedloop/common/entity"
  7. "cicv-data-closedloop/common/util"
  8. "github.com/gin-gonic/gin"
  9. "github.com/signintech/gopdf"
  10. "io"
  11. "log"
  12. "net/http"
  13. "os"
  14. "time"
  15. )
  16. var defaultTime = time.Date(2006, time.January, 2, 15, 4, 5, 0, time.Local)
  17. // 考试开始时间
  18. func Begin(c *gin.Context) {
  19. param := new(webServerEntity.ExamPao)
  20. // 映射到结构体
  21. if err := c.ShouldBindJSON(&param); err != nil {
  22. c_log.GlobalLogger.Error("项目启动接收请求参数报错:", err)
  23. c.JSON(http.StatusBadRequest, commonEntity.Response{
  24. Code: 500,
  25. Msg: "请求体解析失败。",
  26. })
  27. return
  28. }
  29. // 插入到数据库
  30. sqlTemplate, _ := util.ReadFile(c_db.SqlFilesMap["exam-insert-begin_time-by-team_name.sql"])
  31. if err := c_db.DoTx(sqlTemplate, []any{
  32. param.TeamName,
  33. time.Now(),
  34. }); err != nil {
  35. c_log.GlobalLogger.Error("插入数据报错:", err)
  36. c.JSON(http.StatusBadRequest, commonEntity.Response{
  37. Code: 500,
  38. Msg: "插入数据报错。",
  39. })
  40. return
  41. }
  42. c.JSON(http.StatusOK, commonEntity.Response{
  43. Code: 200,
  44. Msg: "插入数据成功。",
  45. })
  46. }
  47. // 考试结束时间
  48. func End(c *gin.Context) {
  49. param := new(webServerEntity.ExamPao)
  50. // 映射到结构体
  51. if err := c.ShouldBindJSON(&param); err != nil {
  52. c_log.GlobalLogger.Error("项目启动接收请求参数报错:", err)
  53. c.JSON(http.StatusBadRequest, commonEntity.Response{
  54. Code: 500,
  55. Msg: "请求体解析失败。",
  56. })
  57. return
  58. }
  59. // 1 查询指定队伍的开始时间最新的考试是否有结束时间,如果有则不在处理,如果没有则更新
  60. var result webServerEntity.ExamPo
  61. selectSql, err := util.ReadFile(c_db.SqlFilesMap["exam-select-latest-by-team_name.sql"])
  62. if err != nil {
  63. c_log.GlobalLogger.Error("读取sql文件报错:", err)
  64. c.JSON(http.StatusBadRequest, commonEntity.Response{
  65. Code: 500,
  66. Msg: "读取sql文件报错。",
  67. })
  68. return
  69. }
  70. // 可以传参数
  71. if err = c_db.MysqlDb.Select(&result, selectSql, param.TeamName); err != nil {
  72. c_log.GlobalLogger.Error("数据库查询报错:", err)
  73. c.JSON(http.StatusBadRequest, commonEntity.Response{
  74. Code: 500,
  75. Msg: "数据库查询报错。",
  76. })
  77. return
  78. }
  79. c_log.GlobalLogger.Info("数据库查询成功:", result)
  80. if !result.EndTime.IsZero() {
  81. c_log.GlobalLogger.Error("赛队", param.TeamName, "重复请求考试结束接口!")
  82. c.JSON(http.StatusBadRequest, commonEntity.Response{
  83. Code: 500,
  84. Msg: "重复请求。",
  85. })
  86. return
  87. }
  88. // 更新到数据库
  89. sqlTemplate, _ := util.ReadFile(c_db.SqlFilesMap["exam-update-end_time-by-team_name.sql"])
  90. if err := c_db.DoTx(sqlTemplate, []any{
  91. time.Now(),
  92. param.TeamName,
  93. }); err != nil {
  94. c_log.GlobalLogger.Error("插入数据报错:", err)
  95. c.JSON(http.StatusBadRequest, commonEntity.Response{
  96. Code: 500,
  97. Msg: "插入数据报错。",
  98. })
  99. return
  100. }
  101. c.JSON(http.StatusOK, commonEntity.Response{
  102. Code: 200,
  103. Msg: "插入数据成功。",
  104. })
  105. }
  106. // 分页查询
  107. // todo 如果日期为默认值,则返回空""
  108. func Page(c *gin.Context) {
  109. param := new(webServerEntity.ExamPagePao)
  110. _ = c.ShouldBindJSON(&param)
  111. var resultPos []webServerEntity.ExamPo
  112. var resultPosTotal []int
  113. var pageSql string
  114. var totalSql string
  115. offset := (param.CurrentPage - 1) * param.PageSize
  116. size := param.PageSize
  117. if param.TeamName == "" && param.Topic == "" {
  118. pageSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-page.sql"])
  119. totalSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-total.sql"])
  120. err := c_db.MysqlDb.Select(&resultPos, pageSql, offset, size)
  121. if err != nil {
  122. c_log.GlobalLogger.Error(err)
  123. }
  124. err = c_db.MysqlDb.Select(&resultPosTotal, totalSql)
  125. if err != nil {
  126. c_log.GlobalLogger.Error(err)
  127. }
  128. }
  129. if param.TeamName != "" && param.Topic == "" {
  130. pageSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-page-by-team_name.sql"])
  131. totalSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-total-by-team_name.sql"])
  132. _ = c_db.MysqlDb.Select(&resultPos, pageSql, "%"+param.TeamName+"%", offset, size)
  133. _ = c_db.MysqlDb.Select(&resultPosTotal, totalSql, "%"+param.TeamName+"%")
  134. }
  135. if param.TeamName == "" && param.Topic != "" {
  136. pageSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-page-by-topic.sql"])
  137. totalSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-total-by-topic.sql"])
  138. _ = c_db.MysqlDb.Select(&resultPos, pageSql, "%"+param.Topic+"%", offset, size)
  139. _ = c_db.MysqlDb.Select(&resultPosTotal, totalSql, "%"+param.Topic+"%")
  140. }
  141. if param.TeamName != "" && param.Topic != "" {
  142. pageSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-page-by-team_name-and-topic.sql"])
  143. totalSql, _ = util.ReadFile(c_db.SqlFilesMap["exam-select-total-by-team_name-and-topic.sql"])
  144. _ = c_db.MysqlDb.Select(&resultPos, pageSql, "%"+param.TeamName+"%", "%"+param.Topic+"%", offset, size)
  145. _ = c_db.MysqlDb.Select(&resultPosTotal, totalSql, "%"+param.TeamName+"%", "%"+param.Topic+"%")
  146. }
  147. var resultVos []webServerEntity.ExamVo
  148. for _, po := range resultPos {
  149. resultVos = append(resultVos, webServerEntity.ExamVo{
  150. Id: po.Id,
  151. TeamName: po.TeamName,
  152. Topic: po.Topic,
  153. BeginTime: util.GetTimeString(po.BeginTime),
  154. EndTime: util.GetTimeString(po.EndTime),
  155. ScoreOnline: po.ScoreOnline,
  156. ScoreOffline: po.ScoreOffline,
  157. ScoreFinal: po.ScoreFinal,
  158. Details: po.Details,
  159. ScoreReportPath: po.ScoreReportPath,
  160. })
  161. }
  162. c.JSON(http.StatusOK, commonEntity.Response{
  163. Code: 200,
  164. Msg: "分页查询成功!",
  165. Data: resultVos,
  166. Total: resultPosTotal[0],
  167. })
  168. }
  169. // 评分报告pdf下载
  170. func Report(c *gin.Context) {
  171. //param := new(webServerEntity.ExamReportPao)
  172. //// 映射到结构体
  173. //if err := c.ShouldBindJSON(&param); err != nil {
  174. // c_log.GlobalLogger.Error("项目启动接收请求参数报错:", err)
  175. // c.JSON(http.StatusBadRequest, commonEntity.Response{
  176. // Code: 500,
  177. // Msg: "请求体解析失败。",
  178. // })
  179. // return
  180. //}
  181. // 1 根据ID查询数据
  182. // 2 根据数据生成pdf
  183. // 3 创建pdf文件
  184. {
  185. // 1 初始化 pdf 对象
  186. pdf := gopdf.GoPdf{}
  187. pdf.Start(gopdf.Config{PageSize: *gopdf.PageSizeA4})
  188. // 2 添加一页
  189. pdf.AddPage()
  190. // 3
  191. err := pdf.AddTTFFont("simfang", "D:\\code\\cicv-data-closedloop\\test\\pdf\\ttf\\simfang.ttf")
  192. if err != nil {
  193. log.Print(err.Error())
  194. return
  195. }
  196. err = pdf.SetFont("simfang", "", 14)
  197. if err != nil {
  198. log.Print(err.Error())
  199. return
  200. }
  201. err = pdf.Cell(nil, "您好")
  202. if err != nil {
  203. return
  204. }
  205. err = pdf.WritePdf("D:\\hello.pdf")
  206. if err != nil {
  207. return
  208. }
  209. }
  210. // 打开要发送的文件
  211. file, err := os.Open("D:\\hello.pdf")
  212. if err != nil {
  213. c.String(http.StatusNotFound, "文件未找到")
  214. return
  215. }
  216. defer file.Close()
  217. // 将文件复制到响应主体
  218. _, err = io.Copy(c.Writer, file)
  219. if err != nil {
  220. c.String(http.StatusInternalServerError, "无法复制文件到响应体")
  221. return
  222. }
  223. }