rpc_status.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. #include "flipper.pb.h"
  2. #include "rpc_i.h"
  3. #include "status.pb.h"
  4. void rpc_system_status_ping_process(const PB_Main* msg_request, void* context) {
  5. if(msg_request->has_next) {
  6. rpc_send_and_release_empty(
  7. context, msg_request->command_id, PB_CommandStatus_ERROR_INVALID_PARAMETERS);
  8. return;
  9. }
  10. PB_Main msg_response = PB_Main_init_default;
  11. msg_response.has_next = false;
  12. msg_response.command_status = PB_CommandStatus_OK;
  13. msg_response.command_id = msg_request->command_id;
  14. msg_response.which_content = PB_Main_ping_response_tag;
  15. const PB_Status_PingRequest* request = &msg_request->content.ping_request;
  16. PB_Status_PingResponse* response = &msg_response.content.ping_response;
  17. if(request->data && (request->data->size > 0)) {
  18. response->data = furi_alloc(PB_BYTES_ARRAY_T_ALLOCSIZE(request->data->size));
  19. memcpy(response->data->bytes, request->data->bytes, request->data->size);
  20. response->data->size = request->data->size;
  21. }
  22. rpc_send_and_release(context, &msg_response);
  23. }
  24. void* rpc_system_status_alloc(Rpc* rpc) {
  25. RpcHandler rpc_handler = {
  26. .message_handler = rpc_system_status_ping_process,
  27. .decode_submessage = NULL,
  28. .context = rpc,
  29. };
  30. rpc_add_handler(rpc, PB_Main_ping_request_tag, &rpc_handler);
  31. return NULL;
  32. }