common.go 52 KB

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