common.go 62 KB

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