…
This directory contains sample code for using BearSSL. client_basic.c A sample client code, that connects to a server, performs a SSL handshake, sends a basic HTTP GET request, and dumps the complete answer on stdout. Compile it against BearSSL headers (in the ../inc directory) and library (libbearssl.a). This code will validate the server certificate against two hardcoded trust anchors. server_basic.c A sample SSL server, that serves one client at a time. It reads a single HTTP request (that it does not really parse; it just waits for the two successive line endings that mark the end of the request), and pushes a basic response. Compile it against BearSSL headers (in the ../inc directory) and library (libbearssl.a). Depending on compilation options (see the code), it will use one of several certificate chains, that exercise various combinations of RSA and EC keys and signatures. These certificate chains link to the trust anchors that are hardcoded in client_basic.c, so the sample client and the sample server can be tested against each other. custom_profile.c A sample C source file that shows how to write your own client or server profiles (selections of cipher suites and algorithms). The .pem files are certificate and keys corresponding to the chains and anchors used by the sample client and server. They are provided for reference only; these files are not used by the examples.