router.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. package routers
  2. import (
  3. "mtp2_if/controllers/cfg"
  4. "mtp2_if/controllers/cptrade"
  5. "mtp2_if/controllers/delivery"
  6. "mtp2_if/controllers/erms2"
  7. "mtp2_if/controllers/login"
  8. "mtp2_if/controllers/wrtrade"
  9. "mtp2_if/logger"
  10. "mtp2_if/token"
  11. "net/http"
  12. "time"
  13. "github.com/gin-gonic/gin"
  14. // Swagger生成的文档
  15. _ "mtp2_if/docs"
  16. ginSwagger "github.com/swaggo/gin-swagger"
  17. "github.com/swaggo/gin-swagger/swaggerFiles"
  18. )
  19. // InitRouter 初始化路由器的方法
  20. func InitRouter() *gin.Engine {
  21. r := gin.New()
  22. // 设置日志中间件
  23. r.Use(ginLoggerMiddleware())
  24. // 设置奔溃中间件
  25. r.Use(ginRecoveryMiddleware())
  26. // 跨域
  27. r.Use(CORSMiddleware())
  28. // Swagger
  29. r.GET("/swagger/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))
  30. // 终端配置
  31. r.GET("/cfg", cfg.QueryCfg)
  32. // 主业务路由分组
  33. apiR := r.Group("/api")
  34. // apiR.Use(token.Auth())
  35. // ************************ 账号登录 ************************
  36. loginR := apiR.Group("Login")
  37. loginR.Use()
  38. {
  39. loginR.GET("/GetLoginID", login.GetLoginID)
  40. }
  41. // ************************ 仓单贸易 ************************
  42. wrTradeR := apiR.Group("WRTrade")
  43. wrTradeR.Use(token.Auth())
  44. {
  45. wrTradeR.GET("/GetAllDeliveryGoods", wrtrade.GetAllDeliveryGoods)
  46. }
  47. // ************************ 产能预售 ************************
  48. cpTradeR := apiR.Group("CPTrade")
  49. cpTradeR.Use(token.Auth())
  50. {
  51. // 查询产能预售申请表
  52. cpTradeR.GET("/QueryPreasleApply", cptrade.QueryPreasleApply)
  53. // 查询远期订单信息
  54. cpTradeR.GET("/QueryUserGoodsData", cptrade.QueryUserGoodsData)
  55. // 查询远期订单注销申请信息
  56. cpTradeR.GET("/QueryPositionCancel", cptrade.QueryPositionCancel)
  57. // 查询产能预售商品扩展信息
  58. cpTradeR.GET("/QueryPresaleGoodsEx", cptrade.QueryPresaleGoodsEx)
  59. // 查询产能预售我的出价信息
  60. cpTradeR.GET("/QueryCPTradeMyBidInfos", cptrade.QueryCPTradeMyBidInfos)
  61. // 查询我的预售信息
  62. cpTradeR.GET("/QueryMyCPTradeGoods", cptrade.QueryMyCPTradeGoods)
  63. // 查询产能预售委托单信息
  64. cpTradeR.GET("/QueryCPTradeOrderDetail", cptrade.QueryCPTradeOrderDetail)
  65. }
  66. // ************************ 交割服务 ************************
  67. deliveryR := apiR.Group("Delivery")
  68. deliveryR.Use(token.Auth())
  69. {
  70. // 查询商品交割关系表
  71. deliveryR.GET("/QueryDeliveryRelation", delivery.QueryDeliveryRelation)
  72. }
  73. // ************************ 风险管理 ************************
  74. erms2R := apiR.Group("Erms2")
  75. erms2R.Use(token.Auth())
  76. {
  77. // 查询内部成交单信息
  78. erms2R.GET("/QueryInnerTradeDetail", erms2.QueryInnerTradeDetail)
  79. // 查询期现套利策略表信息(指定资金账户、未结束的)
  80. erms2R.GET("/QueryArbitrageStrategy", erms2.QueryArbitrageStrategy)
  81. // 查询现货合同表信息(指定策略ID、未结束的)
  82. erms2R.GET("/QuerySpotContract", erms2.QuerySpotContract)
  83. }
  84. return r
  85. }
  86. func ginLoggerMiddleware() gin.HandlerFunc {
  87. return func(c *gin.Context) {
  88. start := time.Now()
  89. c.Next()
  90. end := time.Now()
  91. latency := end.Sub(start)
  92. path := c.Request.URL.RequestURI()
  93. clientip := c.ClientIP()
  94. method := c.Request.Method
  95. statuscode := c.Writer.Status()
  96. logger.GetLogger().Infof("|%3d|%13v|%15s|%s %s",
  97. statuscode,
  98. latency,
  99. clientip,
  100. method,
  101. path)
  102. }
  103. }
  104. func ginRecoveryMiddleware() gin.HandlerFunc {
  105. return gin.RecoveryWithWriter(logger.GetLogWriter())
  106. }
  107. // CORSMiddleware cors跨域.
  108. func CORSMiddleware() gin.HandlerFunc {
  109. return func(c *gin.Context) {
  110. c.Writer.Header().Set("Access-Control-Allow-Origin", "*")
  111. c.Writer.Header().Set("Access-Control-Allow-Credentials", "true")
  112. c.Writer.Header().Set("Access-Control-Allow-Headers", "Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization, accept, origin, Cache-Control, X-Requested-With, X-session-Token")
  113. c.Writer.Header().Set("Access-Control-Allow-Methods", "POST, OPTIONS, GET, PUT")
  114. c.Writer.Header().Set("Access-Control-Expose-Headers", "Content-Length, Access-Control-Allow-Origin, Access-Control-Allow-Headers, Content-Type, X-session-Token")
  115. if c.Request.Method == "OPTIONS" {
  116. c.AbortWithStatus(http.StatusNoContent)
  117. return
  118. }
  119. c.Next()
  120. }
  121. }