server.c 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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. #include "internal.h"
  17. #include "cgrpc.h"
  18. #include <assert.h>
  19. #include <stdlib.h>
  20. #include <stdio.h>
  21. #include <string.h>
  22. cgrpc_server *cgrpc_server_create(const char *address) {
  23. cgrpc_server *server = (cgrpc_server *) malloc(sizeof (cgrpc_server));
  24. server->server = grpc_server_create(NULL, NULL);
  25. server->completion_queue = grpc_completion_queue_create_for_next(NULL);
  26. grpc_server_register_completion_queue(server->server, server->completion_queue, NULL);
  27. // prepare the server to listen
  28. server->port = grpc_server_add_insecure_http2_port(server->server, address);
  29. return server;
  30. }
  31. cgrpc_server *cgrpc_server_create_secure(const char *address,
  32. const char *private_key,
  33. const char *cert_chain,
  34. const char *root_certs,
  35. int force_client_auth) {
  36. cgrpc_server *server = (cgrpc_server *) malloc(sizeof (cgrpc_server));
  37. server->server = grpc_server_create(NULL, NULL);
  38. server->completion_queue = grpc_completion_queue_create_for_next(NULL);
  39. grpc_server_register_completion_queue(server->server, server->completion_queue, NULL);
  40. grpc_ssl_pem_key_cert_pair server_credentials;
  41. server_credentials.private_key = private_key;
  42. server_credentials.cert_chain = cert_chain;
  43. grpc_server_credentials *credentials = grpc_ssl_server_credentials_create
  44. (root_certs,
  45. &server_credentials,
  46. 1,
  47. force_client_auth,
  48. NULL);
  49. // prepare the server to listen
  50. server->port = grpc_server_add_secure_http2_port(server->server, address, credentials);
  51. return server;
  52. }
  53. void cgrpc_server_stop(cgrpc_server *server) {
  54. grpc_server_shutdown_and_notify(server->server,
  55. server->completion_queue,
  56. cgrpc_create_tag((void *) 0));
  57. }
  58. void cgrpc_server_destroy(cgrpc_server *server) {
  59. grpc_server_shutdown_and_notify(server->server,
  60. server->completion_queue,
  61. cgrpc_create_tag((void *) 1000));
  62. while (1) {
  63. double timeout = 5;
  64. gpr_timespec deadline = cgrpc_deadline_in_seconds_from_now(timeout);
  65. grpc_event completion_event = grpc_completion_queue_next(server->completion_queue, deadline, NULL);
  66. if (completion_event.type == GRPC_OP_COMPLETE) {
  67. break;
  68. }
  69. }
  70. grpc_server_destroy(server->server);
  71. server->server = NULL;
  72. }
  73. void cgrpc_server_start(cgrpc_server *server) {
  74. grpc_server_start(server->server);
  75. }
  76. cgrpc_completion_queue *cgrpc_server_get_completion_queue(cgrpc_server *s) {
  77. return s->completion_queue;
  78. }