| 41 |
(strlen (hostaddr) > 0 ? inet_addr (hostaddr) : INADDR_ANY); |
(strlen (hostaddr) > 0 ? inet_addr (hostaddr) : INADDR_ANY); |
| 42 |
sin.sin_port = htons (port); |
sin.sin_port = htons (port); |
| 43 |
|
|
| 44 |
if (bind (socket_server, (struct sockaddr *)&sin, sizeof(sin)) < 0) |
if (bind (socket_server, (struct sockaddr *) &sin, sizeof (sin)) < 0) |
| 45 |
{ |
{ |
| 46 |
log_error ("Bind address %s:%u failed\n", |
log_error ("Bind address %s:%u failed\n", |
| 47 |
inet_ntoa(sin.sin_addr), ntohs(sin.sin_port)); |
inet_ntoa (sin.sin_addr), ntohs (sin.sin_port)); |
| 48 |
exit (2); |
exit (2); |
| 49 |
} |
} |
| 50 |
|
|
| 54 |
exit (3); |
exit (3); |
| 55 |
} |
} |
| 56 |
|
|
| 57 |
strcpy(hostaddr_server, inet_ntoa(sin.sin_addr)); |
strcpy (hostaddr_server, inet_ntoa (sin.sin_addr)); |
| 58 |
port_server = ntohs(sin.sin_port); |
port_server = ntohs (sin.sin_port); |
| 59 |
|
|
| 60 |
log_std ("Listening at %s:%d\n", hostaddr_server, port_server); |
log_std ("Listening at %s:%d\n", hostaddr_server, port_server); |
| 61 |
|
|
| 62 |
namelen = sizeof (sin); |
namelen = sizeof (sin); |
| 63 |
while(1) |
while (1) |
| 64 |
{ |
{ |
| 65 |
if ((socket_client = accept (socket_server, (struct sockaddr *) &sin, &namelen)) < 0) |
if ((socket_client = |
| 66 |
{ |
accept (socket_server, (struct sockaddr *) &sin, &namelen)) < 0) |
| 67 |
log_error ("Accept connection error\n"); |
{ |
| 68 |
continue; |
log_error ("Accept connection error\n"); |
| 69 |
} |
continue; |
| 70 |
|
} |
| 71 |
strcpy (hostaddr_client, (const char *)inet_ntoa(sin.sin_addr)); |
|
| 72 |
port_client = ntohs(sin.sin_port); |
strcpy (hostaddr_client, (const char *) inet_ntoa (sin.sin_addr)); |
| 73 |
|
port_client = ntohs (sin.sin_port); |
| 74 |
log_std ("Accept connection from %s:%d\n", hostaddr_client, port_client); |
|
| 75 |
|
log_std ("Accept connection from %s:%d\n", hostaddr_client, |
| 76 |
if (fork_server()<0) |
port_client); |
| 77 |
{ |
|
| 78 |
log_error ("Fork error\n"); |
if (fork_server () < 0) |
| 79 |
} |
{ |
| 80 |
|
log_error ("Fork error\n"); |
| 81 |
if (close(socket_client) == -1) |
} |
| 82 |
{ |
|
| 83 |
log_error("Close client socket failed\n"); |
if (close (socket_client) == -1) |
| 84 |
} |
{ |
| 85 |
|
log_error ("Close client socket failed\n"); |
| 86 |
|
} |
| 87 |
} |
} |
| 88 |
|
|
| 89 |
if (close(socket_server) == -1) |
if (close (socket_server) == -1) |
| 90 |
{ |
{ |
| 91 |
log_error("Close server socket failed\n"); |
log_error ("Close server socket failed\n"); |
| 92 |
} |
} |
| 93 |
|
|
| 94 |
return 0; |
return 0; |