grpc.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package notifier
  2. import (
  3. "context"
  4. "time"
  5. "google.golang.org/protobuf/types/known/emptypb"
  6. "github.com/drakkan/sftpgo/v2/sdk/plugin/notifier/proto"
  7. )
  8. const (
  9. rpcTimeout = 20 * time.Second
  10. )
  11. // GRPCClient is an implementation of Notifier interface that talks over RPC.
  12. type GRPCClient struct {
  13. client proto.NotifierClient
  14. }
  15. // NotifyFsEvent implements the Notifier interface
  16. func (c *GRPCClient) NotifyFsEvent(event *FsEvent) error {
  17. ctx, cancel := context.WithTimeout(context.Background(), rpcTimeout)
  18. defer cancel()
  19. _, err := c.client.SendFsEvent(ctx, &proto.FsEvent{
  20. Timestamp: event.Timestamp,
  21. Action: event.Action,
  22. Username: event.Username,
  23. FsPath: event.Path,
  24. FsTargetPath: event.TargetPath,
  25. SshCmd: event.SSHCmd,
  26. FileSize: event.FileSize,
  27. Protocol: event.Protocol,
  28. Ip: event.IP,
  29. Status: int32(event.Status),
  30. VirtualPath: event.VirtualPath,
  31. VirtualTargetPath: event.VirtualTargetPath,
  32. SessionId: event.SessionID,
  33. FsProvider: int32(event.FsProvider),
  34. Bucket: event.Bucket,
  35. Endpoint: event.Endpoint,
  36. })
  37. return err
  38. }
  39. // NotifyProviderEvent implements the Notifier interface
  40. func (c *GRPCClient) NotifyProviderEvent(event *ProviderEvent) error {
  41. ctx, cancel := context.WithTimeout(context.Background(), rpcTimeout)
  42. defer cancel()
  43. _, err := c.client.SendProviderEvent(ctx, &proto.ProviderEvent{
  44. Timestamp: event.Timestamp,
  45. Action: event.Action,
  46. ObjectType: event.ObjectType,
  47. Username: event.Username,
  48. Ip: event.IP,
  49. ObjectName: event.ObjectName,
  50. ObjectData: event.ObjectData,
  51. })
  52. return err
  53. }
  54. // GRPCServer defines the gRPC server that GRPCClient talks to.
  55. type GRPCServer struct {
  56. Impl Notifier
  57. }
  58. // SendFsEvent implements the serve side fs notify method
  59. func (s *GRPCServer) SendFsEvent(ctx context.Context, req *proto.FsEvent) (*emptypb.Empty, error) {
  60. event := &FsEvent{
  61. Action: req.Action,
  62. Username: req.Username,
  63. Path: req.FsPath,
  64. TargetPath: req.FsTargetPath,
  65. VirtualPath: req.VirtualPath,
  66. SSHCmd: req.SshCmd,
  67. FileSize: req.FileSize,
  68. Status: int(req.Status),
  69. Protocol: req.Protocol,
  70. IP: req.Ip,
  71. SessionID: req.SessionId,
  72. Timestamp: req.Timestamp,
  73. FsProvider: int(req.FsProvider),
  74. Bucket: req.Bucket,
  75. Endpoint: req.Endpoint,
  76. }
  77. err := s.Impl.NotifyFsEvent(event)
  78. return &emptypb.Empty{}, err
  79. }
  80. // SendProviderEvent implements the serve side provider event notify method
  81. func (s *GRPCServer) SendProviderEvent(ctx context.Context, req *proto.ProviderEvent) (*emptypb.Empty, error) {
  82. event := &ProviderEvent{
  83. Action: req.Action,
  84. Username: req.Username,
  85. ObjectType: req.ObjectType,
  86. ObjectName: req.ObjectName,
  87. IP: req.Ip,
  88. ObjectData: req.ObjectData,
  89. Timestamp: req.Timestamp,
  90. }
  91. err := s.Impl.NotifyProviderEvent(event)
  92. return &emptypb.Empty{}, err
  93. }