openssl/demos/sslecho
slontis 09ff84bd27 Fixup demo exit status magic numbers
The demo code is quite often block copied for new demos,
so this PR changes demos to use EXIT_SUCCESS & EXIT_FAILURE
instead of using 0 and 1.
Internal functions use the normal notation of 0 = error, 1 = success,
but the value returned by main() must use EXIT_SUCCESS and EXIT_FAILURE.

Reviewed-by: Paul Dale <pauli@openssl.org>
Reviewed-by: Tomas Mraz <tomas@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/20545)
2023-04-24 14:39:19 +02:00
..
A-SSL-Docs.txt Added Simple SSL Echo Client/Server to demos. 2022-04-12 15:12:57 +01:00
cert.pem Added Simple SSL Echo Client/Server to demos. 2022-04-12 15:12:57 +01:00
key.pem Added Simple SSL Echo Client/Server to demos. 2022-04-12 15:12:57 +01:00
main.c Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
makefile Added Simple SSL Echo Client/Server to demos. 2022-04-12 15:12:57 +01:00
README.md Added Simple SSL Echo Client/Server to demos. 2022-04-12 15:12:57 +01:00

OpenSSL Simple Echo Client/Server

This project implements a simple echo client/server.

It is a console application, with command line parameters determining the mode of operation (client or server). Start it with no parameters to see usage.

The server code was adapted from the Simple TLS Server on the OpenSSL Wiki. The server code was modified to perform the echo function, and client code was added to open a connection with the server and to send keyboard input to the server.

The new client code illustrates that:

  • Connection to the SSL server starts as a standard TCP 'connect'.
  • Once connected with TCP, the client 'upgrades' to SSL using SSL_connect().
  • When the SSL connection completes, data is sent and received using SSL_write() and SSL_read().
  • Pretty simple.

The cert.pem and key.pem files included are self signed certificates with the "Common Name" of 'localhost'.

Best to create the 'pem' files using an actual hostname.