This repository has been archived by the owner on May 3, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 370
/
Copy pathserpico.rb
56 lines (47 loc) · 1.88 KB
/
serpico.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
require 'bundler/setup'
require 'webrick/https'
require 'openssl'
require 'json'
require './server.rb'
config_options = JSON.parse(File.read('./config.json'))
## SSL Settings
ssl_certificate = config_options['ssl_certificate']
ssl_key = config_options['ssl_key']
use_ssl = config_options['use_ssl']
port = config_options['port']
bind_address = config_options['bind_address']
server_options = {
Port: port,
Host: bind_address
}
if config_options['show_exceptions'].to_s.casecmp('false').zero? || !(config_options['show_exceptions'])
puts "|+| [#{DateTime.now.strftime('%d/%m/%Y %H:%M')}] Sending Webrick logging to /dev/null.."
server_options[:Logger] = WEBrick::Log.new(File.open(File::NULL, 'w'))
server_options[:AccessLog] = []
end
if use_ssl
certificate_content = File.open(ssl_certificate).read
key_content = File.open(ssl_key).read
server_options[:SSLEnable] = true
server_options[:SSLCertificate] = OpenSSL::X509::Certificate.new(certificate_content)
server_options[:SSLPrivateKey] = OpenSSL::PKey::RSA.new(key_content)
server_options[:SSLVerifyClient] = OpenSSL::SSL::VERIFY_NONE
no_ssl3 = OpenSSL::SSL::OP_NO_SSLv3
no_ssl2 = OpenSSL::SSL::OP_NO_SSLv2
no_compression = OpenSSL::SSL::OP_NO_COMPRESSION
ssl_options = no_ssl2 + no_ssl3 + no_compression
server_options[:SSLOptions] = ssl_options
server_options[:SSLVersion] = :TLSv1_2
if(config_options.key?('ssl_ciphers'))
cz = config_options['ssl_ciphers']
else
# SSL Ciphers
cz = ['ECDHE-RSA-AES128-GCM-SHA256','ECDHE-RSA-AES256-GCM-SHA384',
'ECDHE-RSA-AES128-CBC-SHA','ECDHE-RSA-AES256-CBC-SHA',
'AES128-GCM-SHA256','AES256-GCM-SHA384','AES128-SHA256',
'AES256-SHA256','AES128-SHA','AES256-SHA']
end
CIPHERS = cz.push("TLSv1.2","!aNULL","!eNULL","!SSLv2","!SSLv3")
server_options[:SSLCiphers] = CIPHERS.join(":")
end
Rack::Handler::WEBrick.run Server, server_options