common.go 46 KB

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