token_client.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. package mqe
  2. import (
  3. "context"
  4. "encoding/json"
  5. "fmt"
  6. "io/ioutil"
  7. "net/http"
  8. "net/url"
  9. "path"
  10. "time"
  11. "golang.org/x/net/context/ctxhttp"
  12. "strconv"
  13. "github.com/grafana/grafana/pkg/log"
  14. "github.com/grafana/grafana/pkg/models"
  15. "github.com/patrickmn/go-cache"
  16. )
  17. var tokenCache *cache.Cache
  18. func init() {
  19. tokenCache = cache.New(5*time.Minute, 30*time.Second)
  20. }
  21. type TokenClient struct {
  22. log log.Logger
  23. Datasource *models.DataSource
  24. HttpClient *http.Client
  25. }
  26. func NewTokenClient(datasource *models.DataSource) *TokenClient {
  27. httpClient, _ := datasource.GetHttpClient()
  28. return &TokenClient{
  29. log: log.New("tsdb.mqe.tokenclient"),
  30. Datasource: datasource,
  31. HttpClient: httpClient,
  32. }
  33. }
  34. func (client *TokenClient) GetTokenData(ctx context.Context) (*TokenBody, error) {
  35. key := strconv.FormatInt(client.Datasource.Id, 10)
  36. item, found := tokenCache.Get(key)
  37. if found {
  38. if result, ok := item.(*TokenBody); ok {
  39. return result, nil
  40. }
  41. }
  42. b, err := client.RequestTokenData(ctx)
  43. if err != nil {
  44. return nil, err
  45. }
  46. tokenCache.Set(key, b, cache.DefaultExpiration)
  47. return b, nil
  48. }
  49. func (client *TokenClient) RequestTokenData(ctx context.Context) (*TokenBody, error) {
  50. u, _ := url.Parse(client.Datasource.Url)
  51. u.Path = path.Join(u.Path, "token")
  52. req, err := http.NewRequest(http.MethodGet, u.String(), nil)
  53. if err != nil {
  54. client.log.Info("Failed to create request", "error", err)
  55. }
  56. res, err := ctxhttp.Do(ctx, client.HttpClient, req)
  57. if err != nil {
  58. return nil, err
  59. }
  60. body, err := ioutil.ReadAll(res.Body)
  61. defer res.Body.Close()
  62. if err != nil {
  63. return nil, err
  64. }
  65. if res.StatusCode/100 != 2 {
  66. client.log.Info("Request failed", "status", res.Status, "body", string(body))
  67. return nil, fmt.Errorf("Request failed status: %v", res.Status)
  68. }
  69. var result *TokenResponse
  70. err = json.Unmarshal(body, &result)
  71. if err != nil {
  72. client.log.Info("Failed to unmarshal response", "error", err, "status", res.Status, "body", string(body))
  73. return nil, err
  74. }
  75. if !result.Success {
  76. return nil, fmt.Errorf("Request failed for unknown reason.")
  77. }
  78. return &result.Body, nil
  79. }