server_tcp.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /*
  2. * File: server_tcp.c
  3. * Author: Arthur Brandao
  4. *
  5. * Created on 14 novembre 2018
  6. */
  7. #include <stdlib.h>
  8. #include <stdio.h>
  9. #include <unistd.h>
  10. #include <string.h>
  11. #include <errno.h>
  12. #include "error.h"
  13. #include "server.h"
  14. /* --- Extern --- */
  15. extern int serrno;
  16. extern int errno;
  17. /* --- Fonctions privées --- */
  18. boolean server_bind_tcp(Server this, int port) {
  19. /* Declaration variable */
  20. int tmp;
  21. /* Bind */
  22. this->serv.sin_family = AF_INET;
  23. this->serv.sin_port = htons(port);
  24. this->serv.sin_addr.s_addr = htonl(INADDR_ANY);
  25. tmp = bind(this->socket, (struct sockaddr*) &this->serv, sizeof (struct sockaddr_in));
  26. if (tmp == ERR) {
  27. free(this);
  28. serrno = SEBIND;
  29. addperror("Impossible de bind la socket");
  30. return false;
  31. }
  32. /* Listen */
  33. tmp = listen(this->socket, SOMAXCONN);
  34. if (tmp == ERR) {
  35. free(this);
  36. serrno = SEBIND;
  37. addperror("Impossible d'ecouter");
  38. return false;
  39. }
  40. return true;
  41. }
  42. boolean server_accept_tcp(Server this) {
  43. /* Accept */
  44. this->socket_client = accept(this->socket, NULL, NULL);
  45. if (this->socket_client == ERR) {
  46. serrno = SEACCEPT;
  47. addperror("Impossible d'accepter");
  48. return false;
  49. }
  50. return true;
  51. }
  52. ssize_t server_receive_tcp(Server this, char* buf, size_t size) {
  53. int tmp;
  54. /* Lecture message */
  55. memset(buf, 0, size);
  56. tmp = read(this->socket_client, buf, size);
  57. if (tmp == ERR) {
  58. serrno = SERECEIVE;
  59. addperror("Impossible de récupèrer les données");
  60. return ERR;
  61. }
  62. return tmp;
  63. }
  64. boolean server_send_tcp(Server this, char* msg) {
  65. int tmp;
  66. /* Envoi message */
  67. tmp = write(this->socket_client, msg, strlen(msg) * sizeof (char));
  68. if (tmp == ERR) {
  69. //Si connexion coupé (et SIGPIPE)
  70. if(errno == EPIPE){
  71. serrno = SEABORT;
  72. } else {
  73. serrno = SESEND;
  74. }
  75. addperror("Impossible d'envoyer les données");
  76. return false;
  77. }
  78. return true;
  79. }
  80. /* --- Fonctions publiques --- */
  81. Server server_create_tcp() {
  82. /* Declaration variable */
  83. Server this;
  84. int tmp, option;
  85. /* Creation socket */
  86. this = malloc(sizeof (struct server));
  87. this->socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
  88. if (this->socket == ERR) {
  89. free(this);
  90. serrno = SESOCKET;
  91. addperror("Impossible de créer la socket");
  92. return NULL;
  93. }
  94. this->addr = sizeof (struct sockaddr_in);
  95. memset(&this->serv, 0, sizeof (struct sockaddr_in));
  96. /* Indique la possibilité de réutiliser la socket même si elle est en TIME_WAIT */
  97. option = 1;
  98. tmp = setsockopt(this->socket, SOL_SOCKET, SO_REUSEADDR, &option, sizeof (option));
  99. if (tmp == -1) {
  100. free(this);
  101. serrno = SESOCKET;
  102. addperror("Impossible de modifier les options de la socket");
  103. return NULL;
  104. }
  105. /* Lien fonctions */
  106. this->server_bind = server_bind_tcp;
  107. this->server_receive = server_receive_tcp;
  108. this->server_send = server_send_tcp;
  109. this->server_accept = server_accept_tcp;
  110. /* Type de serveur */
  111. this->type = SERV_TCP;
  112. /* Retour */
  113. return this;
  114. }
  115. boolean server_close_client(Server this) {
  116. /* Que pour TCP */
  117. if (this->type != SERV_TCP) {
  118. serrno = SETYPE;
  119. adderror("Type de la socket incorrect");
  120. return false;
  121. }
  122. /* Ferme */
  123. if (close(this->socket_client) == ERR) {
  124. serrno = SECLOSE;
  125. addperror("Impossible de fermer la socket");
  126. return false;
  127. }
  128. return true;
  129. }