common.go 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970
  1. package models
  2. import (
  3. "errors"
  4. "fmt"
  5. "mtp2_if/db"
  6. "mtp2_if/mtpcache"
  7. "mtp2_if/utils"
  8. "strconv"
  9. "time"
  10. )
  11. // Funcmenulist 功能菜单表
  12. type Funcmenulist struct {
  13. Resourcecode string `json:"resourcecode" xorm:"'RESOURCECODE'" binding:"required"` // 资源代码
  14. Resourcename string `json:"resourcename" xorm:"'RESOURCENAME'"` // 资源名
  15. Resourcelevel uint32 `json:"resourcelevel" xorm:"'RESOURCELEVEL'"` // 级别 1-一级 2-二级 3-三级 4-四级
  16. Menutype uint32 `json:"menutype" xorm:"'MENUTYPE'"` // 菜单类型 1-管理端 2-交易端 3-终端权限
  17. Parentcode string `json:"parentcode" xorm:"'PARENTCODE'"` // 上级资源代码
  18. URL string `json:"url" xorm:"'URL'"` // URL
  19. Sort uint32 `json:"sort" xorm:"'SORT'"` // 排序 - 一级时,是所有一级菜单的排序顺序;二级时是所属同一个一级菜单下的排序、三级时是同一个二级菜单下的排序
  20. Iconame string `json:"iconame" xorm:"'ICONAME'"` // 菜单图标
  21. Remark string `json:"remark" xorm:"'REMARK'"` // 备注
  22. }
  23. // TableName is FUNCMENULIST
  24. func (Funcmenulist) TableName() string {
  25. return "FUNCMENULIST"
  26. }
  27. // GetPCMenuList 获取PC版本功能菜单表
  28. func (t *Funcmenulist) GetPCMenuList(resourceCode, parentCode string) ([]Funcmenulist, error) {
  29. funcMenuLists := make([]Funcmenulist, 0)
  30. session := db.GetEngine().Table("FUNCMENULIST T").Where("T.MENUTYPE = 2")
  31. if len(resourceCode) != 0 {
  32. session = session.And("T.RESOURCECODE = ?", resourceCode)
  33. }
  34. if len(parentCode) != 0 {
  35. session = session.And("T.PARENTCODE = ?", parentCode)
  36. }
  37. if err := session.Find(&funcMenuLists); err != nil {
  38. return nil, err
  39. }
  40. return funcMenuLists, nil
  41. }
  42. // GetMenuList 获取指定类型的功能菜单表
  43. func (t *Funcmenulist) GetMenuList(menuType int) ([]Funcmenulist, error) {
  44. funcMenuLists := make([]Funcmenulist, 0)
  45. session := db.GetEngine().Table("FUNCMENULIST T").Where("T.MENUTYPE = ?", menuType)
  46. if err := session.Find(&funcMenuLists); err != nil {
  47. return nil, err
  48. }
  49. return funcMenuLists, nil
  50. }
  51. // Rolefuncmenu 角色菜单表
  52. type Rolefuncmenu struct {
  53. Roleid uint32 `json:"roleid" xorm:"'ROLEID'" binding:"required"` // 角色权限ID
  54. Resourcecode string `json:"resourcecode" xorm:"'RESOURCECODE'" binding:"required"` // 菜单代码
  55. }
  56. // TableName is ROLEFUNCMENU
  57. func (Rolefuncmenu) TableName() string {
  58. return "ROLEFUNCMENU"
  59. }
  60. // Tabledefine 列表定义表
  61. type Tabledefine struct {
  62. Tablekey string `json:"tablekey" xorm:"'TABLEKEY'" binding:"required"` // 列表Key
  63. Tabletype uint32 `json:"tabletype" xorm:"'TABLETYPE'"` // 列表类型 - 1:管理端 2:终端
  64. Tablename string `json:"tablename" xorm:"'TABLENAME'"` // 列表名称
  65. Tabelmenu string `json:"tabelmenu" xorm:"'TABELMENU'"` // 列表菜单
  66. Remark string `json:"remark" xorm:"'REMARK'"` // Remark
  67. }
  68. // TableName is TABLEDEFINE
  69. func (Tabledefine) TableName() string {
  70. return "TABLEDEFINE"
  71. }
  72. // Tablecolumnconfig 列表表头配置表
  73. type Tablecolumnconfig struct {
  74. Autoid uint64 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // AutoID
  75. Tablekey string `json:"tablekey" xorm:"'TABLEKEY'"` // 列表Key
  76. Columnfield string `json:"columnfield" xorm:"'COLUMNFIELD'"` // 列字段
  77. Columntitle string `json:"columntitle" xorm:"'COLUMNTITLE'"` // 列Title
  78. Columnwidth string `json:"columnwidth" xorm:"'COLUMNWIDTH'"` // 列宽
  79. Orderindex uint32 `json:"orderindex" xorm:"'ORDERINDEX'"` // 顺序
  80. Isshow uint32 `json:"isshow" xorm:"'ISSHOW'"` // 是否显示 - 0:不显示 1:显示
  81. Aligntype uint32 `json:"aligntype" xorm:"'ALIGNTYPE'"` // 对齐方式 - 1:居中对齐 2:左对齐 3:右对齐
  82. Formattertype string `json:"formattertype" xorm:"'FORMATTERTYPE'"` // 格式化类型
  83. Formatterstring string `json:"formatterstring" xorm:"'FORMATTERSTRING'"` // 格式化字符
  84. Remark string `json:"remark" xorm:"'REMARK'"` // 备注
  85. Needsummary uint32 `json:"needsummary" xorm:"'NEEDSUMMARY'"` // 是否需要汇总 - 0:不需要 1:需要
  86. Summarytype uint32 `json:"summarytype" xorm:"'SUMMARYTYPE'"` // 汇总类型 - 1:加总 2:最后一个
  87. Groupname string `json:"groupname" xorm:"'GROUPNAME'"` // 表头分组名称
  88. }
  89. // TableName is TABLECOLUMNCONFIG
  90. func (Tablecolumnconfig) TableName() string {
  91. return "TABLECOLUMNCONFIG"
  92. }
  93. // Enumdicitem 枚举项字典表
  94. type Enumdicitem struct {
  95. Autoid int64 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 自增ID
  96. Enumdicid int32 `json:"enumdicid" xorm:"'ENUMDICID'" binding:"required"` // 所属枚举ID
  97. Enumdiccode string `json:"enumdiccode" xorm:"'ENUMDICCODE'" binding:"required"` // 所属枚举代码
  98. Enumdicname string `json:"enumdicname" xorm:"'ENUMDICNAME'"` // 枚举项名称
  99. Enumitemname int64 `json:"enumitemname" xorm:"'ENUMITEMNAME'" binding:"required"` // 枚举项值
  100. Enumitemstatus int32 `json:"enumitemstatus" xorm:"'ENUMITEMSTATUS'"` // 枚举项状态 - 1.启用 2.不启用
  101. Bankmappedvalue string `json:"bankmappedvalue" xorm:"'BANKMAPPEDVALUE'"` // 银行服务对应值
  102. Remark string `json:"remark" xorm:"'REMARK'"` // 备注
  103. Enumitemvalue string `json:"enumitemvalue" xorm:"'ENUMITEMVALUE'"` // 通用值 - [币种通用简写]
  104. Param1 string `json:"param1" xorm:"'PARAM1'"` // 参数1[币种:币种小数位]
  105. Param2 string `json:"param2" xorm:"'PARAM2'"` // 参数1[币种:币种显示单位]
  106. }
  107. // TableName is ENUMDICITEM
  108. func (Enumdicitem) TableName() string {
  109. return "ENUMDICITEM"
  110. }
  111. // Noticemsg 公告消息表
  112. type Noticemsg struct {
  113. Autoid int32 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 自增ID
  114. Msgtype int32 `json:"msgtype" xorm:"'MSGTYPE'"` // 消息类型 - 1:公告通知 2:系统消息 3:商品到期提货通知
  115. Title string `json:"title" xorm:"'TITLE'"` // 标题
  116. Content string `json:"content" xorm:"'CONTENT'"` // 内容
  117. Scheduletime time.Time `json:"scheduletime" xorm:"'SCHEDULETIME'"` // 计划发送时间
  118. Publisher string `json:"publisher" xorm:"'PUBLISHER'"` // 消息发布者
  119. Sendtype int32 `json:"sendtype" xorm:"'SENDTYPE'"` // 推送方式 - 1:全体广播 2:按会员广播 3:个人推送 4:按会员广播(仅会员)
  120. Userid int64 `json:"userid" xorm:"'USERID'"` // 会员/投资者ID推送方式 为 个人时,填写投资者ID
  121. Istop int32 `json:"istop" xorm:"'ISTOP'"` // 是否置顶 - 0:不置顶 1:置顶
  122. Sentstatus int32 `json:"sentstatus" xorm:"'SENTSTATUS'"` // 推送状态 - 0:未推送 1:已推送 2:审核拒绝
  123. Endtime time.Time `json:"endtime" xorm:"'ENDTIME'"` // 结束时间
  124. Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 建仓人
  125. Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
  126. Auditoruserid int64 `json:"auditoruserid" xorm:"'AUDITORUSERID'"` // 审核人
  127. Audittime time.Time `json:"audittime" xorm:"'AUDITTIME'"` // 审核日期
  128. Auditremark string `json:"auditremark" xorm:"'AUDITREMARK'"` // 审核备注
  129. Msgiconurl string `json:"msgiconurl" xorm:"'MSGICONURL'"` // 消息图标Url
  130. }
  131. // TableName is NOTICEMSG
  132. func (Noticemsg) TableName() string {
  133. return "NOTICEMSG"
  134. }
  135. // Memberrecv 会员消息接受表
  136. type Memberrecv struct {
  137. Msgid int32 `json:"msgid" xorm:"'MSGID'" binding:"required"` // 消息ID
  138. Memberid int64 `json:"memberid" xorm:"'MEMBERID'" binding:"required"` // 会员用户ID
  139. }
  140. // TableName is MEMBERRECV
  141. func (Memberrecv) TableName() string {
  142. return "MEMBERRECV"
  143. }
  144. // Msgreceiver 管理端消息接收者
  145. type Msgreceiver struct {
  146. Autoid int32 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 消息ID
  147. Managerid int64 `json:"managerid" xorm:"'MANAGERID'" binding:"required"` // 用户ID
  148. Readstatus int32 `json:"readstatus" xorm:"'READSTATUS'" binding:"required"` // 消息状态 - 1:未阅读 2:已阅读 3:已删除
  149. Receivertype int32 `json:"receivertype" xorm:"'RECEIVERTYPE'" binding:"required"` // 接收用户类型 - 1:管理端用户 2:终端用户
  150. Updatetime time.Time `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  151. }
  152. // TableName is MSGRECEIVER
  153. func (Msgreceiver) TableName() string {
  154. return "MSGRECEIVER"
  155. }
  156. // Division 行政区域表
  157. type Division struct {
  158. Autoid int64 `json:"autoid" xorm:"'AUTOID'" binding:"required"` // 自增ID
  159. Divisioncode string `json:"divisioncode" xorm:"'DIVISIONCODE'" binding:"required"` // 行政代码
  160. Shortcode string `json:"shortcode" xorm:"'SHORTCODE'"` // 地区简码
  161. Parentcode string `json:"parentcode" xorm:"'PARENTCODE'"` // 上级行政代码
  162. Divisionlevel string `json:"divisionlevel" xorm:"'DIVISIONLEVEL'"` // 行政级别
  163. Divisionname string `json:"divisionname" xorm:"'DIVISIONNAME'"` // 行政名称
  164. Pathname string `json:"pathname" xorm:"'PATHNAME'"` // 路径名称
  165. Separablename string `json:"separablename" xorm:"'SEPARABLENAME'"` // 可拆分的全称
  166. Postcode string `json:"postcode" xorm:"'POSTCODE'"` // 邮政编码
  167. Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
  168. Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 修改人
  169. }
  170. // TableName is DIVISION
  171. func (Division) TableName() string {
  172. return "DIVISION"
  173. }
  174. // Szdz2imageconfig 终端图片配置 - 通用功能
  175. type Szdz2imageconfig struct {
  176. Configid int64 `json:"configid" xorm:"'CONFIGID'" binding:"required"` // 配置ID(SEQ_SZDZ2_IMAGECONFIG)
  177. Imagetype int32 `json:"imagetype" xorm:"'IMAGETYPE'"` // 类型 - 1:首页轮播(移动) 2:我的(移动)
  178. Title string `json:"title" xorm:"'TITLE'"` // 标题
  179. Imagepath string `json:"imagepath" xorm:"'IMAGEPATH'"` // 图片
  180. URL string `json:"url" xorm:"'URL'"` // 链接(地址或商品ID)
  181. Sort int64 `json:"sort" xorm:"'SORT'"` // 排序
  182. Isshow int32 `json:"isshow" xorm:"'ISSHOW'"` // 是否展示 - 0:不展示 1:展示
  183. Createdate time.Time `json:"createdate" xorm:"'CREATEDATE'"` // 创建时间
  184. Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 创建人
  185. Updatedate time.Time `json:"updatedate" xorm:"'UPDATEDATE'"` // 修改时间
  186. Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 操作人
  187. Areauserid int64 `json:"areauserid" xorm:"'AREAUSERID'"` // 所属机构ID
  188. Urltype int32 `json:"urltype" xorm:"'URLTYPE'"` // 链接类型 - 1:直接地址 2:商品ID
  189. IMAGEDETAILPATH string `json:"imagedetailpath" xorm:"'IMAGEDETAILPATH'"` // 详情图片 [UrlType = 3时 有且必填,其它类型不需要]
  190. }
  191. // TableName is SZDZ2_IMAGECONFIG
  192. func (Szdz2imageconfig) TableName() string {
  193. return "SZDZ2_IMAGECONFIG"
  194. }
  195. // Errorcode 异常代码表
  196. type Errorcode struct {
  197. Errorid int64 `json:"errorid" xorm:"'ERRORID'" binding:"required"` // 异常ID
  198. Errorcode string `json:"errorcode" xorm:"'ERRORCODE'"` // 异常代码
  199. Modulecode string `json:"modulecode" xorm:"'MODULECODE'"` // 所属模块
  200. Operatecode string `json:"operatecode" xorm:"'OPERATECODE'"` // 所属操作
  201. Description string `json:"description" xorm:"'DESCRIPTION'"` // 异常描述
  202. }
  203. // TableName is ERRORCODE
  204. func (Errorcode) TableName() string {
  205. return "ERRORCODE"
  206. }
  207. // Systemparam 系统参数表
  208. type Systemparam struct {
  209. Paramcode string `json:"paramcode" xorm:"'PARAMCODE'" binding:"required"` // 参数代码
  210. Paramname string `json:"paramname" xorm:"'PARAMNAME'"` // 参数名
  211. Paramvalue string `json:"paramvalue" xorm:"'PARAMVALUE'"` // 参数值
  212. Paramtype int32 `json:"paramtype" xorm:"'PARAMTYPE'"` // 参数类型 0-通用 1-管理端 2-终端 3-后台 4-商城
  213. Showflag int32 `json:"showflag" xorm:"'SHOWFLAG'"` // 是否显示0 不显示 1 显示
  214. Modifyflag int32 `json:"modifyflag" xorm:"'MODIFYFLAG'"` // 修改标志0 不允许修改 1 允许修改
  215. Serverip string `json:"serverip" xorm:"'SERVERIP'"` // 限制服务器IP,备份参数,现在界面不用显示0.0.0.0则无限制,是通用参数192.168.0.211 指定服务器的参数配置
  216. Userid int64 `json:"userid" xorm:"'USERID'"` // 更新用户ID
  217. Loginid string `json:"loginid" xorm:"'LOGINID'"` // 更新用户账号,登录账号
  218. Updatetime time.Time `json:"updatetime" xorm:"'UPDATETIME'"` // 更新时间
  219. Remark string `json:"remark" xorm:"'REMARK'"` // 备注
  220. Paramvalue2 string `json:"paramvalue2" xorm:"'PARAMVALUE2'"` // 参数值(CLOB)
  221. Regexpress string `json:"regexpress" xorm:"'REGEXPRESS'"` // 正则表达式
  222. }
  223. // TableName is SYSTEMPARAM
  224. func (Systemparam) TableName() string {
  225. return "SYSTEMPARAM"
  226. }
  227. // Ermcpmemberfuncmenu 企业成员菜单表
  228. type Ermcpmemberfuncmenu struct {
  229. Userid int64 `json:"userid" xorm:"'USERID'" binding:"required"` // 用户ID
  230. Roleid int32 `json:"roleid" xorm:"'ROLEID'" binding:"required"` // 角色权限ID(0-管理员 22-业务员 23-跟单员 24-交易员)
  231. Resourcecode string `json:"resourcecode" xorm:"'RESOURCECODE'" binding:"required"` // 菜单代码
  232. Modifysrc int32 `json:"modifysrc" xorm:"'MODIFYSRC'"` // 修改来源 - 1:管理端 2:终端
  233. Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
  234. Modifyid int64 `json:"modifyid" xorm:"'MODIFYID'"` // 修改人
  235. Modifyremark string `json:"modifyremark" xorm:"'MODIFYREMARK'"` // 修改备注
  236. Isvalid int32 `json:"isvalid" xorm:"'ISVALID'"` // 是否有效 - 0:无效 1:有效
  237. }
  238. // TableName is ERMCP_MEMBERFUNCMENU
  239. func (Ermcpmemberfuncmenu) TableName() string {
  240. return "ERMCP_MEMBERFUNCMENU"
  241. }
  242. // QuotePrimaryMenu 报价牌一级分类菜单
  243. type QuotePrimaryMenu struct {
  244. Index int `json:"Index"` // 序号
  245. Key string `json:"Key"` // 键名
  246. Name string `json:"Name"` // 菜单名称
  247. SubTitleType int `json:"SubTitleType"` // 子菜单标题模式:0-市场名称;1-外部交易所名称
  248. TradeModes string `json:"TradeModes"` // 包含市场交易类型
  249. SubMenus []QuoteSecondaryMenu `json:"SubMenus"` // 子菜单
  250. }
  251. // QuoteSecondaryMenu 报价牌二级分类菜单
  252. type QuoteSecondaryMenu struct {
  253. Index int `json:"Index"` // 序号
  254. MarketID int `json:"MarketID"` // 市场ID
  255. TradeMode int `json:"TradeMode"` // 交易模式
  256. MenuTitle string `json:"MenuTitle" xorm:"'ExExchangeName'"` // 菜单标题(市场名称或外部交易所名称)
  257. GoodsGroupIDs []int `json:"GoodsGroupIDs"` // 商品组ID列表
  258. ExExchangeID int `json:"ExExchangeID" xorm:"'ExExchangeID'"` // 外部交易所ID
  259. ExExchangeCode string `json:"ExExchangeCode" xorm:"'ExExchangeCode'"` // 外部交易所代码
  260. }
  261. // OperationPrimaryMenu 一级功能菜单
  262. type OperationPrimaryMenu struct {
  263. Key string `json:"Key"` // 菜单KEY
  264. Label string `json:"Label"` // 菜单标题
  265. Children []OperationSecondaryMenu `json:"Children"` // 二级功能菜单
  266. }
  267. // OperationSecondaryMenu 二级功能菜单
  268. type OperationSecondaryMenu struct {
  269. Key string `json:"Key"` // 菜单KEY
  270. Label string `json:"Label"` // 菜单标题
  271. TabList []OperationTabMenu `json:"TabList"` // 三级功能菜单
  272. }
  273. // OperationTabMenu 三级功能菜单
  274. type OperationTabMenu struct {
  275. Key string `json:"Key"` // 菜单KEY
  276. Label string `json:"Label"` // 菜单标题
  277. }
  278. // GetQuoteMenu 获取行情报价牌分类菜单
  279. func GetQuoteMenu(loginID int) ([]QuotePrimaryMenu, error) {
  280. engine := db.GetEngine()
  281. rst := make([]QuotePrimaryMenu, 0)
  282. // 账户下有权限的市场ID列表
  283. var marketIDs []int
  284. // 获取账户类型 - 1:交易所 2:机构 3:会员子机构 4:经纪人 5:投资者 6:客户 (目前可能登录交易端的账号类型为 2 5)
  285. userAccount := new(Useraccount)
  286. has, err := engine.Join("INNER", "LOGINACCOUNT", "USERACCOUNT.UserID = LOGINACCOUNT.UserID").Where("LOGINACCOUNT.LoginID = ?", loginID).Get(userAccount)
  287. if err != nil || !has {
  288. return nil, err
  289. }
  290. if userAccount.Usertype == 5 {
  291. // 如果账户类型为5(投资者),则需要通过其所属经济会员来获取市场权限(表:AreaRoleMarket, 条件:对应市场状态为正常;角色类型:经济会员)
  292. if err := engine.Table("AREAROLEMARKET").
  293. Cols("AREAROLEMARKET.MARKETID").
  294. Join("INNER", "MARKET", "MARKET.MARKETID = AREAROLEMARKET.MARKETID").
  295. Where("MARKET.MARKETSTATUS = 2 and AREAROLEMARKET.ROLETYPE = 7 and AREAROLEMARKET.AREAUSERID = ?", userAccount.Memberuserid).Find(&marketIDs); err != nil {
  296. return nil, err
  297. }
  298. } else {
  299. // 非投资者账号直接通过资金账号获取市场权限(表:TAAccountMarket)
  300. var taAccounts []string // 账户下所有资金账户
  301. // 先要获取当前登录账户对应的资金账户;如果为外部子资金账号(TaAccount.TaAccountType = 1),则使用TaAccount.FromAccountID来获取市场权限
  302. type taAccount struct {
  303. AccountID int `xorm:"ACCOUNTID"`
  304. TaAccountType int `xorm:"TAACCOUNTTYPE"`
  305. FromAccountID int `xorm:"FROMACCOUNTID"`
  306. }
  307. datas := make([]taAccount, 0)
  308. if err := engine.Table("LOGINTAACCOUNT").
  309. Join("INNER", "TAACCOUNT", "LOGINTAACCOUNT.ACCOUNTID = TAACCOUNT.ACCOUNTID").
  310. Cols("TAACCOUNT.ACCOUNTID", "TAACCOUNT.TAACCOUNTTYPE", "TAACCOUNT.FROMACCOUNTID").
  311. Where("LOGINTAACCOUNT.LOGINID = ?", loginID).Find(&datas); err != nil {
  312. return nil, err
  313. }
  314. // 如果一条记录都没有(未配置自营会员资金账户)则直接通过资金账户表获取
  315. if len(datas) == 0 {
  316. // 这里要注意,TaAccount表与LoginAccount表关联时,要使用TaAccount.RelatedUserID
  317. if err := engine.Table("TAACCOUNT").
  318. Join("INNER", "LOGINACCOUNT", "TAACCOUNT.RELATEDUSERID = LOGINACCOUNT.USERID").
  319. Cols("TAACCOUNT.ACCOUNTID", "TAACCOUNT.TAACCOUNTTYPE", "TAACCOUNT.FROMACCOUNTID").
  320. Where("LOGINACCOUNT.LOGINID = ?", loginID).Find(&datas); err != nil {
  321. return nil, err
  322. }
  323. }
  324. for _, v := range datas {
  325. if v.TaAccountType == 1 {
  326. // 外部资金账户使用TaAccount.FromAccountID来获取市场权限
  327. taAccounts = append(taAccounts, strconv.Itoa(v.FromAccountID))
  328. } else {
  329. taAccounts = append(taAccounts, strconv.Itoa(v.AccountID))
  330. }
  331. }
  332. // 获取资金账户对应的市场权限(有权限的市场ID)
  333. if len(taAccounts) > 0 {
  334. // taAccountStr := strings.Join(taAccounts, ",")
  335. if err := engine.Table("TAACCOUNTMARKET").
  336. Join("INNER", "MARKET", "MARKET.MARKETID = TAACCOUNTMARKET.MARKETID").
  337. Cols("TAACCOUNTMARKET.MARKETID").
  338. In("TAACCOUNTMARKET.ACCOUNTID", taAccounts).
  339. And("MARKET.MARKETSTATUS = 2").Find(&marketIDs); err != nil {
  340. return nil, err
  341. }
  342. }
  343. }
  344. // ********************* 构建行情报价牌菜单 *********************
  345. datas := make([]Funcmenulist, 0)
  346. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  347. Where("FUNCMENULIST.PARENTCODE = 'trader_master_menu'").
  348. Asc("SORT").
  349. Find(&datas); err != nil {
  350. return nil, err
  351. }
  352. // 构建一级菜单对象
  353. for i, v := range datas {
  354. quotePrimaryMenu := QuotePrimaryMenu{
  355. Index: i,
  356. Key: v.Resourcecode,
  357. Name: v.Resourcename,
  358. SubMenus: make([]QuoteSecondaryMenu, 0),
  359. }
  360. // 跳过自选
  361. if v.Resourcecode == "optional" {
  362. rst = append(rst, quotePrimaryMenu)
  363. continue
  364. }
  365. // URL:模式,0-使用市场名称,1-使用外部交易所名称;Remark:包含市场交易模式
  366. quotePrimaryMenu.SubTitleType, _ = strconv.Atoi(v.URL)
  367. quotePrimaryMenu.TradeModes = v.Remark
  368. // 如果传入的LoginID获取不到有权限的市场ID列表(有可能LoginID是错误的),则不构建二级子菜单
  369. if len(marketIDs) == 0 {
  370. rst = append(rst, quotePrimaryMenu)
  371. continue
  372. }
  373. // 构建二级子菜单对象
  374. marketIDsStr := utils.JoinItoString(marketIDs, ",")
  375. if quotePrimaryMenu.SubTitleType == 0 {
  376. // 获取目标交易模式的市场信息
  377. markets := make([]Market, 0)
  378. if err := engine.Where(fmt.Sprintf(`TradeMode in (%s) and MarketID in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)).Find(&markets); err != nil {
  379. return nil, err
  380. }
  381. // 使用市场名称
  382. for mi, mv := range markets {
  383. quoteSecondaryMenu := QuoteSecondaryMenu{
  384. Index: mi,
  385. MarketID: int(mv.Marketid),
  386. TradeMode: int(mv.Trademode),
  387. MenuTitle: mv.Marketname,
  388. GoodsGroupIDs: make([]int, 0),
  389. }
  390. quotePrimaryMenu.SubMenus = append(quotePrimaryMenu.SubMenus, quoteSecondaryMenu)
  391. }
  392. } else {
  393. // 使用外部交易所名称
  394. quoteSecondaryMenus := make([]QuoteSecondaryMenu, 0)
  395. sql := fmt.Sprintf(`select distinct
  396. e.autoid ExExchangeID,
  397. e.ExExchangeName,
  398. e.ExExchangeCode
  399. from ExternalExchange e
  400. inner join goodsgroup g on g.exexchangeid = e.autoid
  401. inner join Market m on g.marketid = m.marketid
  402. where m.trademode in (%s) and m.marketid in (%s)`, quotePrimaryMenu.TradeModes, marketIDsStr)
  403. if err := engine.SQL(sql).Find(&quoteSecondaryMenus); err != nil {
  404. return nil, err
  405. }
  406. // 获取外部交易所对应的商品组信息
  407. for ei, ev := range quoteSecondaryMenus {
  408. q := &quoteSecondaryMenus[ei]
  409. q.Index = ei
  410. // 商品组列表
  411. goodsgroups := make([]Goodsgroup, 0)
  412. if err := engine.Where("Exexchangeid = ?", ev.ExExchangeID).Find(&goodsgroups); err != nil {
  413. return nil, err
  414. }
  415. marketID := 0
  416. var goodsGroupIDs []int
  417. for _, gv := range goodsgroups {
  418. marketID = int(gv.Marketid)
  419. goodsGroupIDs = append(goodsGroupIDs, int(gv.Goodsgroupid))
  420. }
  421. q.MarketID = marketID
  422. q.GoodsGroupIDs = goodsGroupIDs
  423. }
  424. quotePrimaryMenu.SubMenus = quoteSecondaryMenus
  425. }
  426. rst = append(rst, quotePrimaryMenu)
  427. }
  428. return rst, nil
  429. }
  430. // GetOperationMenu 获取功能菜单
  431. func GetOperationMenu() ([]OperationPrimaryMenu, error) {
  432. engine := db.GetEngine()
  433. rst := make([]OperationPrimaryMenu, 0)
  434. // 获取一级功能菜单
  435. opm := make([]Funcmenulist, 0)
  436. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  437. Where("FUNCMENULIST.PARENTCODE = 'trader_operation_master_menu'").
  438. Asc("SORT").
  439. Find(&opm); err != nil {
  440. return nil, err
  441. }
  442. for _, pv := range opm {
  443. var operationPrimaryMenu = OperationPrimaryMenu{
  444. Key: pv.Resourcecode,
  445. Label: pv.Resourcename,
  446. Children: make([]OperationSecondaryMenu, 0),
  447. }
  448. // 获取二级功能菜单
  449. osm := make([]Funcmenulist, 0)
  450. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  451. Where("FUNCMENULIST.PARENTCODE = ?", operationPrimaryMenu.Key).
  452. Asc("SORT").
  453. Find(&osm); err != nil {
  454. return nil, err
  455. }
  456. for _, sv := range osm {
  457. var operationSecondaryMenu = OperationSecondaryMenu{
  458. Key: sv.Resourcecode,
  459. Label: sv.Resourcename,
  460. TabList: make([]OperationTabMenu, 0),
  461. }
  462. // 获取三级功能菜单
  463. otm := make([]Funcmenulist, 0)
  464. if err := engine.Join("INNER", "ROLEFUNCMENU", "FUNCMENULIST.RESOURCECODE = ROLEFUNCMENU.RESOURCECODE").
  465. Where("FUNCMENULIST.PARENTCODE = ?", operationSecondaryMenu.Key).
  466. Asc("SORT").
  467. Find(&otm); err != nil {
  468. return nil, err
  469. }
  470. for _, tv := range otm {
  471. var operationTabMenu = OperationTabMenu{
  472. Key: tv.Resourcecode,
  473. Label: tv.Resourcename,
  474. }
  475. operationSecondaryMenu.TabList = append(operationSecondaryMenu.TabList, operationTabMenu)
  476. }
  477. operationPrimaryMenu.Children = append(operationPrimaryMenu.Children, operationSecondaryMenu)
  478. }
  479. rst = append(rst, operationPrimaryMenu)
  480. }
  481. return rst, nil
  482. }
  483. // GetClientTableDefines 获取终端列表定义信息
  484. func GetClientTableDefines(tableKey string, tableType int) ([]Tabledefine, error) {
  485. engine := db.GetEngine()
  486. tableDefiles := make([]Tabledefine, 0)
  487. s := engine.Table("TABLEDEFINE")
  488. if tableType != 0 {
  489. s = s.Where("TABLEDEFINE.TableType = ?", tableType)
  490. }
  491. if len(tableKey) > 0 {
  492. s = s.And("TABLEDEFINE.TableKey = ?", tableKey)
  493. }
  494. if err := s.Find(&tableDefiles); err != nil {
  495. return nil, err
  496. }
  497. return tableDefiles, nil
  498. }
  499. // GetClientTableColumns 获取客户端指定表的列头信息
  500. // tableKey 列表Key
  501. func GetClientTableColumns(tableKey string, tableType int) ([]Tablecolumnconfig, error) {
  502. engine := db.GetEngine()
  503. // 获取列表数据 2 - H5; 3 - APP
  504. tablecolumnconfigs := make([]Tablecolumnconfig, 0)
  505. // 这里的表名必须要大写 (Oracle的表名都是大写)
  506. if err := engine.Join("INNER", "TABLEDEFINE", "TABLEDEFINE.TableKey = TABLECOLUMNCONFIG.TableKey").
  507. Where("TABLEDEFINE.TableType = ?", tableType).And("TABLEDEFINE.TableKey = ?", tableKey).OrderBy("TABLECOLUMNCONFIG.ORDERINDEX").Find(&tablecolumnconfigs); err != nil {
  508. return nil, err
  509. }
  510. return tablecolumnconfigs, nil
  511. }
  512. // GetNotices 获取指定账户的通知信息(终端)
  513. // 参数 loginID int 登录账号
  514. // 参数 msgType int 消息类型 - 1:公告通知 2:系统消息
  515. // 参数 onlyUnRead bool 是否只获取未读信息
  516. func GetNotices(loginID, msgType int, onlyUnRead bool) ([]Noticemsg, error) {
  517. engine := db.GetEngine()
  518. rst := make([]Noticemsg, 0)
  519. // 获取登录账号所属会员信息
  520. var userAccount Useraccount
  521. if has, _ := engine.Join("LEFT", "LOGINACCOUNT", "LOGINACCOUNT.USERID = USERACCOUNT.USERID").
  522. Where("LOGINACCOUNT.LOGINID = ?", loginID).Get(&userAccount); !has {
  523. return nil, errors.New("获取登录账号所属会员ID失败")
  524. }
  525. // 获取登录账号已读公告ID, 这里要使用的是个人的UserID来查询
  526. var msgReceivers []int
  527. engine.Table("MSGRECEIVER").Select("AUTOID").Where("RECEIVERTYPE = 2 and MANAGERID = ?", userAccount.Userid).Find(&msgReceivers)
  528. // 查询SENDTYPE = 1的数据
  529. datas1 := make([]Noticemsg, 0)
  530. s := engine.Where("SENDTYPE = 1 and SYSDATE > SCHEDULETIME and SYSDATE < ENDTIME and SENTSTATUS=1").
  531. And("PUBLISHER = ? or PUBLISHER in (select USERACCOUNT.USERID from USERACCOUNT where USERACCOUNT.USERTYPE = 1)", userAccount.Memberuserid)
  532. if msgType > 0 {
  533. s = s.And("MSGTYPE = ?", msgType)
  534. }
  535. if onlyUnRead && len(msgReceivers) > 0 {
  536. s = s.NotIn("AUTOID", msgReceivers)
  537. }
  538. if err := s.Find(&datas1); err != nil {
  539. // 查询失败
  540. return nil, err
  541. }
  542. rst = append(rst, datas1...)
  543. // 查询SENDTYPE = 2的数据
  544. datas2 := make([]Noticemsg, 0)
  545. s = engine.Where(fmt.Sprintf(`AUTOID in (select MEMBERRECV.MSGID from MEMBERRECV where MEMBERRECV.MEMBERID = %d)`, userAccount.Memberuserid)).
  546. And("SENDTYPE = 2 and SYSDATE > SCHEDULETIME and SYSDATE < ENDTIME and SENTSTATUS=1")
  547. if msgType > 0 {
  548. s = s.And("MSGTYPE = ?", msgType)
  549. }
  550. if onlyUnRead && len(msgReceivers) > 0 {
  551. s = s.NotIn("AUTOID", msgReceivers)
  552. }
  553. if err := s.Find(&datas2); err != nil {
  554. // 查询失败
  555. return nil, err
  556. }
  557. rst = append(rst, datas2...)
  558. // 查询SENDTYPE = 3的数据
  559. datas3 := make([]Noticemsg, 0)
  560. s = engine.Where(fmt.Sprintf(`USERID = (SELECT USERID FROM LOGINACCOUNT WHERE LOGINID = %d)`, loginID)).
  561. And("SENDTYPE = 3 and SYSDATE > SCHEDULETIME and SYSDATE < ENDTIME and SENTSTATUS=1")
  562. if msgType > 0 {
  563. s = s.And("MSGTYPE = ?", msgType)
  564. }
  565. if onlyUnRead && len(msgReceivers) > 0 {
  566. s = s.NotIn("AUTOID", msgReceivers)
  567. }
  568. if err := s.Find(&datas3); err != nil {
  569. // 查询失败
  570. return nil, err
  571. }
  572. rst = append(rst, datas3...)
  573. return rst, nil
  574. }
  575. // GetEnumDicItem 获取枚举信息数组
  576. // 参数 enumDicCode string 所属枚举代码,必填
  577. // 参数 enumItemName int 枚举项值,选填,不需要则传入0
  578. // 返回 []Enumdicitem 枚举信息数组
  579. // 返回 error error
  580. func GetEnumDicItem(enumDicCode string, enumItemName int) ([]Enumdicitem, error) {
  581. engine := db.GetEngine()
  582. enumDicItems := make([]Enumdicitem, 0)
  583. session := engine.Where("ENUMDICCODE = ?", enumDicCode)
  584. if enumItemName > 0 {
  585. session = session.And("ENUMITEMNAME = ?", enumItemName)
  586. }
  587. if err := session.Find(&enumDicItems); err != nil {
  588. return nil, err
  589. }
  590. return enumDicItems, nil
  591. }
  592. // GetEnums 获取所有枚举信息
  593. func GetEnums(autoID int) ([]Enumdicitem, error) {
  594. engine := db.GetEngine()
  595. enumDicItems := make([]Enumdicitem, 0)
  596. session := engine.Table("ENUMDICITEM")
  597. if autoID != 0 {
  598. session = session.Where("AUTOID > ?", autoID)
  599. }
  600. if err := session.Find(&enumDicItems); err != nil {
  601. return nil, err
  602. }
  603. return enumDicItems, nil
  604. }
  605. // GetProvincesAndCities 获取省市信息数组
  606. // 参数 provinceID int 省ID,选填
  607. // 返回 []Division 枚举信息数组
  608. // 返回 error error
  609. func GetProvincesAndCities(provinceID int) ([]Division, error) {
  610. engine := db.GetEngine()
  611. divisions := make([]Division, 0)
  612. session := engine.Where("DIVISIONLEVEL = 'province' or DIVISIONLEVEL = 'city'")
  613. if provinceID > 0 {
  614. session = session.And("AUTOID = ?", provinceID)
  615. }
  616. if err := session.Find(&divisions); err != nil {
  617. return nil, err
  618. }
  619. return divisions, nil
  620. }
  621. // GetDivisions 获取所有区域信息
  622. func GetDivisions() ([]Division, error) {
  623. engine := db.GetEngine()
  624. divisions := make([]Division, 0)
  625. if err := engine.Find(&divisions); err != nil {
  626. return nil, err
  627. }
  628. return divisions, nil
  629. }
  630. // GetImageConfigs 获取轮播图配置信息
  631. func GetImageConfigs(userId int64, imageType int) ([]Szdz2imageconfig, error) {
  632. engine := db.GetEngine()
  633. imageConfigs := make([]Szdz2imageconfig, 0)
  634. session := engine.Where("ISSHOW = 1")
  635. if userId > 0 {
  636. session = session.And("AREAUSERID = ?", mtpcache.GetAreaUserId(userId, 0))
  637. }
  638. if imageType > 0 {
  639. session = session.And("IMAGETYPE = ?", imageType)
  640. }
  641. session = session.Asc("SORT")
  642. if err := session.Find(&imageConfigs); err != nil {
  643. return nil, err
  644. }
  645. return imageConfigs, nil
  646. }
  647. // GetServerTime 获取服务器时间
  648. func GetServerTime() (*string, error) {
  649. engine := db.GetEngine()
  650. rst, err := engine.QueryString("select sysdate from dual")
  651. if err != nil {
  652. return nil, err
  653. }
  654. if len(rst) > 0 {
  655. r := rst[0]["SYSDATE"]
  656. return &r, nil
  657. }
  658. return nil, nil
  659. }
  660. // QueryErrorInfosRsp 获取数据库错误信息模型
  661. type QueryErrorInfosRsp struct {
  662. Errorid int64 `json:"errorid" xorm:"'ERRORID'" binding:"required"` // 异常ID
  663. Errorcode string `json:"errorcode" xorm:"'ERRORCODE'"` // 异常代码
  664. Modulecode string `json:"modulecode" xorm:"'MODULECODE'"` // 所属模块
  665. Operatecode string `json:"operatecode" xorm:"'OPERATECODE'"` // 所属操作
  666. Description string `json:"description" xorm:"'DESCRIPTION'"` // 异常描述
  667. Rownumber string `json:"rownumber" xorm:"ROWNUMBER"` // 行号
  668. }
  669. // GetErrorInfos 获取数据库错误信息
  670. func GetErrorInfos(rowNumber string) ([]QueryErrorInfosRsp, error) {
  671. engine := db.GetEngine()
  672. errorCodes := make([]QueryErrorInfosRsp, 0)
  673. session := engine.Table("ERRORCODE E").Select("E.*, rowid ROWNUMBER").Where("1 = 1")
  674. if len(rowNumber) != 0 {
  675. session = session.And("rowid > ?", rowNumber)
  676. }
  677. if err := session.Find(&errorCodes); err != nil {
  678. return nil, err
  679. }
  680. return errorCodes, nil
  681. }
  682. // GetTableUpdateTimeStamp 获取目标表最后记录变更时间
  683. func GetTableUpdateTimeStamp(tableName string) (*string, error) {
  684. engine := db.GetEngine()
  685. var timeStamp string
  686. if _, err := engine.SQL(fmt.Sprintf("SELECT to_char(SCN_TO_TIMESTAMP(MAX(ora_rowscn)), 'yyyy-MM-dd hh24:mi:ss') TIMESTAMP from %s", tableName)).
  687. Get(&timeStamp); err != nil {
  688. return nil, err
  689. }
  690. return &timeStamp, nil
  691. }
  692. // GetSystemParams 获取系统参数信息
  693. func GetSystemParams() ([]Systemparam, error) {
  694. systemParams := make([]Systemparam, 0)
  695. if err := db.GetEngine().Where("PARAMTYPE in (0,2,3)").Find(&systemParams); err != nil {
  696. return nil, err
  697. }
  698. return systemParams, nil
  699. }
  700. // GetRoleFuncMenuLists 获取终端权限(交易所版本)
  701. func GetRoleFuncMenuLists(loginID int, resourceCode string) ([]Funcmenulist, error) {
  702. funcMenuLists := make([]Funcmenulist, 0)
  703. sql := fmt.Sprintf(`select F.* from FUNCMENULIST F where F.MENUTYPE = 3
  704. and
  705. F.RESOURCECODE in
  706. (select R.RESOURCECODE from ROLEFUNCMENU R
  707. inner join LOGINACCOUNT L on L.CLIENTROLEID = R.ROLEID where L.LOGINID = %d)`, loginID)
  708. if len(resourceCode) != 0 {
  709. sql += fmt.Sprintf(" and F.RESOURCECODE = '%s'", resourceCode)
  710. }
  711. if err := db.GetEngine().SQL(sql).Find(&funcMenuLists); err != nil {
  712. return nil, err
  713. }
  714. return funcMenuLists, nil
  715. }
  716. // GetErmcpRoleFuncMenuLists 获取终端权限(企业风管专用,区分企业和企业成员)
  717. func GetErmcpRoleFuncMenuLists(loginID int, resourceCode string) ([]Funcmenulist, error) {
  718. funcMenuLists := make([]Funcmenulist, 0)
  719. // 获取对应的Loginaccount信息
  720. var loginAccount Loginaccount
  721. has, err := db.GetEngine().Where("LOGINID = ?", loginID).Get(&loginAccount)
  722. if err != nil {
  723. return nil, err
  724. }
  725. if !has {
  726. return nil, errors.New("没有对应的登录用户信息")
  727. }
  728. // 获取对应的Useraccount信息
  729. var userAccount Useraccount
  730. has, err = db.GetEngine().Table("USERACCOUNT U").
  731. Join("INNER", "LOGINACCOUNT L", "L.USERID = U.USERID").
  732. Where("L.LOGINID = ?", loginID).Get(&userAccount)
  733. if err != nil {
  734. return nil, err
  735. }
  736. if !has {
  737. return nil, errors.New("没有对应的用户信息")
  738. }
  739. // 是否企业
  740. isEnterprise := false
  741. // 是否自营会员
  742. isTrader := false
  743. // 查询机构角色表
  744. var arearole Arearole
  745. arearoles, err := arearole.GetAreaRoles(int(userAccount.Userid), 0)
  746. if err != nil {
  747. return nil, err
  748. }
  749. for _, v := range arearoles {
  750. if v.Roletype == 6 {
  751. isTrader = true
  752. } else if v.Roletype == 20 {
  753. arearole = arearoles[0]
  754. if arearole.Suborgtype == 0 {
  755. isEnterprise = true
  756. }
  757. }
  758. }
  759. if userAccount.Usertype == 5 || (userAccount.Usertype == 2 && isTrader) {
  760. // 交易所,自营会员及投资者的权限不进行判断
  761. sql := "select F.* from FUNCMENULIST F where F.MENUTYPE = 4"
  762. if len(resourceCode) != 0 {
  763. sql += fmt.Sprintf(" and F.RESOURCECODE = '%s'", resourceCode)
  764. }
  765. if err := db.GetEngine().SQL(sql).Find(&funcMenuLists); err != nil {
  766. return nil, err
  767. }
  768. } else {
  769. // 判断是企业还是企业成员
  770. // 账户类型 - 1:交易所 2:机构 3:会员子机构 4:经纪人 5:投资者 6:客户 7:企业成员(云平台)
  771. if userAccount.Usertype == 2 && isEnterprise {
  772. // UserType=2:企业。原逻辑:根据LoginAccount表"ClientRoleID"查询”ERMCP_MemberFuncMenu“表中该用户对应角色的菜单权限
  773. sql := fmt.Sprintf(`select F.* from FUNCMENULIST F where F.MENUTYPE in (3,5)
  774. and
  775. F.RESOURCECODE in
  776. (select R.RESOURCECODE from ERMCP_MEMBERFUNCMENU R
  777. where R.ISVALID = 1 and R.USERID = %d and R.ROLEID = %d)`, loginAccount.Userid, loginAccount.Clientroleid)
  778. if len(resourceCode) != 0 {
  779. sql += fmt.Sprintf(" and F.RESOURCECODE = '%s'", resourceCode)
  780. }
  781. if err := db.GetEngine().SQL(sql).Find(&funcMenuLists); err != nil {
  782. return nil, err
  783. }
  784. } else if userAccount.Usertype == 6 || userAccount.Usertype == 7 || (userAccount.Usertype == 2 && !isEnterprise) {
  785. // UserType=7:企业成员
  786. // 查询本用户的角色ID - AreaRole表
  787. // 根据 Rootuserid 和 自己的角色查询 ERMCP_MemberFuncMenu 表中的菜单权限
  788. areaRoles := make([]Arearole, 0)
  789. if err := db.GetEngine().Where("USERID = ?", loginAccount.Userid).Find(&areaRoles); err != nil {
  790. return nil, err
  791. }
  792. if len(areaRoles) == 0 {
  793. // 无角色,返回空数组s
  794. return make([]Funcmenulist, 0), nil
  795. }
  796. // 构建RoleID列表
  797. roleIDs := ""
  798. for _, areaRole := range areaRoles {
  799. roleIDs += "," + strconv.Itoa(int(areaRole.Roletype))
  800. }
  801. if len(roleIDs) > 0 {
  802. roleIDs = roleIDs[1:]
  803. }
  804. sql := fmt.Sprintf(`select F.* from FUNCMENULIST F where F.MENUTYPE in (3,5)
  805. and
  806. F.RESOURCECODE in
  807. (select R.RESOURCECODE from ERMCP_MEMBERFUNCMENU R
  808. where R.ISVALID = 1 and R.USERID = %d and R.ROLEID in (%s))`, userAccount.Rootuserid, roleIDs)
  809. if len(resourceCode) != 0 {
  810. sql += fmt.Sprintf(" and F.RESOURCECODE = '%s'", resourceCode)
  811. }
  812. if err := db.GetEngine().SQL(sql).Find(&funcMenuLists); err != nil {
  813. return nil, err
  814. }
  815. } else {
  816. return nil, errors.New("错误的用户类型")
  817. }
  818. }
  819. return funcMenuLists, nil
  820. }
  821. // IsTrader 判断是否交易所,自营会员及投资者
  822. func IsTrader(loginID int) (bool, error) {
  823. // 获取对应的Loginaccount信息
  824. var loginAccount Loginaccount
  825. has, err := db.GetEngine().Where("LOGINID = ?", loginID).Get(&loginAccount)
  826. if err != nil {
  827. return false, err
  828. }
  829. if !has {
  830. return false, errors.New("没有对应的登录用户信息")
  831. }
  832. // 获取对应的Useraccount信息
  833. var userAccount Useraccount
  834. has, err = db.GetEngine().Table("USERACCOUNT U").
  835. Join("INNER", "LOGINACCOUNT L", "L.USERID = U.USERID").
  836. Where("L.LOGINID = ?", loginID).Get(&userAccount)
  837. if err != nil {
  838. return false, err
  839. }
  840. if !has {
  841. return false, errors.New("没有对应的用户信息")
  842. }
  843. // 是否自营会员
  844. isTrader := false
  845. // 查询机构角色表
  846. var arearole Arearole
  847. arearoles, err := arearole.GetAreaRoles(int(userAccount.Userid), 0)
  848. if err != nil {
  849. return false, err
  850. }
  851. for _, v := range arearoles {
  852. if v.Roletype == 6 {
  853. isTrader = true
  854. }
  855. }
  856. // 交易所,自营会员及投资者的权限不进行判断
  857. if userAccount.Usertype == 5 || (userAccount.Usertype == 2 && isTrader) {
  858. return true, nil
  859. }
  860. return false, nil
  861. }