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

80 lines
2.2 KiB

  1. syntax = "proto3";
  2. package messaging_pb;
  3. import "mq_schema.proto";
  4. option go_package = "github.com/seaweedfs/seaweedfs/weed/pb/mq_agent_pb";
  5. option java_package = "seaweedfs.mq_agent";
  6. option java_outer_classname = "MessageQueueAgentProto";
  7. //////////////////////////////////////////////////
  8. service SeaweedMessagingAgent {
  9. // Publishing
  10. rpc StartPublishSession (StartPublishSessionRequest) returns (StartPublishSessionResponse) {
  11. }
  12. rpc ClosePublishSession (ClosePublishSessionRequest) returns (ClosePublishSessionResponse) {
  13. }
  14. rpc PublishRecord (stream PublishRecordRequest) returns (stream PublishRecordResponse) {
  15. }
  16. // Subscribing
  17. rpc SubscribeRecord (stream SubscribeRecordRequest) returns (stream SubscribeRecordResponse) {
  18. }
  19. }
  20. //////////////////////////////////////////////////
  21. message StartPublishSessionRequest {
  22. schema_pb.Topic topic = 1;
  23. int32 partition_count = 2;
  24. schema_pb.RecordType record_type = 3;
  25. string publisher_name = 4;
  26. }
  27. message StartPublishSessionResponse {
  28. string error = 1;
  29. int64 session_id = 2;
  30. }
  31. message ClosePublishSessionRequest {
  32. int64 session_id = 1;
  33. }
  34. message ClosePublishSessionResponse {
  35. string error = 1;
  36. }
  37. //////////////////////////////////////////////////
  38. message PublishRecordRequest {
  39. int64 session_id = 1; // session_id is required for the first record
  40. bytes key = 2;
  41. schema_pb.RecordValue value = 3;
  42. }
  43. message PublishRecordResponse {
  44. int64 ack_sequence = 1;
  45. string error = 2;
  46. }
  47. //////////////////////////////////////////////////
  48. message SubscribeRecordRequest {
  49. message InitSubscribeRecordRequest {
  50. string consumer_group = 1;
  51. string consumer_group_instance_id = 2;
  52. schema_pb.Topic topic = 4;
  53. repeated schema_pb.PartitionOffset partition_offsets = 5;
  54. string filter = 6;
  55. int32 max_subscribed_partitions = 8;
  56. int32 sliding_window_size = 9;
  57. }
  58. InitSubscribeRecordRequest init = 1;
  59. int64 ack_sequence = 2;
  60. bytes ack_key = 3;
  61. }
  62. message SubscribeRecordResponse {
  63. bytes key = 2;
  64. schema_pb.RecordValue value = 3;
  65. int64 ts_ns = 4;
  66. string error = 5;
  67. bool is_end_of_stream = 6;
  68. bool is_end_of_topic = 7;
  69. }
  70. //////////////////////////////////////////////////