gobus.proto 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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 (SubscribeRequest) returns (stream SyncResponse){}
  18. // Get -- возвращает значения топиков по шаблону
  19. rpc Get(SubscribeRequest) returns (GetRequest){}
  20. }
  21. // GetRequest -- ответ на запрос топиков по шаблону
  22. message GetRequest{
  23. repeated bytes Msg = 1; // Список сообщений в ответе
  24. }
  25. // SubscribeRequest -- запрос на подписку топиков по шаблону
  26. message SubscribeRequest{
  27. string Sample =1; // Шаблон топика на подписку
  28. }
  29. // SyncRequest -- синхронный запрос в шину данных
  30. message SyncRequest{
  31. int32 Source = 1; // Источник данных (0 -- клиент, другое -- реплика)
  32. string Topic = 2; // Где опубликовать запрос
  33. bytes Msg = 3; // Байтовое представление сообщения
  34. }
  35. // SyncResponse -- ответ на синхронный запрос
  36. message SyncResponse{
  37. bytes Msg = 1; // Содержимое ответа на синхроныый запрос
  38. }
  39. // PublicRequest -- запрос на публикацию сообщения
  40. message PublicRequest {
  41. int32 Source = 1; // Источник данных (0 -- клиент, другое -- реплика)
  42. string Topic = 2; // Куда опубликовать сообщение
  43. bytes Msg = 3; // Байтовое представление сообщения
  44. }
  45. // DefaultResponse -- возвращаемое значение по умолчанию (ничего не содержит)
  46. message DefaultResponse {
  47. }