table.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. package common
  2. import (
  3. "fmt"
  4. "mtp2_if/db"
  5. "mtp2_if/global/app"
  6. "mtp2_if/global/e"
  7. "mtp2_if/global/utils"
  8. "mtp2_if/logger"
  9. "mtp2_if/models"
  10. "net/http"
  11. "strconv"
  12. "strings"
  13. "github.com/gin-gonic/gin"
  14. )
  15. // QueryTraderMenuReq 查询交易端菜单请求参数
  16. type QueryTraderMenuReq struct {
  17. LoginID int `form:"loginid" binding:"required"`
  18. }
  19. // QueryTraderMenuRsp 交易端菜单
  20. type QueryTraderMenuRsp struct {
  21. QuoteMenu []QuotePrimaryMenu `json:"QuoteMenu"` // 报价牌分类菜单
  22. OperationMenu []OperationPrimaryMenu `json:"OperationMenu"` // 功能菜单
  23. }
  24. // QuotePrimaryMenu 报价牌一级分类菜单
  25. type QuotePrimaryMenu struct {
  26. Index int `json:"Index"` // 序号
  27. Key string `json:"Key"` // 键名
  28. Name string `json:"Name"` // 菜单名称
  29. SubTitleType int `json:"SubTitleType"` // 子菜单标题模式:0-市场名称;1-外部交易所名称
  30. TradeModes string `json:"TradeModes"` // 包含市场交易类型
  31. SubMenus []QuoteSecondaryMenu `json:"SubMenus"` // 子菜单
  32. }
  33. // QuoteSecondaryMenu 报价牌二级分类菜单
  34. type QuoteSecondaryMenu struct {
  35. Index int `json:"Index"` // 序号
  36. MarketID int `json:"MarketID"` // 市场ID
  37. TradeMode int `json:"TradeMode"` // 交易模式
  38. MenuTitle string `json:"MenuTitle" xorm:"'ExExchangeName'"` // 菜单标题(市场名称或外部交易所名称)
  39. GoodsGroupIDs []int `json:"GoodsGroupIDs"` // 商品组ID列表
  40. ExExchangeID int `json:"ExExchangeID" xorm:"'ExExchangeID'"` // 外部交易所ID
  41. ExExchangeCode string `json:"ExExchangeCode" xorm:"'ExExchangeCode'"` // 外部交易所代码
  42. }
  43. // OperationPrimaryMenu 一级功能菜单
  44. type OperationPrimaryMenu struct {
  45. Key string `json:"Key"` // 菜单KEY
  46. Label string `json:"Label"` // 菜单标题
  47. Children []OperationSecondaryMenu `json:"Children"` // 二级功能菜单
  48. }
  49. // OperationSecondaryMenu 二级功能菜单
  50. type OperationSecondaryMenu struct {
  51. Key string `json:"Key"` // 菜单KEY
  52. Label string `json:"Label"` // 菜单标题
  53. TabList []OperationTabMenu `json:"TabList"` // 三级功能菜单
  54. }
  55. // OperationTabMenu 三级功能菜单
  56. type OperationTabMenu struct {
  57. Key string `json:"Key"` // 菜单KEY
  58. Label string `json:"Label"` // 菜单标题
  59. }
  60. // QueryTraderMenu 查询交易端菜单
  61. // @Summary 查询交易端菜单
  62. // @Produce json
  63. // @Security ApiKeyAuth
  64. // @Param loginid query int true "登录账号"
  65. // @Success 200 {object} QueryTraderMenuRsp
  66. // @Failure 500 {object} app.Response
  67. // @Router /Common/QueryTraderMenu [get]
  68. // @Tags 通用
  69. func QueryTraderMenu(c *gin.Context) {
  70. appG := app.Gin{C: c}
  71. // 获取请求参数
  72. var req QueryTraderMenuReq
  73. if err := appG.C.ShouldBindQuery(&req); err != nil {
  74. logger.GetLogger().Errorf("QueryTraderMenu failed: %s", err.Error())
  75. appG.Response(http.StatusBadRequest, e.INVALID_PARAMS, nil)
  76. return
  77. }
  78. var queryTraderMenuRsp QueryTraderMenuRsp
  79. // 获取行情报价牌分类菜单
  80. if datas, err := getQuoteMenu(req.LoginID); err == nil {
  81. queryTraderMenuRsp.QuoteMenu = datas
  82. } else {
  83. logger.GetLogger().Errorf("QueryTraderMenu failed: %s", err.Error())
  84. appG.Response(http.StatusBadRequest, e.ERROR_QUERY_QUOTEMENU_FAIL, nil)
  85. return
  86. }
  87. // 获取功能菜单
  88. if datas, err := getOperationMenu(); err == nil {
  89. queryTraderMenuRsp.OperationMenu = datas
  90. } else {
  91. logger.GetLogger().Errorf("QueryTraderMenu failed: %s", err.Error())
  92. appG.Response(http.StatusBadRequest, e.ERROR_QUERY_OPERATIONMENU_FAIL, nil)
  93. return
  94. }
  95. // 查询成功
  96. logger.GetLogger().Infof("QueryTraderMenu successed: %v", queryTraderMenuRsp)
  97. appG.Response(http.StatusOK, e.SUCCESS, queryTraderMenuRsp)
  98. }
  99. // getQuoteMenu 获取行情报价牌分类菜单
  100. func getQuoteMenu(loginID int) ([]QuotePrimaryMenu, error) {
  101. engine := db.GetEngine()
  102. rst := make([]QuotePrimaryMenu, 0)
  103. // ********************* 准备数据 *********************
  104. var taAccounts []string // 账户下所有资金账户
  105. var marketIDs []int // 资金账户下有权限的市场ID列表
  106. // 先要获取当前登录账户对应的资金账户
  107. if err := engine.SQL(fmt.Sprintf(`select to_char(AccountID) from LoginTAAccount where LoginID = %d`, loginID)).Find(&taAccounts); err != nil {
  108. return nil, err
  109. }
  110. // 如果一条记录都没有则直接通过资金账户表获取
  111. if len(taAccounts) == 0 {
  112. sql := fmt.Sprintf(`select to_char(ta.accountid) from taaccount ta
  113. inner join loginaccount l on ta.userid = l.userid
  114. where l.loginid = %d`, loginID)
  115. if err := engine.SQL(sql).Find(&taAccounts); err != nil {
  116. return nil, err
  117. }
  118. }
  119. // 获取资金账户对应的市场权限(有权限的市场ID)
  120. if len(taAccounts) > 0 {
  121. taAccountStr := strings.Join(taAccounts, ",")
  122. if err := engine.SQL(fmt.Sprintf(`select MarketID from TAAccountMarket where AccountID in (%s)`, taAccountStr)).Find(&marketIDs); err != nil {
  123. return nil, err
  124. }
  125. }
  126. // ********************* 构建行情报价牌菜单 *********************
  127. // 获取一级菜单列表
  128. datas := make([]models.Tablecolumnconfig, 0)
  129. if err := engine.Where("TableKey = 'trader_master_menu' and IsShow = 1").Find(&datas); err != nil {
  130. return nil, err
  131. }
  132. // 构建一级菜单对象
  133. for i, v := range datas {
  134. quotePrimaryMenu := QuotePrimaryMenu{
  135. Index: i,
  136. Key: v.Columnfield,
  137. Name: v.Columntitle,
  138. }
  139. // 跳过自选
  140. if v.Columnfield == "optional" {
  141. rst = append(rst, quotePrimaryMenu)
  142. continue
  143. }
  144. // FormatterString:模式,0-使用市场名称,1-使用外部交易所名称;Remark:包含市场交易模式
  145. quotePrimaryMenu.SubTitleType, _ = strconv.Atoi(v.Formatterstring)
  146. quotePrimaryMenu.TradeModes = v.Remark
  147. // 构建二级子菜单对象
  148. marketIDsStr := utils.JoinItoString(marketIDs, ",")
  149. if quotePrimaryMenu.SubTitleType == 0 {
  150. // 获取目标交易模式的市场信息
  151. markets := make([]models.Market, 0)
  152. if err := engine.Where(fmt.Sprintf(`TradeMode in (%s) and MarketID in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)).Find(&markets); err != nil {
  153. return nil, err
  154. }
  155. // 使用市场名称
  156. for mi, mv := range markets {
  157. quoteSecondaryMenu := QuoteSecondaryMenu{
  158. Index: mi,
  159. MarketID: int(mv.Marketid),
  160. TradeMode: int(mv.Trademode),
  161. MenuTitle: mv.Marketname,
  162. }
  163. quotePrimaryMenu.SubMenus = append(quotePrimaryMenu.SubMenus, quoteSecondaryMenu)
  164. }
  165. } else {
  166. // 使用外部交易所名称
  167. quoteSecondaryMenus := make([]QuoteSecondaryMenu, 0)
  168. sql := fmt.Sprintf(`select distinct
  169. e.autoid ExExchangeID,
  170. e.ExExchangeName,
  171. e.ExExchangeCode
  172. from ExternalExchange e
  173. inner join goodsgroup g on g.exexchangeid = e.autoid
  174. inner join Market m on g.marketid = m.marketid
  175. where m.trademode in (%s) and m.marketid in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)
  176. if err := engine.SQL(sql).Find(&quoteSecondaryMenus); err != nil {
  177. return nil, err
  178. }
  179. // 获取外部交易所对应的商品组信息
  180. for ei, ev := range quoteSecondaryMenus {
  181. q := &quoteSecondaryMenus[ei]
  182. q.Index = ei
  183. // 商品组列表
  184. goodsgroups := make([]models.Goodsgroup, 0)
  185. if err := engine.Where("Exexchangeid = ?", ev.ExExchangeID).Find(&goodsgroups); err != nil {
  186. return nil, err
  187. }
  188. marketID := 0
  189. var goodsGroupIDs []int
  190. for _, gv := range goodsgroups {
  191. marketID = int(gv.Marketid)
  192. goodsGroupIDs = append(goodsGroupIDs, int(gv.Goodsgroupid))
  193. }
  194. q.MarketID = marketID
  195. q.GoodsGroupIDs = goodsGroupIDs
  196. }
  197. quotePrimaryMenu.SubMenus = quoteSecondaryMenus
  198. }
  199. rst = append(rst, quotePrimaryMenu)
  200. }
  201. return rst, nil
  202. }
  203. // getOperationMenu 获取功能菜单
  204. func getOperationMenu() ([]OperationPrimaryMenu, error) {
  205. engine := db.GetEngine()
  206. rst := make([]OperationPrimaryMenu, 0)
  207. // 获取一级功能菜单
  208. opm := make([]models.Tablecolumnconfig, 0)
  209. if err := engine.Where("IsShow = 1 and TableKey = ?", "trader_operation_master_menu").Asc("ORDERINDEX").Find(&opm); err != nil {
  210. return nil, err
  211. }
  212. for _, pv := range opm {
  213. var operationPrimaryMenu = OperationPrimaryMenu{
  214. Key: pv.Columnfield,
  215. Label: pv.Columntitle,
  216. Children: make([]OperationSecondaryMenu, 0),
  217. }
  218. // 获取二级功能菜单
  219. osm := make([]models.Tablecolumnconfig, 0)
  220. if err := engine.Where("IsShow = 1 and Remark = ?", operationPrimaryMenu.Key).Asc("ORDERINDEX").Find(&osm); err != nil {
  221. return nil, err
  222. }
  223. for _, sv := range osm {
  224. var operationSecondaryMenu = OperationSecondaryMenu{
  225. Key: sv.Columnfield,
  226. Label: sv.Columntitle,
  227. TabList: make([]OperationTabMenu, 0),
  228. }
  229. // 获取三级功能菜单
  230. otm := make([]models.Tablecolumnconfig, 0)
  231. if err := engine.Where("IsShow = 1 and Remark = ?", operationSecondaryMenu.Key).Asc("ORDERINDEX").Find(&otm); err != nil {
  232. return nil, err
  233. }
  234. for _, tv := range otm {
  235. var operationTabMenu = OperationTabMenu{
  236. Key: tv.Columnfield,
  237. Label: tv.Columntitle,
  238. }
  239. operationSecondaryMenu.TabList = append(operationSecondaryMenu.TabList, operationTabMenu)
  240. }
  241. operationPrimaryMenu.Children = append(operationPrimaryMenu.Children, operationSecondaryMenu)
  242. }
  243. rst = append(rst, operationPrimaryMenu)
  244. }
  245. return rst, nil
  246. }
  247. // QueryTableColumnConfigReq 查询交易端列表头信息请求参数
  248. type QueryTableColumnConfigReq struct {
  249. TableKey string `json:"TableKey"` // 表key
  250. }
  251. // QueryTableColumnConfig 查询交易端列表头信息
  252. // @Summary 查询交易端列表头信息
  253. // @Produce json
  254. // @Security ApiKeyAuth
  255. // @Param TableKey query string false "表key"
  256. // @Success 200 {object} models.Tablecolumnconfig
  257. // @Failure 500 {object} app.Response
  258. // @Router /Common/QueryTableColumnConfig [get]
  259. // @Tags 通用
  260. func QueryTableColumnConfig(c *gin.Context) {
  261. appG := app.Gin{C: c}
  262. // 获取请求参数
  263. var req QueryTableColumnConfigReq
  264. if err := appG.C.ShouldBindQuery(&req); err != nil {
  265. logger.GetLogger().Errorf("QueryTableColumnConfig failed: %s", err.Error())
  266. appG.Response(http.StatusBadRequest, e.INVALID_PARAMS, nil)
  267. return
  268. }
  269. engine := db.GetEngine()
  270. tablecolumnconfigs := make([]models.Tablecolumnconfig, 0)
  271. // 这里的表名必须要大写 (Oracle的表名都是大写)
  272. s := engine.Join("INNER", "TABLEDEFINE", "TABLEDEFINE.TableKey = TABLECOLUMNCONFIG.TableKey")
  273. if len(req.TableKey) > 0 {
  274. s = s.Where("TABLEDEFINE.TableType = 2 and TABLEDEFINE.TableKey = ?", req.TableKey)
  275. } else {
  276. s = s.Where("TABLEDEFINE.TableType = 2")
  277. }
  278. if err := s.Find(&tablecolumnconfigs); err != nil {
  279. logger.GetLogger().Errorf("QueryTableColumnConfig failed: %s", err.Error())
  280. appG.Response(http.StatusBadRequest, e.ERROR_QUERY_FAIL, nil)
  281. return
  282. }
  283. // 查询成功
  284. logger.GetLogger().Infof("QueryTableColumnConfig successed: %v", tablecolumnconfigs)
  285. appG.Response(http.StatusOK, e.SUCCESS, tablecolumnconfigs)
  286. }