gobus.proto 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. syntax = "proto3";
  2. /*
  3. Файл содержит описание сервиса шины данных с необходимыми
  4. структурами.
  5. */
  6. package parserin;
  7. option go_package = "./netapi";
  8. // GoBus -- сервис шины данных
  9. service GoBus {
  10. // Public -- создаёт запись в открытом разделе хранилище
  11. rpc Public(PublicRequest) returns (DefaultResponse) {}
  12. // SendSync -- синхронный запрос в топик
  13. rpc SendSync(SyncRequest) returns (SyncResponse){}
  14. // Subscribe -- подписка по шаблону
  15. rpc Subscribe(SubscribeRequest) returns (stream SyncResponse){}
  16. // SubscribeBuffer -- подписка по шаблону с буфером на выход
  17. rpc SubscribeBuffer (BuffRequest) returns (stream BuffResponse){}
  18. // Get -- возвращает значения топиков по шаблону
  19. rpc Get(SubscribeRequest) returns (SyncResponse){}
  20. }
  21. // BuffRequest -- запрос на буферизованную подписку
  22. message BuffRequest{
  23. string Sample = 1; // Шаблон топиков на подписку
  24. string ClientName = 2; // Уникальное имя клиента
  25. int32 MsgSumSizeLimit = 3; // Предел суммарного количества сообщений
  26. int32 MsgSaveSecondLimit = 4; // Предел в секундах как долго хранить буфер с момента последнего доступа
  27. }
  28. // BuffResponse -- ответ на буферизованную подписку
  29. message BuffResponse{
  30. bool IsLost = 1; // Признак, что часть данных была потеряна
  31. bytes Msg = 2; // Сообщение из буфера
  32. }
  33. // GetRequest -- ответ на запрос топиков по шаблону
  34. message GetRequest{
  35. repeated bytes Msg = 1; // Список сообщений в ответе
  36. }
  37. // SubscribeRequest -- запрос на подписку топиков по шаблону
  38. message SubscribeRequest{
  39. string Sample = 1; // Шаблон топиков на подписку
  40. string ClientName = 2; // Уникальное имя клиента
  41. }
  42. // SyncRequest -- синхронный запрос в шину данных
  43. message SyncRequest{
  44. int32 Source = 1; // Источник данных (0 -- клиент, другое -- реплика)
  45. string Topic = 2; // Где опубликовать запрос
  46. bytes Msg = 3; // Байтовое представление сообщения
  47. }
  48. // TopicMsg -- сообщение топика (внутри шины данных)
  49. message TopicMsg{
  50. int32 Source = 1; // Источник данных (0 -- клиент, другое -- реплика)
  51. string Topic = 2; // Где опубликовать запрос
  52. bytes Msg = 3; // Байтовое представление сообщения
  53. }
  54. // SyncResponse -- ответ на синхронный запрос
  55. message SyncResponse{
  56. bytes Msg = 1; // Содержимое ответа на синхроныый запрос
  57. }
  58. // PublicRequest -- запрос на публикацию сообщения
  59. message PublicRequest {
  60. int32 Source = 1; // Источник данных (0 -- клиент, другое -- для реплики)
  61. string Topic = 2; // Куда опубликовать сообщение
  62. bytes Msg = 3; // Байтовое представление сообщения
  63. string Uuid = 4; // Уникальная метка сообщения
  64. repeated int32 RepliesList = 5; // Список реплик, на которых сообщение уже опубликовано
  65. }
  66. // DefaultResponse -- возвращаемое значение по умолчанию (ничего не содержит)
  67. message DefaultResponse {
  68. }