internal.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /*
  2. * Copyright 2016, gRPC Authors All rights reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #ifndef cgrpc_internal_h
  17. #define cgrpc_internal_h
  18. #include <grpc/grpc.h>
  19. #include <grpc/grpc_security.h>
  20. #include <grpc/byte_buffer_reader.h>
  21. typedef struct {
  22. grpc_call *call; // owned
  23. } cgrpc_call;
  24. typedef struct {
  25. grpc_op *ops; // owned
  26. int ops_count;
  27. } cgrpc_operations;
  28. typedef struct {
  29. grpc_channel *channel; // owned
  30. grpc_completion_queue *completion_queue; // owned
  31. } cgrpc_channel;
  32. typedef struct {
  33. grpc_server *server; // owned
  34. grpc_completion_queue *completion_queue; // owned
  35. int port;
  36. } cgrpc_server;
  37. typedef struct {
  38. cgrpc_server *server; // reference
  39. grpc_completion_queue *completion_queue; // owned; handlers have dedicated completion queues
  40. grpc_metadata_array request_metadata_recv;
  41. grpc_call_details call_details;
  42. grpc_call *server_call; // owned
  43. } cgrpc_handler;
  44. typedef grpc_byte_buffer cgrpc_byte_buffer;
  45. typedef grpc_completion_queue cgrpc_completion_queue;
  46. typedef grpc_metadata cgrpc_metadata;
  47. typedef grpc_metadata_array cgrpc_metadata_array;
  48. typedef gpr_mu cgrpc_mutex;
  49. // OPERATIONS
  50. typedef struct {
  51. grpc_op_type op_type;
  52. } cgrpc_observer;
  53. typedef struct {
  54. grpc_op_type op_type;
  55. grpc_metadata_array initial_metadata;
  56. } cgrpc_observer_send_initial_metadata;
  57. typedef struct {
  58. grpc_op_type op_type;
  59. grpc_byte_buffer *request_payload;
  60. } cgrpc_observer_send_message;
  61. typedef struct {
  62. grpc_op_type op_type;
  63. } cgrpc_observer_send_close_from_client;
  64. typedef struct {
  65. grpc_op_type op_type;
  66. grpc_metadata_array trailing_metadata;
  67. grpc_status_code status;
  68. grpc_slice status_details;
  69. } cgrpc_observer_send_status_from_server;
  70. typedef struct {
  71. grpc_op_type op_type;
  72. grpc_metadata_array initial_metadata_recv;
  73. } cgrpc_observer_recv_initial_metadata;
  74. typedef struct {
  75. grpc_op_type op_type;
  76. grpc_byte_buffer *response_payload_recv;
  77. } cgrpc_observer_recv_message;
  78. typedef struct {
  79. grpc_op_type op_type;
  80. grpc_metadata_array trailing_metadata_recv;
  81. grpc_status_code server_status;
  82. grpc_slice server_details;
  83. } cgrpc_observer_recv_status_on_client;
  84. typedef struct {
  85. grpc_op_type op_type;
  86. int was_cancelled;
  87. } cgrpc_observer_recv_close_on_server;
  88. // internal utilities
  89. void *cgrpc_create_tag(void *t);
  90. gpr_timespec cgrpc_deadline_in_seconds_from_now(float seconds);
  91. void cgrpc_observer_apply(cgrpc_observer *observer, grpc_op *op);
  92. #endif /* cgrpc_internal_h */