apikey.go 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package sqlstore
  2. import (
  3. "time"
  4. "github.com/grafana/grafana/pkg/bus"
  5. m "github.com/grafana/grafana/pkg/models"
  6. )
  7. func init() {
  8. bus.AddHandler("sql", GetApiKeys)
  9. bus.AddHandler("sql", GetApiKeyById)
  10. bus.AddHandler("sql", GetApiKeyByName)
  11. bus.AddHandler("sql", DeleteApiKey)
  12. bus.AddHandler("sql", AddApiKey)
  13. }
  14. func GetApiKeys(query *m.GetApiKeysQuery) error {
  15. sess := x.Limit(100, 0).Where("org_id=?", query.OrgId).Asc("name")
  16. query.Result = make([]*m.ApiKey, 0)
  17. return sess.Find(&query.Result)
  18. }
  19. func DeleteApiKey(cmd *m.DeleteApiKeyCommand) error {
  20. return inTransaction(func(sess *DBSession) error {
  21. var rawSql = "DELETE FROM api_key WHERE id=? and org_id=?"
  22. _, err := sess.Exec(rawSql, cmd.Id, cmd.OrgId)
  23. return err
  24. })
  25. }
  26. func AddApiKey(cmd *m.AddApiKeyCommand) error {
  27. return inTransaction(func(sess *DBSession) error {
  28. t := m.ApiKey{
  29. OrgId: cmd.OrgId,
  30. Name: cmd.Name,
  31. Role: cmd.Role,
  32. Key: cmd.Key,
  33. Created: time.Now(),
  34. Updated: time.Now(),
  35. }
  36. if _, err := sess.Insert(&t); err != nil {
  37. return err
  38. }
  39. cmd.Result = &t
  40. return nil
  41. })
  42. }
  43. func GetApiKeyById(query *m.GetApiKeyByIdQuery) error {
  44. var apikey m.ApiKey
  45. has, err := x.Id(query.ApiKeyId).Get(&apikey)
  46. if err != nil {
  47. return err
  48. } else if !has {
  49. return m.ErrInvalidApiKey
  50. }
  51. query.Result = &apikey
  52. return nil
  53. }
  54. func GetApiKeyByName(query *m.GetApiKeyByNameQuery) error {
  55. var apikey m.ApiKey
  56. has, err := x.Where("org_id=? AND name=?", query.OrgId, query.KeyName).Get(&apikey)
  57. if err != nil {
  58. return err
  59. } else if !has {
  60. return m.ErrInvalidApiKey
  61. }
  62. query.Result = &apikey
  63. return nil
  64. }