openssl/demos
Matt Caswell 02e36ed352 Update demos/tutorial to distinguish between stream and connection errors
We can use SSL_get_stream_read_state() to distinguish these cases.

Reviewed-by: Tomas Mraz <tomas@openssl.org>
Reviewed-by: Hugo Landau <hlandau@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/21765)
2023-08-25 11:42:51 +01:00
..
bio Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
certs
cipher Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
cms Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
digest Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
encode Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
encrypt demo: Fix makefile target 2023-03-15 13:58:01 +11:00
guide Update demos/tutorial to distinguish between stream and connection errors 2023-08-25 11:42:51 +01:00
kdf Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
keyexch Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
mac Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
pkcs12 Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
pkey Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
signature Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
smime Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
sslecho Fixup demo exit status magic numbers 2023-04-24 14:39:19 +02:00
README.txt

OpenSSL Demonstration Applications

This folder contains source code that demonstrates the proper use of the OpenSSL
library API.

bio:                   Demonstration of a simple TLS client and server

certs:                 Demonstration of creating certs, using OCSP

cipher:
aesgcm.c               Demonstration of symmetric cipher GCM mode encrypt/decrypt
aesccm.c               Demonstration of symmetric cipher CCM mode encrypt/decrypt
ariacbc.c              Demonstration of symmetric cipher CBC mode encrypt/decrypt

cms:

digest:
EVP_MD_demo.c          Compute a digest from multiple buffers
EVP_MD_stdin.c         Compute a digest with data read from stdin
EVP_MD_xof.c           Compute a digest using the SHAKE256 XOF
EVP_f_md.c             Compute a digest using BIO and EVP_f_md

encrypt:
rsa_encrypt.c          Encrypt and decrypt data using an RSA keypair.

encode:
rsa_encode.c           Encode and decode PEM-encoded RSA keys

kdf:
hkdf.c                 Demonstration of HMAC based key derivation
pbkdf2.c               Demonstration of PBKDF2 password based key derivation
scrypt.c               Demonstration of SCRYPT password based key derivation

mac:
gmac.c                 Demonstration of GMAC message authentication
poly1305.c             Demonstration of Poly1305-AES message authentication
siphash.c              Demonstration of SIPHASH message authentication

pkey:
EVP_PKEY_EC_keygen.c           Generate an EC key.
EVP_PKEY_RSA_keygen.c          Generate an RSA key.
EVP_PKEY_DSA_keygen.c          Generate a DSA key.
EVP_PKEY_DSA_paramgen.c        Generate a DSA param key.
EVP_PKEY_DSA_paramvalidate.c   Validate a DSA param key.
EVP_PKEY_DSA_paramfromdata.c   Load a DSA param key using raw data.

smime:

pkcs12:
pkread.c               Print out a description of a PKCS12 file.
pkwrite.c              Add a password to an existing PKCS12 file.

signature:
EVP_Signature_demo.c   Compute and verify a signature from multiple buffers
rsa_pss_direct.c       Compute and verify an RSA-PSS signature from a hash
rsa_pss_hash.c         Compute and verify an RSA-PSS signature over a buffer

sslecho:
main.c                 Simple SSL echo client/server.