emqx.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. package mq
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "fmt"
  6. "io"
  7. "net/http"
  8. "github.com/gravitl/netmaker/servercfg"
  9. )
  10. type (
  11. emqxUser struct {
  12. UserID string `json:"user_id"`
  13. Password string `json:"password"`
  14. Admin bool `json:"is_superuser"`
  15. }
  16. emqxLogin struct {
  17. Username string `json:"username"`
  18. Password string `json:"password"`
  19. }
  20. emqxLoginResponse struct {
  21. License struct {
  22. Edition string `json:"edition"`
  23. } `json:"license"`
  24. Token string `json:"token"`
  25. Version string `json:"version"`
  26. }
  27. )
  28. func getEmqxAuthToken() (string, error) {
  29. payload, err := json.Marshal(&emqxLogin{
  30. Username: servercfg.GetMqUserName(),
  31. Password: servercfg.GetMqPassword(),
  32. })
  33. if err != nil {
  34. return "", err
  35. }
  36. resp, err := http.Post(servercfg.GetEmqxRestEndpoint()+"/api/v5/login", "application/json", bytes.NewReader(payload))
  37. if err != nil {
  38. return "", err
  39. }
  40. msg, err := io.ReadAll(resp.Body)
  41. if err != nil {
  42. return "", err
  43. }
  44. if resp.StatusCode != http.StatusOK {
  45. return "", fmt.Errorf("error during EMQX login %v", string(msg))
  46. }
  47. var loginResp emqxLoginResponse
  48. if err := json.Unmarshal(msg, &loginResp); err != nil {
  49. return "", err
  50. }
  51. return loginResp.Token, nil
  52. }
  53. // CreateEmqxUser - creates an EMQX user
  54. func CreateEmqxUser(username, password string, admin bool) error {
  55. token, err := getEmqxAuthToken()
  56. if err != nil {
  57. return err
  58. }
  59. payload, err := json.Marshal(&emqxUser{
  60. UserID: username,
  61. Password: password,
  62. Admin: admin,
  63. })
  64. if err != nil {
  65. return err
  66. }
  67. req, err := http.NewRequest(http.MethodPost, servercfg.GetEmqxRestEndpoint()+"/api/v5/authentication/password_based:built_in_database/users", bytes.NewReader(payload))
  68. if err != nil {
  69. return err
  70. }
  71. req.Header.Add("content-type", "application/json")
  72. req.Header.Add("authorization", "Bearer "+token)
  73. resp, err := (&http.Client{}).Do(req)
  74. if err != nil {
  75. return err
  76. }
  77. defer resp.Body.Close()
  78. if resp.StatusCode >= 300 {
  79. msg, err := io.ReadAll(resp.Body)
  80. if err != nil {
  81. return err
  82. }
  83. return fmt.Errorf("error creating EMQX user %v", string(msg))
  84. }
  85. return nil
  86. }
  87. // DeleteEmqxUser - deletes an EMQX user
  88. func DeleteEmqxUser(username string) error {
  89. token, err := getEmqxAuthToken()
  90. if err != nil {
  91. return err
  92. }
  93. req, err := http.NewRequest(http.MethodDelete, servercfg.GetEmqxRestEndpoint()+"/api/v5/authentication/password_based:built_in_database/users/"+username, nil)
  94. if err != nil {
  95. return err
  96. }
  97. req.Header.Add("authorization", "Bearer "+token)
  98. resp, err := (&http.Client{}).Do(req)
  99. if err != nil {
  100. return err
  101. }
  102. defer resp.Body.Close()
  103. if resp.StatusCode >= 300 {
  104. msg, err := io.ReadAll(resp.Body)
  105. if err != nil {
  106. return err
  107. }
  108. return fmt.Errorf("error deleting EMQX user %v", string(msg))
  109. }
  110. return nil
  111. }
  112. // CreateEmqxDefaultAuthenticator - creates a default authenticator based on password and using EMQX's built in database as storage
  113. func CreateEmqxDefaultAuthenticator() error {
  114. token, err := getEmqxAuthToken()
  115. if err != nil {
  116. return err
  117. }
  118. payload, err := json.Marshal(&struct {
  119. Mechanism string `json:"mechanism"`
  120. Backend string `json:"backend"`
  121. UserIDType string `json:"user_id_type"`
  122. }{Mechanism: "password_based", Backend: "built_in_database", UserIDType: "username"})
  123. if err != nil {
  124. return err
  125. }
  126. req, err := http.NewRequest(http.MethodPost, servercfg.GetEmqxRestEndpoint()+"/api/v5/authentication", bytes.NewReader(payload))
  127. if err != nil {
  128. return err
  129. }
  130. req.Header.Add("content-type", "application/json")
  131. req.Header.Add("authorization", "Bearer "+token)
  132. resp, err := (&http.Client{}).Do(req)
  133. if err != nil {
  134. return err
  135. }
  136. defer resp.Body.Close()
  137. if resp.StatusCode != http.StatusOK {
  138. msg, err := io.ReadAll(resp.Body)
  139. if err != nil {
  140. return err
  141. }
  142. return fmt.Errorf("error creating default EMQX authenticator %v", string(msg))
  143. }
  144. return nil
  145. }