|
|
@ -4,74 +4,85 @@ |
|
|
|
Socket::Socket(string def) { |
|
|
|
size_t split = def.rfind(':'); |
|
|
|
|
|
|
|
string tmp = def.substr(0, split - 1); |
|
|
|
_ip = isInt(tmp) ? "localhost" : tmp; |
|
|
|
string tmp = def.substr(0, split); |
|
|
|
_ip = isInt(tmp) || tmp == "localhost" ? "127.0.0.1" : tmp; |
|
|
|
tmp = def.substr(split + 1, def.length() - split - 1).c_str(); |
|
|
|
_port = !isInt(tmp) ? 80 : std::atoi(tmp.c_str()); |
|
|
|
|
|
|
|
_max_clients = 30; |
|
|
|
for (int i = 0; i < _max_clients; i++) |
|
|
|
_client_socket[i] = 0; |
|
|
|
} |
|
|
|
Socket::~Socket() { |
|
|
|
close(_master_socket); |
|
|
|
cout << "Socket destroyed!\n"; |
|
|
|
} |
|
|
|
|
|
|
|
int Socket::launch() { |
|
|
|
int opt = 1; |
|
|
|
_master_socket = socket(AF_INET, SOCK_STREAM, 0); |
|
|
|
if (_master_socket == 0) { |
|
|
|
cout << "Socket creation: " << strerror(errno) << "\n"; |
|
|
|
exit(EXIT_FAILURE); |
|
|
|
return (EXIT_FAILURE); |
|
|
|
} |
|
|
|
int opt_ret = setsockopt(_master_socket, SOL_SOCKET, SO_REUSEADDR, |
|
|
|
(char *)&opt, sizeof(opt)); |
|
|
|
if (opt_ret < 0) { |
|
|
|
cout << "Sockopt: " << strerror(errno) << "\n"; |
|
|
|
exit(EXIT_FAILURE); |
|
|
|
return (EXIT_FAILURE); |
|
|
|
} |
|
|
|
|
|
|
|
_address.sin_family = AF_INET; |
|
|
|
_address.sin_addr.s_addr = INADDR_ANY; |
|
|
|
_address.sin_addr.s_addr = inet_addr(_ip.c_str()); |
|
|
|
_address.sin_port = htons(_port); |
|
|
|
|
|
|
|
if (bind(_master_socket, (struct sockaddr *)&_address, sizeof(_address)) < |
|
|
|
0) { |
|
|
|
cout << "Bind: " << strerror(errno) << "\n"; |
|
|
|
cout << "Socket destroyed!\n"; |
|
|
|
return; |
|
|
|
exit(EXIT_FAILURE); |
|
|
|
return (EXIT_FAILURE); |
|
|
|
} |
|
|
|
cout << "Listener on port " << _port << "\n"; |
|
|
|
cout << "Listener " << _ip << " on port " << _port << "\n"; |
|
|
|
|
|
|
|
if (listen(_master_socket, 3) < 0) { |
|
|
|
cout << "Listen: " << strerror(errno) << "\n"; |
|
|
|
exit(EXIT_FAILURE); |
|
|
|
return (EXIT_FAILURE); |
|
|
|
} |
|
|
|
for (int i = 0; i < _max_clients; i++) |
|
|
|
_client_socket[i] = 0; |
|
|
|
cout << "Socket::_master_socket: " << _master_socket << "\n"; |
|
|
|
if (_master_socket < _min_sd) |
|
|
|
_min_sd = _master_socket; |
|
|
|
_amount++; |
|
|
|
return (EXIT_SUCCESS); |
|
|
|
} |
|
|
|
void Socket::check() { |
|
|
|
int new_socket, activity, i, valread, sd; |
|
|
|
char buffer[1024]; |
|
|
|
char r404[72] = |
|
|
|
"HTTP/1.1 200 OK\nContent-Type: text/plain\nContent-Length: 4\n\n404!"; |
|
|
|
|
|
|
|
fd_set readfds; |
|
|
|
int max_sd = _master_socket; |
|
|
|
void Socket::check() { |
|
|
|
int sd; |
|
|
|
|
|
|
|
int addrlen = sizeof(_address); |
|
|
|
FD_ZERO(&readfds); |
|
|
|
FD_SET(_master_socket, &readfds); |
|
|
|
FD_SET(_master_socket, &_readfds); |
|
|
|
cout << "sd_set " << _master_socket << "\n"; |
|
|
|
|
|
|
|
for (i = 0; i < _max_clients; i++) { |
|
|
|
for (int i = 0; i < _max_clients; i++) { |
|
|
|
sd = _client_socket[i]; |
|
|
|
//cout << "id: " << i << " -> sd: " << sd << "\n";
|
|
|
|
if (sd > 0) |
|
|
|
FD_SET(sd, &readfds); |
|
|
|
if (sd > max_sd) |
|
|
|
max_sd = sd; |
|
|
|
{ |
|
|
|
FD_SET(sd, &_readfds); |
|
|
|
cout << "fd_set " << sd << "\n"; |
|
|
|
} |
|
|
|
if (sd > _max_sd) |
|
|
|
_max_sd = sd; |
|
|
|
} |
|
|
|
cout << "Socket checked\n"; |
|
|
|
} |
|
|
|
|
|
|
|
activity = select(max_sd + 1, &readfds, NULL, NULL, NULL); |
|
|
|
|
|
|
|
if ((activity < 0) && (errno != EINTR)) |
|
|
|
cout << "Select: " << strerror(errno) << "\n"; |
|
|
|
|
|
|
|
if (FD_ISSET(_master_socket, &readfds)) { |
|
|
|
new_socket = accept(_master_socket, (struct sockaddr *)&_address, |
|
|
|
void Socket::answer() { |
|
|
|
int i, sd, valread; |
|
|
|
int addrlen = sizeof(_address); |
|
|
|
char buffer[1024]; |
|
|
|
char r404[72] = |
|
|
|
"HTTP/1.1 200 OK\nContent-Type: text/plain\nContent-Length: 4\n\n404!"; |
|
|
|
if (FD_ISSET(_master_socket, &_readfds)) { |
|
|
|
int new_socket = accept(_master_socket, (struct sockaddr *)&_address, |
|
|
|
(socklen_t *)&addrlen); |
|
|
|
if (new_socket < 0) { |
|
|
|
cout << "Accept: " << strerror(errno) << "\n"; |
|
|
@ -94,7 +105,7 @@ void Socket::check() { |
|
|
|
cout << "Socket: " << _ip << ":" << _port << "\n"; |
|
|
|
for (i = 0; i < _max_clients; i++) { |
|
|
|
sd = _client_socket[i]; |
|
|
|
if (FD_ISSET(sd, &readfds)) { |
|
|
|
if (FD_ISSET(sd, &_readfds)) { |
|
|
|
cout << "Client " << i << ": set\n"; |
|
|
|
valread = read(sd, buffer, 1024); |
|
|
|
if (valread == 0) { |
|
|
@ -114,4 +125,5 @@ void Socket::check() { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
cout << "Socket answered\n"; |
|
|
|
} |
|
|
|