trans_mic.go 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. package database
  2. import (
  3. "encoding/json"
  4. "runtime/debug"
  5. "bet24.com/database"
  6. "bet24.com/log"
  7. pb "bet24.com/servers/micros/audioroom/proto"
  8. dbengine "bet24.com/servers/micros/dbengine/proto"
  9. )
  10. // 获取麦位信息
  11. func GetMicInfo(roomId int) []pb.MicInfo {
  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 list []pb.MicInfo
  19. statement := database.NewStatement()
  20. statement.SetNeedReturnValue(false)
  21. statement.SetOpenRecordSet(true)
  22. statement.SetProcName("WS_AudioRoom_GetMicInfo")
  23. statement.AddParamter("@RoomID", database.AdParamInput, database.AdInteger, 4, roomId)
  24. sqlString := statement.GenSql()
  25. retRows := dbengine.ExecuteRs(sqlString)
  26. if len(retRows) <= 0 {
  27. return list
  28. }
  29. micsInfo := retRows[0][0].(string)
  30. if err := json.Unmarshal([]byte(micsInfo), &list); err != nil {
  31. log.Error("transaction.getMicInfo json unmarshal err %v", err)
  32. }
  33. return list
  34. }
  35. // 设置麦位信息
  36. func SetMicInfo(roomId int, mics []pb.MicInfo) {
  37. defer func() {
  38. if err := recover(); err != nil {
  39. log.Error("transaction recover err %v", err)
  40. log.Error("%s", debug.Stack())
  41. }
  42. }()
  43. buf, _ := json.Marshal(mics)
  44. micInfo := string(buf)
  45. statement := database.NewStatement()
  46. statement.SetNeedReturnValue(false)
  47. statement.SetOpenRecordSet(true)
  48. statement.SetProcName("WS_AudioRoom_SetMicInfo")
  49. statement.AddParamter("@RoomID", database.AdParamInput, database.AdInteger, 4, roomId)
  50. statement.AddParamter("@MicInfo", database.AdParamInput, database.AdVarChar, 1024, micInfo)
  51. sqlString := statement.GenSql()
  52. dbengine.Execute(sqlString)
  53. return
  54. }
  55. // 添加麦位日志
  56. func AddMicLog(userId, roomId, roleId, sn, micMode, onMicStamp, offMicStamp, seconds, opUserId int) {
  57. defer func() {
  58. if err := recover(); err != nil {
  59. log.Error("transaction recover err %v", err)
  60. log.Error("%s", debug.Stack())
  61. }
  62. }()
  63. statement := database.NewStatement()
  64. statement.SetNeedReturnValue(false)
  65. statement.SetOpenRecordSet(true)
  66. statement.SetProcName("WS_AudioRoom_AddMicLog")
  67. statement.AddParamter("@UserID", database.AdParamInput, database.AdInteger, 4, userId)
  68. statement.AddParamter("@RoomID", database.AdParamInput, database.AdInteger, 4, roomId)
  69. statement.AddParamter("@RoleID", database.AdParamInput, database.AdInteger, 4, roleId)
  70. statement.AddParamter("@SN", database.AdParamInput, database.AdInteger, 4, sn)
  71. statement.AddParamter("@MicMode", database.AdParamInput, database.AdInteger, 4, micMode)
  72. statement.AddParamter("@OnMicTime", database.AdParamInput, database.AdInteger, 4, onMicStamp)
  73. statement.AddParamter("@OffMicTime", database.AdParamInput, database.AdInteger, 4, offMicStamp)
  74. statement.AddParamter("@Seconds", database.AdParamInput, database.AdInteger, 4, seconds)
  75. statement.AddParamter("@OpUserID", database.AdParamInput, database.AdInteger, 4, opUserId)
  76. sqlString := statement.GenSql()
  77. //log.Debug(sqlString)
  78. dbengine.Execute(sqlString)
  79. return
  80. }