cash.go 35 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133
  1. package dao
  2. import (
  3. "bet24.com/servers/adminserver/ip"
  4. "encoding/json"
  5. "runtime/debug"
  6. "sort"
  7. "bet24.com/database"
  8. "bet24.com/log"
  9. )
  10. // 金币日志
  11. type (
  12. getCashLog_in struct {
  13. UserID int //用户ID
  14. PartnerID int //渠道ID
  15. SourceName string //应用名称
  16. BeginTime string //开始时间
  17. EndTime string //截止时间
  18. PageIndex int //页索引
  19. PageSize int //页大小
  20. }
  21. getCashLogInfo struct {
  22. LogID int //标识
  23. SourceName string //源名称
  24. MoneyType string //货币类型
  25. UserID int //用户ID
  26. NickName string //昵称
  27. CurrentAmount int //当前金额
  28. ModifyAmount int //修改金额
  29. StillAmount int //剩余金额
  30. Remark string //备注
  31. IPAddress string //IP地址
  32. Crdate string //时间
  33. PartnerName string //渠道名称
  34. TaxAmount int //台费
  35. }
  36. getCashLog_out struct {
  37. RecordCount int //记录数
  38. List []getCashLogInfo
  39. }
  40. getCashLog struct {
  41. database.Trans_base
  42. In getCashLog_in
  43. Out getCashLog_out
  44. }
  45. )
  46. func NewGetCashLog() *getCashLog {
  47. return &getCashLog{}
  48. }
  49. func (this *getCashLog) DoAction(ch chan<- interface{}) {
  50. defer func() {
  51. if err := recover(); err != nil {
  52. log.Release("transaction recover fail %v", err)
  53. log.Release("%s", debug.Stack())
  54. }
  55. if ch != nil {
  56. ch <- this
  57. }
  58. }()
  59. statement := database.NewStatement()
  60. statement.SetNeedReturnValue(false)
  61. statement.SetOpenRecordSet(true)
  62. statement.SetProcName("Manage_Money_GetCashLog")
  63. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  64. statement.AddParamter("@PartnerID", database.AdParamInput, database.AdInteger, 4, this.In.PartnerID)
  65. statement.AddParamter("@SourceName", database.AdParamInput, database.AdNVarChar, 32, this.In.SourceName)
  66. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  67. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  68. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, this.In.PageIndex)
  69. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, this.In.PageSize)
  70. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, this.Out.RecordCount)
  71. sqlstring := statement.GenSql()
  72. retRows := CenterDB.ExecSql(sqlstring)
  73. rowLen := len(retRows)
  74. if rowLen <= 0 {
  75. this.State = false
  76. return
  77. }
  78. this.State = true
  79. if rowLen > 1 {
  80. this.Out.List = make([]getCashLogInfo, rowLen-1)
  81. for i := 0; i < rowLen-1; i++ {
  82. ret := retRows[i]
  83. out := &this.Out.List[i]
  84. out.LogID = int((*ret[0].(*interface{})).(int64))
  85. out.SourceName = (*ret[1].(*interface{})).(string)
  86. out.MoneyType = (*ret[2].(*interface{})).(string)
  87. out.UserID = int((*ret[3].(*interface{})).(int64))
  88. out.NickName = (*ret[4].(*interface{})).(string)
  89. if info := tagMgr.getInfo(out.UserID); info != nil {
  90. out.NickName = info.NickName
  91. }
  92. out.CurrentAmount = int((*ret[5].(*interface{})).(int64))
  93. out.ModifyAmount = int((*ret[6].(*interface{})).(int64))
  94. out.StillAmount = int((*ret[7].(*interface{})).(int64))
  95. out.Remark = (*ret[8].(*interface{})).(string)
  96. out.IPAddress = (*ret[9].(*interface{})).(string)
  97. out.IPAddress = ip.GetCountryAndRegion(out.IPAddress, false)
  98. out.Crdate = (*ret[10].(*interface{})).(string)
  99. out.PartnerName = (*ret[11].(*interface{})).(string)
  100. out.TaxAmount = int((*ret[12].(*interface{})).(int64))
  101. }
  102. }
  103. this.Out.RecordCount = int((*retRows[rowLen-1][0].(*interface{})).(int64))
  104. }
  105. // 钻石日志
  106. type (
  107. getDiamondLog_in struct {
  108. UserID int //用户ID
  109. PartnerID int //渠道ID
  110. BeginTime string //开始时间
  111. EndTime string //截止时间
  112. PageIndex int //页索引
  113. PageSize int //页大小
  114. }
  115. getDiamondLogInfo struct {
  116. LogID int //标识
  117. UserID int //用户ID
  118. NickName string //昵称
  119. CurrentAmount int //当前金额
  120. ModifyAmount int //修改金额
  121. StillAmount int //剩余金额
  122. Remark string //备注
  123. IPAddress string //IP地址
  124. Crdate string //时间
  125. PartnerName string //渠道名称
  126. }
  127. getDiamondLog_out struct {
  128. RecordCount int //记录数
  129. List []getDiamondLogInfo
  130. }
  131. getDiamondLog struct {
  132. database.Trans_base
  133. In getDiamondLog_in
  134. Out getDiamondLog_out
  135. }
  136. )
  137. func NewGetDiamondLog() *getDiamondLog {
  138. return &getDiamondLog{}
  139. }
  140. func (this *getDiamondLog) DoAction(ch chan<- interface{}) {
  141. defer func() {
  142. if err := recover(); err != nil {
  143. log.Release("transaction recover fail %v", err)
  144. log.Release("%s", debug.Stack())
  145. }
  146. if ch != nil {
  147. ch <- this
  148. }
  149. }()
  150. statement := database.NewStatement()
  151. statement.SetNeedReturnValue(false)
  152. statement.SetOpenRecordSet(true)
  153. statement.SetProcName("Manage_Diamond_GetLog")
  154. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  155. statement.AddParamter("@PartnerID", database.AdParamInput, database.AdInteger, 4, this.In.PartnerID)
  156. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  157. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  158. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, this.In.PageIndex)
  159. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, this.In.PageSize)
  160. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, this.Out.RecordCount)
  161. sqlstring := statement.GenSql()
  162. retRows := CenterDB.ExecSql(sqlstring)
  163. rowLen := len(retRows)
  164. if rowLen <= 0 {
  165. this.State = false
  166. return
  167. }
  168. this.State = true
  169. if rowLen > 1 {
  170. this.Out.List = make([]getDiamondLogInfo, rowLen-1)
  171. for i := 0; i < rowLen-1; i++ {
  172. ret := retRows[i]
  173. out := &this.Out.List[i]
  174. out.LogID = int((*ret[0].(*interface{})).(int64))
  175. out.UserID = int((*ret[1].(*interface{})).(int64))
  176. out.NickName = (*ret[2].(*interface{})).(string)
  177. if info := tagMgr.getInfo(out.UserID); info != nil {
  178. out.NickName = info.NickName
  179. }
  180. out.CurrentAmount = int((*ret[3].(*interface{})).(int64))
  181. out.ModifyAmount = int((*ret[4].(*interface{})).(int64))
  182. out.StillAmount = int((*ret[5].(*interface{})).(int64))
  183. out.Remark = (*ret[6].(*interface{})).(string)
  184. out.IPAddress = (*ret[7].(*interface{})).(string)
  185. out.IPAddress = ip.GetCountryAndRegion(out.IPAddress, false)
  186. out.Crdate = (*ret[8].(*interface{})).(string)
  187. out.PartnerName = (*ret[9].(*interface{})).(string)
  188. }
  189. }
  190. this.Out.RecordCount = int((*retRows[rowLen-1][0].(*interface{})).(int64))
  191. }
  192. // 投注日志
  193. type (
  194. getBetLog_in struct {
  195. UserID int //用户ID
  196. GameID int //游戏ID
  197. BeginTime string //开始时间
  198. EndTime string //截止时间
  199. PageIndex int //页索引
  200. PageSize int //页大小
  201. }
  202. getBetLogInfo struct {
  203. RecordID string //标识
  204. UserID int //用户ID
  205. NickName string //昵称
  206. ChineseName string //游戏名
  207. BetAmount int //下注金额
  208. BetTime string //下注时间
  209. BetZone string //下注区域
  210. Odds string //赔率
  211. ResultAmount int //结算金额
  212. ResultTime string //结算时间
  213. ResultZone string //结算区域
  214. WinAmount int //输赢金额
  215. StillAmount int //剩余金额
  216. Status int //状态 0=下注 1=结算
  217. Tax int //台费
  218. SubSeconds int // 时间差
  219. }
  220. getBetLog_out struct {
  221. RecordCount int //记录数
  222. WinAmount int //输赢金额
  223. List []getBetLogInfo
  224. }
  225. getBetLog struct {
  226. database.Trans_base
  227. In getBetLog_in
  228. Out getBetLog_out
  229. }
  230. )
  231. func NewGetBetLog() *getBetLog {
  232. return &getBetLog{}
  233. }
  234. func (this *getBetLog) DoAction(ch chan<- interface{}) {
  235. defer func() {
  236. if err := recover(); err != nil {
  237. log.Release("transaction recover fail %v", err)
  238. log.Release("%s", debug.Stack())
  239. }
  240. if ch != nil {
  241. ch <- this
  242. }
  243. }()
  244. statement := database.NewStatement()
  245. statement.SetNeedReturnValue(false)
  246. statement.SetOpenRecordSet(true)
  247. statement.SetProcName("Manage_Game_GetBetLog")
  248. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  249. statement.AddParamter("@GameID", database.AdParamInput, database.AdInteger, 4, this.In.GameID)
  250. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  251. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  252. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, this.In.PageIndex)
  253. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, this.In.PageSize)
  254. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, this.Out.RecordCount)
  255. statement.AddParamter("@WinAmount", database.AdParamOutput, database.AdBigint, 8, this.Out.WinAmount)
  256. sqlstring := statement.GenSql()
  257. retRows := CenterDB.ExecSql(sqlstring)
  258. rowLen := len(retRows)
  259. if rowLen <= 0 {
  260. this.State = false
  261. return
  262. }
  263. this.State = true
  264. if rowLen > 1 {
  265. this.Out.List = make([]getBetLogInfo, rowLen-1)
  266. for i := 0; i < rowLen-1; i++ {
  267. ret := retRows[i]
  268. out := &this.Out.List[i]
  269. out.RecordID = (*ret[0].(*interface{})).(string)
  270. out.UserID = int((*ret[1].(*interface{})).(int64))
  271. out.NickName = (*ret[2].(*interface{})).(string)
  272. if info := tagMgr.getInfo(out.UserID); info != nil {
  273. out.NickName = info.NickName
  274. }
  275. out.ChineseName = (*ret[3].(*interface{})).(string)
  276. out.BetAmount = int((*ret[4].(*interface{})).(int64))
  277. out.BetTime = (*ret[5].(*interface{})).(string)
  278. out.BetZone = (*ret[6].(*interface{})).(string)
  279. out.Odds = string((*ret[7].(*interface{})).([]byte))
  280. out.ResultAmount = int((*ret[8].(*interface{})).(int64))
  281. out.ResultTime = (*ret[9].(*interface{})).(string)
  282. out.ResultZone = (*ret[10].(*interface{})).(string)
  283. out.WinAmount = int((*ret[11].(*interface{})).(int64))
  284. out.StillAmount = int((*ret[12].(*interface{})).(int64))
  285. out.Status = int((*ret[13].(*interface{})).(int64))
  286. out.Tax = int((*ret[14].(*interface{})).(int64))
  287. out.SubSeconds = int((*ret[15].(*interface{})).(int64))
  288. }
  289. }
  290. this.Out.RecordCount = int((*retRows[rowLen-1][0].(*interface{})).(int64))
  291. this.Out.WinAmount = int((*retRows[rowLen-1][1].(*interface{})).(int64))
  292. }
  293. // 投注详情
  294. type (
  295. getBetDetail_in struct {
  296. UserID int //用户ID
  297. RecordID string //记录ID
  298. BeginTime string //开始时间
  299. EndTime string //截止时间
  300. }
  301. recordInfo struct {
  302. FishID int // 鱼ID
  303. FishOdds int // 鱼的倍率
  304. Catched int // 捕获数量
  305. Consume int // 消耗金币
  306. Return int // 返还金币
  307. Settle int //结算金币
  308. ROI float64 //投入产出率
  309. }
  310. getBetDetail_out struct {
  311. RecordID int
  312. TotalConsume int //总消耗
  313. TotalReturn int //总返还
  314. TotalSettle int //总结算
  315. TotalROI float64 //投入产出率
  316. List []recordInfo
  317. }
  318. getBetDetail struct {
  319. database.Trans_base
  320. In getBetDetail_in
  321. Out getBetDetail_out
  322. }
  323. )
  324. func NewGetBetDetail() *getBetDetail {
  325. return &getBetDetail{}
  326. }
  327. func (this *getBetDetail) DoAction() {
  328. defer func() {
  329. if err := recover(); err != nil {
  330. log.Release("transaction recover fail %v", err)
  331. log.Release("%s", debug.Stack())
  332. }
  333. }()
  334. statement := database.NewStatement()
  335. statement.SetNeedReturnValue(false)
  336. statement.SetOpenRecordSet(true)
  337. statement.SetProcName("Manage_Game_GetBetDetail")
  338. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  339. statement.AddParamter("@RecordID", database.AdParamInput, database.AdVarChar, 32, this.In.RecordID)
  340. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  341. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  342. sqlstring := statement.GenSql()
  343. retRows := CenterDB.ExecSql(sqlstring)
  344. rowLen := len(retRows)
  345. if rowLen <= 0 {
  346. return
  347. }
  348. for i := 0; i < rowLen; i++ {
  349. ret := retRows[i]
  350. //recordId := (*ret[0].(*interface{})).(string)
  351. resultZone := (*ret[1].(*interface{})).(string)
  352. var records [][]int
  353. if err := json.Unmarshal([]byte(resultZone), &records); err != nil {
  354. log.Error("getBetDetail resultZone unmarshal fail %v", err)
  355. return
  356. }
  357. for _, record := range records {
  358. var info recordInfo
  359. for idx, val := range record {
  360. switch idx {
  361. case 0: //鱼ID
  362. info.FishID = val
  363. case 1: //鱼的倍率
  364. info.FishOdds = val
  365. case 2: //捕获数量
  366. info.Catched = val
  367. case 3: //消耗金币
  368. info.Consume = val
  369. info.Settle += -info.Consume
  370. case 4: //返还金币
  371. info.Return = val
  372. info.Settle += info.Return
  373. }
  374. }
  375. this.Out.TotalConsume += info.Consume
  376. this.Out.TotalReturn += info.Return
  377. this.Out.TotalSettle += info.Settle
  378. info.ROI = float64(info.Return) / float64(info.Consume)
  379. //log.Debug("info ==> %+v", info)
  380. addFlag := true
  381. for idx, val := range this.Out.List {
  382. if val.FishID != info.FishID {
  383. continue
  384. }
  385. addFlag = false
  386. out := &this.Out.List[idx]
  387. out.Catched += info.Catched
  388. out.Consume += info.Consume
  389. out.Return += info.Return
  390. out.Settle += info.Settle
  391. out.ROI = float64(out.Return) / float64(out.Consume)
  392. }
  393. if !addFlag {
  394. continue
  395. }
  396. this.Out.List = append(this.Out.List, info)
  397. }
  398. }
  399. this.Out.TotalROI = float64(this.Out.TotalReturn) / float64(this.Out.TotalConsume)
  400. //sort.SliceStable(this.Out.List, func(i, j int) bool {
  401. // return this.Out.List[i].Catched > this.Out.List[j].Catched
  402. //})
  403. sort.SliceStable(this.Out.List, func(i, j int) bool {
  404. return this.Out.List[i].ROI > this.Out.List[j].ROI
  405. })
  406. //log.Debug("getBetDetail this.Out.List %+v", this.Out.List)
  407. }
  408. // 加金
  409. type (
  410. cashSend_in struct {
  411. OpUserID int //操作员ID
  412. OpUserName string //操作员名称
  413. UserID int //用户ID
  414. SourceName string //应用名称
  415. Reason string //原因
  416. WantAmount int //操作金额
  417. WantBank int //操作保险柜
  418. IpAddress string //IP地址
  419. }
  420. cashSend_out struct {
  421. RetCode int //操作结果
  422. ErrorMsg string //操作描述
  423. }
  424. cashSend struct {
  425. database.Trans_base
  426. In cashSend_in
  427. Out cashSend_out
  428. }
  429. )
  430. func NewCashSend() *cashSend {
  431. return &cashSend{}
  432. }
  433. func (this *cashSend) DoAction(ch chan<- interface{}) {
  434. defer func() {
  435. if err := recover(); err != nil {
  436. log.Release("transaction recover fail %v", err)
  437. log.Release("%s", debug.Stack())
  438. }
  439. if ch != nil {
  440. ch <- this
  441. }
  442. }()
  443. statement := database.NewStatement()
  444. statement.SetNeedReturnValue(false)
  445. statement.SetOpenRecordSet(true)
  446. statement.SetProcName("prMoney_WebSendCoin")
  447. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  448. statement.AddParamter("@SourceName", database.AdParamInput, database.AdNVarChar, 32, this.In.SourceName)
  449. statement.AddParamter("@Reason", database.AdParamInput, database.AdNVarChar, 128, this.In.Reason)
  450. statement.AddParamter("@WantAmount", database.AdParamInput, database.AdInteger, 4, this.In.WantAmount)
  451. statement.AddParamter("@WantBank", database.AdParamInput, database.AdInteger, 4, this.In.WantBank)
  452. statement.AddParamter("@IPAddress", database.AdParamInput, database.AdVarChar, 16, this.In.IpAddress)
  453. statement.AddParamter("@OpUserID", database.AdParamInput, database.AdInteger, 4, this.In.OpUserID)
  454. statement.AddParamter("@OpUserName", database.AdParamInput, database.AdVarChar, 32, this.In.OpUserName)
  455. statement.AddParamter("@RetCode", database.AdParamOutput, database.AdInteger, 4, this.Out.RetCode)
  456. statement.AddParamter("@ErrorMsg", database.AdParamOutput, database.AdNVarChar, 128, this.Out.ErrorMsg)
  457. sqlstring := statement.GenSql()
  458. retRows := CenterDB.ExecSql(sqlstring)
  459. rowLen := len(retRows)
  460. if rowLen <= 0 {
  461. this.State = false
  462. return
  463. }
  464. this.State = true
  465. this.Out.RetCode = int((*retRows[0][0].(*interface{})).(int64))
  466. this.Out.ErrorMsg = (*retRows[0][1].(*interface{})).(string)
  467. }
  468. // 扣金
  469. type (
  470. cashDel_in struct {
  471. OpUserID int //操作员ID
  472. OpUserName string //操作员名称
  473. UserID int //用户ID
  474. SourceName string //应用名称
  475. Reason string //原因
  476. WantAmount int //操作金额
  477. WantBank int //操作保险柜
  478. IpAddress string //IP地址
  479. }
  480. cashDel_out struct {
  481. RetCode int //操作结果
  482. ErrorMsg string //操作描述
  483. }
  484. cashDel struct {
  485. database.Trans_base
  486. In cashDel_in
  487. Out cashDel_out
  488. }
  489. )
  490. func NewCashDel() *cashDel {
  491. return &cashDel{}
  492. }
  493. func (this *cashDel) DoAction(ch chan<- interface{}) {
  494. defer func() {
  495. if err := recover(); err != nil {
  496. log.Release("transaction recover fail %v", err)
  497. log.Release("%s", debug.Stack())
  498. }
  499. if ch != nil {
  500. ch <- this
  501. }
  502. }()
  503. statement := database.NewStatement()
  504. statement.SetNeedReturnValue(false)
  505. statement.SetOpenRecordSet(true)
  506. statement.SetProcName("prMoney_WebDelCoin_v2")
  507. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  508. statement.AddParamter("@SourceName", database.AdParamInput, database.AdNVarChar, 32, this.In.SourceName)
  509. statement.AddParamter("@Reason", database.AdParamInput, database.AdNVarChar, 128, this.In.Reason)
  510. statement.AddParamter("@WantAmount", database.AdParamInput, database.AdBigint, 8, this.In.WantAmount)
  511. statement.AddParamter("@WantBank", database.AdParamInput, database.AdBigint, 8, this.In.WantBank)
  512. statement.AddParamter("@IPAddress", database.AdParamInput, database.AdVarChar, 16, this.In.IpAddress)
  513. statement.AddParamter("@OpUserID", database.AdParamInput, database.AdInteger, 4, this.In.OpUserID)
  514. statement.AddParamter("@OpUserName", database.AdParamInput, database.AdVarChar, 32, this.In.OpUserName)
  515. statement.AddParamter("@RetCode", database.AdParamOutput, database.AdInteger, 4, this.Out.RetCode)
  516. statement.AddParamter("@ErrorMsg", database.AdParamOutput, database.AdNVarChar, 128, this.Out.ErrorMsg)
  517. sqlstring := statement.GenSql()
  518. retRows := CenterDB.ExecSql(sqlstring)
  519. rowLen := len(retRows)
  520. if rowLen <= 0 {
  521. this.State = false
  522. return
  523. }
  524. this.State = true
  525. this.Out.RetCode = int((*retRows[0][0].(*interface{})).(int64))
  526. this.Out.ErrorMsg = (*retRows[0][1].(*interface{})).(string)
  527. }
  528. // 金币场解锁
  529. type (
  530. cashUnlock_in struct {
  531. OpUserID int //操作员ID
  532. OpUserName string //操作员名称
  533. UserID int //用户ID
  534. IpAddress string //IP地址
  535. }
  536. cashUnlock_out struct {
  537. RetCode int //操作结果
  538. ErrorMsg string //操作描述
  539. }
  540. cashUnlock struct {
  541. database.Trans_base
  542. In cashUnlock_in
  543. Out cashUnlock_out
  544. }
  545. )
  546. func NewCashUnlock() *cashUnlock {
  547. return &cashUnlock{}
  548. }
  549. func (this *cashUnlock) DoAction(ch chan<- interface{}) {
  550. defer func() {
  551. if err := recover(); err != nil {
  552. log.Release("transaction recover fail %v", err)
  553. log.Release("%s", debug.Stack())
  554. }
  555. if ch != nil {
  556. ch <- this
  557. }
  558. }()
  559. statement := database.NewStatement()
  560. statement.SetNeedReturnValue(false)
  561. statement.SetOpenRecordSet(true)
  562. statement.SetProcName("Manage_CasinoOnline_Unlock")
  563. statement.AddParamter("@OpUserID", database.AdParamInput, database.AdInteger, 4, this.In.OpUserID)
  564. statement.AddParamter("@OpUserName", database.AdParamInput, database.AdVarChar, 32, this.In.OpUserName)
  565. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  566. statement.AddParamter("@IPAddress", database.AdParamInput, database.AdVarChar, 16, this.In.IpAddress)
  567. statement.AddParamter("@RetCode", database.AdParamOutput, database.AdInteger, 4, this.Out.RetCode)
  568. sqlstring := statement.GenSql()
  569. retRows := CenterDB.ExecSql(sqlstring)
  570. rowLen := len(retRows)
  571. if rowLen <= 0 {
  572. this.State = false
  573. return
  574. }
  575. this.State = true
  576. this.Out.RetCode = int((*retRows[0][0].(*interface{})).(int64))
  577. }
  578. // 金币锁信息
  579. type (
  580. cashLockInfo_in struct {
  581. UserID int //用户ID
  582. NickName string //昵称
  583. }
  584. cashLockInfo_out struct {
  585. UserID int //用户ID
  586. NickName string //昵称
  587. LoginTime string //登陆时间
  588. ServerName string //服务器名称
  589. }
  590. cashLockInfo struct {
  591. database.Trans_base
  592. In cashLockInfo_in
  593. Out cashLockInfo_out
  594. }
  595. )
  596. func NewCashLockInfo() *cashLockInfo {
  597. return &cashLockInfo{}
  598. }
  599. func (this *cashLockInfo) DoAction(ch chan<- interface{}) {
  600. defer func() {
  601. if err := recover(); err != nil {
  602. log.Release("transaction recover fail %v", err)
  603. log.Release("%s", debug.Stack())
  604. }
  605. if ch != nil {
  606. ch <- this
  607. }
  608. }()
  609. statement := database.NewStatement()
  610. statement.SetNeedReturnValue(false)
  611. statement.SetOpenRecordSet(true)
  612. statement.SetProcName("Manage_CasinoOnline_GetInfo")
  613. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  614. statement.AddParamter("@NickName", database.AdParamInput, database.AdNVarChar, 32, this.In.NickName)
  615. sqlstring := statement.GenSql()
  616. retRows := CenterDB.ExecSql(sqlstring)
  617. rowLen := len(retRows)
  618. if rowLen <= 0 {
  619. this.State = false
  620. return
  621. }
  622. this.State = true
  623. ret := retRows[0]
  624. this.Out.UserID = int((*ret[0].(*interface{})).(int64))
  625. this.Out.NickName = (*ret[1].(*interface{})).(string)
  626. if info := tagMgr.getInfo(this.Out.UserID); info != nil {
  627. this.Out.NickName = info.NickName
  628. }
  629. this.Out.LoginTime = (*ret[2].(*interface{})).(string)
  630. this.Out.ServerName = (*ret[3].(*interface{})).(string)
  631. }
  632. // 货币统计
  633. type (
  634. moneyStat_in struct {
  635. BeginTime string //开始时间
  636. EndTime string //截止时间
  637. }
  638. moneyStatInfo struct {
  639. LogType int //日志类型
  640. LogTypeName string //日志类型名称
  641. GameID int //游戏ID
  642. ChineseName string //游戏名
  643. Amount int //金额
  644. SendAmount int //发行金额
  645. DelAmount int //消耗金额
  646. DiffAmount int //差额
  647. }
  648. moneyStat_out struct {
  649. Send int //总发行
  650. Consume int //总消耗
  651. GameSend int //游戏发行
  652. GameConsume int //游戏消耗
  653. GameDiff int //游戏差额
  654. Cash int //金币总额
  655. Bank int //保险柜总额
  656. YesterdayAmount int //前日总额
  657. CurrAmount int //当前总额
  658. List []moneyStatInfo
  659. }
  660. moneyStat struct {
  661. database.Trans_base
  662. In moneyStat_in
  663. Out moneyStat_out
  664. }
  665. )
  666. func NewMoneyStat() *moneyStat {
  667. return &moneyStat{}
  668. }
  669. func (this *moneyStat) DoAction(ch chan<- interface{}) {
  670. defer func() {
  671. if err := recover(); err != nil {
  672. log.Release("transaction recover fail %v", err)
  673. log.Release("%s", debug.Stack())
  674. }
  675. if ch != nil {
  676. ch <- this
  677. }
  678. }()
  679. statement := database.NewStatement()
  680. statement.SetNeedReturnValue(false)
  681. statement.SetOpenRecordSet(true)
  682. statement.SetProcName("Manage_MoneyStat_GetList")
  683. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  684. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  685. statement.AddParamter("@Send", database.AdParamOutput, database.AdBigint, 8, this.Out.Send)
  686. statement.AddParamter("@Consume", database.AdParamOutput, database.AdBigint, 8, this.Out.Consume)
  687. statement.AddParamter("@GameSend", database.AdParamOutput, database.AdBigint, 8, this.Out.GameSend)
  688. statement.AddParamter("@GameConsume", database.AdParamOutput, database.AdBigint, 8, this.Out.GameConsume)
  689. statement.AddParamter("@GameDiff", database.AdParamOutput, database.AdBigint, 8, this.Out.GameDiff)
  690. statement.AddParamter("@Cash", database.AdParamOutput, database.AdBigint, 8, this.Out.Cash)
  691. statement.AddParamter("@Bank", database.AdParamOutput, database.AdBigint, 8, this.Out.Bank)
  692. statement.AddParamter("@YesterdayAmount", database.AdParamOutput, database.AdBigint, 8, this.Out.YesterdayAmount)
  693. statement.AddParamter("@CurrAmount", database.AdParamOutput, database.AdBigint, 8, this.Out.CurrAmount)
  694. sqlstring := statement.GenSql()
  695. retRows := CenterDB.ExecSql(sqlstring)
  696. rowLen := len(retRows)
  697. if rowLen <= 0 {
  698. this.State = false
  699. return
  700. }
  701. this.State = true
  702. if rowLen > 1 {
  703. this.Out.List = make([]moneyStatInfo, rowLen-1)
  704. for i := 0; i < rowLen-1; i++ {
  705. ret := retRows[i]
  706. out := &this.Out.List[i]
  707. out.LogType = int((*ret[0].(*interface{})).(int64))
  708. out.LogTypeName = (*ret[1].(*interface{})).(string)
  709. out.GameID = int((*ret[2].(*interface{})).(int64))
  710. out.Amount = int((*ret[3].(*interface{})).(int64))
  711. out.ChineseName = (*ret[4].(*interface{})).(string)
  712. out.SendAmount = int((*ret[5].(*interface{})).(int64))
  713. out.DelAmount = int((*ret[6].(*interface{})).(int64))
  714. out.DiffAmount = int((*ret[7].(*interface{})).(int64))
  715. }
  716. }
  717. ret := retRows[rowLen-1]
  718. this.Out.Send = int((*ret[0].(*interface{})).(int64))
  719. this.Out.Consume = int((*ret[1].(*interface{})).(int64))
  720. this.Out.GameSend = int((*ret[2].(*interface{})).(int64))
  721. this.Out.GameConsume = int((*ret[3].(*interface{})).(int64))
  722. this.Out.GameDiff = int((*ret[4].(*interface{})).(int64))
  723. this.Out.Cash = int((*ret[5].(*interface{})).(int64))
  724. this.Out.Bank = int((*ret[6].(*interface{})).(int64))
  725. this.Out.YesterdayAmount = int((*ret[7].(*interface{})).(int64))
  726. this.Out.CurrAmount = int((*ret[8].(*interface{})).(int64))
  727. }
  728. // 后台扣减钻石
  729. type (
  730. diamondWebReduce_in struct {
  731. OpUserID int //操作员ID
  732. OpUserName string //操作员名称
  733. UserID int //用户ID
  734. WantAmount int //钻石数
  735. Memo string //描述
  736. IpAddress string //IP地址
  737. }
  738. diamondWebReduce_out struct {
  739. RetCode int //操作结果
  740. ErrorMsg string //操作描述
  741. DiamondAmount int //钻石数
  742. }
  743. diamondWebReduce struct {
  744. database.Trans_base
  745. In diamondWebReduce_in
  746. Out diamondWebReduce_out
  747. }
  748. )
  749. func NewDiamondWebReduce() *diamondWebReduce {
  750. return &diamondWebReduce{}
  751. }
  752. func (this *diamondWebReduce) DoAction() {
  753. defer func() {
  754. if err := recover(); err != nil {
  755. log.Error("transaction recover err %v", err)
  756. log.Error("%s", debug.Stack())
  757. }
  758. }()
  759. statement := database.NewStatement()
  760. statement.SetNeedReturnValue(false)
  761. statement.SetOpenRecordSet(true)
  762. statement.SetProcName("Manage_Diamond_WebReduce")
  763. statement.AddParamter("@OpUserID", database.AdParamInput, database.AdInteger, 4, this.In.OpUserID)
  764. statement.AddParamter("@OpUserName", database.AdParamInput, database.AdVarChar, 32, this.In.OpUserName)
  765. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  766. statement.AddParamter("@WantAmount", database.AdParamInput, database.AdInteger, 4, this.In.WantAmount)
  767. statement.AddParamter("@Memo", database.AdParamInput, database.AdVarChar, 128, this.In.Memo)
  768. statement.AddParamter("@IPAddress", database.AdParamInput, database.AdVarChar, 16, this.In.IpAddress)
  769. statement.AddParamter("@DiamondAmount", database.AdParamOutput, database.AdBigint, 8, this.Out.DiamondAmount)
  770. sqlstring := statement.GenSql()
  771. retRows := CenterDB.ExecSql(sqlstring)
  772. if len(retRows) <= 0 {
  773. this.Out.RetCode = 11
  774. this.Out.ErrorMsg = "操作失败"
  775. return
  776. }
  777. this.Out.DiamondAmount = int((*retRows[0][0].(*interface{})).(int64))
  778. this.Out.RetCode = 1
  779. this.Out.ErrorMsg = "操作成功"
  780. }
  781. // 后台钻石日志
  782. type (
  783. getDiamondAdminLog_in struct {
  784. UserID int //用户ID
  785. PartnerID int //渠道ID
  786. BeginTime string //开始时间
  787. EndTime string //截止时间
  788. PageIndex int //页索引
  789. PageSize int //页大小
  790. }
  791. getDiamondAdminLogInfo struct {
  792. LogID int //标识
  793. UserID int //用户ID
  794. NickName string //昵称
  795. CurrentAmount int //当前金额
  796. ModifyAmount int //修改金额
  797. StillAmount int //剩余金额
  798. Remark string //备注
  799. IPAddress string //IP地址
  800. Crdate string //时间
  801. }
  802. getDiamondAdminLog_out struct {
  803. RecordCount int //记录数
  804. List []getDiamondAdminLogInfo
  805. }
  806. getDiamondAdminLog struct {
  807. database.Trans_base
  808. In getDiamondAdminLog_in
  809. Out getDiamondAdminLog_out
  810. }
  811. )
  812. func NewGetDiamondAdminLog() *getDiamondAdminLog {
  813. return &getDiamondAdminLog{}
  814. }
  815. func (this *getDiamondAdminLog) DoAction(ch chan<- interface{}) {
  816. defer func() {
  817. if err := recover(); err != nil {
  818. log.Release("transaction recover fail %v", err)
  819. log.Release("%s", debug.Stack())
  820. }
  821. if ch != nil {
  822. ch <- this
  823. }
  824. }()
  825. statement := database.NewStatement()
  826. statement.SetNeedReturnValue(false)
  827. statement.SetOpenRecordSet(true)
  828. statement.SetProcName("Manage_Diamond_GetAdminLog")
  829. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  830. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  831. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  832. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, this.In.PageIndex)
  833. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, this.In.PageSize)
  834. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, this.Out.RecordCount)
  835. sqlstring := statement.GenSql()
  836. retRows := CenterDB.ExecSql(sqlstring)
  837. rowLen := len(retRows)
  838. if rowLen <= 0 {
  839. this.State = false
  840. return
  841. }
  842. this.State = true
  843. if rowLen > 1 {
  844. this.Out.List = make([]getDiamondAdminLogInfo, rowLen-1)
  845. for i := 0; i < rowLen-1; i++ {
  846. ret := retRows[i]
  847. out := &this.Out.List[i]
  848. out.LogID = int((*ret[0].(*interface{})).(int64))
  849. out.UserID = int((*ret[1].(*interface{})).(int64))
  850. out.NickName = (*ret[2].(*interface{})).(string)
  851. if info := tagMgr.getInfo(out.UserID); info != nil {
  852. out.NickName = info.NickName
  853. }
  854. out.CurrentAmount = int((*ret[3].(*interface{})).(int64))
  855. out.ModifyAmount = int((*ret[4].(*interface{})).(int64))
  856. out.StillAmount = int((*ret[5].(*interface{})).(int64))
  857. out.Remark = (*ret[6].(*interface{})).(string)
  858. out.IPAddress = (*ret[7].(*interface{})).(string)
  859. out.IPAddress = ip.GetCountryAndRegion(out.IPAddress, false)
  860. out.Crdate = (*ret[8].(*interface{})).(string)
  861. }
  862. }
  863. this.Out.RecordCount = int((*retRows[rowLen-1][0].(*interface{})).(int64))
  864. }
  865. // 游戏金币流量统计
  866. type (
  867. moneyFlowStat_in struct {
  868. GameID int //游戏ID
  869. BeginTime string //开始时间
  870. EndTime string //截止时间
  871. PageIndex int //页索引
  872. PageSize int //页大小
  873. }
  874. moneyFlowStatModel struct {
  875. DateFlag string //时间
  876. ChineseName string //游戏名称
  877. Amount int //金币
  878. Tax int //台费
  879. }
  880. moneyFlowStat_out struct {
  881. RecordCount int //记录数
  882. List []moneyFlowStatModel
  883. }
  884. moneyFlowStat struct {
  885. database.Trans_base
  886. In moneyFlowStat_in
  887. Out moneyFlowStat_out
  888. }
  889. )
  890. func NewMoneyFlowStat() *moneyFlowStat {
  891. return &moneyFlowStat{}
  892. }
  893. func (this *moneyFlowStat) DoAction(ch chan<- interface{}) {
  894. defer func() {
  895. if err := recover(); err != nil {
  896. log.Release("transaction recover fail %v", err)
  897. log.Release("%s", debug.Stack())
  898. }
  899. if ch != nil {
  900. ch <- this
  901. }
  902. }()
  903. statement := database.NewStatement()
  904. statement.SetNeedReturnValue(false)
  905. statement.SetOpenRecordSet(true)
  906. statement.SetProcName("Manage_MoneyFlow_GetList")
  907. statement.AddParamter("@GameID", database.AdParamInput, database.AdInteger, 4, this.In.GameID)
  908. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  909. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  910. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, this.In.PageIndex)
  911. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, this.In.PageSize)
  912. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, this.Out.RecordCount)
  913. sqlstring := statement.GenSql()
  914. retRows := CenterDB.ExecSql(sqlstring)
  915. rowLen := len(retRows)
  916. if rowLen <= 0 {
  917. this.State = false
  918. return
  919. }
  920. this.State = true
  921. if rowLen > 1 {
  922. this.Out.List = make([]moneyFlowStatModel, rowLen-1)
  923. for i := 0; i < rowLen-1; i++ {
  924. ret := retRows[i]
  925. out := &this.Out.List[i]
  926. out.DateFlag = (*ret[0].(*interface{})).(string)
  927. out.ChineseName = (*ret[1].(*interface{})).(string)
  928. out.Amount = int((*ret[2].(*interface{})).(int64))
  929. out.Tax = int((*ret[3].(*interface{})).(int64))
  930. }
  931. }
  932. this.Out.RecordCount = int((*retRows[rowLen-1][0].(*interface{})).(int64))
  933. }
  934. // 赠送日志
  935. func (this *transferLog) GetCashTransferLog() {
  936. defer func() {
  937. if err := recover(); err != nil {
  938. log.Error("transaction recover err %v", err)
  939. log.Error("%s", debug.Stack())
  940. }
  941. }()
  942. statement := database.NewStatement()
  943. statement.SetNeedReturnValue(false)
  944. statement.SetOpenRecordSet(true)
  945. statement.SetProcName("Manage_Cash_GetTransferLog")
  946. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, this.In.UserID)
  947. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, this.In.BeginTime)
  948. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, this.In.EndTime)
  949. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, this.In.PageIndex)
  950. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, this.In.PageSize)
  951. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, this.Out.RecordCount)
  952. statement.AddParamter("@OutTotalAmount", database.AdParamOutput, database.AdBigint, 8, this.Out.OutTotalAmount)
  953. statement.AddParamter("@InTotalAmount", database.AdParamOutput, database.AdBigint, 8, this.Out.InTotalAmount)
  954. statement.AddParamter("@TotalTaxAmount", database.AdParamOutput, database.AdBigint, 8, this.Out.TotalTaxAmount)
  955. statement.AddParamter("@AcceptUserID", database.AdParamInput, database.AdInteger, 4, this.In.AcceptUserID)
  956. sqlstring := statement.GenSql()
  957. retRows := CenterDB.ExecSql(sqlstring)
  958. rowLen := len(retRows)
  959. if rowLen <= 0 {
  960. return
  961. }
  962. if rowLen > 1 {
  963. this.Out.List = make([]transferLogModel, rowLen-1)
  964. for i := 0; i < rowLen-1; i++ {
  965. ret := retRows[i]
  966. out := &this.Out.List[i]
  967. out.Rid = int((*ret[0].(*interface{})).(int64))
  968. out.UserID = int((*ret[1].(*interface{})).(int64))
  969. out.NickName = (*ret[2].(*interface{})).(string)
  970. if info := tagMgr.getInfo(out.UserID); info != nil {
  971. out.NickName = info.NickName
  972. }
  973. out.CurrAmount = int((*ret[3].(*interface{})).(int64))
  974. out.ModifyAmount = int((*ret[4].(*interface{})).(int64))
  975. out.StillAmount = int((*ret[5].(*interface{})).(int64))
  976. out.Action = (*ret[6].(*interface{})).(string)
  977. out.AcceptUserID = int((*ret[7].(*interface{})).(int64))
  978. out.AcceptNickName = (*ret[8].(*interface{})).(string)
  979. out.AcceptCurrAmount = int((*ret[9].(*interface{})).(int64))
  980. out.AcceptModifyAmount = int((*ret[10].(*interface{})).(int64))
  981. out.AcceptStillAmount = int((*ret[11].(*interface{})).(int64))
  982. out.TaxAmount = int((*ret[12].(*interface{})).(int64))
  983. out.Remark = (*ret[13].(*interface{})).(string)
  984. out.IPAddress = (*ret[14].(*interface{})).(string)
  985. out.IPAddress = ip.GetCountryAndRegion(out.IPAddress, false)
  986. out.Crdate = (*ret[15].(*interface{})).(string)
  987. }
  988. }
  989. this.Out.RecordCount = int((*retRows[rowLen-1][0].(*interface{})).(int64))
  990. this.Out.OutTotalAmount = int((*retRows[rowLen-1][1].(*interface{})).(int64))
  991. this.Out.InTotalAmount = int((*retRows[rowLen-1][2].(*interface{})).(int64))
  992. this.Out.TotalTaxAmount = int((*retRows[rowLen-1][3].(*interface{})).(int64))
  993. }