| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634 |
- package models
- import (
- "encoding/hex"
- "fmt"
- "math"
- "mtp2_if/db"
- "mtp2_if/utils"
- "strconv"
- "strings"
- "time"
- )
- // Hsbygoodsex 商品扩展表
- type Hsbygoodsex struct {
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商 品ID
- Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
- Descprovinceid int64 `json:"descprovinceid" xorm:"'DESCPROVINCEID'"` // 目的地(省)
- Desccityid int64 `json:"desccityid" xorm:"'DESCCITYID'"` // 目的地(市)
- Vendorid int32 `json:"vendorid" xorm:"'VENDORID'"` // 供应商ID
- Goodsdesc string `json:"goodsdesc" xorm:"'GOODSDESC'"` // 商品详情
- Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
- Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 创建人
- Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 修改人
- Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
- Memberratio float64 `json:"memberratio" xorm:"'MEMBERRATIO'"` // 会员货款比例 [71]
- Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Goodsprice float64 `json:"goodsprice" xorm:"'GOODSPRICE'"` // 商品价格
- Categoryid int32 `json:"categoryid" xorm:"'CATEGORYID'"` // 类别ID(WRCATEGORY)
- }
- // TableName is HSBY_GOODSEX
- func (Hsbygoodsex) TableName() string {
- return "HSBY_GOODSEX"
- }
- // Hsbysupplierinfo 供应商表
- type Hsbysupplierinfo struct {
- Vendorid int32 `json:"vendorid" xorm:"'VENDORID'" binding:"required"` // 供应商ID(SEQ_HSBY_SUPPLIERINFO)
- Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 名称描述客服电话名称
- Vendordesc string `json:"vendordesc" xorm:"'VENDORDESC'"` // 描述
- Vendorphone string `json:"vendorphone" xorm:"'VENDORPHONE'"` // 客服电话
- Vendorattr string `json:"vendorattr" xorm:"'VENDORATTR'"` // 附件(多张,逗号分隔)
- Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
- Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 创建人
- Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 修改人
- Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
- }
- // TableName is HSBY_SUPPLIERINFO
- func (Hsbysupplierinfo) TableName() string {
- return "HSBY_SUPPLIERINFO"
- }
- // Tradepayorder 交易待付款表
- type Tradepayorder struct {
- Tradeid int64 `json:"tradeid" xorm:"'TRADEID'" binding:"required"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
- Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
- Buyorderid int64 `json:"buyorderid" xorm:"'BUYORDERID'"` // 买方委托单号
- Buyaccountid int64 `json:"buyaccountid" xorm:"'BUYACCOUNTID'"` // 买方账号ID[报价币种]
- Sellorderid int64 `json:"sellorderid" xorm:"'SELLORDERID'"` // 卖方委托单号
- Sellaccountid int64 `json:"sellaccountid" xorm:"'SELLACCOUNTID'"` // 卖方账号ID[报价币种]
- Tradeamount float64 `json:"tradeamount" xorm:"'TRADEAMOUNT'"` // 成交金额
- Tradecharge float64 `json:"tradecharge" xorm:"'TRADECHARGE'"` // 成交手续费(买方)
- Payflag int32 `json:"payflag" xorm:"'PAYFLAG'"` // 付款标识 - 1:未支付 2:已支付 3:已过期 4:已撤销 5:结算过期 6:预售终止
- Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
- Paytime time.Time `json:"paytime" xorm:"'PAYTIME'"` // 付款时间
- Paylimitedtime time.Time `json:"paylimitedtime" xorm:"'PAYLIMITEDTIME'"` // 支付期限
- Offamount float64 `json:"offamount" xorm:"'OFFAMOUNT'"` // 优惠金额
- Tradeprice float64 `json:"tradeprice" xorm:"'TRADEPRICE'"` // 成交价格
- Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
- Payamount float64 `json:"payamount" xorm:"'PAYAMOUNT'"` // 支付金额 = TradeAmount + TradeCharge - OffAmount
- }
- // TableName is TRADE_PAYORDER
- func (Tradepayorder) TableName() string {
- return "TRADE_PAYORDER"
- }
- // Coupontype 优惠券类型表
- type Coupontype struct {
- Coupontypeid int32 `json:"coupontypeid" xorm:"'COUPONTYPEID'" binding:"required"` // 优惠券类型ID - SEQ_COUPONTYPE
- Areauserid int64 `json:"areauserid" xorm:"'AREAUSERID'"` // 所属机构
- Couponname string `json:"couponname" xorm:"'COUPONNAME'"` // 优惠券名称
- Couponcategroy int32 `json:"couponcategroy" xorm:"'COUPONCATEGROY'"` // 种类 - 1:现金券 2:折扣券 3:折扣券(单张)
- Conditionvalue float64 `json:"conditionvalue" xorm:"'CONDITIONVALUE'"` // 条件阈值(可为0)
- Couponvalue float64 `json:"couponvalue" xorm:"'COUPONVALUE'"` // 面值[1:现金券 - 抵扣值 2:折扣券-折扣值]
- Limitedflag int32 `json:"limitedflag" xorm:"'LIMITEDFLAG'"` // 是否指定商品 - 0:不限 1:限制
- Limitedgoodsids string `json:"limitedgoodsids" xorm:"'LIMITEDGOODSIDS'"` // 指定商品IDs[逗号分隔,前后加逗号]
- Isgeneral int32 `json:"isgeneral" xorm:"'ISGENERAL'"` // 是否通用券 - 0:否 1:是
- Userscope string `json:"userscope" xorm:"'USERSCOPE'"` // 卖家范围(用户ID,逗号分隔,前后加逗号) [IsGeneral =0时使用]
- Qty int64 `json:"qty" xorm:"'QTY'"` // 数量
- Curqty int64 `json:"curqty" xorm:"'CURQTY'"` // 剩余数量
- Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
- Creatorid int64 `json:"creatorid" xorm:"'CREATORID'"` // 创建人
- Modifierid int64 `json:"modifierid" xorm:"'MODIFIERID'"` // 修改人
- Modifytime time.Time `json:"modifytime" xorm:"'MODIFYTIME'"` // 修改时间
- Usedqty int64 `json:"usedqty" xorm:"'USEDQTY'"` // 使用量
- Isvalid int32 `json:"isvalid" xorm:"'ISVALID'"` // 是否有效 - 0:无效 1:有效
- Expiredqty int64 `json:"expiredqty" xorm:"'EXPIREDQTY'"` // 失效量
- }
- // TableName is COUPONTYPE
- func (Coupontype) TableName() string {
- return "COUPONTYPE"
- }
- // Couponposition 优惠券头寸表 - 导历史(期末为0的清除)
- type Couponposition struct {
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 资金账户ID
- Coupontypeid int32 `json:"coupontypeid" xorm:"'COUPONTYPEID'" binding:"required"` // 优惠券类型ID
- Userid int64 `json:"userid" xorm:"'USERID'"` // 用户ID
- Oriqty int64 `json:"oriqty" xorm:"'ORIQTY'"` // 期初数量
- Orifreezeqty int64 `json:"orifreezeqty" xorm:"'ORIFREEZEQTY'"` // 期初冻结数量
- Curqty int64 `json:"curqty" xorm:"'CURQTY'"` // 期末数量
- Curfreezeqty int64 `json:"curfreezeqty" xorm:"'CURFREEZEQTY'"` // 期末冻结数量
- Todayincrease int64 `json:"todayincrease" xorm:"'TODAYINCREASE'"` // 今日增加
- Todaydecrease int64 `json:"todaydecrease" xorm:"'TODAYDECREASE'"` // 今日减少
- }
- // TableName is COUPONPOSITION
- func (Couponposition) TableName() string {
- return "COUPONPOSITION"
- }
- // HsbyTopGoods 热卖商品(二级市场挂牌点选)
- type HsbyTopGoods struct {
- Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
- Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
- Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Last float64 `json:"last" xorm:"-"` // 现价
- }
- // GetHsbyTopGoodses 获取热门商品列表
- // 参数 marketIDs string 所属市场ID列表, 格式 1,2,3
- // 参数 descProvinceID int 目标省ID
- // 参数 descCityID int 目标城市ID
- // 返回 []TopGoods 热门商品列表
- // 返回 error error
- func GetHsbyTopGoodses(marketIDs string, descProvinceID, descCityID int) ([]HsbyTopGoods, error) {
- // 热门商品为二级市场(挂牌点选)下的商品信息
- engine := db.GetEngine()
- topGoodses := make([]HsbyTopGoods, 0)
- // 获取挂牌商品信息,以及扩展表信息
- // 与商城不一样的是,挂牌点选以商品表作为主表,同一商品可有多个委托单
- session := engine.Table("GOODS").
- Select(`GOODS.*,
- HSBY_GOODSEX.HOTINDEX, HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS,
- ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
- MARKET.TRADEMODE`).
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
- Where(fmt.Sprintf("GOODS.GOODSSTATUS = 3 and GOODS.MARKETID in (%s)", marketIDs)) // 二级市场只获取 3:上市 状态的商品
- if descProvinceID > 0 {
- session = session.And("HSBY_GOODSEX.DESCPROVINCEID = ?", descProvinceID)
- }
- if descCityID > 0 {
- session = session.And("HSBY_GOODSEX.DESCCITYID = ?", descCityID)
- }
- if err := session.Find(&topGoodses); err != nil {
- return nil, err
- }
- if len(topGoodses) == 0 {
- // 无数据
- return topGoodses, nil
- }
- // 获取商品ID列表
- goodsCodes := ""
- for _, v := range topGoodses {
- if len(goodsCodes) == 0 {
- goodsCodes = v.Goodscode
- } else {
- goodsCodes += "," + v.Goodscode
- }
- }
- // 获取商品现价
- quoteDays, err := GetQuoteDays(goodsCodes)
- if err != nil {
- return nil, err
- }
- for i, g := range topGoodses {
- topGoods := &topGoodses[i]
- // FIXME: - 这里应该使用 Duck Typing,后期再处理
- // 计算最小变动单位
- // lotSize := float64(topGoods.Quoteminunit) * math.Pow(0.1, float64(topGoods.Decimalplace))
- // topGoods.LotSize, _ = strconv.ParseFloat(utils.FormatFloat(lotSize, int(topGoods.Decimalplace)), 64)
- for _, q := range quoteDays {
- if g.Goodscode == q.Goodscode {
- if q.Last != 0 {
- topGoods.Last = utils.IntToFloat64(int(q.Last), int(g.Decimalplace))
- }
- // 没有现价则尝试用昨结
- if topGoods.Last == 0 && q.Presettle != 0 {
- topGoods.Last = utils.IntToFloat64(int(q.Presettle), int(g.Decimalplace))
- }
- continue
- }
- }
- }
- return topGoodses, nil
- }
- // HsbyListingGoodsDetail 二级市场(挂牌点选)商品信息详情
- type HsbyListingGoodsDetail struct {
- Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
- Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
- Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Descprovinceid int64 `json:"descprovinceid" xorm:"'DESCPROVINCEID'"` // 目的地(省)ID
- Desccityid int64 `json:"desccityid" xorm:"'DESCCITYID'"` // 目的地(市)ID
- Goodsdesc string `json:"goodsdesc" xorm:"'GOODSDESC'"` // 商品详情
- Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
- Vendorphone string `json:"vendorphone" xorm:"'VENDORPHONE'"` // 供应商客服电话
- Vendorattr string `json:"vendorattr" xorm:"'VENDORATTR'"` // 供应商附件(多张,逗号分隔)
- Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Last float64 `json:"last" xorm:"-"` // 现价
- Limitup float64 `json:"limitup" xorm:"-"` // 涨停价
- Limitdown float64 `json:"limitdown" xorm:"-"` // 跌停价
- StepValue float64 `json:"stepvalue" xorm:"-"` // 价格最小变动单位
- LotSize int `json:"lotsize" xorm:"-"` // 手数最小变动单位
- }
- // GetHsbyListingGoodsDetail 获取二级市场(挂牌点选)商品信息详情
- // 参数 goodsID int 目标商品ID
- // 返回 *HsbyListingGoodsDetail 二级市场(挂牌点选)商品信息详情,查询无结果返回nil
- // 返回 error error
- func GetHsbyListingGoodsDetail(goodsID int) (*HsbyListingGoodsDetail, error) {
- engine := db.GetEngine()
- details := make([]HsbyListingGoodsDetail, 0)
- // 获取挂牌商品信息,以及扩展表信息
- // FIXME: - 这里使用Get方法,会造成SQL语句的嵌套出错,后期再研究
- session := engine.Table("GOODS").
- Select(`GOODS.GOODSID, GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.MARKETID, GOODS.QUOTEMINUNIT, GOODS.AGREEUNIT,
- HSBY_GOODSEX.HOTINDEX, HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS, HSBY_GOODSEX.DESCPROVINCEID, HSBY_GOODSEX.Desccityid, HSBY_GOODSEX.Goodsdesc,
- ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HSBY_SUPPLIERINFO.VENDORNAME, HSBY_SUPPLIERINFO.VENDORPHONE, HSBY_SUPPLIERINFO.VENDORATTR,
- MARKET.TRADEMODE`).
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
- Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
- Where("GOODS.GOODSID = ?", goodsID)
- if err := session.Find(&details); err != nil {
- return nil, err
- }
- // 无目标商品
- if len(details) == 0 {
- return nil, nil
- }
- hsbyListingGoodsDetail := details[0]
- // 获取商品现价和涨跌停价
- quoteDays, err := GetQuoteDays(hsbyListingGoodsDetail.Goodscode)
- if err != nil {
- return nil, err
- }
- if len(quoteDays) > 0 {
- if quoteDays[0].Last != 0 {
- hsbyListingGoodsDetail.Last = utils.IntToFloat64(int(quoteDays[0].Last), int(hsbyListingGoodsDetail.Decimalplace))
- }
- // 没有现价则尝试用昨结
- if hsbyListingGoodsDetail.Last == 0 && quoteDays[0].Presettle != 0 {
- hsbyListingGoodsDetail.Last = utils.IntToFloat64(int(quoteDays[0].Presettle), int(hsbyListingGoodsDetail.Decimalplace))
- }
- if quoteDays[0].Limitup != 0 {
- hsbyListingGoodsDetail.Limitup = utils.IntToFloat64(int(quoteDays[0].Limitup), int(hsbyListingGoodsDetail.Decimalplace))
- }
- if quoteDays[0].Limitdown != 0 {
- hsbyListingGoodsDetail.Limitdown = utils.IntToFloat64(int(quoteDays[0].Limitdown), int(hsbyListingGoodsDetail.Decimalplace))
- }
- }
- // 计算价格最小变动单位
- stepValue := float64(hsbyListingGoodsDetail.Quoteminunit) * math.Pow(0.1, float64(hsbyListingGoodsDetail.Decimalplace))
- hsbyListingGoodsDetail.StepValue, _ = strconv.ParseFloat(utils.FormatFloat(stepValue, int(hsbyListingGoodsDetail.Decimalplace)), 64)
- // 计算手数最小变动单位
- hsbyListingGoodsDetail.LotSize = 1
- return &hsbyListingGoodsDetail, nil
- }
- // HsbyGoodsOrderDetail 二级市场挂牌商品当前可摘委托单信息
- type HsbyGoodsOrderDetail struct {
- Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 委托单号(100+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
- Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
- Ordertime time.Time `json:"ordertime" xorm:"'ORDERTIME'" binding:"required"` // 委托时间
- Orderprice float64 `json:"orderprice" xorm:"'ORDERPRICE'"` // 委托价格
- Enableqty int64 `json:"enableqty" xorm:"ENABLEQTY"` // 可用数量
- Customername string `json:"customername" xorm:"'CUSTOMERNAME'"` // 客户名称(企业名称),已脱敏
- Currencysign string `json:"currencysign" xorm:"-"` // 货币符号
- Goodunit string `json:"goodunit" xorm:"-"` // 报价单位
- }
- // GetHsbyGoodsOrderDetails 获取二级市场(挂牌点选)商品对应的挂牌委托单信息
- // 输入 goodsID int 商品ID
- // 输入 buyOrSell int 挂牌委托单方向(对手单方向),0:买 1:卖
- // 输入 price float64 参考价格。买方向委托单则价格小于等于(站在摘牌人的角度);卖方向委托单则价格大于等于
- // 输出 []HsbyGoodsOrderDetail 商品对应的挂牌委托单信息
- // 输出 error error
- func GetHsbyGoodsOrderDetails(goodsID, buyOrSell int, price float64, accountIDs string) ([]HsbyGoodsOrderDetail, error) {
- engine := db.GetEngine()
- // 获取与目标商品相关的挂牌委托单信息(ListingSelectType = 1 or 3; OrderStatus =3 or 7)
- hsbyGoodsOrderDetails := make([]HsbyGoodsOrderDetail, 0)
- session := engine.Table("TRADE_ORDERDETAIL").
- Select(`to_char(TRADE_ORDERDETAIL.ORDERID) ORDERID, TRADE_ORDERDETAIL.BUYORSELL, TRADE_ORDERDETAIL.ORDERTIME, TRADE_ORDERDETAIL.ORDERPRICE, (TRADE_ORDERDETAIL.ORDERQTY - TRADE_ORDERDETAIL.TRADEQTY - TRADE_ORDERDETAIL.CANCELQTY) ENABLEQTY,
- substr(USERINFO.CUSTOMERNAME,0,1)||'****' as CUSTOMERNAME`).
- Join("LEFT", "TAACCOUNT", "TAACCOUNT.ACCOUNTID = TRADE_ORDERDETAIL.ACCOUNTID").
- Join("LEFT", "USERINFO", "USERINFO.USERID = TAACCOUNT.RELATEDUSERID").
- Where("(TRADE_ORDERDETAIL.LISTINGSELECTTYPE = 1 or TRADE_ORDERDETAIL.LISTINGSELECTTYPE = 3) and (TRADE_ORDERDETAIL.ORDERSTATUS = 3 or TRADE_ORDERDETAIL.ORDERSTATUS = 7)").
- And("TRADE_ORDERDETAIL.GOODSID = ?", goodsID).
- And("TRADE_ORDERDETAIL.BUYORSELL = ?", buyOrSell)
- if len(accountIDs) > 0 {
- session = session.And(fmt.Sprintf("TRADE_ORDERDETAIL.ACCOUNTID not in (%s)", accountIDs))
- }
- if price > 0 {
- if buyOrSell == 0 {
- // 对手单买方向委托单则价格大于等于(站在摘牌人的角度,摘牌方面是卖,我的闲置下单)
- session = session.And("TRADE_ORDERDETAIL.ORDERPRICE >= ?", price)
- } else {
- // 对手单卖方向委托单则价格小于等于(站在摘牌人的角度,摘牌方面是买,热门商品下单)
- session = session.And("TRADE_ORDERDETAIL.ORDERPRICE <= ?", price)
- }
- }
- if err := session.Find(&hsbyGoodsOrderDetails); err != nil {
- return nil, err
- }
- // 获取商品货币符号和报价单位
- goods, err := GetGoods(goodsID)
- if err != nil {
- return nil, err
- }
- currencyEnums, err := GetEnumDicItem("currency", int(goods.Currencyid))
- if err != nil {
- return nil, err
- }
- currencysign := ""
- if len(currencyEnums) > 0 {
- currencysign = currencyEnums[0].Param2
- }
- goodsUnitEnums, err := GetEnumDicItem("goodsunit", int(goods.Goodunitid))
- if err != nil {
- return nil, err
- }
- goodsUnit := ""
- if len(goodsUnitEnums) > 0 {
- goodsUnit = goodsUnitEnums[0].Enumdicname
- }
- for i := range hsbyGoodsOrderDetails {
- orderDetail := &hsbyGoodsOrderDetails[i]
- // 设置货币符号和报价单位
- orderDetail.Currencysign = currencysign
- orderDetail.Goodunit = goodsUnit
- }
- return hsbyGoodsOrderDetails, nil
- }
- // HybsMyBuyOrderDetail 我的订单(一二级市场的买方向委托单)
- type HybsMyBuyOrderDetail struct {
- Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 委托单号(100+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
- Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
- Orderprice float64 `json:"orderprice" xorm:"'ORDERPRICE'"` // 委托价格
- Orderqty int64 `json:"orderqty" xorm:"'ORDERQTY'" binding:"required"` // 委托数量
- Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
- Cancelqty int64 `json:"cancelqty" xorm:"'CANCELQTY'"` // 撤单数量
- Ordertime time.Time `json:"ordertime" xorm:"'ORDERTIME'" binding:"required"` // 委托时间
- Listingselecttype int32 `json:"listingselecttype" xorm:"'LISTINGSELECTTYPE'"` // 挂牌点选类型 - 1:挂牌 2:摘牌 3:先摘后挂
- Orderstatus int32 `json:"orderstatus" xorm:"'ORDERSTATUS'"` // 委托状态 - 1: 委托请求 2:待冻结 3:委托成功 4: 委托失败 5:配对成功 6: 已撤销 7:部分成交 8:已成交 9:部成部撤 10:成交失败 11:已拒绝 12:经过摘牌(先摘后挂专用-先摘后挂已摘过) 13:冻结成功(通道交易专用) 14:通道已撤 15:通道部成部撤 16:成交失败违约(荷兰式竞拍专用)
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Picurls1 string `json:"picurls1" xorm:"'PICURLS1'"` // 预售商品介绍图片[多张用逗号分隔]
- Picurls2 string `json:"picurls2" xorm:"'PICURLS2'"` // 挂牌商品介绍图片[多张用逗号分隔]
- Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Vendorname1 string `json:"vendorname1" xorm:"'VENDORNAME1'"` // 预售商品供应商名称
- Vendorname2 string `json:"vendorname2" xorm:"'VENDORNAME2'"` // 挂牌商品供应商名称
- MyBuyStatus int `json:"mybuystatus" xorm:"-"` // "我的订单"显示状态- 1:抢购中 2:求购中 3:已完成 4:已撤消 5:委托失败
- Orderamount float64 `json:"orderamount" xorm:"-"` // 委托金额
- }
- // GetHsbyBuyMyOrderDetails 获取“我的订单”数据(包括一二级市场)
- // 输入 accountIDs string 资金账户列表
- // 输入 myBuyStatus int "我的订单"状态, 1:抢购中 2:求购中 3:已完成
- // 输出 []HybsMyBuyOrderDetail “我的订单”数据
- // 输出 error error
- func GetHsbyBuyMyOrderDetails(accountIDs string, myBuyStatus int) ([]HybsMyBuyOrderDetail, error) {
- // 获取市场信息
- markets, err := GetMarkets()
- if err != nil {
- return nil, err
- }
- engine := db.GetEngine()
- // 委托状态
- orderStatus := "0" // 单据状态,为0的时候查询全部
- marketIDs := "" // 我的订单包括一二级市场的单据
- switch myBuyStatus {
- case 1: // 抢购中 (一级市场)
- // 获取市场ID
- for _, v := range markets {
- if v.Trademode == 71 { // 预售挂牌
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- orderStatus = "3,7"
- case 2: // 求购中(二级市场)
- // 获取市场ID
- for _, v := range markets {
- if v.Trademode == 16 { // 挂牌点选
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- orderStatus = "3,7"
- case 3: // 已完成
- orderStatus = "8,9"
- }
- // 默认取 TradeMode = 16 or 71 的市场
- if len(marketIDs) == 0 {
- for _, v := range markets {
- if v.Trademode == 16 || v.Trademode == 71 {
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- }
- hybsMyBuyOrderDetails := make([]HybsMyBuyOrderDetail, 0)
- // "我的订单"都是买委托
- session := engine.Table("TRADE_ORDERDETAIL").
- Select(`to_char(TRADE_ORDERDETAIL.ORDERID) ORDERID, TRADE_ORDERDETAIL.*,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HG1.PICURLS PICURLS1,
- HG2.PICURLS PICURLS2,
- MARKET.TRADEMODE,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HS1.VENDORNAME VENDORNAME1,
- HS2.VENDORNAME VENDORNAME2`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_ORDERDETAIL.GOODSID").
- Join("LEFT", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = TRADE_ORDERDETAIL.GOODSID").
- Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
- Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_ORDERDETAIL.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
- Where(fmt.Sprintf("TRADE_ORDERDETAIL.BUYORSELL = 0 and TRADE_ORDERDETAIL.ACCOUNTID in (%s)", accountIDs)).
- And(fmt.Sprintf("TRADE_ORDERDETAIL.MARKETID in (%s)", marketIDs))
- // 是否过滤状态(抢购中、求购中、已完成)
- if orderStatus != "0" {
- session = session.And(fmt.Sprintf("TRADE_ORDERDETAIL.ORDERSTATUS in (%s)", orderStatus))
- }
- if err := session.Find(&hybsMyBuyOrderDetails); err != nil {
- return nil, err
- }
- // 设置“我的订单”显示状态
- for i := range hybsMyBuyOrderDetails {
- detail := &hybsMyBuyOrderDetails[i]
- // 委托金额 = 委托价格 * 委托数量 * 合约单位
- detail.Orderamount = detail.Orderprice * float64(detail.Orderqty) * float64(detail.Agreeunit)
- if detail.Trademode == 71 && (detail.Orderstatus == 3 || detail.Orderstatus == 7) {
- // 抢购中
- detail.MyBuyStatus = 1
- } else if detail.Trademode == 16 && (detail.Orderstatus == 3 || detail.Orderstatus == 7) {
- // 求购中
- detail.MyBuyStatus = 2
- } else if detail.Orderstatus == 8 || detail.Orderstatus == 9 {
- // 已完成
- detail.MyBuyStatus = 3
- } else if detail.Orderstatus == 6 || detail.Orderstatus == 22 {
- // 已撤销
- detail.MyBuyStatus = 4
- } else if detail.Orderstatus == 4 {
- // 委托失败
- detail.MyBuyStatus = 5
- }
- }
- return hybsMyBuyOrderDetails, nil
- }
- // HsbyMyGoods 我的商品(买方向持仓)
- type HsbyMyGoods struct {
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账号Id
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品Id
- Buycurpositionqty int64 `json:"buycurpositionqty" xorm:"'BUYCURPOSITIONQTY'"` // 买当前持仓总数量
- Buycurholderamount float64 `json:"buycurholderamount" xorm:"'BUYCURHOLDERAMOUNT'"` // 买当前持仓总金额[商品币种]
- EnableQty int64 `json:"enableqty" xorm:"'ENABLEQTY'"` // 可用数量
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Goodsstatus int64 `json:"goodsstatus" xorm:"'GOODSSTATUS'"` // 商品状态- 1:待审核 2:未上市 3:上市 4:已注销 5:审核拒绝 6:退市 7:待退市
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Buyaverageprice float64 `json:"buyaverageprice" xorm:"-"` // 持仓均价
- }
- // GetHsbyMyGoods 获取“我的商品”信息
- // 输入 accountIDs string 资金账户列表,格式 1,2,3
- // 输出 []HsbyMyGoods “我的商品”信息
- // 输入 error error
- func GetHsbyMyGoods(accountIDs string) ([]HsbyMyGoods, error) {
- engine := db.GetEngine()
- hsbyMyGoodses := make([]HsbyMyGoods, 0)
- // 此定制版本,只查询出当前手数(期末)大于0的数据 (TRADEPOSITION.BUYCURPOSITIONQTY > 0)
- if err := engine.Table("TRADEPOSITION").
- Select(`TRADEPOSITION.*, (TRADEPOSITION.BUYCURPOSITIONQTY - TRADEPOSITION.BUYFROZENQTY - TRADEPOSITION.BUYOTHERFROZENQTY) ENABLEQTY,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT, GOODS.GOODSSTATUS,
- HSBY_GOODSEX.PICURLS,
- ENUMDICITEM.PARAM2 CURRENCYSIGN`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = TRADEPOSITION.GOODSID").
- Join("INNER", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Where(fmt.Sprintf("TRADEPOSITION.BUYCURPOSITIONQTY > 0 and TRADEPOSITION.ACCOUNTID in (%s)", accountIDs)).Find(&hsbyMyGoodses); err != nil {
- return nil, err
- }
- for i := range hsbyMyGoodses {
- myGoods := &hsbyMyGoodses[i]
- // 持仓均价
- averagePrice := myGoods.Buycurholderamount / float64(myGoods.Buycurpositionqty) / myGoods.Agreeunit
- myGoods.Buyaverageprice, _ = strconv.ParseFloat(utils.FormatFloat(averagePrice, int(myGoods.Decimalplace)), 64)
- }
- return hsbyMyGoodses, nil
- }
- // HsbyPreGoods 新品上市商品(一级市场产能预售)
- type HsbyPreGoods struct {
- Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
- Goodsstatus int64 `json:"goodsstatus" xorm:"'GOODSSTATUS'"` // 商品状态- 2:未上市 3:上市
- Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Listingdate time.Time `json:"listingdate" xorm:"'LISTINGDATE'"` // 交易开始日期
- Lasttradedate time.Time `json:"lasttradedate" xorm:"'LASTTRADEDATE'"` // 最后交易日期(状态:待退市)
- Relatedgoodsid int64 `json:"relatedgoodsid" xorm:"'RELATEDGOODSID'"` // 关联交易合约ID
- Presaleqty int64 `json:"presaleqty" xorm:"'PRESALEQTY'"` // 预售数量
- Refprice float64 `json:"refprice" xorm:"'REFPRICE'"` // 参考价格[一口价]
- Presaledqty int64 `json:"presaledqty" xorm:"'PRESALEDQTY'"` // 已预售量(预售结束时更新)
- EnableQty int64 `json:"enableqty" xorm:"ENABLEQTY"` // 剩余数量
- Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- }
- // GetHsbyPreGoodses 获取“新品上市”商品列表(一级市场产能预售)
- // 输入 marketIDs string 市场ID列表,格式 1,2,3
- // 输入 descProvinceID int 省ID
- // 输入 descCityID int 市ID
- // 输出 []HsbyPreGoods “新品上市”商品列表
- // 输出 error error
- func GetHsbyPreGoodses(marketIDs string, descProvinceID, descCityID int) ([]HsbyPreGoods, error) {
- engine := db.GetEngine()
- // 注意:一级产能预售市场使用的商品实际上是和二级市场有关系的,所以要使用 CPTRADE_PRESALEGOODSEX.RELATEDGOODSID 进行关联
- // 注意:CPTRADE_PRESALEGOODSEX 表的开始与结束时间是给大宗用的
- preGoodses := make([]HsbyPreGoods, 0)
- session := engine.Table("GOODS").
- Select(`GOODS.*,
- CPTRADE_PRESALEGOODSEX.RELATEDGOODSID, CPTRADE_PRESALEGOODSEX.PRESALEQTY, CPTRADE_PRESALEGOODSEX.REFPRICE,
- CPTRADE_PRESALEGOODSEX.PRESALEDQTY, (CPTRADE_PRESALEGOODSEX.PRESALEQTY - CPTRADE_PRESALEGOODSEX.PRESALEDQTY) ENABLEQTY,
- ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS,
- MARKET.TRADEMODE`).
- Join("INNER", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
- Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
- Where(fmt.Sprintf("GOODS.GOODSSTATUS in (2,3) and GOODS.MARKETID in (%s)", marketIDs)) // 一级市场获取 2:未上市 3:上市 状态的商品
- if descProvinceID > 0 {
- session = session.And("HSBY_GOODSEX.DESCPROVINCEID = ?", descProvinceID)
- }
- if descCityID > 0 {
- session = session.And("HSBY_GOODSEX.DESCCITYID = ?", descCityID)
- }
- if err := session.Find(&preGoodses); err != nil {
- return nil, err
- }
- // for i := range preGoodses {
- // preGoods := &preGoodses[i]
- // // FIXME: - 这里应该使用 Duck Typing,后期再处理
- // // 计算最小变动单位
- // lotSize := float64(preGoods.Quoteminunit) * math.Pow(0.1, float64(preGoods.Decimalplace))
- // preGoods.LotSize, _ = strconv.ParseFloat(utils.FormatFloat(lotSize, int(preGoods.Decimalplace)), 64)
- // }
- return preGoodses, nil
- }
- // HsbyPreGoodsDetail 一级市场(产能预售)商品信息详情
- type HsbyPreGoodsDetail struct {
- Goodsid int64 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID(自增ID SEQ_GOODS)
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Marketid int64 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 所属市场ID
- Goodsstatus int64 `json:"goodsstatus" xorm:"'GOODSSTATUS'"` // 商品状态- 2:未上市 3:上市
- Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Listingdate time.Time `json:"listingdate" xorm:"'LISTINGDATE'"` // 交易开始日期
- Lasttradedate time.Time `json:"lasttradedate" xorm:"'LASTTRADEDATE'"` // 最后交易日期(状态:待退市)
- Relatedgoodsid int64 `json:"relatedgoodsid" xorm:"'RELATEDGOODSID'"` // 关联交易合约ID
- Presaleqty int64 `json:"presaleqty" xorm:"'PRESALEQTY'"` // 预售数量
- Refprice float64 `json:"refprice" xorm:"'REFPRICE'"` // 参考价格[一口价]
- Presaledqty int64 `json:"presaledqty" xorm:"'PRESALEDQTY'"` // 已预售量(预售结束时更新)
- EnableQty int64 `json:"enableqty" xorm:"ENABLEQTY"` // 剩余数量
- Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Descprovinceid int64 `json:"descprovinceid" xorm:"'DESCPROVINCEID'"` // 目的地(省)ID
- Desccityid int64 `json:"desccityid" xorm:"'DESCCITYID'"` // 目的地(市)ID
- Goodsdesc string `json:"goodsdesc" xorm:"'GOODSDESC'"` // 商品详情
- Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Goodunit string `json:"goodunit" xorm:"GOODUNIT"` // 报价单位
- Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
- Vendorphone string `json:"vendorphone" xorm:"'VENDORPHONE'"` // 供应商客服电话
- Vendorattr string `json:"vendorattr" xorm:"'VENDORATTR'"` // 供应商附件(多张,逗号分隔)
- Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Customername string `json:"customername" xorm:"'CUSTOMERNAME'"` // 发行单位
- StepValue float64 `json:"stepvalue" xorm:"-"` // 价格最小变动单位
- LotSize int `json:"lotsize" xorm:"-"` // 手数最小变动单位
- Buymaxqty int `json:"buymaxqty" xorm:"'-'"` // 购买上限 [71] - 0为不限
- }
- // GetHsbyPreGoodsDetail 获取一级市场(产能预售)商品信息详情
- // 参数 goodsID int 目标商品ID
- // 返回 *HsbyListingGoodsDetail 二级市场(挂牌点选)商品信息详情,查询无结果返回nil
- // 返回 error error
- func GetHsbyPreGoodsDetail(goodsID, accountID int) (*HsbyPreGoodsDetail, error) {
- engine := db.GetEngine()
- details := make([]HsbyPreGoodsDetail, 0)
- // 获取挂牌商品信息,以及扩展表信息
- // FIXME: - 这里使用Get方法,会造成SQL语句的嵌套出错,后期再研究
- session := engine.Table("GOODS").
- Select(`GOODS.*,
- CPTRADE_PRESALEGOODSEX.RELATEDGOODSID, CPTRADE_PRESALEGOODSEX.PRESALEQTY, CPTRADE_PRESALEGOODSEX.REFPRICE,
- CPTRADE_PRESALEGOODSEX.PRESALEDQTY, (CPTRADE_PRESALEGOODSEX.PRESALEQTY - CPTRADE_PRESALEGOODSEX.PRESALEDQTY) ENABLEQTY,
- HSBY_GOODSEX.VIDEOURLS, HSBY_GOODSEX.PICURLS, HSBY_GOODSEX.DESCPROVINCEID, HSBY_GOODSEX.Desccityid, HSBY_GOODSEX.Goodsdesc,
- ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
- E1.ENUMDICNAME GOODUNIT,
- HSBY_SUPPLIERINFO.VENDORNAME, HSBY_SUPPLIERINFO.VENDORPHONE, HSBY_SUPPLIERINFO.VENDORATTR,
- MARKET.TRADEMODE,
- USERINFO.CUSTOMERNAME`).
- Join("INNER", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
- Join("LEFT", "ENUMDICITEM", "ENUMDICITEM.ENUMITEMNAME = GOODS.CURRENCYID and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "ENUMDICITEM E1", "E1.ENUMITEMNAME = GOODS.GOODUNITID and E1.ENUMDICCODE = 'goodsunit'").
- Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
- Join("LEFT", "MARKET", "MARKET.MARKETID = GOODS.MARKETID").
- Join("LEFT", "USERINFO", "USERINFO.USERID = CPTRADE_PRESALEGOODSEX.USERID").
- Where("GOODS.GOODSID = ?", goodsID)
- if err := session.Find(&details); err != nil {
- return nil, err
- }
- // 无目标商品
- if len(details) == 0 {
- return nil, nil
- }
- preGoodsDetail := details[0]
- // FIXME: - 这里应该使用 Duck Typing,后期再处理
- // 计算价格最小变动单位
- stepValue := float64(preGoodsDetail.Quoteminunit) * math.Pow(0.1, float64(preGoodsDetail.Decimalplace))
- preGoodsDetail.StepValue, _ = strconv.ParseFloat(utils.FormatFloat(stepValue, int(preGoodsDetail.Decimalplace)), 64)
- // 计算手数最小变动单位,一级市场固定为1
- preGoodsDetail.LotSize = 1
- // 获取购买上限
- if accountID != 0 {
- buyMaxQty, err := GetCPTradeBuyLimit(goodsID, accountID)
- if err != nil {
- return nil, err
- }
- preGoodsDetail.Buymaxqty = buyMaxQty
- }
- return &preGoodsDetail, nil
- }
- // HsbySellMyDetail "我的闲置"单据信息(发布中 - 二级市场卖挂,3:委托成功、7:部分成交; 已完成 - 二级市场成交单,包括历史数据)
- type HsbySellMyDetail struct {
- Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 单号(发布中 - 委托单号;已完成 - 成交单号)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
- Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
- Price float64 `json:"price" xorm:"'PRICE'"` // 价格
- Time time.Time `json:"time" xorm:"'TIME'" binding:"required"` // 时间
- Qty int64 `json:"qty" xorm:"'QTY'"` // 数量
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
- OrderType int32 `json:"ordertype" xorm:"'ORDERTYPE'"` // 单据类型:0 - 发布中, 1 - 已完成
- }
- // GetHsbySellMyOrderDetails 获取"我的闲置 - 发布中"单据信息
- // 输入 accountIDs string 资金账户列表
- // 输出 []HsbySellMyDetail "我的闲置 - 发布中"单据信息
- // 输出 error error
- func GetHsbySellMyOrderDetails(accountIDs string) ([]HsbySellMyDetail, error) {
- // 获取市场信息
- markets, err := GetMarkets()
- if err != nil {
- return nil, err
- }
- engine := db.GetEngine()
- marketIDs := "" // 我的闲置-发布中: 二级市场卖挂牌
- // 默认取 TradeMode = 16
- for _, v := range markets {
- if v.Trademode == 16 {
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- orderDetails := make([]HsbySellMyDetail, 0)
- // “我的闲置 - 发布中”都是卖挂委托
- session := engine.Table("TRADE_ORDERDETAIL").
- Select(`to_char(TRADE_ORDERDETAIL.ORDERID) ORDERID,
- TRADE_ORDERDETAIL.MARKETID, TRADE_ORDERDETAIL.GOODSID, TRADE_ORDERDETAIL.ACCOUNTID, TRADE_ORDERDETAIL.BUYORSELL,
- TRADE_ORDERDETAIL.ORDERPRICE PRICE, TRADE_ORDERDETAIL.ORDERTIME TIME,
- (TRADE_ORDERDETAIL.ORDERQTY - TRADE_ORDERDETAIL.TRADEQTY - TRADE_ORDERDETAIL.CANCELQTY) QTY,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HSBY_GOODSEX.PICURLS,
- MARKET.TRADEMODE,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HSBY_SUPPLIERINFO.VENDORNAME,
- 0 ORDERTYPE`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_ORDERDETAIL.GOODSID").
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_ORDERDETAIL.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
- Where(fmt.Sprintf(`TRADE_ORDERDETAIL.BUYORSELL = 1 and TRADE_ORDERDETAIL.LISTINGSELECTTYPE = 1 and (TRADE_ORDERDETAIL.ORDERSTATUS = 3 or TRADE_ORDERDETAIL.ORDERSTATUS = 7)
- and TRADE_ORDERDETAIL.ACCOUNTID in (%s)`, accountIDs)).
- And(fmt.Sprintf("TRADE_ORDERDETAIL.MARKETID in (%s)", marketIDs))
- if err := session.Find(&orderDetails); err != nil {
- return nil, err
- }
- return orderDetails, nil
- }
- // GetHsbySellMyTradeDetails 获取"我的闲置 - 已完成"单据信息
- // 输入 accountIDs string 资金账户列表
- // 输出 []HsbySellMyDetail "我的闲置 - 已完成"单据信息
- // 输出 error error
- func GetHsbySellMyTradeDetails(accountIDs string) ([]HsbySellMyDetail, error) {
- // 获取市场信息
- markets, err := GetMarkets()
- if err != nil {
- return nil, err
- }
- engine := db.GetEngine()
- marketIDs := "" // 我的闲置-发布中: 二级市场卖方向成交单(包括历史成交单)
- // 默认取 TradeMode = 16
- for _, v := range markets {
- if v.Trademode == 16 {
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- orders := make([]HsbySellMyDetail, 0)
- // 当前成交单
- curOrders := make([]HsbySellMyDetail, 0)
- if err := engine.Table("TRADE_TRADEDETAIL").
- Select(`to_char(TRADE_TRADEDETAIL.TRADEID) ORDERID,
- TRADE_TRADEDETAIL.MARKETID, TRADE_TRADEDETAIL.GOODSID, TRADE_TRADEDETAIL.ACCOUNTID, TRADE_TRADEDETAIL.BUYORSELL,
- TRADE_TRADEDETAIL.TRADEPRICE PRICE, TRADE_TRADEDETAIL.TRADEQTY QTY, TRADE_TRADEDETAIL.TRADETIME TIME, TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HSBY_GOODSEX.PICURLS,
- MARKET.TRADEMODE,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HSBY_SUPPLIERINFO.VENDORNAME,
- 1 ORDERTYPE`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_TRADEDETAIL.GOODSID").
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_TRADEDETAIL.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
- Where(fmt.Sprintf(`TRADE_TRADEDETAIL.BUYORSELL = 1 and TRADE_TRADEDETAIL.TRADETYPE in (1,24)
- and TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
- And(fmt.Sprintf("TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&curOrders); err != nil {
- return nil, err
- }
- if len(curOrders) > 0 {
- orders = append(orders, curOrders...)
- }
- // 历史成交单
- hisOrders := make([]HsbySellMyDetail, 0)
- if err := engine.Table("HIS_TRADE_TRADEDETAIL").
- Select(`to_char(HIS_TRADE_TRADEDETAIL.TRADEID) ORDERID,
- HIS_TRADE_TRADEDETAIL.MARKETID, HIS_TRADE_TRADEDETAIL.GOODSID, HIS_TRADE_TRADEDETAIL.ACCOUNTID, HIS_TRADE_TRADEDETAIL.BUYORSELL,
- HIS_TRADE_TRADEDETAIL.TRADEPRICE PRICE, HIS_TRADE_TRADEDETAIL.TRADEQTY QTY, HIS_TRADE_TRADEDETAIL.TRADETIME TIME, HIS_TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HSBY_GOODSEX.PICURLS,
- MARKET.TRADEMODE,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HSBY_SUPPLIERINFO.VENDORNAME,
- 1 ORDERTYPE`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = HIS_TRADE_TRADEDETAIL.GOODSID").
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = HIS_TRADE_TRADEDETAIL.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
- Where(fmt.Sprintf(`HIS_TRADE_TRADEDETAIL.BUYORSELL = 1 and HIS_TRADE_TRADEDETAIL.TRADETYPE in (1,24) and HIS_TRADE_TRADEDETAIL.ISVALIDDATA = 1
- and HIS_TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
- And(fmt.Sprintf("HIS_TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&hisOrders); err != nil {
- return nil, err
- }
- if len(hisOrders) > 0 {
- orders = append(orders, hisOrders...)
- }
- return orders, nil
- }
- // HsbyMyPackage 我的包裹信息
- type HsbyMyPackage struct {
- Takeorderid string `json:"takeorderid" xorm:"'TAKEORDERID'" binding:"required"` // 提货单号(905+Unix秒时间戳(10位)+xxxxxx)
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'"` // 账户ID
- Goodsid int64 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
- Userid int64 `json:"userid" xorm:"'USERID'"` // 用户ID
- Qty float64 `json:"qty" xorm:"'QTY'"` // 提货数量
- Reqtime time.Time `json:"reqtime" xorm:"'REQTIME'"` // 更新时间
- Recivername string `json:"recivername" xorm:"'RECIVERNAME'"` // 提货人姓名
- Cardtypeid int32 `json:"cardtypeid" xorm:"'CARDTYPEID'"` // 提货人证件类型
- Cardnum string `json:"cardnum" xorm:"'CARDNUM'"` // 提货人证件号码
- Phonenum string `json:"phonenum" xorm:"'PHONENUM'"` // 提货人联系方式
- Takemode int32 `json:"takemode" xorm:"'TAKEMODE'"` // 提货方式 - 2:自提 3:配送
- Address string `json:"address" xorm:"'ADDRESS'"` // 提货人详细地址
- Takeremark string `json:"takeremark" xorm:"'TAKEREMARK'"` // 提货备注
- Takeorderstatus int32 `json:"takeorderstatus" xorm:"'TAKEORDERSTATUS'"` // 提货状态 - 1:待发货 2:已发货 3:已收货
- Auditer int32 `json:"auditer" xorm:"'AUDITER'"` // 审核人
- Audittime time.Time `json:"audittime" xorm:"'AUDITTIME'"` // 审核时间
- Checkremark string `json:"checkremark" xorm:"'CHECKREMARK'"` // 审核备注
- Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
- Handlestatus int32 `json:"handlestatus" xorm:"'HANDLESTATUS'"` // 处理状态
- Amount float64 `json:"amount" xorm:"'AMOUNT'"` // 提货金额
- Averageprice float64 `json:"averageprice" xorm:"'AVERAGEPRICE'"` // 均价
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
- }
- // GetHsbyMyPackages 获取我的包裹信息
- // 输入 accountIDs string 资金账户列表
- // 输入 takeOrderStatus int 提货状态 - 1:待发货 2:已发货 3:已收货
- // 输出 []HsbyMyPackage 我的包裹信息
- // 输出 error error
- func GetHsbyMyPackages(accountIDs string, takeOrderStatus int) ([]HsbyMyPackage, error) {
- engine := db.GetEngine()
- myPackages := make([]HsbyMyPackage, 0)
- session := engine.Table("TRADE_GOODSPICKUP").
- Select(`to_char(TRADE_GOODSPICKUP.TAKEORDERID) TAKEORDERID, (DIVISION.PATHNAME || TRADE_GOODSPICKUP.ADDRESS) ADDRESS, TRADE_GOODSPICKUP.*,
- (TRADE_GOODSPICKUP.AMOUNT/TRADE_GOODSPICKUP.QTY/GOODS.AGREEUNIT) AVERAGEPRICE,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HSBY_GOODSEX.PICURLS,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HSBY_SUPPLIERINFO.VENDORNAME`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_GOODSPICKUP.GOODSID").
- Join("LEFT", "HSBY_GOODSEX", "HSBY_GOODSEX.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "HSBY_SUPPLIERINFO", "HSBY_SUPPLIERINFO.VENDORID = HSBY_GOODSEX.VENDORID").
- Join("LEFT", "DIVISION", "DIVISION.AUTOID = TRADE_GOODSPICKUP.DISTRICTID").
- Where(fmt.Sprintf("TRADE_GOODSPICKUP.ACCOUNTID in (%s)", accountIDs))
- if takeOrderStatus > 0 {
- session = session.And("TAKEORDERSTATUS = ?", takeOrderStatus)
- }
- if err := session.Find(&myPackages); err != nil {
- return nil, err
- }
- // FIXME:- 目前暂时在服务端对手机号码进行解密
- key, _ := hex.DecodeString(utils.AESSecretKey)
- for i := range myPackages {
- myPackage := &myPackages[i]
- // 解密手机号码
- if phonenum, err := hex.DecodeString(myPackage.Phonenum); err == nil { // hex -> []byte
- if mobile, err := utils.AESDecrypt(phonenum, key); err == nil {
- myPackage.Phonenum = string(mobile)
- }
- }
- }
- return myPackages, nil
- }
- // SetHsbyMyPackagesStatus 设置我的包裹提货状态
- func SetHsbyMyPackagesStatus(takeOrderID string, accountID, status int) error {
- engine := db.GetEngine()
- sql := fmt.Sprintf("update TRADE_GOODSPICKUP set TAKEORDERSTATUS = %d where TAKEORDERID = %s and ACCOUNTID = %d", status, takeOrderID, accountID)
- _, err := engine.Exec(sql)
- return err
- }
- // GetHsbyProvincesAndCities 获取省市信息数组
- // 参数 provinceID int 省ID,选填
- // 返回 []Division 枚举信息数组
- // 返回 error error
- func GetHsbyProvincesAndCities(provinceID int) ([]Division, error) {
- engine := db.GetEngine()
- divisions := make([]Division, 0)
- session := engine.Where("DIVISIONLEVEL = 'province' or DIVISIONLEVEL = 'city'").
- And(`AUTOID in (
- (select DESCPROVINCEID AUTOID from HSBY_GOODSEX inner join GOODS on GOODS.GOODSID = HSBY_GOODSEX.GOODSID and GOODS.GOODSSTATUS in (2,3))
- union all
- (select DESCCITYID AUTOID from HSBY_GOODSEX inner join GOODS on GOODS.GOODSID = HSBY_GOODSEX.GOODSID and GOODS.GOODSSTATUS in (2,3))
- )`)
- if provinceID > 0 {
- session = session.And("AUTOID = ?", provinceID)
- }
- if err := session.Find(&divisions); err != nil {
- return nil, err
- }
- return divisions, nil
- }
- // HsbyBuyMyTradeDetail "我的订单 - 已完成"单据信息(一二级市场成交单,包括历史数据)
- type HsbyBuyMyTradeDetail struct {
- Orderid string `json:"orderid" xorm:"'ORDERID'" binding:"required"` // 单号(成交单号)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
- Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
- Price float64 `json:"price" xorm:"'PRICE'"` // 价格
- Qty int64 `json:"qty" xorm:"'QTY'" binding:"required"` // 数量
- Time time.Time `json:"time" xorm:"'TIME'" binding:"required"` // 时间
- Amount float64 `json:"amount" xorm:"'AMOUNT'"` // 金额 = 价格 * 数量 * 合约单位
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Picurls1 string `json:"picurls1" xorm:"'PICURLS1'"` // 预售商品介绍图片[多张用逗号分隔]
- Picurls2 string `json:"picurls2" xorm:"'PICURLS2'"` // 挂牌商品介绍图片[多张用逗号分隔]
- Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Vendorname1 string `json:"vendorname1" xorm:"'VENDORNAME1'"` // 预售商品供应商名称
- Vendorname2 string `json:"vendorname2" xorm:"'VENDORNAME2'"` // 挂牌商品供应商名称
- }
- // GetHsbyBuyMyTradeDetails 获取"我的订单 - 已完成"单据信息(一二级市场成交单,包括历史数据)
- // 输入 accountIDs string 资金账户列表
- // 输出 []HsbyBuyMyTradeDetail "我的订单 - 已完成"单据信息
- // 输出 error error
- func GetHsbyBuyMyTradeDetails(accountIDs string) ([]HsbyBuyMyTradeDetail, error) {
- // 获取市场信息
- markets, err := GetMarkets()
- if err != nil {
- return nil, err
- }
- engine := db.GetEngine()
- marketIDs := "" // 我的订单包括一二级市场卖方向成交单(包括历史成交单)
- // 默认取 TradeMode = 16
- for _, v := range markets {
- if v.Trademode == 16 || v.Trademode == 71 {
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- orders := make([]HsbyBuyMyTradeDetail, 0)
- // 当前成交单
- curOrders := make([]HsbyBuyMyTradeDetail, 0)
- if err := engine.Table("TRADE_TRADEDETAIL").
- Select(`to_char(TRADE_TRADEDETAIL.TRADEID) ORDERID,
- TRADE_TRADEDETAIL.MARKETID, TRADE_TRADEDETAIL.GOODSID, TRADE_TRADEDETAIL.ACCOUNTID, TRADE_TRADEDETAIL.BUYORSELL,
- TRADE_TRADEDETAIL.TRADEPRICE PRICE, TRADE_TRADEDETAIL.TRADEQTY QTY, TRADE_TRADEDETAIL.TRADETIME TIME, TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HG1.PICURLS PICURLS1, HG2.PICURLS PICURLS2,
- MARKET.TRADEMODE,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HS1.VENDORNAME VENDORNAME1, HS2.VENDORNAME VENDORNAME2`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = TRADE_TRADEDETAIL.GOODSID").
- Join("LEFT", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = TRADE_TRADEDETAIL.GOODSID").
- Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
- Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = TRADE_TRADEDETAIL.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
- Where(fmt.Sprintf(`TRADE_TRADEDETAIL.BUYORSELL = 0 and TRADE_TRADEDETAIL.TRADETYPE in (1,24)
- and TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
- And(fmt.Sprintf("TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&curOrders); err != nil {
- return nil, err
- }
- if len(curOrders) > 0 {
- orders = append(orders, curOrders...)
- }
- // 历史成交单
- hisOrders := make([]HsbyBuyMyTradeDetail, 0)
- if err := engine.Table("HIS_TRADE_TRADEDETAIL").
- Select(`to_char(HIS_TRADE_TRADEDETAIL.TRADEID) ORDERID,
- HIS_TRADE_TRADEDETAIL.MARKETID, HIS_TRADE_TRADEDETAIL.GOODSID, HIS_TRADE_TRADEDETAIL.ACCOUNTID, HIS_TRADE_TRADEDETAIL.BUYORSELL,
- HIS_TRADE_TRADEDETAIL.TRADEPRICE PRICE, HIS_TRADE_TRADEDETAIL.TRADEQTY QTY, HIS_TRADE_TRADEDETAIL.TRADETIME TIME, HIS_TRADE_TRADEDETAIL.TRADEAMOUNT AMOUNT,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HG1.PICURLS PICURLS1, HG2.PICURLS PICURLS2,
- MARKET.TRADEMODE,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HS1.VENDORNAME VENDORNAME1, HS2.VENDORNAME VENDORNAME2`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = HIS_TRADE_TRADEDETAIL.GOODSID").
- Join("LEFT", "CPTRADE_PRESALEGOODSEX", "CPTRADE_PRESALEGOODSEX.GOODSID = HIS_TRADE_TRADEDETAIL.GOODSID").
- Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CPTRADE_PRESALEGOODSEX.RELATEDGOODSID").
- Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = HIS_TRADE_TRADEDETAIL.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
- Where(fmt.Sprintf(`HIS_TRADE_TRADEDETAIL.BUYORSELL = 0 and HIS_TRADE_TRADEDETAIL.TRADETYPE in (1,24) and HIS_TRADE_TRADEDETAIL.ISVALIDDATA = 1
- and HIS_TRADE_TRADEDETAIL.ACCOUNTID in (%s)`, accountIDs)).
- And(fmt.Sprintf("HIS_TRADE_TRADEDETAIL.MARKETID in (%s)", marketIDs)).Find(&hisOrders); err != nil {
- return nil, err
- }
- if len(hisOrders) > 0 {
- orders = append(orders, hisOrders...)
- }
- return orders, nil
- }
- // HsbyBuyMyPayOrder "我的订单 - 待付款"单据信息(一二级市场待付款信息)
- type HsbyBuyMyPayOrder struct {
- Tradeid string `json:"tradeid" xorm:"'TRADEIDSTR'" binding:"required"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
- Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
- Buyorderid string `json:"buyorderid" xorm:"'BUYORDERIDSTR'"` // 买方委托单号
- Buyaccountid int64 `json:"buyaccountid" xorm:"'BUYACCOUNTID'"` // 买方账号ID[报价币种]
- Sellorderid string `json:"sellorderid" xorm:"'SELLORDERIDSTR'"` // 卖方委托单号
- Sellaccountid int64 `json:"sellaccountid" xorm:"'SELLACCOUNTID'"` // 卖方账号ID[报价币种]
- Tradeamount float64 `json:"tradeamount" xorm:"'TRADEAMOUNT'"` // 成交金额
- Tradecharge float64 `json:"tradecharge" xorm:"'TRADECHARGE'"` // 成交手续费(买方)
- Payflag int32 `json:"payflag" xorm:"'PAYFLAG'"` // 付款标识 - 1:未支付 2:已支付 3:已过期 4:已撤销 5:结算过期 6:预售终止
- Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
- Paytime time.Time `json:"paytime" xorm:"'PAYTIME'"` // 付款时间
- Paylimitedtime time.Time `json:"paylimitedtime" xorm:"'PAYLIMITEDTIME'"` // 支付期限
- Offamount float64 `json:"offamount" xorm:"'OFFAMOUNT'"` // 优惠金额
- Tradeprice float64 `json:"tradeprice" xorm:"'TRADEPRICE'"` // 成交价格
- Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
- Payamount float64 `json:"payamount" xorm:"'PAYAMOUNT'"` // 支付金额 = TradeAmount + TradeCharge - OffAmount
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Picurls1 string `json:"picurls1" xorm:"'PICURLS1'"` // 预售商品介绍图片[多张用逗号分隔]
- Picurls2 string `json:"picurls2" xorm:"'PICURLS2'"` // 挂牌商品介绍图片[多张用逗号分隔]
- Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Vendorname1 string `json:"vendorname1" xorm:"'VENDORNAME1'"` // 预售商品供应商名称
- Vendorname2 string `json:"vendorname2" xorm:"'VENDORNAME2'"` // 挂牌商品供应商名称
- }
- // GetHsbyBuyMyPayOrders 获取待付款信息
- func GetHsbyBuyMyPayOrders(accountIDs string, buyOrderID, sellOrderID int) ([]HsbyBuyMyPayOrder, error) {
- // 获取市场信息
- markets, err := GetMarkets()
- if err != nil {
- return nil, err
- }
- engine := db.GetEngine()
- marketIDs := "" // 我的订单包括一二级市场卖方向成交单
- // 默认取 TradeMode = 16
- for _, v := range markets {
- if v.Trademode == 16 || v.Trademode == 71 {
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- orders := make([]HsbyBuyMyPayOrder, 0)
- session := engine.Table("TRADE_PAYORDER TP").
- Select(`to_char(TP.TRADEID) TRADEIDSTR, to_char(TP.BUYORDERID) BUYORDERIDSTR, to_char(TP.SELLORDERID) SELLORDERIDSTR, TP.*,
- GOODS.GOODSCODE, GOODS.GOODSNAME, GOODS.DECIMALPLACE, GOODS.AGREEUNIT,
- HG1.PICURLS PICURLS1, HG2.PICURLS PICURLS2,
- MARKET.TRADEMODE,
- ENUMDICITEM.PARAM2 CURRENCYSIGN,
- HS1.VENDORNAME VENDORNAME1, HS2.VENDORNAME VENDORNAME2`).
- Join("LEFT", "GOODS", "GOODS.GOODSID = TP.GOODSID").
- Join("LEFT", "CPTRADE_PRESALEGOODSEX CP", "CP.GOODSID = TP.GOODSID").
- Join("LEFT", "HSBY_GOODSEX HG1", "HG1.GOODSID = CP.RELATEDGOODSID").
- Join("LEFT", "HSBY_GOODSEX HG2", "HG2.GOODSID = GOODS.GOODSID").
- Join("LEFT", "ENUMDICITEM", "GOODS.CURRENCYID = ENUMDICITEM.ENUMITEMNAME and ENUMDICITEM.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET", "MARKET.MARKETID = TP.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS1", "HS1.VENDORID = HG1.VENDORID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS2", "HS2.VENDORID = HG2.VENDORID").
- Where(fmt.Sprintf(`TP.PAYFLAG = 1 and TP.BUYACCOUNTID in (%s)`, accountIDs)).
- And(fmt.Sprintf("TP.MARKETID in (%s)", marketIDs))
- if buyOrderID != 0 {
- session = session.And("TP.BUYORDERID = ?", buyOrderID)
- }
- if sellOrderID != 0 {
- session = session.And("TP.SELLORDERID = ?", sellOrderID)
- }
- if err := session.Find(&orders); err != nil {
- return nil, err
- }
- return orders, nil
- }
- // HsbyMarketInfo 海商报业相关市场信息
- type HsbyMarketInfo struct {
- Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID正常5位,前三位固定:两位表示交易模式, 一位表示交易属性(1:收益权,2:所有权) 其它特殊市场:0-系统 1-交割服务 2-账户服务3-履约服务 4-仓单服务 5-积分服务 6-银行服务
- Marketname string `json:"marketname" xorm:"'MARKETNAME'"` // 市场名称
- Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Marketstatus int32 `json:"marketstatus" xorm:"'MARKETSTATUS'" binding:"required"` // 生效状态(ValidStatus枚举): 1:待生效 2:正常 3:注销
- }
- // GetHsbyMarketInfos 获取海商报业相关市场信息
- func GetHsbyMarketInfos() ([]HsbyMarketInfo, error) {
- engine := db.GetEngine()
- markets := make([]HsbyMarketInfo, 0)
- if err := engine.Table("MARKET").Where("TRADEMODE in (71,16,70)").Find(&markets); err != nil {
- return nil, err
- }
- return markets, nil
- }
- // HsbySellCollectionOrder 我的闲置中收款信息
- type HsbySellCollectionOrder struct {
- Tradeid string `json:"tradeid" xorm:"'TRADEIDSTR'" binding:"required"` // 成交单号(101+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
- Tradedate string `json:"tradedate" xorm:"'TRADEDATE'"` // 交易日(yyyyMMdd)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'"` // 商品ID
- Buyorderid string `json:"buyorderid" xorm:"'BUYORDERIDSTR'"` // 买方委托单号
- Buyaccountid int64 `json:"buyaccountid" xorm:"'BUYACCOUNTID'"` // 买方账号ID[报价币种]
- Sellorderid string `json:"sellorderid" xorm:"'SELLORDERIDSTR'"` // 卖方委托单号
- Sellaccountid int64 `json:"sellaccountid" xorm:"'SELLACCOUNTID'"` // 卖方账号ID[报价币种]
- Tradeamount float64 `json:"tradeamount" xorm:"'TRADEAMOUNT'"` // 成交金额
- Tradecharge float64 `json:"tradecharge" xorm:"'TRADECHARGE'"` // 成交手续费(买方)
- Payflag int32 `json:"payflag" xorm:"'PAYFLAG'"` // 付款标识 - 1:未支付 2:已支付 3:已过期 4:已撤销 5:结算过期 6:预售终止
- Createtime time.Time `json:"createtime" xorm:"'CREATETIME'"` // 创建时间
- Paytime time.Time `json:"paytime" xorm:"'PAYTIME'"` // 付款时间
- Paylimitedtime time.Time `json:"paylimitedtime" xorm:"'PAYLIMITEDTIME'"` // 支付期限
- Offamount float64 `json:"offamount" xorm:"'OFFAMOUNT'"` // 优惠金额
- Tradeprice float64 `json:"tradeprice" xorm:"'TRADEPRICE'"` // 成交价格
- Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
- Payamount float64 `json:"payamount" xorm:"'PAYAMOUNT'"` // 支付金额 = TradeAmount + TradeCharge - OffAmount
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 商品介绍图片[多张用逗号分隔]
- Trademode uint32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- }
- // GetHsbySellCollectionOrders 获取我的闲置中待收款信息
- func GetHsbySellCollectionOrders(accountIDs string) ([]HsbySellCollectionOrder, error) {
- // 获取市场信息
- markets, err := GetMarkets()
- if err != nil {
- return nil, err
- }
- engine := db.GetEngine()
- marketIDs := ""
- // 默认取 TradeMode = 16
- for _, v := range markets {
- if v.Trademode == 16 {
- if len(marketIDs) == 0 {
- marketIDs = strconv.Itoa(int(v.Marketid))
- } else {
- marketIDs += "," + strconv.Itoa(int(v.Marketid))
- }
- }
- }
- orders := make([]HsbySellCollectionOrder, 0)
- session := engine.Table("TRADE_PAYORDER TP").
- Select(`to_char(TP.TRADEID) TRADEIDSTR, to_char(TP.BUYORDERID) BUYORDERIDSTR, to_char(TP.SELLORDERID) SELLORDERIDSTR, TP.*,
- G.GOODSCODE, G.GOODSNAME, G.DECIMALPLACE, G.AGREEUNIT,
- HG.PICURLS,
- M.TRADEMODE,
- E.PARAM2 CURRENCYSIGN`).
- Join("LEFT", "GOODS G", "G.GOODSID = TP.GOODSID").
- Join("LEFT", "HSBY_GOODSEX HG", "HG.GOODSID = G.GOODSID").
- Join("LEFT", "ENUMDICITEM E", "G.CURRENCYID = E.ENUMITEMNAME and E.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET M", "M.MARKETID = TP.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO HS", "HS.VENDORID = HG.VENDORID").
- Where(fmt.Sprintf(`TP.PAYFLAG = 1 and TP.SELLACCOUNTID in (%s)`, accountIDs)).
- And(fmt.Sprintf("TP.MARKETID in (%s)", marketIDs))
- if err := session.Find(&orders); err != nil {
- return nil, err
- }
- return orders, nil
- }
- // HsbyMarketGoods 特卖商城商品(三级市场商场)
- type HsbyMarketGoods struct {
- Orderid string `json:"orderid" xorm:"'ORDERIDSTR'" binding:"required"` // 委托单号(100+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
- Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
- Orderprice float64 `json:"orderprice" xorm:"'ORDERPRICE'"` // 委托价格
- Orderstatus int32 `json:"orderstatus" xorm:"'ORDERSTATUS'"` // 委托状态 - 1: 委托请求 2:待冻结 3:委托成功 4: 委托失败 5:配对成功 6: 已撤销 7:部分成交 8:已成交 9:部成部撤 10:成交失败 11:已拒绝 12:经过摘牌(先摘后挂专用-先摘后挂已摘过) 13:冻结成功(通道交易专用) 14:通道已撤 15:通道部成部撤 16:成交失败违约(荷兰式竞拍专用)
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
- Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Categoryid int32 `json:"categoryid" xorm:"'CATEGORYID'"` // 类别ID(WRCATEGORY)
- Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Customername string `json:"customername" xorm:"'CUSTOMERNAME'"` // 卖家名称
- HasCoupon bool `json:"hascoupon" xorm:"-"` // 是否可用优惠卷
- SellUserID int `json:"sellUserID" xorm:"-"` // 卖方UserID
- }
- // GetHsbyMarketGoodses 获取商城商品列表(三级商城)
- func GetHsbyMarketGoodses(marketIDs string, accountID, categoryID, goodsID int) ([]HsbyMarketGoods, error) {
- engine := db.GetEngine()
- orders := make([]HsbyMarketGoods, 0)
- // 与挂牌点选不一样的是商城是以委托单为主表;已经卖完的委托单不显示
- session := engine.Table("TRADE_ORDERDETAIL T").
- Select(`to_char(T.ORDERID) ORDERIDSTR, T.*,
- G.GOODSCODE, G.GOODSNAME, G.DECIMALPLACE, G.QUOTEMINUNIT, G.AGREEUNIT,
- GX.HOTINDEX, GX.PICURLS, GX.CATEGORYID, GX.GOODSDESC,
- ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
- M.TRADEMODE`).
- Join("LEFT", "GOODS G", "G.GOODSID = T.GOODSID").
- Join("LEFT", "HSBY_GOODSEX GX", "GX.GOODSID = T.GOODSID").
- Join("LEFT", "ENUMDICITEM E", "E.ENUMITEMNAME = G.CURRENCYID and E.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET M", "M.MARKETID = T.MARKETID").
- Where(fmt.Sprintf("T.MARKETID in (%s)", marketIDs)).
- And("T.ORDERSTATUS in (3,7) and T.BUYORSELL = 1 and (T.ORDERQTY - T.TRADEQTY - T.CANCELQTY) > 0")
- if categoryID != 0 {
- session = session.And("GX.CATEGORYID = ?", categoryID)
- }
- if goodsID != 0 {
- session = session.And("G.GOODSID = ?", goodsID)
- }
- if err := session.Find(&orders); err != nil {
- return nil, err
- }
- // 获取当前账户的优惠卷
- type myCouponPosition struct {
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 资金账户ID
- Coupontypeid int32 `json:"coupontypeid" xorm:"'COUPONTYPEID'" binding:"required"` // 优惠券类型ID
- Curqty int64 `json:"curqty" xorm:"'CURQTY'"` // 期末数量
- Curfreezeqty int64 `json:"curfreezeqty" xorm:"'CURFREEZEQTY'"` // 期末冻结数量
- Limitedflag int32 `json:"limitedflag" xorm:"'LIMITEDFLAG'"` // 是否指定商品 - 0:不限 1:限制
- Limitedgoodsids string `json:"limitedgoodsids" xorm:"'LIMITEDGOODSIDS'"` // 指定商品IDs[逗号分隔,前后加逗号]
- Isgeneral int32 `json:"isgeneral" xorm:"'ISGENERAL'"` // 是否通用券 - 0:否 1:是
- Userscope string `json:"userscope" xorm:"'USERSCOPE'"` // 卖家范围(用户ID,逗号分隔,前后加逗号) [IsGeneral =0时使用]
- }
- myCouponPositions := make([]myCouponPosition, 0)
- if accountID != 0 {
- if err := engine.Table("COUPONPOSITION C").
- Select(`C.ACCOUNTID, C.COUPONTYPEID, C.CURQTY, C.CURFREEZEQTY,
- CT.LIMITEDFLAG, CT.LIMITEDGOODSIDS, CT.ISGENERAL, CT.USERSCOPE`).
- Join("INNER", "COUPONTYPE CT", "CT.COUPONTYPEID = C.COUPONTYPEID").
- Where("C.ACCOUNTID = ?", accountID).Find(&myCouponPositions); err != nil {
- return nil, err
- }
- }
- // 是否有优惠卷可用
- if len(orders) > 0 && len(myCouponPositions) > 0 {
- for _, coupon := range myCouponPositions {
- if coupon.Limitedflag == 0 && coupon.Isgeneral == 1 {
- // 有不指定商品的通用卷则所有委托单都可以用卷
- for i := range orders {
- order := &orders[i]
- order.HasCoupon = true
- }
- break
- } else {
- for i := range orders {
- order := &orders[i]
- // 获取卖家UserID
- userInfo, err := GetUserInfoByAccountID(int(order.Accountid))
- if err != nil {
- continue
- }
- order.SellUserID = int(userInfo.Userid)
- order.Customername = userInfo.Customername
- tmpGoodsID := fmt.Sprintf(",%d,", order.Goodsid)
- tmpUserID := fmt.Sprintf(",%d,", userInfo.Userid)
- // 优惠卷是否可用于商品
- isRightGoods := false
- if coupon.Limitedflag == 0 {
- isRightGoods = true
- } else {
- if strings.Contains(coupon.Limitedgoodsids, tmpGoodsID) {
- isRightGoods = true
- }
- }
- // 优惠卷是否可用于卖家
- isRightAccount := false
- if coupon.Isgeneral == 1 {
- isRightAccount = true
- } else {
- if strings.Contains(coupon.Userscope, tmpUserID) {
- isRightAccount = true
- }
- }
- if isRightGoods && isRightAccount {
- order.HasCoupon = true
- }
- }
- }
- }
- }
- return orders, nil
- }
- // HsbyMarketGoodsDetail 特卖商城商品(三级市场商场)
- type HsbyMarketGoodsDetail struct {
- Orderid string `json:"orderid" xorm:"'ORDERIDSTR'" binding:"required"` // 委托单号(100+Unix秒时间戳(10位)+2位(MarketServiceID)+xxxx)
- Marketid int32 `json:"marketid" xorm:"'MARKETID'" binding:"required"` // 市场ID
- Goodsid int32 `json:"goodsid" xorm:"'GOODSID'" binding:"required"` // 商品ID
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 账户ID[报价币种]
- Buyorsell int32 `json:"buyorsell" xorm:"'BUYORSELL'" binding:"required"` // 买卖 - 0:买 1:卖
- Orderprice float64 `json:"orderprice" xorm:"'ORDERPRICE'"` // 委托价格
- Orderqty int64 `json:"orderqty" xorm:"'ORDERQTY'" binding:"required"` // 委托数量
- Tradeqty int64 `json:"tradeqty" xorm:"'TRADEQTY'"` // 成交数量
- Cancelqty int64 `json:"cancelqty" xorm:"'CANCELQTY'"` // 撤单数量
- Orderstatus int32 `json:"orderstatus" xorm:"'ORDERSTATUS'"` // 委托状态 - 1: 委托请求 2:待冻结 3:委托成功 4: 委托失败 5:配对成功 6: 已撤销 7:部分成交 8:已成交 9:部成部撤 10:成交失败 11:已拒绝 12:经过摘牌(先摘后挂专用-先摘后挂已摘过) 13:冻结成功(通道交易专用) 14:通道已撤 15:通道部成部撤 16:成交失败违约(荷兰式竞拍专用)
- Goodscode string `json:"goodscode" xorm:"'GOODSCODE'" binding:"required"` // 商品代码(内部)
- Goodsname string `json:"goodsname" xorm:"'GOODSNAME'" binding:"required"` // 商品名称
- Decimalplace int64 `json:"decimalplace" xorm:"'DECIMALPLACE'"` // 报价小数位
- Quoteminunit int64 `json:"quoteminunit" xorm:"'QUOTEMINUNIT'"` // 行情最小变动单位 [整数,报价小数位一起使用]
- Agreeunit float64 `json:"agreeunit" xorm:"'AGREEUNIT'"` // 合约单位
- Hotindex int32 `json:"hotindex" xorm:"'HOTINDEX'"` // 景点热度
- Videourls string `json:"videourls" xorm:"'VIDEOURLS'"` // 介绍视频[多张用逗号分隔]
- Picurls string `json:"picurls" xorm:"'PICURLS'"` // 介绍图片[多张用逗号分隔]
- Categoryid int32 `json:"categoryid" xorm:"'CATEGORYID'"` // 类别ID(WRCATEGORY)
- Goodsdesc string `json:"goodsdesc" xorm:"'GOODSDESC'"` // 商品详情
- Currency string `json:"currency" xorm:"'CURRENCY'"` // 货币
- Currencysign string `json:"currencysign" xorm:"'CURRENCYSIGN'"` // 货币符号
- Trademode int32 `json:"trademode" xorm:"'TRADEMODE'" binding:"required"` // 交易模式 - 10:做市 13:竞价 15:通道交易 16:挂牌点选 17:仓单贸易 18:期权 19:竞拍-降价式 20:竞拍-竞价式 21:竞拍-大宗式 22:受托竞价
- Vendorname string `json:"vendorname" xorm:"'VENDORNAME'"` // 供应商名称
- Customername string `json:"customername" xorm:"'CUSTOMERNAME'"` // 卖家名称
- SellUserID int `json:"sellUserID" xorm:"SELLUSERID"` // 卖方UserID
- }
- // GetHsbyMarketGoodsDetail 获取商城商品详情(三级商城)
- func GetHsbyMarketGoodsDetail(orderID int) (*HsbyMarketGoodsDetail, error) {
- engine := db.GetEngine()
- orders := make([]HsbyMarketGoodsDetail, 0)
- // 与挂牌点选不一样的是商城是以委托单为主表
- session := engine.Table("TRADE_ORDERDETAIL T").
- Select(`to_char(T.ORDERID) ORDERIDSTR, T.*,
- G.GOODSCODE, G.GOODSNAME, G.DECIMALPLACE, G.QUOTEMINUNIT, G.AGREEUNIT,
- GX.HOTINDEX, GX.VIDEOURLS, GX.PICURLS, GX.CATEGORYID, GX.GOODSDESC,
- ENUMDICITEM.ENUMDICNAME CURRENCY, ENUMDICITEM.PARAM2 CURRENCYSIGN,
- M.TRADEMODE,
- H.VENDORNAME,
- U.USERID SELLUSERID, U.CUSTOMERNAME`).
- Join("LEFT", "GOODS G", "G.GOODSID = T.GOODSID").
- Join("LEFT", "HSBY_GOODSEX GX", "GX.GOODSID = T.GOODSID").
- Join("LEFT", "ENUMDICITEM E", "E.ENUMITEMNAME = G.CURRENCYID and E.ENUMDICCODE = 'currency'").
- Join("LEFT", "MARKET M", "M.MARKETID = T.MARKETID").
- Join("LEFT", "HSBY_SUPPLIERINFO H", "H.VENDORID = GX.VENDORID").
- Join("LEFT", "TAACCOUNT TA", "TA.ACCOUNTID = T.ACCOUNTID").
- Join("LEFT", "USERINFO U", "U.USERID = TA.RELATEDUSERID").
- Where("T.ORDERID = ?", orderID)
- if err := session.Find(&orders); err != nil {
- return nil, err
- }
- // 无目标商品
- if len(orders) == 0 {
- return nil, nil
- }
- hsbyMarketGoodsDetail := orders[0]
- return &hsbyMarketGoodsDetail, nil
- }
- // MyCoupon 我的优惠卷
- type MyCoupon struct {
- Accountid int64 `json:"accountid" xorm:"'ACCOUNTID'" binding:"required"` // 资金账户ID
- Coupontypeid int32 `json:"coupontypeid" xorm:"'COUPONTYPEID'" binding:"required"` // 优惠券类型ID
- Userid int64 `json:"userid" xorm:"'USERID'"` // 用户ID
- Oriqty int64 `json:"oriqty" xorm:"'ORIQTY'"` // 期初数量
- Orifreezeqty int64 `json:"orifreezeqty" xorm:"'ORIFREEZEQTY'"` // 期初冻结数量
- Curqty int64 `json:"curqty" xorm:"'CURQTY'"` // 期末数量
- Curfreezeqty int64 `json:"curfreezeqty" xorm:"'CURFREEZEQTY'"` // 期末冻结数量
- Todayincrease int64 `json:"todayincrease" xorm:"'TODAYINCREASE'"` // 今日增加
- Todaydecrease int64 `json:"todaydecrease" xorm:"'TODAYDECREASE'"` // 今日减少
- Areauserid int64 `json:"areauserid" xorm:"'AREAUSERID'"` // 所属机构
- Couponname string `json:"couponname" xorm:"'COUPONNAME'"` // 优惠券名称
- Couponcategroy int32 `json:"couponcategroy" xorm:"'COUPONCATEGROY'"` // 种类 - 1:现金券 2:折扣券 3:折扣券(单张)
- Conditionvalue float64 `json:"conditionvalue" xorm:"'CONDITIONVALUE'"` // 条件阈值(可为0)
- Couponvalue float64 `json:"couponvalue" xorm:"'COUPONVALUE'"` // 面值[1:现金券 - 抵扣值 2:折扣券-折扣值]
- Limitedflag int32 `json:"limitedflag" xorm:"'LIMITEDFLAG'"` // 是否指定商品 - 0:不限 1:限制
- Limitedgoodsids string `json:"limitedgoodsids" xorm:"'LIMITEDGOODSIDS'"` // 指定商品IDs[逗号分隔,前后加逗号]
- Isgeneral int32 `json:"isgeneral" xorm:"'ISGENERAL'"` // 是否通用券 - 0:否 1:是
- Userscope string `json:"userscope" xorm:"'USERSCOPE'"` // 卖家范围(用户ID,逗号分隔,前后加逗号) [IsGeneral =0时使用]
- IsUnusable bool `json:"isunusable" xorm:"-"` // 是否不可用
- ReasonType int `json:"reasontype"` // 不可用原因 - 0:未确认 1:不可用于此商品 2:不可用于此卖家
- }
- // GetMyCoupons 获取我的优惠卷信息
- func GetMyCoupons(accountIDs string, goodsID, sellUserID int) ([]MyCoupon, error) {
- engine := db.GetEngine()
- myCoupons := make([]MyCoupon, 0)
- session := engine.Table("COUPONPOSITION CP").
- Join("INNER", "COUPONTYPE CT", "CT.COUPONTYPEID = CP.COUPONTYPEID").
- Where(fmt.Sprintf("CP.ACCOUNTID in (%s)", accountIDs))
- if err := session.Find(&myCoupons); err != nil {
- return nil, err
- }
- // 如果传入了商品ID和卖方UserID,则判断优惠卷是否可用
- if goodsID != 0 && sellUserID != 0 && len(myCoupons) > 0 {
- for i := range myCoupons {
- myCoupon := &myCoupons[i]
- // 优惠卷是否可用于商品
- isRightGoods := false
- if myCoupon.Limitedflag == 0 {
- isRightGoods = true
- } else {
- if strings.Contains(myCoupon.Limitedgoodsids, fmt.Sprintf(",%d,", goodsID)) {
- isRightGoods = true
- }
- }
- // 优惠卷是否可用于卖家
- isRightAccount := false
- if myCoupon.Isgeneral == 1 {
- isRightAccount = true
- } else {
- if strings.Contains(myCoupon.Userscope, fmt.Sprintf(",%d,", sellUserID)) {
- isRightAccount = true
- }
- }
- if !isRightGoods {
- myCoupon.IsUnusable = true
- myCoupon.ReasonType = 1
- }
- if !isRightAccount {
- myCoupon.IsUnusable = true
- myCoupon.ReasonType = 2
- }
- }
- }
- return myCoupons, nil
- }
|