| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325 |
- package common
- import (
- "fmt"
- "mtp2_if/db"
- "mtp2_if/global/app"
- "mtp2_if/global/e"
- "mtp2_if/global/utils"
- "mtp2_if/logger"
- "mtp2_if/models"
- "net/http"
- "strconv"
- "strings"
- "github.com/gin-gonic/gin"
- )
- // QueryTraderMenuReq 查询交易端菜单请求参数
- type QueryTraderMenuReq struct {
- LoginID int `form:"loginid" binding:"required"`
- }
- // QueryTraderMenuRsp 交易端菜单
- type QueryTraderMenuRsp struct {
- QuoteMenu []QuotePrimaryMenu `json:"QuoteMenu"` // 报价牌分类菜单
- OperationMenu []OperationPrimaryMenu `json:"OperationMenu"` // 功能菜单
- }
- // QuotePrimaryMenu 报价牌一级分类菜单
- type QuotePrimaryMenu struct {
- Index int `json:"Index"` // 序号
- Key string `json:"Key"` // 键名
- Name string `json:"Name"` // 菜单名称
- SubTitleType int `json:"SubTitleType"` // 子菜单标题模式:0-市场名称;1-外部交易所名称
- TradeModes string `json:"TradeModes"` // 包含市场交易类型
- SubMenus []QuoteSecondaryMenu `json:"SubMenus"` // 子菜单
- }
- // QuoteSecondaryMenu 报价牌二级分类菜单
- type QuoteSecondaryMenu struct {
- Index int `json:"Index"` // 序号
- MarketID int `json:"MarketID"` // 市场ID
- TradeMode int `json:"TradeMode"` // 交易模式
- MenuTitle string `json:"MenuTitle" xorm:"'ExExchangeName'"` // 菜单标题(市场名称或外部交易所名称)
- GoodsGroupIDs []int `json:"GoodsGroupIDs"` // 商品组ID列表
- ExExchangeID int `json:"ExExchangeID" xorm:"'ExExchangeID'"` // 外部交易所ID
- ExExchangeCode string `json:"ExExchangeCode" xorm:"'ExExchangeCode'"` // 外部交易所代码
- }
- // OperationPrimaryMenu 一级功能菜单
- type OperationPrimaryMenu struct {
- Key string `json:"Key"` // 菜单KEY
- Label string `json:"Label"` // 菜单标题
- Children []OperationSecondaryMenu `json:"Children"` // 二级功能菜单
- }
- // OperationSecondaryMenu 二级功能菜单
- type OperationSecondaryMenu struct {
- Key string `json:"Key"` // 菜单KEY
- Label string `json:"Label"` // 菜单标题
- TabList []OperationTabMenu `json:"TabList"` // 三级功能菜单
- }
- // OperationTabMenu 三级功能菜单
- type OperationTabMenu struct {
- Key string `json:"Key"` // 菜单KEY
- Label string `json:"Label"` // 菜单标题
- }
- // QueryTraderMenu 查询交易端菜单
- // @Summary 查询交易端菜单
- // @Produce json
- // @Param loginid query int true "登录账号"
- // @Success 200 {object} QueryTraderMenuRsp
- // @Failure 500 {object} app.Response
- // @Router /Common/QueryTraderMenu [get]
- // @Tags 通用
- func QueryTraderMenu(c *gin.Context) {
- appG := app.Gin{C: c}
- // 获取请求参数
- var req QueryTraderMenuReq
- if err := appG.C.ShouldBindQuery(&req); err != nil {
- logger.GetLogger().Errorf("QueryTraderMenu failed: %s", err.Error())
- appG.Response(http.StatusBadRequest, e.INVALID_PARAMS, nil)
- return
- }
- var queryTraderMenuRsp QueryTraderMenuRsp
- // 获取行情报价牌分类菜单
- if datas, err := getQuoteMenu(req.LoginID); err == nil {
- queryTraderMenuRsp.QuoteMenu = datas
- } else {
- logger.GetLogger().Errorf("QueryTraderMenu failed: %s", err.Error())
- appG.Response(http.StatusBadRequest, e.ERROR_QUERY_QUOTEMENU_FAIL, nil)
- return
- }
- // 获取功能菜单
- if datas, err := getOperationMenu(); err == nil {
- queryTraderMenuRsp.OperationMenu = datas
- } else {
- logger.GetLogger().Errorf("QueryTraderMenu failed: %s", err.Error())
- appG.Response(http.StatusBadRequest, e.ERROR_QUERY_OPERATIONMENU_FAIL, nil)
- return
- }
- // 查询成功
- logger.GetLogger().Infof("QueryTraderMenu successed: %v", queryTraderMenuRsp)
- appG.Response(http.StatusOK, e.SUCCESS, queryTraderMenuRsp)
- }
- // getQuoteMenu 获取行情报价牌分类菜单
- func getQuoteMenu(loginID int) ([]QuotePrimaryMenu, error) {
- engine := db.GetEngine()
- rst := make([]QuotePrimaryMenu, 0)
- // ********************* 准备数据 *********************
- var taAccounts []string // 账户下所有资金账户
- var marketIDs []int // 资金账户下有权限的市场ID列表
- // 先要获取当前登录账户对应的资金账户
- if err := engine.SQL(fmt.Sprintf(`select to_char(AccountID) from LoginTAAccount where LoginID = %d`, loginID)).Find(&taAccounts); err != nil {
- return nil, err
- }
- // 如果一条记录都没有则直接通过资金账户表获取
- if len(taAccounts) == 0 {
- sql := fmt.Sprintf(`select to_char(ta.accountid) from taaccount ta
- inner join loginaccount l on ta.userid = l.userid
- where l.loginid = %d`, loginID)
- if err := engine.SQL(sql).Find(&taAccounts); err != nil {
- return nil, err
- }
- }
- // 获取资金账户对应的市场权限(有权限的市场ID)
- if len(taAccounts) > 0 {
- taAccountStr := strings.Join(taAccounts, ",")
- if err := engine.SQL(fmt.Sprintf(`select MarketID from TAAccountMarket where AccountID in (%s)`, taAccountStr)).Find(&marketIDs); err != nil {
- return nil, err
- }
- }
- // ********************* 构建行情报价牌菜单 *********************
- // 获取一级菜单列表
- datas := make([]models.Tablecolumnconfig, 0)
- if err := engine.Where("TableKey = 'trader_master_menu' and IsShow = 1").Find(&datas); err != nil {
- return nil, err
- }
- // 构建一级菜单对象
- for i, v := range datas {
- quotePrimaryMenu := QuotePrimaryMenu{
- Index: i,
- Key: v.Columnfield,
- Name: v.Columntitle,
- SubMenus: make([]QuoteSecondaryMenu, 0),
- }
- // 跳过自选
- if v.Columnfield == "optional" {
- rst = append(rst, quotePrimaryMenu)
- continue
- }
- // FormatterString:模式,0-使用市场名称,1-使用外部交易所名称;Remark:包含市场交易模式
- quotePrimaryMenu.SubTitleType, _ = strconv.Atoi(v.Formatterstring)
- quotePrimaryMenu.TradeModes = v.Remark
- // 如果传入的LoginID获取不到有权限的市场ID列表(有可能LoginID是错误的),则不构建二级子菜单
- if len(marketIDs) == 0 {
- rst = append(rst, quotePrimaryMenu)
- continue
- }
- // 构建二级子菜单对象
- marketIDsStr := utils.JoinItoString(marketIDs, ",")
- if quotePrimaryMenu.SubTitleType == 0 {
- // 获取目标交易模式的市场信息
- markets := make([]models.Market, 0)
- if err := engine.Where(fmt.Sprintf(`TradeMode in (%s) and MarketID in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)).Find(&markets); err != nil {
- return nil, err
- }
- // 使用市场名称
- for mi, mv := range markets {
- quoteSecondaryMenu := QuoteSecondaryMenu{
- Index: mi,
- MarketID: int(mv.Marketid),
- TradeMode: int(mv.Trademode),
- MenuTitle: mv.Marketname,
- GoodsGroupIDs: make([]int, 0),
- }
- quotePrimaryMenu.SubMenus = append(quotePrimaryMenu.SubMenus, quoteSecondaryMenu)
- }
- } else {
- // 使用外部交易所名称
- quoteSecondaryMenus := make([]QuoteSecondaryMenu, 0)
- sql := fmt.Sprintf(`select distinct
- e.autoid ExExchangeID,
- e.ExExchangeName,
- e.ExExchangeCode
- from ExternalExchange e
- inner join goodsgroup g on g.exexchangeid = e.autoid
- inner join Market m on g.marketid = m.marketid
- where m.trademode in (%s) and m.marketid in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)
- if err := engine.SQL(sql).Find("eSecondaryMenus); err != nil {
- return nil, err
- }
- // 获取外部交易所对应的商品组信息
- for ei, ev := range quoteSecondaryMenus {
- q := "eSecondaryMenus[ei]
- q.Index = ei
- // 商品组列表
- goodsgroups := make([]models.Goodsgroup, 0)
- if err := engine.Where("Exexchangeid = ?", ev.ExExchangeID).Find(&goodsgroups); err != nil {
- return nil, err
- }
- marketID := 0
- var goodsGroupIDs []int
- for _, gv := range goodsgroups {
- marketID = int(gv.Marketid)
- goodsGroupIDs = append(goodsGroupIDs, int(gv.Goodsgroupid))
- }
- q.MarketID = marketID
- q.GoodsGroupIDs = goodsGroupIDs
- }
- quotePrimaryMenu.SubMenus = quoteSecondaryMenus
- }
- rst = append(rst, quotePrimaryMenu)
- }
- return rst, nil
- }
- // getOperationMenu 获取功能菜单
- func getOperationMenu() ([]OperationPrimaryMenu, error) {
- engine := db.GetEngine()
- rst := make([]OperationPrimaryMenu, 0)
- // 获取一级功能菜单
- opm := make([]models.Tablecolumnconfig, 0)
- if err := engine.Where("IsShow = 1 and TableKey = ?", "trader_operation_master_menu").Asc("ORDERINDEX").Find(&opm); err != nil {
- return nil, err
- }
- for _, pv := range opm {
- var operationPrimaryMenu = OperationPrimaryMenu{
- Key: pv.Columnfield,
- Label: pv.Columntitle,
- Children: make([]OperationSecondaryMenu, 0),
- }
- // 获取二级功能菜单
- osm := make([]models.Tablecolumnconfig, 0)
- if err := engine.Where("IsShow = 1 and Remark = ?", operationPrimaryMenu.Key).Asc("ORDERINDEX").Find(&osm); err != nil {
- return nil, err
- }
- for _, sv := range osm {
- var operationSecondaryMenu = OperationSecondaryMenu{
- Key: sv.Columnfield,
- Label: sv.Columntitle,
- TabList: make([]OperationTabMenu, 0),
- }
- // 获取三级功能菜单
- otm := make([]models.Tablecolumnconfig, 0)
- if err := engine.Where("IsShow = 1 and Remark = ?", operationSecondaryMenu.Key).Asc("ORDERINDEX").Find(&otm); err != nil {
- return nil, err
- }
- for _, tv := range otm {
- var operationTabMenu = OperationTabMenu{
- Key: tv.Columnfield,
- Label: tv.Columntitle,
- }
- operationSecondaryMenu.TabList = append(operationSecondaryMenu.TabList, operationTabMenu)
- }
- operationPrimaryMenu.Children = append(operationPrimaryMenu.Children, operationSecondaryMenu)
- }
- rst = append(rst, operationPrimaryMenu)
- }
- return rst, nil
- }
- // QueryTableColumnConfigReq 查询交易端列表头信息请求参数
- type QueryTableColumnConfigReq struct {
- TableKey string `json:"TableKey"` // 表key
- }
- // QueryTableColumnConfig 查询交易端列表头信息
- // @Summary 查询交易端列表头信息
- // @Produce json
- // @Param TableKey query string false "表key"
- // @Success 200 {object} models.Tablecolumnconfig
- // @Failure 500 {object} app.Response
- // @Router /Common/QueryTableColumnConfig [get]
- // @Tags 通用
- func QueryTableColumnConfig(c *gin.Context) {
- appG := app.Gin{C: c}
- // 获取请求参数
- var req QueryTableColumnConfigReq
- if err := appG.C.ShouldBindQuery(&req); err != nil {
- logger.GetLogger().Errorf("QueryTableColumnConfig failed: %s", err.Error())
- appG.Response(http.StatusBadRequest, e.INVALID_PARAMS, nil)
- return
- }
- engine := db.GetEngine()
- tablecolumnconfigs := make([]models.Tablecolumnconfig, 0)
- // 这里的表名必须要大写 (Oracle的表名都是大写)
- s := engine.Join("INNER", "TABLEDEFINE", "TABLEDEFINE.TableKey = TABLECOLUMNCONFIG.TableKey")
- if len(req.TableKey) > 0 {
- s = s.Where("TABLEDEFINE.TableType = 2 and TABLEDEFINE.TableKey = ?", req.TableKey)
- } else {
- s = s.Where("TABLEDEFINE.TableType = 2")
- }
- if err := s.Find(&tablecolumnconfigs); err != nil {
- logger.GetLogger().Errorf("QueryTableColumnConfig failed: %s", err.Error())
- appG.Response(http.StatusBadRequest, e.ERROR_QUERY_FAIL, nil)
- return
- }
- // 查询成功
- logger.GetLogger().Infof("QueryTableColumnConfig successed: %v", tablecolumnconfigs)
- appG.Response(http.StatusOK, e.SUCCESS, tablecolumnconfigs)
- }
|