common.go 55 KB

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