transaction.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  1. package audioroom
  2. import (
  3. "bet24.com/database"
  4. "bet24.com/log"
  5. audioroomPb "bet24.com/servers/micros/audioroom/proto"
  6. dbengine "bet24.com/servers/micros/dbengine/proto"
  7. "encoding/json"
  8. "runtime/debug"
  9. )
  10. // 获取所有房间
  11. func getRoomList(roomName, beginTime, endTime, sortName, sortType string, roomId, pageIndex, pageSize int) (int, []audioroomPb.AdminRoomInfo) {
  12. defer func() {
  13. if err := recover(); err != nil {
  14. log.Error("transaction recover err %v", err)
  15. log.Error("%s", debug.Stack())
  16. }
  17. }()
  18. var recordCount int
  19. statement := database.NewStatement()
  20. statement.SetNeedReturnValue(false)
  21. statement.SetOpenRecordSet(true)
  22. statement.SetProcName("Manage_AudioRoom_GetAllRoom")
  23. statement.AddParamter("@RoomId", database.AdParamInput, database.AdInteger, 4, roomId)
  24. statement.AddParamter("@RoomName", database.AdParamInput, database.AdNVarChar, 32, roomName)
  25. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, beginTime)
  26. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, endTime)
  27. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, pageIndex)
  28. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, pageSize)
  29. statement.AddParamter("@SortName", database.AdParamInput, database.AdVarChar, 16, sortName)
  30. statement.AddParamter("@SortType", database.AdParamInput, database.AdChar, 4, sortType)
  31. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, recordCount)
  32. sqlString := statement.GenSql()
  33. //log.Debug(sqlString)
  34. retRows := dbengine.ExecuteRs(sqlString)
  35. rowLen := len(retRows)
  36. var records []audioroomPb.AdminRoomInfo
  37. if rowLen <= 0 {
  38. return 0, records
  39. }
  40. if rowLen > 1 {
  41. for i := 0; i < rowLen-1; i++ {
  42. ret := retRows[i]
  43. var data audioroomPb.AdminRoomInfo
  44. data.RoomId = int(ret[0].(int64))
  45. data.RoomName = ret[1].(string)
  46. data.UserId = int(ret[2].(int64))
  47. data.NickName = ret[3].(string)
  48. data.Level = int(ret[4].(int64))
  49. data.Exps = int(ret[5].(int64))
  50. data.MemberCount = int(ret[6].(int64))
  51. data.CollectDiamond = int(ret[7].(int64))
  52. data.DiamondAmount = int(ret[8].(int64))
  53. data.CollectGold = int(ret[9].(int64))
  54. data.GoldAmount = int(ret[10].(int64))
  55. data.Crdate = ret[11].(string)
  56. records = append(records, data)
  57. }
  58. }
  59. if records == nil {
  60. records = make([]audioroomPb.AdminRoomInfo, 0)
  61. }
  62. recordCount = int(retRows[rowLen-1][0].(int64))
  63. return recordCount, records
  64. }
  65. // 获取语聊房详细信息
  66. func getRoomDetail(roomId int) audioroomPb.AdminRoomDetail {
  67. defer func() {
  68. if err := recover(); err != nil {
  69. log.Error("transaction recover err %v", err)
  70. log.Error("%s", debug.Stack())
  71. }
  72. }()
  73. statement := database.NewStatement()
  74. statement.SetNeedReturnValue(false)
  75. statement.SetOpenRecordSet(true)
  76. statement.SetProcName("Manage_AudioRoom_GetExtraInfo")
  77. statement.AddParamter("@RoomId", database.AdParamInput, database.AdInteger, 4, roomId)
  78. sqlString := statement.GenSql()
  79. //log.Debug(sqlString)
  80. jsonData := dbengine.Execute(sqlString)
  81. var ret []audioroomPb.AdminRoomDetail
  82. if err := json.Unmarshal([]byte(jsonData), &ret); err != nil {
  83. log.Error("transaction.getRoomDetail json unmarshal err %v", err)
  84. }
  85. if len(ret) <= 0 {
  86. return audioroomPb.AdminRoomDetail{}
  87. }
  88. return ret[0]
  89. }
  90. // 获取语聊房成员
  91. func getRoomMember(beginTime, endTime string, roomId, pageIndex, pageSize int) (int, []audioroomPb.AdminRoomMember) {
  92. defer func() {
  93. if err := recover(); err != nil {
  94. log.Error("transaction recover err %v", err)
  95. log.Error("%s", debug.Stack())
  96. }
  97. }()
  98. var recordCount int
  99. statement := database.NewStatement()
  100. statement.SetNeedReturnValue(false)
  101. statement.SetOpenRecordSet(true)
  102. statement.SetProcName("Manage_AudioRoom_GetRoomMember")
  103. statement.AddParamter("@RoomId", database.AdParamInput, database.AdInteger, 4, roomId)
  104. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, beginTime)
  105. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, endTime)
  106. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, pageIndex)
  107. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, pageSize)
  108. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, recordCount)
  109. sqlString := statement.GenSql()
  110. //log.Debug(sqlString)
  111. retRows := dbengine.ExecuteRs(sqlString)
  112. rowLen := len(retRows)
  113. var records []audioroomPb.AdminRoomMember
  114. if rowLen <= 0 {
  115. return 0, records
  116. }
  117. if rowLen > 1 {
  118. for i := 0; i < rowLen-1; i++ {
  119. ret := retRows[i]
  120. var data audioroomPb.AdminRoomMember
  121. data.RoomID = int(ret[0].(int64))
  122. data.UserID = int(ret[1].(int64))
  123. data.NickName = ret[2].(string)
  124. data.RoleID = int(ret[3].(int64))
  125. data.Exps = int(ret[4].(int64))
  126. data.Level = int(ret[5].(int64))
  127. data.Crdate = ret[6].(string)
  128. records = append(records, data)
  129. }
  130. }
  131. if records == nil {
  132. records = make([]audioroomPb.AdminRoomMember, 0)
  133. }
  134. recordCount = int(retRows[rowLen-1][0].(int64))
  135. return recordCount, records
  136. }
  137. // 获取语聊房详细信息
  138. func getBlackList(roomId, blackType, pageIndex, pageSize int, beginTime, endTime string) (int, []audioroomPb.AdminRoomBlackList) {
  139. defer func() {
  140. if err := recover(); err != nil {
  141. log.Error("transaction recover err %v", err)
  142. log.Error("%s", debug.Stack())
  143. }
  144. }()
  145. var recordCount int
  146. statement := database.NewStatement()
  147. statement.SetNeedReturnValue(false)
  148. statement.SetOpenRecordSet(true)
  149. statement.SetProcName("Manage_AudioRoom_BlackIdentity")
  150. statement.AddParamter("@RoomId", database.AdParamInput, database.AdInteger, 4, roomId)
  151. statement.AddParamter("@BlackType", database.AdParamInput, database.AdInteger, 4, blackType)
  152. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, beginTime)
  153. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, endTime)
  154. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, pageIndex)
  155. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, pageSize)
  156. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, recordCount)
  157. sqlString := statement.GenSql()
  158. //log.Debug(sqlString)
  159. retRows := dbengine.ExecuteRs(sqlString)
  160. rowLen := len(retRows)
  161. var records []audioroomPb.AdminRoomBlackList
  162. if rowLen <= 0 {
  163. return 0, records
  164. }
  165. if rowLen > 1 {
  166. for i := 0; i < rowLen-1; i++ {
  167. ret := retRows[i]
  168. var data audioroomPb.AdminRoomBlackList
  169. data.UserID = int(ret[0].(int64))
  170. data.NickName = ret[1].(string)
  171. data.RoleID = int(ret[2].(int64))
  172. data.Level = int(ret[3].(int64))
  173. data.ExpireTime = int(ret[4].(int64))
  174. data.Crdate = ret[5].(string)
  175. records = append(records, data)
  176. }
  177. }
  178. if records == nil {
  179. records = make([]audioroomPb.AdminRoomBlackList, 0)
  180. }
  181. recordCount = int(retRows[rowLen-1][0].(int64))
  182. return recordCount, records
  183. }
  184. // 获取语聊房详细信息
  185. func getRoomLogRecord(roomId, pageIndex, pageSize int, beginTime, endTime string) (int, []audioroomPb.AdminRoomLogRecord) {
  186. defer func() {
  187. if err := recover(); err != nil {
  188. log.Error("transaction recover err %v", err)
  189. log.Error("%s", debug.Stack())
  190. }
  191. }()
  192. var recordCount int
  193. statement := database.NewStatement()
  194. statement.SetNeedReturnValue(false)
  195. statement.SetOpenRecordSet(true)
  196. statement.SetProcName("Manage_AudioRoom_GetRoomLogRecord")
  197. statement.AddParamter("@RoomId", database.AdParamInput, database.AdInteger, 4, roomId)
  198. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, beginTime)
  199. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, endTime)
  200. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, pageIndex)
  201. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, pageSize)
  202. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, recordCount)
  203. sqlString := statement.GenSql()
  204. //log.Debug(sqlString)
  205. retRows := dbengine.ExecuteRs(sqlString)
  206. rowLen := len(retRows)
  207. var records []audioroomPb.AdminRoomLogRecord
  208. if rowLen <= 0 {
  209. return 0, records
  210. }
  211. if rowLen > 1 {
  212. for i := 0; i < rowLen-1; i++ {
  213. ret := retRows[i]
  214. var data audioroomPb.AdminRoomLogRecord
  215. data.RoomID = int(ret[0].(int64))
  216. data.UserID = int(ret[1].(int64))
  217. data.ToUserID = int(ret[2].(int64))
  218. data.OperateType = int(ret[3].(int64))
  219. data.Crdate = ret[4].(string)
  220. records = append(records, data)
  221. }
  222. }
  223. if records == nil {
  224. records = make([]audioroomPb.AdminRoomLogRecord, 0)
  225. }
  226. recordCount = int(retRows[rowLen-1][0].(int64))
  227. return recordCount, records
  228. }
  229. // 获取房间任务列表
  230. func getRoomTask(roomId, pageIndex, pageSize int, beginTime, endTime string) (int, []audioroomPb.AdminRoomTask) {
  231. defer func() {
  232. if err := recover(); err != nil {
  233. log.Error("transaction recover err %v", err)
  234. log.Error("%s", debug.Stack())
  235. }
  236. }()
  237. var recordCount int
  238. statement := database.NewStatement()
  239. statement.SetNeedReturnValue(false)
  240. statement.SetOpenRecordSet(true)
  241. statement.SetProcName("Manage_AudioRoom_GetRoomTaskList")
  242. statement.AddParamter("@RoomID", database.AdParamInput, database.AdInteger, 4, roomId)
  243. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, beginTime)
  244. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, endTime)
  245. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, pageIndex)
  246. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, pageSize)
  247. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, recordCount)
  248. sqlString := statement.GenSql()
  249. //log.Debug(sqlString)
  250. retRows := dbengine.ExecuteRs(sqlString)
  251. rowLen := len(retRows)
  252. var records []audioroomPb.AdminRoomTask
  253. if rowLen <= 0 {
  254. return 0, records
  255. }
  256. if rowLen > 1 {
  257. for i := 0; i < rowLen-1; i++ {
  258. ret := retRows[i]
  259. var data audioroomPb.AdminRoomTask
  260. data.RoomID = int(ret[0].(int64))
  261. data.TaskID = int(ret[1].(int64))
  262. data.Schedule = int(ret[2].(int64))
  263. data.CurrNum = int(ret[3].(int64))
  264. data.UpdateTime = ret[4].(string)
  265. records = append(records, data)
  266. }
  267. }
  268. if records == nil {
  269. records = make([]audioroomPb.AdminRoomTask, 0)
  270. }
  271. recordCount = int(retRows[rowLen-1][0].(int64))
  272. return recordCount, records
  273. }
  274. // 获取用户的房间任务
  275. func getUserRoomTask(roomId, userId, pageIndex, pageSize int) (int, []audioroomPb.AdminUserRoomTask) {
  276. defer func() {
  277. if err := recover(); err != nil {
  278. log.Error("transaction recover err %v", err)
  279. log.Error("%s", debug.Stack())
  280. }
  281. }()
  282. var recordCount int
  283. statement := database.NewStatement()
  284. statement.SetNeedReturnValue(false)
  285. statement.SetOpenRecordSet(true)
  286. statement.SetProcName("Manage_AudioRoom_GetUserRoomTaskList")
  287. statement.AddParamter("@RoomID", database.AdParamInput, database.AdInteger, 4, roomId)
  288. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, userId)
  289. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, pageIndex)
  290. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, pageSize)
  291. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, recordCount)
  292. sqlString := statement.GenSql()
  293. //log.Debug(sqlString)
  294. retRows := dbengine.ExecuteRs(sqlString)
  295. rowLen := len(retRows)
  296. var records []audioroomPb.AdminUserRoomTask
  297. if rowLen <= 0 {
  298. return 0, records
  299. }
  300. if rowLen > 1 {
  301. for i := 0; i < rowLen-1; i++ {
  302. ret := retRows[i]
  303. var data audioroomPb.AdminUserRoomTask
  304. data.UserID = int(ret[0].(int64))
  305. data.RoomID = int(ret[1].(int64))
  306. data.TaskID = int(ret[2].(int64))
  307. data.Schedule = int(ret[3].(int64))
  308. data.CurrNum = int(ret[4].(int64))
  309. data.Status = int(ret[5].(int64))
  310. data.UpdateTime = ret[6].(string)
  311. records = append(records, data)
  312. }
  313. }
  314. if records == nil {
  315. records = make([]audioroomPb.AdminUserRoomTask, 0)
  316. }
  317. recordCount = int(retRows[rowLen-1][0].(int64))
  318. return recordCount, records
  319. }
  320. // 获取房间上下麦日志
  321. func getRoomMicLog(roomId, userId, pageIndex, pageSize int, roomName, nickName, beginTime, endTime string) (int, []audioroomPb.AdminRoomMicLog) {
  322. defer func() {
  323. if err := recover(); err != nil {
  324. log.Error("transaction recover err %v", err)
  325. log.Error("%s", debug.Stack())
  326. }
  327. }()
  328. var recordCount int
  329. statement := database.NewStatement()
  330. statement.SetNeedReturnValue(false)
  331. statement.SetOpenRecordSet(true)
  332. statement.SetProcName("Manage_AudioRoom_GetRoomMicLog")
  333. statement.AddParamter("@RoomId", database.AdParamInput, database.AdInteger, 4, roomId)
  334. statement.AddParamter("@RoomName", database.AdParamInput, database.AdNVarChar, 32, roomName)
  335. statement.AddParamter("@UserId", database.AdParamInput, database.AdInteger, 4, userId)
  336. statement.AddParamter("@NickName", database.AdParamInput, database.AdNVarChar, 32, nickName)
  337. statement.AddParamter("@BeginTime", database.AdParamInput, database.AdVarChar, 20, beginTime)
  338. statement.AddParamter("@EndTime", database.AdParamInput, database.AdVarChar, 20, endTime)
  339. statement.AddParamter("@PageIndex", database.AdParamInput, database.AdInteger, 4, pageIndex)
  340. statement.AddParamter("@PageSize", database.AdParamInput, database.AdInteger, 4, pageSize)
  341. statement.AddParamter("@RecordCount", database.AdParamOutput, database.AdInteger, 4, recordCount)
  342. sqlString := statement.GenSql()
  343. //log.Debug(sqlString)
  344. retRows := dbengine.ExecuteRs(sqlString)
  345. rowLen := len(retRows)
  346. var records []audioroomPb.AdminRoomMicLog
  347. if rowLen <= 0 {
  348. return 0, records
  349. }
  350. if rowLen > 1 {
  351. for i := 0; i < rowLen-1; i++ {
  352. ret := retRows[i]
  353. var data audioroomPb.AdminRoomMicLog
  354. data.RoomID = int(ret[0].(int64))
  355. data.RoomName = ret[1].(string)
  356. data.UserID = int(ret[2].(int64))
  357. data.NickName = ret[3].(string)
  358. data.RoleID = int(ret[4].(int64))
  359. data.MicMode = int(ret[5].(int64))
  360. data.OnMicTime = ret[6].(string)
  361. data.OffMicTime = ret[7].(string)
  362. data.Seconds = int(ret[8].(int64))
  363. data.OpUserID = int(ret[9].(int64))
  364. data.OpUserRoleID = int(ret[10].(int64))
  365. records = append(records, data)
  366. }
  367. }
  368. if records == nil {
  369. records = make([]audioroomPb.AdminRoomMicLog, 0)
  370. }
  371. recordCount = int(retRows[rowLen-1][0].(int64))
  372. return recordCount, records
  373. }