pub.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. package main
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/edgexfoundry/go-mod-core-contracts/clients/coredata"
  6. "github.com/edgexfoundry/go-mod-core-contracts/clients/urlclient/local"
  7. "github.com/edgexfoundry/go-mod-core-contracts/models"
  8. "github.com/edgexfoundry/go-mod-messaging/messaging"
  9. "github.com/edgexfoundry/go-mod-messaging/pkg/types"
  10. "log"
  11. "os"
  12. "time"
  13. )
  14. var msgConfig1 = types.MessageBusConfig{
  15. PublishHost: types.HostInfo{
  16. Host: "*",
  17. Port: 5570,
  18. Protocol: "tcp",
  19. },
  20. Type:messaging.ZeroMQ,
  21. }
  22. func pubEventClientZeroMq() {
  23. if msgClient, err := messaging.NewMessageClient(msgConfig1); err != nil {
  24. log.Fatal(err)
  25. } else {
  26. if ec := msgClient.Connect(); ec != nil {
  27. log.Fatal(ec)
  28. } else {
  29. client := coredata.NewEventClient(local.New("test"))
  30. //r := rand.New(rand.NewSource(time.Now().UnixNano()))
  31. for i := 0; i < 10; i++ {
  32. //temp := r.Intn(100)
  33. //humd := r.Intn(100)
  34. var testEvent = models.Event{Device: "demo", Created: 123, Modified: 123, Origin: 123}
  35. var r1 = models.Reading{Pushed: 123, Created: 123, Origin: 123, Modified: 123, Device: "test device name", Name: "Temperature", Value: fmt.Sprintf("%d", i*8)}
  36. var r2 = models.Reading{Pushed: 123, Created: 123, Origin: 123, Modified: 123, Device: "test device name", Name: "Humidity", Value: fmt.Sprintf("%d", i*9)}
  37. var r3 = models.Reading{Name:"b1"}
  38. if i % 2 == 0 {
  39. r3.Value = "true"
  40. } else {
  41. r3.Value = "false"
  42. }
  43. r4 := models.Reading{Name:"i1", Value:fmt.Sprintf("%d", i)}
  44. r5 := models.Reading{Name:"f1", Value:fmt.Sprintf("%.2f", float64(i)/2.0)}
  45. testEvent.Readings = append(testEvent.Readings, r1, r2, r3, r4, r5)
  46. data, err := client.MarshalEvent(testEvent)
  47. if err != nil {
  48. fmt.Errorf("unexpected error MarshalEvent %v", err)
  49. } else {
  50. fmt.Println(string(data))
  51. }
  52. env := types.NewMessageEnvelope([]byte(data), context.Background())
  53. env.ContentType = "application/json"
  54. if e := msgClient.Publish(env, "events"); e != nil {
  55. log.Fatal(e)
  56. } else {
  57. fmt.Printf("Pub successful: %s\n", data)
  58. }
  59. time.Sleep(1500 * time.Millisecond)
  60. }
  61. }
  62. }
  63. }
  64. func pubToAnother() {
  65. var msgConfig2 = types.MessageBusConfig{
  66. PublishHost: types.HostInfo{
  67. Host: "*",
  68. Port: 5571,
  69. Protocol: "tcp",
  70. },
  71. Type:messaging.ZeroMQ,
  72. }
  73. if msgClient, err := messaging.NewMessageClient(msgConfig2); err != nil {
  74. log.Fatal(err)
  75. } else {
  76. if ec := msgClient.Connect(); ec != nil {
  77. log.Fatal(ec)
  78. }
  79. client := coredata.NewEventClient(local.New("test1"))
  80. var testEvent = models.Event{Device: "demo1", Created: 123, Modified: 123, Origin: 123}
  81. var r1 = models.Reading{Pushed: 123, Created: 123, Origin: 123, Modified: 123, Device: "test device name", Name: "Temperature", Value: "20"}
  82. var r2 = models.Reading{Pushed: 123, Created: 123, Origin: 123, Modified: 123, Device: "test device name", Name: "Humidity", Value: "30"}
  83. testEvent.Readings = append(testEvent.Readings, r1, r2)
  84. data, err := client.MarshalEvent(testEvent)
  85. if err != nil {
  86. fmt.Errorf("unexpected error MarshalEvent %v", err)
  87. } else {
  88. fmt.Println(string(data))
  89. }
  90. env := types.NewMessageEnvelope([]byte(data), context.Background())
  91. env.ContentType = "application/json"
  92. if e := msgClient.Publish(env, "application"); e != nil {
  93. log.Fatal(e)
  94. } else {
  95. fmt.Printf("pubToAnother successful: %s\n", data)
  96. }
  97. time.Sleep(1500 * time.Millisecond)
  98. }
  99. }
  100. func pubMetaSource() {
  101. if msgClient, err := messaging.NewMessageClient(msgConfig1); err != nil {
  102. log.Fatal(err)
  103. } else {
  104. if ec := msgClient.Connect(); ec != nil {
  105. log.Fatal(ec)
  106. } else {
  107. client := coredata.NewEventClient(local.New("test"))
  108. evtDevice := []string{"demo1", "demo2"}
  109. for i, device := range evtDevice {
  110. j := int64(i) + 1
  111. testEvent := models.Event{Device: device, Created: 11*j, Modified: 12*j, Origin: 13*j}
  112. r1 := models.Reading{Pushed: 22*j, Created: 23*j, Origin: 24*j, Modified: 25*j, Device: "Temperature sensor", Name: "Temperature", Value: fmt.Sprintf("%d", j*8)}
  113. r2 := models.Reading{Pushed: 32*j, Created: 33*j, Origin: 34*j, Modified: 35*j, Device: "Humidity sensor", Name: "Humidity", Value: fmt.Sprintf("%d", j*8)}
  114. testEvent.Readings = append(testEvent.Readings, r1, r2)
  115. data, err := client.MarshalEvent(testEvent)
  116. if err != nil {
  117. fmt.Errorf("unexpected error MarshalEvent %v", err)
  118. } else {
  119. fmt.Println(string(data))
  120. }
  121. env := types.NewMessageEnvelope([]byte(data), context.Background())
  122. env.ContentType = "application/json"
  123. if e := msgClient.Publish(env, "events"); e != nil {
  124. log.Fatal(e)
  125. } else {
  126. fmt.Printf("Pub successful: %s\n", data)
  127. }
  128. time.Sleep(1500 * time.Millisecond)
  129. }
  130. }
  131. }
  132. }
  133. func main() {
  134. if len(os.Args) == 1 {
  135. pubEventClientZeroMq()
  136. } else if len(os.Args) == 2 {
  137. if v := os.Args[1]; v == "another" {
  138. pubToAnother()
  139. } else if v == "meta" {
  140. pubMetaSource()
  141. }
  142. }
  143. }