client-ws2.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. //go:build ignore
  2. // +build ignore
  3. package main
  4. import (
  5. "log"
  6. "time"
  7. "git.me9.top/git/tinymq"
  8. "git.me9.top/git/tinymq/config"
  9. )
  10. func main() {
  11. cf := config.NewConfig()
  12. localChannel := "/tinymq/client/ws2"
  13. remoteChannel := "/tinymq/server"
  14. remoteFilter := tinymq.StrChannelFilter(remoteChannel)
  15. host := &tinymq.HostInfo{
  16. Proto: "ws",
  17. Version: 2,
  18. Host: "127.0.0.1",
  19. Port: 34211,
  20. // Path: "/tinymq",
  21. Path: "/tinymq-xor",
  22. Hash: "xor:1qaz2wsx3edc",
  23. }
  24. hub := tinymq.NewHub(
  25. cf,
  26. localChannel,
  27. func(channel string, hostType tinymq.HostType) (hostInfo *tinymq.HostInfo, err error) {
  28. return host, nil
  29. },
  30. func(client bool, proto string, version uint8, channel string, remoteAuth []byte) (auth []byte) {
  31. log.Println("[AuthFunc]", client, proto, version, channel, string(remoteAuth))
  32. return []byte("tinymq-client")
  33. },
  34. func(client bool, proto string, version uint8, channel string, auth []byte) bool {
  35. log.Println("[CheckAuthFunc]", client, proto, version, channel, string(auth))
  36. return string(auth) == "tinymq-server"
  37. },
  38. func(conn *tinymq.Line) {
  39. log.Println("connect state", conn.Channel(), conn.State(), time.Since(conn.Updated()))
  40. },
  41. )
  42. // 订阅频道
  43. hub.Subscribe(remoteFilter, "hello", func(request *tinymq.RequestData) (state uint8, result any) {
  44. log.Println("[client RECV]<-", string(request.Data))
  45. return 1, "tiny client"
  46. },
  47. )
  48. hub.Subscribe(remoteFilter, "nodata", func(request *tinymq.RequestData) (state uint8, result any) {
  49. log.Println("[client RECV]<-", string(request.Data))
  50. return 1, nil
  51. },
  52. )
  53. err := hub.ConnectToServer(remoteChannel, true, nil)
  54. if err != nil {
  55. log.Fatalln("[client ConnectToServer ERROR]", err)
  56. }
  57. log.Println("start get data")
  58. count, err := hub.Get(remoteFilter, "hello", "hello in get model", func(response *tinymq.ResponseData) (ok bool) {
  59. log.Println("get state and data: ", response.State, string(response.Data))
  60. return true
  61. })
  62. log.Println("end get data with count and err:", count, err)
  63. // 获取信息
  64. rsp := hub.GetOne(remoteFilter, "hello", "hello from client,hello from client,hello from client")
  65. if rsp.State != tinymq.STATE_OK {
  66. log.Println("error state:", rsp.State)
  67. return
  68. }
  69. log.Println("[RESULT]<-", string(rsp.Data))
  70. rsp = hub.GetOne(remoteFilter, "hello", func() ([]byte, error) {
  71. return []byte("hello from data function"), nil
  72. })
  73. if rsp.State != tinymq.STATE_OK {
  74. log.Println("error state:", rsp.State)
  75. return
  76. }
  77. log.Println("[RESULT]<-", string(rsp.Data))
  78. // 获取长数据
  79. rsp = hub.GetOne(remoteFilter, "bigdata", nil)
  80. if rsp.State != tinymq.STATE_OK {
  81. log.Println("error state:", rsp.State)
  82. return
  83. } else {
  84. log.Println("get bigdata ok")
  85. }
  86. time.Sleep(time.Second * 5)
  87. hub.Push(remoteFilter, "push", []byte(time.Now().GoString()))
  88. time.Sleep(time.Second * 300)
  89. log.Println("client exit")
  90. }