mirror of
https://github.com/puma/puma.git
synced 2022-11-09 13:48:40 -05:00
37a3bc66ff
Contexts are currently created for every accepted ssl client. That isn't needed, but more importantly, Contexts read two files. For a busy server, this results in slow clients. Update to create the Context in MinSSL::Server.new, and pass it to MinSSL::Engine.server. Only affects MRI builds.
42 lines
1.3 KiB
Ruby
42 lines
1.3 KiB
Ruby
require 'mkmf'
|
|
|
|
dir_config("puma_http11")
|
|
|
|
if $mingw && RUBY_VERSION >= '2.4'
|
|
append_cflags '-fstack-protector-strong -D_FORTIFY_SOURCE=2'
|
|
append_ldflags '-fstack-protector-strong -l:libssp.a'
|
|
have_library 'ssp'
|
|
end
|
|
|
|
unless ENV["DISABLE_SSL"]
|
|
dir_config("openssl")
|
|
|
|
if %w'crypto libeay32'.find {|crypto| have_library(crypto, 'BIO_read')} and
|
|
%w'ssl ssleay32'.find {|ssl| have_library(ssl, 'SSL_CTX_new')}
|
|
|
|
have_header "openssl/bio.h"
|
|
|
|
# below is yes for 1.0.2 & later
|
|
have_func "DTLS_method" , "openssl/ssl.h"
|
|
|
|
# below are yes for 1.1.0 & later
|
|
have_func "TLS_server_method" , "openssl/ssl.h"
|
|
have_func "SSL_CTX_set_min_proto_version(NULL, 0)", "openssl/ssl.h"
|
|
|
|
have_func "X509_STORE_up_ref"
|
|
have_func("SSL_CTX_set_ecdh_auto(NULL, 0)", "openssl/ssl.h")
|
|
end
|
|
end
|
|
|
|
if ENV["MAKE_WARNINGS_INTO_ERRORS"]
|
|
# Make all warnings into errors
|
|
# Except `implicit-fallthrough` since most failures comes from ragel state machine generated code
|
|
if respond_to? :append_cflags
|
|
append_cflags config_string 'WERRORFLAG'
|
|
append_cflags '-Wno-implicit-fallthrough'
|
|
else
|
|
$CFLAGS += ' ' << (config_string 'WERRORFLAG') << ' -Wno-implicit-fallthrough'
|
|
end
|
|
end
|
|
|
|
create_makefile("puma/puma_http11")
|