HTTP Proxy Service - Zentyal 5
HTTP Proxy Service - Zentyal 5
HTTP Proxy Service - Zentyal 5
1 Documentation
Zentyal Server
Overview
Download
Features
Code
Roadmap
I need help
Documentation
Wiki
Forum
Training
Stay tuned
News
Planet
Contribute
Tracker
Translate
Company
FacebookTwitterFlickrYoutuberss
[1] http://www.squid-cache.org/
[2] http://www.dansguardian.org/
The cache size controls the amount of space in the disk you are going to use to temporarily store
web content. It’s configured using Cache Size. You need a good estimation of the amount and type
of traffic you are going to receive to optimize this parameter.
https://doc.zentyal.org/en/proxy.html 1/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
https://doc.zentyal.org/en/proxy.html 2/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
HTTP Proxy
It’s possible to configure which domains are not going to be stored in the cache. For example, if you
have local web servers, you will not improve the access storing a cache and you will waste memory
that could be used for storing remote elements. If a domain is in the cache exemption list, the data
will be retrieved delivered directly to the browser. You can define this domains in Cache
exemptions
Also, you may want to server some web pages directly from the original server, for the privacy of
your users or just because they don’t operate correctly behind a proxy. For these cases, you can
use the Transparent Proxy Exemptions.
The HTTP Proxy is able to remove the advertisement from the web pages as well. This will save
bandwidth and remove distractions, or even security threats. To use this feature you only have to
enable Ad Blocking.
Access Rules
Once you have decided your general configuration for the proxy, you have to define the access
rules. By default you will find a rule in HTTP Proxy ‣ Access Rules which allows all access.
Similarly to the Firewall, the implicit rule is to deny, and the upper rule will have preference if
several can apply to a given traffic.
Using the Time Period you can define in which moment the rule will apply, days of the week and
hours. The default is all times.
https://doc.zentyal.org/en/proxy.html 3/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
The Source is parameter that allows you to configure if this rule will apply to an Object or to all the
traffic going through the proxy.
Again, similarly to the Firewall, once the traffic has matched one of the rules, you have to specify a
Decision, in the case of the Proxy you have three options:
Allow all: Accepts all the traffic without making any check, it still allows the user to have a web
cache and the administrator to have an access log.
Deny all: Denies all the connection attempts to the web.
Apply filter profile: For each request, it will check that the contents don’t violate any of the
filters defined in the profile, you will find out about the available filters in the next section.
Anyone will be able to access without any restriction during the weekends, because is the upper-
most rule. At any other time, the requests coming from the ‘Marketing’ object will have to be
approved by the filter defined in ‘strict_filter’, the request coming from the object ‘Developers’ will
access without restrictions. The request not matching with any of these rules will be denied.
Filter profiles
You can filter web pages with Zentyal depending on their contents. You can define several filter
profiles from HTTP Proxy ‣ Filter Profiles.
https://doc.zentyal.org/en/proxy.html 4/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
If you go to the Configuration of one of these profiles, you can specify different criteria to adjust the
content filters. In the first tab you can find the Threshold and the antivirus filters. To have the
antivirus checkbox available you need to have the antivirus module installed and enabled.
These two filters are dynamic, which means that they will analyse any web page to find
inappropriate content or viruses. The threshold can be adjusted to be more or less strict, this will
influence the number of inappropriate words it will tolerate before rejecting a web page.
https://doc.zentyal.org/en/proxy.html 5/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
In the next tab Domains and URLs you can statically decide which domains will be allowed in this
profile. You can Block sites specified only as IP to avoid bypassing the proxy by just typing IP
addresses. The option Block not listed domains and URLs iallows you to decide if the list of
domains below behaves as a blacklist or a whitelist, that is, if the default behavior will be to accept
or deny an unlisted page.
Finally, at the bottom you have the list of rules, where you can specify which domains you want to
accept or deny.
To use the Domain categories first you need to load a categorized domain list. You can load this list
from HTTP Proxy ‣ Categorized list. Then you can upload a file which contains a list of URLs
grouped by categories to be used by filters like SquidGuardian [3] o DansGuardian [4] . For this
example download two URL lists, one from file from
https://doc.zentyal.org/en/proxy.html 6/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
Categorized list
Once you have configured the list, you can choose which category will be denied or allowed from
the Domain Categories tab.
https://doc.zentyal.org/en/proxy.html 7/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
Using the two left tabs you can select which types of contents or files will be accepted by this
profile, either using MIME types or file extensions. The MIME [5] types are a format identifier for
Internet, for example application/pdf.
https://doc.zentyal.org/en/proxy.html 8/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
As you can see in the image above, the column Allow allows you to configure whether the default
behaviour will be to deny or to accept a given type.
https://doc.zentyal.org/en/proxy.html 9/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
[3] http://www.squid-cache.org/
[4] http://www.dansguardian.org/
[5] http://en.wikipedia.org/wiki/Mime_type
Bandwidth Throttling
Zentyal’s Proxy allows you to implement a flexible limit to control the bandwidth used by your users
while browsing the web. This limit is based on the Token Bucket algorithms [6]. You have a bucket
with a bandwidth reserve and a refilling speed. The emptying speed will depend on the user’s
download. If the user uses the connection sensibly, the bucket will refill faster than he/she empties
it, so there will be no penalization. If the user start to empty the bucket much faster than the refilling
rate, it will empty and then he/she will have to settle with just the refilling speed.
https://doc.zentyal.org/en/proxy.html 10/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
For each bandwidth throttling rule you configure, you have two types of buckets available: global
and per client. Each client will consume their personal buckets and everyone included in the object
will consume the global bucket.
Tip: This type of algorithms are useful to allow medium size downloads, if they are not
sustained over the time. For example, in an education context, you can allow to download PDFs,
this will consume part of the bucket but will download at maximum speed. If an user tries to
download using P2P, he/she will consume the bucket very quick.
Bandwidth Throttling
https://doc.zentyal.org/en/proxy.html 11/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
[6] http://en.wikipedia.org/wiki/Token_bucket
To enable it, go to HTTP Proxy ‣ Filter Profiles, create or edit an existing one and simply mark the
Block HTTPS traffic by domain box inside the Domains and URLs tab.
After saving changes, any domain with Deny decision that we add to the list below will be blocked.
We can see an example in the following figure.
https://doc.zentyal.org/en/proxy.html 12/13
27/11/2018 HTTP Proxy Service — Zentyal 5.1 Documentation
https://doc.zentyal.org/en/proxy.html 13/13