tokens.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package sqlstore
  2. import (
  3. "github.com/go-xorm/xorm"
  4. "github.com/torkelo/grafana-pro/pkg/bus"
  5. m "github.com/torkelo/grafana-pro/pkg/models"
  6. "time"
  7. )
  8. func init() {
  9. bus.AddHandler("sql", GetTokens)
  10. bus.AddHandler("sql", AddToken)
  11. bus.AddHandler("sql", UpdateToken)
  12. bus.AddHandler("sql", DeleteToken)
  13. }
  14. func GetTokens(query *m.GetTokensQuery) error {
  15. sess := x.Limit(100, 0).Where("account_id=?", query.AccountId).Asc("name")
  16. query.Result = make([]*m.Token, 0)
  17. return sess.Find(&query.Result)
  18. }
  19. func DeleteToken(cmd *m.DeleteTokenCommand) error {
  20. return inTransaction(func(sess *xorm.Session) error {
  21. var rawSql = "DELETE FROM token WHERE id=? and account_id=?"
  22. _, err := sess.Exec(rawSql, cmd.Id, cmd.AccountId)
  23. return err
  24. })
  25. }
  26. func AddToken(cmd *m.AddTokenCommand) error {
  27. return inTransaction(func(sess *xorm.Session) error {
  28. t := m.Token{
  29. AccountId: cmd.AccountId,
  30. Name: cmd.Name,
  31. Role: cmd.Role,
  32. Token: cmd.Token,
  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 UpdateToken(cmd *m.UpdateTokenCommand) error {
  44. return inTransaction(func(sess *xorm.Session) error {
  45. t := m.Token{
  46. Id: cmd.Id,
  47. AccountId: cmd.AccountId,
  48. Name: cmd.Name,
  49. Role: cmd.Role,
  50. Updated: time.Now(),
  51. }
  52. _, err := sess.Where("id=? and account_id=?", t.Id, t.AccountId).Update(&t)
  53. return err
  54. })
  55. }