Class: Dory::Proxy
Class Method Summary
collapse
container_exists?, delete, docker_installed?, handle_error, has_docker_client?, ps, run_preconditions, running?, start, start_cmd, stop
Class Method Details
.certs_arg ⇒ Object
17
18
19
20
21
22
23
24
|
# File 'lib/dory/proxy.rb', line 17
def self.certs_arg
certs_dir = Dory::Config.settings[:dory][:nginx_proxy][:ssl_certs_dir]
if certs_dir && !certs_dir.empty?
"-v #{certs_dir}:/etc/nginx/certs"
else
''
end
end
|
.container_name ⇒ Object
13
14
15
|
# File 'lib/dory/proxy.rb', line 13
def self.container_name
Dory::Config.settings[:dory][:nginx_proxy][:container_name]
end
|
.dory_http_proxy_image_name ⇒ Object
7
8
9
10
11
|
# File 'lib/dory/proxy.rb', line 7
def self.dory_http_proxy_image_name
setting = Dory::Config.settings[:dory][:nginx_proxy][:image]
return setting if setting
'freedomben/dory-http-proxy:2.2.0.1'
end
|
.run_command ⇒ Object
36
37
38
39
40
41
42
|
# File 'lib/dory/proxy.rb', line 36
def self.run_command
"docker run -d -p 80:80 #{self.tls_arg} #{self.certs_arg} "\
"-v /var/run/docker.sock:/tmp/docker.sock -e " \
"'CONTAINER_NAME=#{Shellwords.escape(self.container_name)}' --name " \
"'#{Shellwords.escape(self.container_name)}' " \
"#{Shellwords.escape(dory_http_proxy_image_name)}"
end
|
.start_cmd ⇒ Object
44
45
46
|
# File 'lib/dory/proxy.rb', line 44
def self.start_cmd
"docker start #{Shellwords.escape(self.container_name)}"
end
|
.tls_arg ⇒ Object
26
27
28
29
30
31
32
33
34
|
# File 'lib/dory/proxy.rb', line 26
def self.tls_arg
if [:tls_enabled, :ssl_enabled, :https_enabled].any? { |s|
Dory::Config.settings[:dory][:nginx_proxy][s]
}
"-p 443:443"
else
''
end
end
|