You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

publock.go 1.3 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. package rpc
  2. import (
  3. "gitlink.org.cn/cloudream/common/pkgs/logger"
  4. "gitlink.org.cn/cloudream/jcs-pub/client/internal/publock/types"
  5. clirpc "gitlink.org.cn/cloudream/jcs-pub/common/pkgs/rpc/client"
  6. )
  7. func (s *Service) PubLockChannel(ch clirpc.PubLockMessageChan) {
  8. log := logger.WithField("Mod", "RPC")
  9. for {
  10. msg, cerr := ch.Receive()
  11. if cerr != nil {
  12. log.Warnf("receive publock message: %v", cerr.ToError())
  13. break
  14. }
  15. switch msg := msg.(type) {
  16. case *types.AcquireMsg:
  17. go func() {
  18. lkd, err := s.pubLock.Acquire(msg.Request, msg.Option)
  19. if err != nil {
  20. cerr := ch.Send(&types.AcquireResultMsg{
  21. ContextID: msg.ContextID,
  22. Success: false,
  23. Error: err.Error(),
  24. })
  25. if cerr != nil {
  26. log.Warnf("send acquire result message: %v", cerr.ToError())
  27. }
  28. return
  29. }
  30. cerr := ch.Send(&types.AcquireResultMsg{
  31. ContextID: msg.ContextID,
  32. Success: true,
  33. RequestID: lkd.ReqID,
  34. })
  35. if cerr != nil {
  36. log.Warnf("send acquire result message: %v", cerr.ToError())
  37. }
  38. }()
  39. case *types.ReleaseMsg:
  40. s.pubLock.Release(msg.RequestID)
  41. cerr := ch.Send(&types.ReleaseResultMsg{
  42. ContextID: msg.ContextID,
  43. })
  44. if cerr != nil {
  45. log.Warnf("send release result message: %v", cerr.ToError())
  46. }
  47. }
  48. }
  49. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。