stat.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. // The MIT License (MIT)
  2. //
  3. // # Copyright (c) 2021 Winlin
  4. //
  5. // Permission is hereby granted, free of charge, to any person obtaining a copy of
  6. // this software and associated documentation files (the "Software"), to deal in
  7. // the Software without restriction, including without limitation the rights to
  8. // use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  9. // the Software, and to permit persons to whom the Software is furnished to do so,
  10. // subject to the following conditions:
  11. //
  12. // The above copyright notice and this permission notice shall be included in all
  13. // copies or substantial portions of the Software.
  14. //
  15. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  17. // FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  18. // COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  19. // IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  20. // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  21. package live
  22. import (
  23. "context"
  24. "encoding/json"
  25. "net/http"
  26. "strings"
  27. "github.com/ossrs/go-oryx-lib/logger"
  28. )
  29. type statLive struct {
  30. Publishers struct {
  31. Expect int `json:"expect"`
  32. Alive int `json:"alive"`
  33. } `json:"publishers"`
  34. Subscribers struct {
  35. Expect int `json:"expect"`
  36. Alive int `json:"alive"`
  37. } `json:"subscribers"`
  38. PeerConnection interface{} `json:"random-pc"`
  39. }
  40. var gStatLive statLive
  41. func handleStat(ctx context.Context, mux *http.ServeMux, l string) {
  42. if strings.HasPrefix(l, ":") {
  43. l = "127.0.0.1" + l
  44. }
  45. logger.Tf(ctx, "Handle http://%v/api/v1/sb/live", l)
  46. mux.HandleFunc("/api/v1/sb/live", func(w http.ResponseWriter, r *http.Request) {
  47. res := &struct {
  48. Code int `json:"code"`
  49. Data interface{} `json:"data"`
  50. }{
  51. 0, &gStatLive,
  52. }
  53. b, err := json.Marshal(res)
  54. if err != nil {
  55. logger.Wf(ctx, "marshal %v err %+v", res, err)
  56. return
  57. }
  58. w.Write(b)
  59. })
  60. }