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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
|
# File 'lib/bonethug/configurator.rb', line 32
def self.vhost(vh_cnf, base_path, project_type, env = 'development', is_remote = false)
conf = @@conf.get 'project_types.' + project_type
server_aliases = ''
aliases = vh_cnf.get 'server_aliases'
if aliases
aliases.each do |index, server_alias|
server_aliases += 'ServerAlias ' + server_alias + "\n"
end
end
env_vars = 'SetEnv ' + conf.get('env_var') + ' ' + env + "\n"
vars = vh_cnf.get 'env_vars'
if vars
vars.each do |k, v|
env_vars += 'SetEnv ' + k + ' ' + v + "\n"
end
end
admin = vh_cnf.get 'server_admin'
server_admin = admin ? 'ServerAdmin ' + admin : ''
shared_path = is_remote ? '/shared' : ''
current_path = is_remote ? '/current' : ''
ssl_key = vh_cnf.get 'ssl_key'
ssl_key = base_path + current_path + '/' + ssl_key if ssl_key and ssl_key[0...0] != '/'
ssl_crt = vh_cnf.get 'ssl_crt'
ssl_crt = base_path + current_path + '/' + ssl_crt if ssl_crt and ssl_crt[0...0] != '/'
custom = vh_cnf.get 'custom'
custom_str = ''
if custom
custom.each do |k, v|
custom_str += v + "\n"
end
end
ssl_ca_bundle = vh_cnf.get 'ssl_ca_bundle'
ssl_ca_bundle = base_path + current_path + '/' + ssl_ca_bundle if ssl_ca_bundle and ssl_ca_bundle[0...0] != '/'
ca_str = ssl_ca_bundle ? 'SSLCertificateChainFile ' + ssl_ca_bundle : ''
case vh_cnf.get('type')
when "nginx"
vh = ""
else
access = vh_cnf.get('version').to_f >= 2.4 ? "Require all granted" : "Order allow,deny\nAllow from all"
vh = "
<VirtualHost *:80>
ServerName #{vh_cnf.get('server_name')}
#{server_aliases}
#{server_admin}
DocumentRoot #{base_path + current_path}/public
#{env_vars}
PassEnv PATH
#{custom_str}
CustomLog #{base_path + shared_path}/log/bytes.log bytes
CustomLog #{base_path + shared_path}/log/combined.log combined
ErrorLog #{base_path + shared_path}/log/error.log
<Directory #{base_path + current_path}/public>
Options Indexes MultiViews FollowSymLinks
AllowOverride All
#{access}
</Directory>
</VirtualHost>
"
if ssl_key and ssl_crt
vh += "
<VirtualHost *:443>
ServerName #{vh_cnf.get('server_name')}
#{server_aliases}
#{server_admin}
DocumentRoot #{base_path + current_path}/public
#{env_vars}
PassEnv PATH
SSLEngine on
SSLCertificateFile #{ssl_crt}
SSLCertificateKeyFile #{ssl_key}
#{ca_str}
#{custom_str}
CustomLog #{base_path + shared_path}/log/bytes.log bytes
CustomLog #{base_path + shared_path}/log/combined.log combined
ErrorLog #{base_path + shared_path}/log/error.log
<Directory #{base_path + current_path}/public>
SSLOptions +StdEnvVars
Options Indexes MultiViews FollowSymLinks
AllowOverride All
#{access}
</Directory>
BrowserMatch \"MSIE [2-6]\" \
nokeepalive ssl-unclean-shutdown \
downgrade-1.0 force-response-1.0
BrowserMatch \"MSIE [17-9]\" ssl-unclean-shutdown
</VirtualHost>
"
end
end
vh
end
|