common.go 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573
  1. package models
  2. import (
  3. "errors"
  4. "fmt"
  5. "mtp2_if/db"
  6. "mtp2_if/global/utils"
  7. "strconv"
  8. "time"
  9. )
  10. // Funcmenulist 功能菜单表
  11. type Funcmenulist struct {
  12. Resourcecode string `json:"resourcecode" xorm:"'RESOURCECODE'" binding:"required"` // 资源代码 - M001 一级菜单编码 0001 二级菜单编码 0001 三级菜单M00100000000 系统管理M00100010000 参数管理M00100010001 参数管理--修改M00100010002 参数管理--删除M00100020000 区域管理
  13. Resourcename string `json:"resourcename" xorm:"'RESOURCENAME'"` // 资源名
  14. Resourcelevel uint32 `json:"resourcelevel" xorm:"'RESOURCELEVEL'"` // 级别1-一级 2-二级 3-三级4-四级
  15. Menutype uint32 `json:"menutype" xorm:"'MENUTYPE'"` // 1- 管理端 2- 交易端 3 - 已失效
  16. Parentcode string `json:"parentcode" xorm:"'PARENTCODE'"` // 上级资源代码
  17. URL string `json:"url" xorm:"'URL'"` // URL
  18. Sort uint32 `json:"sort" xorm:"'SORT'"` // 排序 - 一级时,是所有一级菜单的排序顺序;二级时是所属同一个一级菜单下的排序、三级时是同一个二级菜单下的排序
  19. Iconame string `json:"iconame" xorm:"'ICONAME'"` // 菜单图标
  20. Remark string `json:"remark" xorm:"'REMARK'"` // Remark
  21. }
  22. // TableName is FUNCMENULIST
  23. func (Funcmenulist) TableName() string {
  24. return "FUNCMENULIST"
  25. }
  26. // Rolefuncmenu 角色菜单表
  27. type Rolefuncmenu struct {
  28. Roleid uint32 `json:"roleid" xorm:"'ROLEID'" binding:"required"` // 角色权限ID
  29. Resourcecode string `json:"resourcecode" xorm:"'RESOURCECODE'" binding:"required"` // 菜单代码
  30. }
  31. // TableName is ROLEFUNCMENU
  32. func (Rolefuncmenu) TableName() string {
  33. return "ROLEFUNCMENU"
  34. }
  35. // Tabledefine 列表定义表
  36. type Tabledefine struct {
  37. Tablekey string `json:"tablekey" xorm:"'TABLEKEY'" binding:"required"` // 列表Key
  38. Tabletype uint32 `json:"tabletype" xorm:"'TABLETYPE'"` // 列表类型 - 1:管理端 2:终端
  39. Tablename string `json:"tablename" xorm:"'TABLENAME'"` // 列表名称
  40. Tabelmenu string `json:"tabelmenu" xorm:"'TABELMENU'"` // 列表菜单
  41. Remark string `json:"remark" xorm:"'REMARK'"` // Remark
  42. }
  43. // TableName is TABLEDEFINE
  44. func (Tabledefine) TableName() string {
  45. return "TABLEDEFINE"
  46. }
  47. // Tablecolumnconfig 列表表头配置表
  48. type Tablecolumnconfig struct {
  49. Autoid uint64 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // AutoID
  50. Tablekey string `json:"tablekey" xorm:"'TABLEKEY'"` // 列表Key
  51. Columnfield string `json:"columnfield" xorm:"'COLUMNFIELD'"` // 列字段
  52. Columntitle string `json:"columntitle" xorm:"'COLUMNTITLE'"` // 列Title
  53. Columnwidth string `json:"columnwidth" xorm:"'COLUMNWIDTH'"` // 列宽
  54. Orderindex uint32 `json:"orderindex" xorm:"'ORDERINDEX'"` // 顺序
  55. Isshow uint32 `json:"isshow" xorm:"'ISSHOW'"` // 是否显示 - 0:不显示 1:显示
  56. Aligntype uint32 `json:"aligntype" xorm:"'ALIGNTYPE'"` // 对齐方式 - 1:居中对齐 2:左对齐 3:右对齐
  57. Formattertype string `json:"formattertype" xorm:"'FORMATTERTYPE'"` // 格式化类型
  58. Formatterstring string `json:"formatterstring" xorm:"'FORMATTERSTRING'"` // 格式化字符
  59. Remark string `json:"remark" xorm:"'REMARK'"` // 备注
  60. Needsummary uint32 `json:"needsummary" xorm:"'NEEDSUMMARY'"` // 是否需要汇总 - 0:不需要 1:需要
  61. Summarytype uint32 `json:"summarytype" xorm:"'SUMMARYTYPE'"` // 汇总类型 - 1:加总 2:最后一个
  62. Groupname string `json:"groupname" xorm:"'GROUPNAME'"` // 表头分组名称
  63. }
  64. // TableName is TABLECOLUMNCONFIG
  65. func (Tablecolumnconfig) TableName() string {
  66. return "TABLECOLUMNCONFIG"
  67. }
  68. // Enumdicitem 枚举项字典表
  69. type Enumdicitem struct {
  70. Autoid uint64 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 自增ID
  71. Enumdicid uint32 `json:"enumdicid" xorm:"'ENUMDICID'" binding:"required"` // 所属枚举ID
  72. Enumdiccode string `json:"enumdiccode" xorm:"'ENUMDICCODE'" binding:"required"` // 所属枚举代码
  73. Enumdicname string `json:"enumdicname" xorm:"'ENUMDICNAME'"` // 枚举项名称
  74. Enumitemname uint64 `json:"enumitemname" xorm:"'ENUMITEMNAME'" binding:"required"` // 枚举项值
  75. Enumitemstatus uint32 `json:"enumitemstatus" xorm:"'ENUMITEMSTATUS'"` // 枚举项状态 - 1.启用 2.不启用
  76. Bankmappedvalue string `json:"bankmappedvalue" xorm:"'BANKMAPPEDVALUE'"` // 银行服务对应值
  77. Remark string `json:"remark" xorm:"'REMARK'"` // 备注
  78. Enumitemvalue string `json:"enumitemvalue" xorm:"'ENUMITEMVALUE'"` // 通用值 - [币种通用简写]
  79. Param1 string `json:"param1" xorm:"'PARAM1'"` // 参数1[币种:币种小数位]
  80. Param2 string `json:"param2" xorm:"'PARAM2'"` // 参数1[币种:币种显示单位]
  81. }
  82. // TableName is ENUMDICITEM
  83. func (Enumdicitem) TableName() string {
  84. return "ENUMDICITEM"
  85. }
  86. // Noticemsg 公告消息表
  87. type Noticemsg struct {
  88. Autoid int32 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 自增ID
  89. Msgtype int32 `json:"msgtype" xorm:"'MSGTYPE'"` // 消息类型 - 1:公告通知 2:系统消息
  90. Title string `json:"title" xorm:"'TITLE'"` // 标题
  91. Content string `json:"content" xorm:"'CONTENT'"` // 内容
  92. Scheduletime time.Time `json:"scheduletime" xorm:"'SCHEDULETIME'"` // 计划发送时间
  93. Publisher string `json:"publisher" xorm:"'PUBLISHER'"` // 消息发布者
  94. Sendtype int32 `json:"sendtype" xorm:"'SENDTYPE'"` // 推送方式 - 1:全体广播 2:按会员广播 3:个人推送 4:按会员广播(仅会员)
  95. Userid int64 `json:"userid" xorm:"'USERID'"` // 会员/投资者ID推送方式 为 个人时,填写投资者ID
  96. Istop int32 `json:"istop" xorm:"'ISTOP'"` // 是否置顶 - 0:不置顶 1:置顶
  97. Sentstatus int32 `json:"sentstatus" xorm:"'SENTSTATUS'"` // 推送状态 - 0:未推送 1:已推送 2:审核拒绝
  98. Endtime time.Time `json:"endtime" xorm:"'ENDTIME'"` // 结束时间
  99. Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 建仓人
  100. Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  101. Auditoruserid int64 `json:"auditoruserid" xorm:"'AUDITORUSERID'"` // 审核人
  102. Audittime time.Time `json:"audittime" xorm:"'AUDITTIME'"` // 审核日期
  103. Auditremark string `json:"auditremark" xorm:"'AUDITREMARK'"` // 审核备注
  104. }
  105. // TableName is NOTICEMSG
  106. func (Noticemsg) TableName() string {
  107. return "NOTICEMSG"
  108. }
  109. // Memberrecv 会员消息接受表
  110. type Memberrecv struct {
  111. Msgid int32 `json:"msgid" xorm:"'MSGID'" binding:"required"` // 消息ID
  112. Memberid int64 `json:"memberid" xorm:"'MEMBERID'" binding:"required"` // 会员用户ID
  113. }
  114. // TableName is MEMBERRECV
  115. func (Memberrecv) TableName() string {
  116. return "MEMBERRECV"
  117. }
  118. // Msgreceiver 管理端消息接收者
  119. type Msgreceiver struct {
  120. Autoid int32 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 消息ID
  121. Managerid int64 `json:"managerid" xorm:"'MANAGERID'" binding:"required"` // 用户ID
  122. Readstatus int32 `json:"readstatus" xorm:"'READSTATUS'" binding:"required"` // 消息状态 - 1:未阅读 2:已阅读 3:已删除
  123. Receivertype int32 `json:"receivertype" xorm:"'RECEIVERTYPE'" binding:"required"` // 接收用户类型 - 1:管理端用户 2:终端用户
  124. Updatetime time.Time `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  125. }
  126. // TableName is MSGRECEIVER
  127. func (Msgreceiver) TableName() string {
  128. return "MSGRECEIVER"
  129. }
  130. // Division 行政区域表
  131. type Division struct {
  132. Autoid int64 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 自增ID
  133. Divisioncode string `json:"divisioncode" xorm:"'DIVISIONCODE'" binding:"required"` // 行政代码
  134. Shortcode string `json:"shortcode" xorm:"'SHORTCODE'"` // 地区简码
  135. Parentcode string `json:"parentcode" xorm:"'PARENTCODE'"` // 上级行政代码
  136. Divisionlevel string `json:"divisionlevel" xorm:"'DIVISIONLEVEL'"` // 行政级别
  137. Divisionname string `json:"divisionname" xorm:"'DIVISIONNAME'"` // 行政名称
  138. Pathname string `json:"pathname" xorm:"'PATHNAME'"` // 路径名称
  139. Separablename string `json:"separablename" xorm:"'SEPARABLENAME'"` // 可拆分的全称
  140. Postcode string `json:"postcode" xorm:"'POSTCODE'"` // 邮政编码
  141. Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
  142. Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 修改人
  143. }
  144. // TableName is DIVISION
  145. func (Division) TableName() string {
  146. return "DIVISION"
  147. }
  148. // QuotePrimaryMenu 报价牌一级分类菜单
  149. type QuotePrimaryMenu struct {
  150. Index int `json:"Index"` // 序号
  151. Key string `json:"Key"` // 键名
  152. Name string `json:"Name"` // 菜单名称
  153. SubTitleType int `json:"SubTitleType"` // 子菜单标题模式:0-市场名称;1-外部交易所名称
  154. TradeModes string `json:"TradeModes"` // 包含市场交易类型
  155. SubMenus []QuoteSecondaryMenu `json:"SubMenus"` // 子菜单
  156. }
  157. // QuoteSecondaryMenu 报价牌二级分类菜单
  158. type QuoteSecondaryMenu struct {
  159. Index int `json:"Index"` // 序号
  160. MarketID int `json:"MarketID"` // 市场ID
  161. TradeMode int `json:"TradeMode"` // 交易模式
  162. MenuTitle string `json:"MenuTitle" xorm:"'ExExchangeName'"` // 菜单标题(市场名称或外部交易所名称)
  163. GoodsGroupIDs []int `json:"GoodsGroupIDs"` // 商品组ID列表
  164. ExExchangeID int `json:"ExExchangeID" xorm:"'ExExchangeID'"` // 外部交易所ID
  165. ExExchangeCode string `json:"ExExchangeCode" xorm:"'ExExchangeCode'"` // 外部交易所代码
  166. }
  167. // OperationPrimaryMenu 一级功能菜单
  168. type OperationPrimaryMenu struct {
  169. Key string `json:"Key"` // 菜单KEY
  170. Label string `json:"Label"` // 菜单标题
  171. Children []OperationSecondaryMenu `json:"Children"` // 二级功能菜单
  172. }
  173. // OperationSecondaryMenu 二级功能菜单
  174. type OperationSecondaryMenu struct {
  175. Key string `json:"Key"` // 菜单KEY
  176. Label string `json:"Label"` // 菜单标题
  177. TabList []OperationTabMenu `json:"TabList"` // 三级功能菜单
  178. }
  179. // OperationTabMenu 三级功能菜单
  180. type OperationTabMenu struct {
  181. Key string `json:"Key"` // 菜单KEY
  182. Label string `json:"Label"` // 菜单标题
  183. }
  184. // GetQuoteMenu 获取行情报价牌分类菜单
  185. func GetQuoteMenu(loginID int) ([]QuotePrimaryMenu, error) {
  186. engine := db.GetEngine()
  187. rst := make([]QuotePrimaryMenu, 0)
  188. // 账户下有权限的市场ID列表
  189. var marketIDs []int
  190. // 获取账户类型 - 1:交易所 2:机构 3:会员子机构 4:经纪人 5:投资者 6:客户 (目前可能登录交易端的账号类型为 2 5)
  191. userAccount := new(Useraccount)
  192. has, err := engine.Join("INNER", "LOGINACCOUNT", "USERACCOUNT.UserID = LOGINACCOUNT.UserID").Where("LOGINACCOUNT.LoginID = ?", loginID).Get(userAccount)
  193. if err != nil || !has {
  194. return nil, err
  195. }
  196. if userAccount.Usertype == 5 {
  197. // 如果账户类型为5(投资者),则需要通过其所属经济会员来获取市场权限(表:AreaRoleMarket, 条件:对应市场状态为正常;角色类型:经济会员)
  198. if err := engine.Table("AREAROLEMARKET").
  199. Cols("AREAROLEMARKET.MARKETID").
  200. Join("INNER", "MARKET", "MARKET.MARKETID = AREAROLEMARKET.MARKETID").
  201. Where("MARKET.MARKETSTATUS = 2 and AREAROLEMARKET.ROLETYPE = 7 and AREAROLEMARKET.AREAUSERID = ?", userAccount.Memberuserid).Find(&marketIDs); err != nil {
  202. return nil, err
  203. }
  204. } else {
  205. // 非投资者账号直接通过资金账号获取市场权限(表:TAAccountMarket)
  206. var taAccounts []string // 账户下所有资金账户
  207. // 先要获取当前登录账户对应的资金账户;如果为外部子资金账号(TaAccount.TaAccountType = 1),则使用TaAccount.FromAccountID来获取市场权限
  208. type taAccount struct {
  209. AccountID int `xorm:"ACCOUNTID"`
  210. TaAccountType int `xorm:"TAACCOUNTTYPE"`
  211. FromAccountID int `xorm:"FROMACCOUNTID"`
  212. }
  213. datas := make([]taAccount, 0)
  214. if err := engine.Table("LOGINTAACCOUNT").
  215. Join("INNER", "TAACCOUNT", "LOGINTAACCOUNT.ACCOUNTID = TAACCOUNT.ACCOUNTID").
  216. Cols("TAACCOUNT.ACCOUNTID", "TAACCOUNT.TAACCOUNTTYPE", "TAACCOUNT.FROMACCOUNTID").
  217. Where("LOGINTAACCOUNT.LOGINID = ?", loginID).Find(&datas); err != nil {
  218. return nil, err
  219. }
  220. // 如果一条记录都没有(未配置自营会员资金账户)则直接通过资金账户表获取
  221. if len(datas) == 0 {
  222. // 这里要注意,TaAccount表与LoginAccount表关联时,要使用TaAccount.RelatedUserID
  223. if err := engine.Table("TAACCOUNT").
  224. Join("INNER", "LOGINACCOUNT", "TAACCOUNT.RELATEDUSERID = LOGINACCOUNT.USERID").
  225. Cols("TAACCOUNT.ACCOUNTID", "TAACCOUNT.TAACCOUNTTYPE", "TAACCOUNT.FROMACCOUNTID").
  226. Where("LOGINACCOUNT.LOGINID = ?", loginID).Find(&datas); err != nil {
  227. return nil, err
  228. }
  229. }
  230. for _, v := range datas {
  231. if v.TaAccountType == 1 {
  232. // 外部资金账户使用TaAccount.FromAccountID来获取市场权限
  233. taAccounts = append(taAccounts, strconv.Itoa(v.FromAccountID))
  234. } else {
  235. taAccounts = append(taAccounts, strconv.Itoa(v.AccountID))
  236. }
  237. }
  238. // 获取资金账户对应的市场权限(有权限的市场ID)
  239. if len(taAccounts) > 0 {
  240. // taAccountStr := strings.Join(taAccounts, ",")
  241. if err := engine.Table("TAACCOUNTMARKET").
  242. Join("INNER", "MARKET", "MARKET.MARKETID = TAACCOUNTMARKET.MARKETID").
  243. Cols("TAACCOUNTMARKET.MARKETID").
  244. In("TAACCOUNTMARKET.ACCOUNTID", taAccounts).
  245. And("MARKET.MARKETSTATUS = 2").Find(&marketIDs); err != nil {
  246. return nil, err
  247. }
  248. }
  249. }
  250. // ********************* 构建行情报价牌菜单 *********************
  251. datas := make([]Funcmenulist, 0)
  252. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  253. Where("FUNCMENULIST.PARENTCODE = 'trader_master_menu'").
  254. Asc("SORT").
  255. Find(&datas); err != nil {
  256. return nil, err
  257. }
  258. // 构建一级菜单对象
  259. for i, v := range datas {
  260. quotePrimaryMenu := QuotePrimaryMenu{
  261. Index: i,
  262. Key: v.Resourcecode,
  263. Name: v.Resourcename,
  264. SubMenus: make([]QuoteSecondaryMenu, 0),
  265. }
  266. // 跳过自选
  267. if v.Resourcecode == "optional" {
  268. rst = append(rst, quotePrimaryMenu)
  269. continue
  270. }
  271. // URL:模式,0-使用市场名称,1-使用外部交易所名称;Remark:包含市场交易模式
  272. quotePrimaryMenu.SubTitleType, _ = strconv.Atoi(v.URL)
  273. quotePrimaryMenu.TradeModes = v.Remark
  274. // 如果传入的LoginID获取不到有权限的市场ID列表(有可能LoginID是错误的),则不构建二级子菜单
  275. if len(marketIDs) == 0 {
  276. rst = append(rst, quotePrimaryMenu)
  277. continue
  278. }
  279. // 构建二级子菜单对象
  280. marketIDsStr := utils.JoinItoString(marketIDs, ",")
  281. if quotePrimaryMenu.SubTitleType == 0 {
  282. // 获取目标交易模式的市场信息
  283. markets := make([]Market, 0)
  284. if err := engine.Where(fmt.Sprintf(`TradeMode in (%s) and MarketID in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)).Find(&markets); err != nil {
  285. return nil, err
  286. }
  287. // 使用市场名称
  288. for mi, mv := range markets {
  289. quoteSecondaryMenu := QuoteSecondaryMenu{
  290. Index: mi,
  291. MarketID: int(mv.Marketid),
  292. TradeMode: int(mv.Trademode),
  293. MenuTitle: mv.Marketname,
  294. GoodsGroupIDs: make([]int, 0),
  295. }
  296. quotePrimaryMenu.SubMenus = append(quotePrimaryMenu.SubMenus, quoteSecondaryMenu)
  297. }
  298. } else {
  299. // 使用外部交易所名称
  300. quoteSecondaryMenus := make([]QuoteSecondaryMenu, 0)
  301. sql := fmt.Sprintf(`select distinct
  302. e.autoid ExExchangeID,
  303. e.ExExchangeName,
  304. e.ExExchangeCode
  305. from ExternalExchange e
  306. inner join goodsgroup g on g.exexchangeid = e.autoid
  307. inner join Market m on g.marketid = m.marketid
  308. where m.trademode in (%s) and m.marketid in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)
  309. if err := engine.SQL(sql).Find(&quoteSecondaryMenus); err != nil {
  310. return nil, err
  311. }
  312. // 获取外部交易所对应的商品组信息
  313. for ei, ev := range quoteSecondaryMenus {
  314. q := &quoteSecondaryMenus[ei]
  315. q.Index = ei
  316. // 商品组列表
  317. goodsgroups := make([]Goodsgroup, 0)
  318. if err := engine.Where("Exexchangeid = ?", ev.ExExchangeID).Find(&goodsgroups); err != nil {
  319. return nil, err
  320. }
  321. marketID := 0
  322. var goodsGroupIDs []int
  323. for _, gv := range goodsgroups {
  324. marketID = int(gv.Marketid)
  325. goodsGroupIDs = append(goodsGroupIDs, int(gv.Goodsgroupid))
  326. }
  327. q.MarketID = marketID
  328. q.GoodsGroupIDs = goodsGroupIDs
  329. }
  330. quotePrimaryMenu.SubMenus = quoteSecondaryMenus
  331. }
  332. rst = append(rst, quotePrimaryMenu)
  333. }
  334. return rst, nil
  335. }
  336. // GetOperationMenu 获取功能菜单
  337. func GetOperationMenu() ([]OperationPrimaryMenu, error) {
  338. engine := db.GetEngine()
  339. rst := make([]OperationPrimaryMenu, 0)
  340. // 获取一级功能菜单
  341. opm := make([]Funcmenulist, 0)
  342. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  343. Where("FUNCMENULIST.PARENTCODE = 'trader_operation_master_menu'").
  344. Asc("SORT").
  345. Find(&opm); err != nil {
  346. return nil, err
  347. }
  348. for _, pv := range opm {
  349. var operationPrimaryMenu = OperationPrimaryMenu{
  350. Key: pv.Resourcecode,
  351. Label: pv.Resourcename,
  352. Children: make([]OperationSecondaryMenu, 0),
  353. }
  354. // 获取二级功能菜单
  355. osm := make([]Funcmenulist, 0)
  356. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  357. Where("FUNCMENULIST.PARENTCODE = ?", operationPrimaryMenu.Key).
  358. Asc("SORT").
  359. Find(&osm); err != nil {
  360. return nil, err
  361. }
  362. for _, sv := range osm {
  363. var operationSecondaryMenu = OperationSecondaryMenu{
  364. Key: sv.Resourcecode,
  365. Label: sv.Resourcename,
  366. TabList: make([]OperationTabMenu, 0),
  367. }
  368. // 获取三级功能菜单
  369. otm := make([]Funcmenulist, 0)
  370. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  371. Where("FUNCMENULIST.PARENTCODE = ?", operationSecondaryMenu.Key).
  372. Asc("SORT").
  373. Find(&otm); err != nil {
  374. return nil, err
  375. }
  376. for _, tv := range otm {
  377. var operationTabMenu = OperationTabMenu{
  378. Key: tv.Resourcecode,
  379. Label: tv.Resourcename,
  380. }
  381. operationSecondaryMenu.TabList = append(operationSecondaryMenu.TabList, operationTabMenu)
  382. }
  383. operationPrimaryMenu.Children = append(operationPrimaryMenu.Children, operationSecondaryMenu)
  384. }
  385. rst = append(rst, operationPrimaryMenu)
  386. }
  387. return rst, nil
  388. }
  389. // GetClientTableDefines 获取终端列表定义信息
  390. // tableKey 列表Key
  391. func GetClientTableDefines(tableKey string) ([]Tabledefine, error) {
  392. engine := db.GetEngine()
  393. tableDefiles := make([]Tabledefine, 0)
  394. s := engine.Where("TABLEDEFINE.TableType = 2") // TableType = 2 表示终端专用表定义
  395. if len(tableKey) > 0 {
  396. s = s.And("TABLEDEFINE.TableKey = ?", tableKey)
  397. }
  398. if err := s.Find(&tableDefiles); err != nil {
  399. return nil, err
  400. }
  401. return tableDefiles, nil
  402. }
  403. // GetClientTableColumns 获取客户端指定表的列头信息
  404. // tableKey 列表Key
  405. func GetClientTableColumns(tableKey string) ([]Tablecolumnconfig, error) {
  406. engine := db.GetEngine()
  407. // 获取列表数据
  408. tablecolumnconfigs := make([]Tablecolumnconfig, 0)
  409. // 这里的表名必须要大写 (Oracle的表名都是大写)
  410. if err := engine.Join("INNER", "TABLEDEFINE", "TABLEDEFINE.TableKey = TABLECOLUMNCONFIG.TableKey").
  411. Where("TABLEDEFINE.TableType = 2 and TABLEDEFINE.TableKey = ?", tableKey).Find(&tablecolumnconfigs); err != nil {
  412. return nil, err
  413. }
  414. return tablecolumnconfigs, nil
  415. }
  416. // GetNotices 获取指定账户的通知信息(终端)
  417. // 参数 loginID int 登录账号
  418. // 参数 msgType int 消息类型 - 1:公告通知 2:系统消息
  419. // 参数 onlyUnRead bool 是否只获取未读信息
  420. func GetNotices(loginID, msgType int, onlyUnRead bool) ([]Noticemsg, error) {
  421. engine := db.GetEngine()
  422. rst := make([]Noticemsg, 0)
  423. // 获取登录账号所属会员信息
  424. var userAccount Useraccount
  425. if has, _ := engine.Join("LEFT", "LOGINACCOUNT", "LOGINACCOUNT.USERID = USERACCOUNT.USERID").
  426. Where("LOGINACCOUNT.LOGINID = ?", loginID).Get(&userAccount); !has {
  427. return nil, errors.New("获取登录账号所属会员ID失败")
  428. }
  429. // 获取登录账号已读公告ID, 这里要使用的是个人的UserID来查询
  430. var msgReceivers []int
  431. engine.Table("MSGRECEIVER").Select("AUTOID").Where("RECEIVERTYPE = 2 and MANAGERID = ?", userAccount.Userid).Find(&msgReceivers)
  432. // 查询SENDTYPE = 1的数据
  433. datas1 := make([]Noticemsg, 0)
  434. s := engine.Where("SENDTYPE = 1 and SYSDATE > SCHEDULETIME and SYSDATE < ENDTIME and SENTSTATUS=1").
  435. And("PUBLISHER = ? or PUBLISHER in (select USERACCOUNT.USERID from USERACCOUNT where USERACCOUNT.USERTYPE = 1)", userAccount.Memberuserid)
  436. if msgType > 0 {
  437. s = s.And("MSGTYPE = ?", msgType)
  438. }
  439. if onlyUnRead && len(msgReceivers) > 0 {
  440. s = s.NotIn("AUTOID", msgReceivers)
  441. }
  442. if err := s.Find(&datas1); err != nil {
  443. // 查询失败
  444. return nil, err
  445. }
  446. rst = append(rst, datas1...)
  447. // 查询SENDTYPE = 2的数据
  448. datas2 := make([]Noticemsg, 0)
  449. s = engine.Where(fmt.Sprintf(`AUTOID in (select MEMBERRECV.MSGID from MEMBERRECV where MEMBERRECV.MEMBERID = %d)`, userAccount.Memberuserid)).
  450. And("SENDTYPE = 2 and SYSDATE > SCHEDULETIME and SYSDATE < ENDTIME and SENTSTATUS=1")
  451. if msgType > 0 {
  452. s = s.And("MSGTYPE = ?", msgType)
  453. }
  454. if onlyUnRead && len(msgReceivers) > 0 {
  455. s = s.NotIn("AUTOID", msgReceivers)
  456. }
  457. if err := s.Find(&datas2); err != nil {
  458. // 查询失败
  459. return nil, err
  460. }
  461. rst = append(rst, datas2...)
  462. // 查询SENDTYPE = 3的数据
  463. datas3 := make([]Noticemsg, 0)
  464. s = engine.Where(fmt.Sprintf(`USERID = (SELECT USERID FROM LOGINACCOUNT WHERE LOGINID = %d)`, loginID)).
  465. And("SENDTYPE = 3 and SYSDATE > SCHEDULETIME and SYSDATE < ENDTIME and SENTSTATUS=1")
  466. if msgType > 0 {
  467. s = s.And("MSGTYPE = ?", msgType)
  468. }
  469. if onlyUnRead && len(msgReceivers) > 0 {
  470. s = s.NotIn("AUTOID", msgReceivers)
  471. }
  472. if err := s.Find(&datas3); err != nil {
  473. // 查询失败
  474. return nil, err
  475. }
  476. rst = append(rst, datas3...)
  477. return rst, nil
  478. }
  479. // GetEnumDicItem 获取枚举信息数组
  480. // 参数 enumDicCode string 所属枚举代码,必填
  481. // 参数 enumItemName int 枚举项值,选填,不需要则传入0
  482. // 返回 []Enumdicitem 枚举信息数组
  483. // 返回 error error
  484. func GetEnumDicItem(enumDicCode string, enumItemName int) ([]Enumdicitem, error) {
  485. engine := db.GetEngine()
  486. enumDicItems := make([]Enumdicitem, 0)
  487. session := engine.Where("ENUMDICCODE = ?", enumDicCode)
  488. if enumItemName > 0 {
  489. session = session.And("ENUMITEMNAME = ?", enumItemName)
  490. }
  491. if err := session.Find(&enumDicItems); err != nil {
  492. return nil, err
  493. }
  494. return enumDicItems, nil
  495. }
  496. // GetProvincesAndCities 获取省市信息数组
  497. // 参数 provinceID int 省ID,选填
  498. // 返回 []Division 枚举信息数组
  499. // 返回 error error
  500. func GetProvincesAndCities(provinceID int) ([]Division, error) {
  501. engine := db.GetEngine()
  502. divisions := make([]Division, 0)
  503. session := engine.Where("DIVISIONLEVEL = 'province' or DIVISIONLEVEL = 'city'")
  504. if provinceID > 0 {
  505. session = session.And("AUTOID = ?", provinceID)
  506. }
  507. if err := session.Find(&divisions); err != nil {
  508. return nil, err
  509. }
  510. return divisions, nil
  511. }