fixing litle issues.

master
Steffen Pohle 4 weeks ago
parent 0c3b402c17
commit c59be1fc3c

1
.gitignore vendored

@ -9,6 +9,7 @@ test-tcpserver
test-udp test-udp
.depend .depend
.Makefile.rules .Makefile.rules
Makefile.rules
# ---> Eclipse # ---> Eclipse
.metadata .metadata

@ -23,6 +23,7 @@ help:
echo "set up configuration" echo "set up configuration"
echo " make configwindows to generate the windows build" echo " make configwindows to generate the windows build"
echo " make configlinux to generate the linix build" echo " make configlinux to generate the linix build"
echo " make keygen create self signed certificate"
configlinux: clean configlinux: clean
cp -f Makefile.rules.linux Makefile.rules cp -f Makefile.rules.linux Makefile.rules

@ -100,6 +100,9 @@ int SSLSocket::NewClientCTX() {
int SSLSocket::SetCertificat(string certf, string keyf) { int SSLSocket::SetCertificat(string certf, string keyf) {
certfile = certf; certfile = certf;
keyfile = keyf; keyfile = keyf;
if (access (certf.c_str(), R_OK) != 0) return 0;
if (access (keyf.c_str(), R_OK) != 0) return 0;
return 1; return 1;
}; };

@ -21,20 +21,23 @@ void server () {
// //
// start the server // start the server
printf ("server: starting server\n");
if (tcpserver.Listen(DEFAULT_PORT) != 1) { if (tcpserver.Listen(DEFAULT_PORT) != 1) {
printf ("cloud not start the tcp server\n"); printf ("server: cloud not start the tcp server\n");
exit (1); exit (1);
} }
// //
// init SSL // init SSL
if (ssl.SetCertificat("cert.pem", "privkey.pem") != 1) { printf ("server: setting up certificates\n");
printf ("SetCertificat error:%s\n", strerror(errno)); if (ssl.SetCertificat("cert.pem", "privkey.pem") != 0) {
printf ("server: SetCertificat error:%s\n", strerror(errno));
exit (1); exit (1);
} }
// //
// check for connections // check for connections
printf ("server: wait for connection\n");
for (;time_now - time_start < 10; time_now = time(NULL)) { for (;time_now - time_start < 10; time_now = time(NULL)) {
connection = tcpserver.Accept(); connection = tcpserver.Accept();
if (connection != NULL) { if (connection != NULL) {
@ -42,45 +45,32 @@ void server () {
// someone connected - create new process // someone connected - create new process
// take care of parallel processing (parent is always the server) // take care of parallel processing (parent is always the server)
// //
printf (" server: got a connection forking new process\n"); printf ("server: someone connected.\n");
pid = fork(); printf ("server: accept ssl connection\n");
if (pid == 0) { if (ssl.Accept(connection->GetSocket(), 0) != 1) {
// printf ("server: could not establish SSL connection:%s\n", strerror(errno));
// child process - always close server since it will handeled
// by the parent process. Make sure the client exits and never
// returns.
tcpserver.Close();
if (ssl.Accept(connection->GetSocket(), 0) != 1) {
printf ("could not establish SSL connection:%s\n", strerror(errno));
exit (1);
}
i = ssl.Read(buffer, NET_BUFFERSIZE);
if (i > 0) {
int c;
printf (" server: got: '%s'\n", buffer);
for (c = 0; c < i; c++) buffer[c] = toupper(buffer[c]);
ssl.Write(buffer, i);
}
//
// just delete the class object, it will close the client connection
ssl.Close();
delete (connection);
//
// exit child process
exit (1); exit (1);
} }
i = ssl.Read(buffer, NET_BUFFERSIZE);
if (i > 0) {
int c;
printf ("server: got: '%s'\n", buffer);
for (c = 0; c < i; c++) buffer[c] = toupper(buffer[c]);
ssl.Write(buffer, i);
}
else { else {
// printf ("server: nothing to read. close connection.\n");
// parent process - just close the client connection
// it will be handeled by the child process.
delete (connection);
} }
//
// just delete the class object, it will close the client connection
ssl.Close();
delete (connection);
connection = NULL;
} }
usleep (25000); usleep (250000);
} }
printf ("server: terminating server process.\n");
}; };
@ -94,34 +84,45 @@ void client () {
// //
// connect to the server // connect to the server
printf ("client: connect to localhost\n");
if (tcpclient.Connect ("localhost", DEFAULT_PORT) != 1) { if (tcpclient.Connect ("localhost", DEFAULT_PORT) != 1) {
printf ("cloud not connect to server\n"); printf ("client: cloud not connect to server\n");
exit (1); exit (1);
} }
printf ("client: connected\n");
res = ssl.Connect(tcpclient.GetSocket(), 100); printf ("client: start SSL connection\n");
if (res == -1) { if (ssl.Connect(tcpclient.GetSocket(), 100) != 1) {
printf ("could not establish SSL connection:errno:%s sslerror:%s\n", strerror(errno), ssl.GetSSLErrorText(ssl.sslerror).c_str()); printf ("client: could not establish SSL connection:errno:%s sslerror:%s\n", strerror(errno), ssl.GetSSLErrorText(ssl.sslerror).c_str());
exit (1); exit (1);
} }
printf ("client: ssl connected.\n");
// //
// send some data // send some data
snprintf (buffer, NET_BUFFERSIZE, "nur ein kleiner Test."); snprintf (buffer, NET_BUFFERSIZE, "nur ein kleiner Test.");
printf ("client:send '%s' to the server.\n", buffer); printf ("client: send '%s' to the server.\n", buffer);
if (ssl.Write(buffer, strlen (buffer)) != strlen (buffer)) { if (ssl.Write(buffer, strlen (buffer)) != strlen (buffer)) {
printf ("could not send all data. errno:%s sslerror:%s\n", strerror(errno), ssl.GetSSLErrorText(ssl.sslerror).c_str()); printf ("client: could not send all data. errno:%s sslerror:%s\n", strerror(errno), ssl.GetSSLErrorText(ssl.sslerror).c_str());
exit (1); exit (1);
} }
// //
// read some data (wait maximum 10x1000ms) // read some data (wait maximum 10x1000ms)
for (i = 10; i > 0; i--) for (i = 10; i > 0; i--) {
if (ssl.Read(buffer, NET_BUFFERSIZE) > 0) { printf ("client: try to read\n");
printf ("client:got '%s' from server.\n", buffer); if ((res = ssl.Read(buffer, NET_BUFFERSIZE)) > 0) {
printf ("client: got '%s' from server.\n", buffer);
break; break;
} }
else if (res < 0) {
printf ("client: error on read: Error: %s\n", strerror(errno));
}
else {
printf ("client: no data\n");
}
}
// //
// close connection // close connection

Loading…
Cancel
Save