Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
OpnSense
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
OpnSense
Commits
6d0f4b4b
Commit
6d0f4b4b
authored
Feb 01, 2017
by
Ad Schellevis
Committed by
GitHub
Feb 01, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1332 from mmorev/master
Non-transparent SSL Bumping
parents
f12e4e4b
2e707046
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
42 additions
and
34 deletions
+42
-34
main.xml
...pnsense/mvc/app/controllers/OPNsense/Proxy/forms/main.xml
+10
-9
squid.conf
src/opnsense/service/templates/OPNsense/Proxy/squid.conf
+32
-25
No files found.
src/opnsense/mvc/app/controllers/OPNsense/Proxy/forms/main.xml
View file @
6d0f4b4b
...
...
@@ -223,23 +223,24 @@
</field>
<field>
<id>
proxy.forward.sslbump
</id>
<label>
Enable SSL
mode
</label>
<label>
Enable SSL
inspection
</label>
<type>
checkbox
</type>
<help>
<![CDATA[
Enable sslbump mode,
which makes the proxy act as a man in the middle between the internet and your clients.<br/>
Enable SSL inspection mode,
which allows to log HTTPS connections information, such as requested URL and/or
make the proxy act as a man in the middle between the internet and your clients.<br/>
Be aware of the security implications before enabling this option.
<br/><br/>
Transparent HTTP proxy needs to be enabled and you need nat rules to reflect your traffic
for this feature to work.
<br/>
<a
href=
"/firewall_nat_edit.php?template=transparent_proxy&https=1"
>
Add a new firewall rule
</a>
]]>
</help>
</field>
<field>
<id>
proxy.forward.sslurlonly
</id>
<label>
SSL Domain/IP
only
</label>
<label>
Log SNI information
only
</label>
<type>
checkbox
</type>
<help>
Do not filter content, only domains and addresses
</help>
<help>
<![CDATA[
Do not decode and/or filter SSL content, only log requested domains and IP addresses.<br/>
Some old servers may not provide SNI, so their addresses will not be indicated.
<br/>
Get more information about
<a
href=
"https://wikipedia.org/wiki/Server_Name_Indication"
target=
"_blank"
>
Server Name Indication
</a>
.
]]>
</help>
</field>
<field>
<id>
proxy.forward.sslbumpport
</id>
...
...
src/opnsense/service/templates/OPNsense/Proxy/squid.conf
View file @
6d0f4b4b
...
...
@@ -3,34 +3,41 @@
# Do not edit this file manually.
#
{
# wrap http_port ssl bump configuration for reuse #}
{%
macro
sslbump_httpsconfig
(
network
,
tags
=
''
) -%}
{%
if
helpers
.
exists
(
'OPNsense.proxy.forward.sslbump'
)
and
OPNsense
.
proxy
.
forward
.
sslbump
==
'1'
%}
https_port
{{
network
}}:{{
OPNsense
.
proxy
.
forward
.
sslbumpport
|
default
(
'3129'
)}} {{
tags
}}
ssl
-
bump
cert
=/
var
/
squid
/
ssl
/
ca
.
pem
dynamic_cert_mem_cache_size
=
10
MB
generate
-
host
-
certificates
=
on
{%
endif
%}
{
# wrap listener configuration for reuse #}
{%
macro
listener_config
(
network
,
port
=
'3129'
,
tags
=
''
,
protocol
=
''
) -%}
{%
if
protocol
==
'ssl'
%}
{%
set
listener_type
=
'https_port'
%}
{%
else
%}
{%
set
listener_type
=
'http_port'
%}
{%
endif
%}
{%
set
sslparams
=
''
%}
{%
if
helpers
.
exists
(
'OPNsense.proxy.forward.sslbump'
)
and
OPNsense
.
proxy
.
forward
.
sslbump
==
'1'
%}
{%
set
sslparams
=
'ssl-bump cert=/var/squid/ssl/ca.pem dynamic_cert_mem_cache_size=10MB generate-host-certificates=on'
%}
{%
endif
%}
{{
listener_type
}} {{
network
}}:{{
port
}} {{
tags
}} {{
sslparams
}}
{%-
endmacro
%}
{%
if
helpers
.
exists
(
'OPNsense.proxy.forward.transparentMode'
)
and
OPNsense
.
proxy
.
forward
.
transparentMode
==
'1'
%}
#
transparent mode, listen on localhost
http_port
127
.
0
.
0
.
1
:{{
OPNsense
.
proxy
.
forward
.
port
}}
intercept
{{
sslbump_httpsconfig
(
'127.0.0.1'
,
'intercept
'
) }}
http_port
[::
1
]:{{
OPNsense
.
proxy
.
forward
.
port
}}
intercept
{{
sslbump_httpsconfig
(
'[::1]'
,
'intercept
'
) }}
#
Setup transparent mode listeners on loopback interfaces
{{
listener_config
(
'127.0.0.1'
,
OPNsense
.
proxy
.
forward
.
port
,
'intercept'
) }}
{{
listener_config
(
'127.0.0.1'
,
OPNsense
.
proxy
.
forward
.
sslbumpport
,
'intercept'
,
'ssl
'
) }}
{{
listener_config
(
'[::1]'
,
OPNsense
.
proxy
.
forward
.
port
,
'intercept'
) }}
{{
listener_config
(
'[::1]'
,
OPNsense
.
proxy
.
forward
.
sslbumpport
,
'intercept'
,
'ssl
'
) }}
{%
endif
%}
# Setup
listen
configuration
# Setup
regular listeners
configuration
{%
if
helpers
.
exists
(
'OPNsense.proxy.forward.interfaces'
) %}
{%
for
interface
in
OPNsense
.
proxy
.
forward
.
interfaces
.
split
(
","
) %}
{%
for
intf_key
,
intf_item
in
interfaces
.
iteritems
() %}
{%
if
intf_key
==
interface
and
intf_item
.
ipaddr
!=
'dhcp'
%}
http_port
{{
intf_item
.
ipaddr
}}:{{
OPNsense
.
proxy
.
forward
.
port
}}
{{
listener_config
(
intf_item
.
ipaddr
,
OPNsense
.
proxy
.
forward
.
port
)
}}
{%
endif
%}
{%
endfor
%}
{
# virtual ip's #}
{%
if
helpers
.
exists
(
'virtualip'
) %}
{%
for
intf_key
,
intf_item
in
virtualip
.
iteritems
() %}
{%
if
intf_item
.
interface
==
interface
and
intf_item
.
mode
==
'ipalias'
%}
http_port
{{
intf_item
.
subnet
}}:{{
OPNsense
.
proxy
.
forward
.
port
}}
{{
listener_config
(
intf_item
.
subnet
,
OPNsense
.
proxy
.
forward
.
port
)
}}
{%
endif
%}
{%
endfor
%}
{%
endif
%}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment