task.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package mc
  2. import (
  3. "context"
  4. "encoding/json"
  5. "fmt"
  6. "go-common/app/admin/main/aegis/model/common"
  7. gmc "go-common/library/cache/memcache"
  8. "go-common/library/log"
  9. )
  10. // ConsumerOn 登入
  11. func (d *Dao) ConsumerOn(c context.Context, opt *common.BaseOptions) (err error) {
  12. conn := d.mc.Get(c)
  13. defer conn.Close()
  14. key := mcKey(opt)
  15. if err = conn.Set(&gmc.Item{Key: key, Value: []byte{1}, Expiration: d.c.Consumer.OnExp}); err != nil {
  16. log.Error("conn.Set error(%v)", err)
  17. }
  18. return
  19. }
  20. // ConsumerOff .
  21. func (d *Dao) ConsumerOff(c context.Context, opt *common.BaseOptions) (err error) {
  22. conn := d.mc.Get(c)
  23. defer conn.Close()
  24. key := mcKey(opt)
  25. if err = conn.Delete(key); err != nil {
  26. if err != gmc.ErrNotFound {
  27. log.Error("conn.Delete error(%v)", err)
  28. }
  29. err = nil
  30. }
  31. return
  32. }
  33. // IsConsumerOn .
  34. func (d *Dao) IsConsumerOn(c context.Context, opt *common.BaseOptions) (isOn bool, err error) {
  35. conn := d.mc.Get(c)
  36. defer conn.Close()
  37. key := mcKey(opt)
  38. if _, err = conn.Get(key); err != nil {
  39. if err == gmc.ErrNotFound {
  40. err = nil
  41. } else {
  42. log.Error("IsConsumerOn error(%v)", err)
  43. }
  44. return
  45. }
  46. isOn = true
  47. if err = conn.Set(&gmc.Item{Key: key, Value: []byte{1}, Expiration: d.c.Consumer.OnExp}); err != nil {
  48. log.Error("conn.Set error(%v)", err)
  49. }
  50. return
  51. }
  52. func mcKey(opt *common.BaseOptions) string {
  53. return fmt.Sprintf("aegis%d_%d_%d", opt.BusinessID, opt.FlowID, opt.UID)
  54. }
  55. func roleKey(opt *common.BaseOptions) string {
  56. return fmt.Sprintf("aegis_role%d_%d_%d", opt.BusinessID, opt.FlowID, opt.UID)
  57. }
  58. // Role .
  59. type Role struct {
  60. Role int8 `json:"role"`
  61. Uname string `json:"uname"`
  62. }
  63. // GetRole TODO 目前缓存组长组员,以后扩展到存管理员
  64. func (d *Dao) GetRole(c context.Context, opt *common.BaseOptions) (role int8, uname string, err error) {
  65. conn := d.mc.Get(c)
  66. defer conn.Close()
  67. key := roleKey(opt)
  68. var item *gmc.Item
  69. if item, err = conn.Get(key); err != nil {
  70. if err == gmc.ErrNotFound {
  71. log.Info("GetRole opt(%+v) miss", opt)
  72. err = nil
  73. } else {
  74. log.Error("GetRole opt(%+v) error(%v)", opt, err)
  75. }
  76. return
  77. }
  78. rt := new(Role)
  79. if err = json.Unmarshal(item.Value, rt); err != nil {
  80. log.Error("GetRole value(%s) error(%v)", string(item.Value), err)
  81. return
  82. }
  83. role = rt.Role
  84. uname = rt.Uname
  85. return
  86. }
  87. // SetRole .
  88. func (d *Dao) SetRole(c context.Context, opt *common.BaseOptions, role int8) (err error) {
  89. conn := d.mc.Get(c)
  90. defer conn.Close()
  91. key := roleKey(opt)
  92. val := &Role{
  93. Role: role,
  94. Uname: opt.Uname,
  95. }
  96. var roleb []byte
  97. if roleb, err = json.Marshal(val); err != nil {
  98. log.Error("SetRole error(%v)", err)
  99. return
  100. }
  101. if err = conn.Set(&gmc.Item{Key: key, Value: roleb, Expiration: d.c.Consumer.RoleExp}); err != nil {
  102. log.Error("conn.Set error(%v)", err)
  103. }
  104. return
  105. }
  106. //DelRole .
  107. func (d *Dao) DelRole(c context.Context, bizid, flowid int64, uids []int64) (err error) {
  108. conn := d.mc.Get(c)
  109. defer conn.Close()
  110. for _, uid := range uids {
  111. key := roleKey(&common.BaseOptions{
  112. BusinessID: bizid,
  113. FlowID: flowid,
  114. UID: uid})
  115. conn.Delete(key)
  116. }
  117. return
  118. }