Commit Briefs

8af9da9843 Omar Polo

fix the build with some yacc implementations


611dffe816 Omar Polo

remove regress/sha

we can use cmp to tell if two files are different, which also has the benefit of being available everywhere and reporting the byte offset of the first difference. Reduces the test dependencies on some systems.


1b9031f1fc Omar Polo

work around missing SOCK_NONBLOCK/CLOEXEC on macos


94893746ae Omar Polo

use the default prefork in tests


2cef5cf42a Omar Polo

load_ca: get a buffer instead of a fd

We dup(1) the ca fd and send it to various processes, so they fail loading it. Instead, use load_file to get a buffer with the file content and pass that to load_ca which then loads via BIO.


89cfcb4569 Omar Polo

simplify config_send_kp: use config_send_file


5d160453f2 Omar Polo

remove proc_ispeer()

unused, and was dropped by other copies of proc.c; reduces the diff with httpd' proc.c.


ba290ef3af Omar Polo

disable the privsep crypto engine on !OpenBSD

it fails bandly at runtime on various linux distros and on freebsd. Until a fix is found, disable it so I can move forward.


237095fd9a Omar Polo

remove has_siginfo

and wrap siginfo behind #ifdef SIGINFO. avoids some warnings in !BSD.


1ef09e6313 Omar Polo

add -Wpointer-sign to the mix

It's not present in -W -Wall -Wextra on OpenBSD but it is enabled on other systems.


b8d68fc8e4 Omar Polo

fixes for -Wpointer-sign


d1739e3f03 Omar Polo

cast uint64_t to unsigned long long



86693a33ab Omar Polo

add a privsep crypto engine

Incorporate the OpenSMTPD' privsep crypto engine. The idea behind it is to never load the certificate' private keys in a networked process, instead they are loaded in a separate process (the `crypto' one) which signs payloads on the behalf of the server processes. This way, we greatly reduce the risk of leaking the certificate' private key should the server process be compromised. This currently compiles only on LibreSSL (portable fix is in the way).


f81a97b356 Omar Polo

drop useless debug statement