The package configures ufdbGuard, a URL filter for squid. The configuration is based on profiles. Each profile is composed by:
- a user, group of users, host or group of hosts accessing a web page
- a filter which includes allowed and denied sites
- a time frame in which the filter is active
The system comes with a default profile which is applied to any host/user who doesn't fit on a specific profile.
Features of ufdbGuard:
- 3-4 times faster than squidGuard
- a multithreaded daemon with one copy of the database in memory
- detects HTTPS proxy tunnels
- detects SSH-based tunnels
- blocks HTTPS for URLs without FQDN
- blocks HTTPS for sites without a properly signed SSL certificate
- uses in-memory databases
- enforce the SafeSearch feature on Google and other search engines
- a test mode (-T option) allows you to test a URL filter database without actually blocking sites
For the block page on th server, see https://github.com/NethServer/blocked.nethserver.org/.
For each request, squid sends the URL to one ufdbgclient
redirector (which runs as user squid),
which in turn asks to the ufdb
daemon (which runs as user ufdb).
- Transparent URL filtering on HTTPS websites can only block whole domains, because ufdbGuard can only receive
the domain name, not the full URL
- Redirected HTTPS show an error instead of the block page
Blacklists are updated every night using the script: :file:`/etc/cron.daily/update-squidguard-blacklists` The script will download and merge all blacklists listed in :file:`/etc/squid/blacklists`. This actions can take several minutes.
The package uses the squidguard
key inside the configuration
database, also it creates a new contentfilter
database
for profiles and filters configuration.
The key squidguard
contains all settings. Properties are:
- BlockedFileTypes: comma separated list of blocked file extensions
- CustomListURL: URL to download a custom blacklist. The blacklist must follow SquidGuard standard
- DomainBlacklist: comma separated domain list, this domains are always blocked
- DomainWhitelist: comma separated domain list, this domains are always allowed
- Expressions: if enabled, allow regular expression on blacklists categories. Can be
enabled
ordisabled
, default isdisabled
- IdleChildren: minimum number of idle processes. Default is 5
- Lists: comma separated list of blacklist names. Possible values are:
toulouse
andcustom
. If set tocustom
, make sureCustomListURL
is set. - MaxChildren: maximum number of processes. Default is 20
- RedirectUrl: custom URL for block page. See :ref:`squidguard-blockpage-section`
- StartupChildren: minimum number of process children on startup. Default is 5
Note
Modifying following parameters can greatly affect memory usage: IdleChildren, MaxChildren, StartupChildren
Example:
squidguard=configuration BlockedFileTypes= CustomListURL= DomainBlacklist=microsoft.com DomainWhitelist=nethserver.org,nethesis.it Expressions=disabled IdleChildren=5 Lists=toulouse MaxChildren=20 RedirectUrl= StartupChildren=5 UrlBlacklist= UrlWhitelist= status=enabled
The service key ufdbGuard
has enabled/disabled state
according to the status prop of the squidguard
(see nethserver-squidguard-ufdb-status action).
The contentfilter
database can contain three kind of records:
- category: a custom categorized list of domains blocked or allowed. Custom categories can be added to a filter
- filter: an object describing which categories must be blocked or allowed
- time: when the filter must be applied, it contains week days and time
- profile: a link between the above objects describing WHO (host or user), WHAT (filter) and WHEN (time)
Properties:
- Domains: comma separated list of domains
- Description: optional description
Category example:
mycategory=category Description=My Category Domains=nethesis.it,nethserver.org
Properties:
- BlackList: enable or disable the global blacklist (
DomainBlacklist
). Can beenabled
ordisabled
- BlockAll: can be
enabled
ordisabled
. If disabled, all categories listed inCategories
are blocked and all other sites are allowed. If enabled, all listed categories inCategories
are allowed and all other sites are blocked - BlockFileTypes: enable or disable the global file extension list (
BlockedFileTypes
). Can beenabled
ordisabled
- BlockIpAccess: if enabled, sites can be accessed only using a domain name (not an IP address). Can be
enabled
ordisabled
- Categories: comma separated list of categories blocked or allowed. If a category is not present inside the SquidGuard db (:file:`/var/squidGuard/Blacklists`), the category will be excluded from configuration file to avoid ufdbGuard panic-mode (no filter)
- Description: optional description
- WhiteList: enable or disable the global whitelist (
DomainWhitelist
. Can beenabled
ordisabled
- Removable: can be
yes
orno
. If set tono
the record can't be removed from web interface
Filter example:
myfilter=filter BlackList=enabled BlockAll=disabled BlockFileTypes=disabled BlockIpAccess=disabled Categories=aggressive,alcohol,weapons,warez Description=Default filter WhiteList=enabled
Properties:
- Days: comma separated list of week days. Valid values are:
- m: Monday
- t: Tuesday
- w: Wednesday
- h: Thursday
- f: Friday
- a: Saturday
- s: Sunday
- Description: optional description
- EndTime: hour of the day in 24h format or empty
- StartTime: our of the day in 24h format or empty
Time example:
worktime=time Days=m,t,w,h,f Description=Work time EndTime=18:30 StartTime=08:30
Properties:
- Filter: a filter object
- *FilterElse: an optional filter object, applied when none of the referenced Time rules apply
- Src: it can be an object of type user, user group, host, host group, zone or role. Otherwise, if it is a string, the system will assume the profile is associated with an user from Active Directory; the system must be joined to a domain
- Time: a CSV list time object references (optional)
- Description: optional description
- Removable: can be
yes
orno
. If set tono
the record can't be removed from web interface
Profile example:
myprofile=profile Description=My profile Filter=filter;badboys FilterElse=filter;enjoy Src=host;demo Time=time;worktime-am,time;worktime-pm
The block page is a CGI used to inform the user about the block reason. It's a single page which can handle requests from ufdbGuard and SquidClamav (:ref:`squidclamav-section`).
The page is localized depending on browser language.
This configuration can be overwritten using RedirectUrl
property.
Useful test commands:
echo "http://bit.ly 10.10.0.1/ - - GET" | /usr/sbin/ufdbgclient -d echo "http://bit.ly 10.10.0.1/ user@mydomain.com - GET" | /usr/sbin/ufdbgclient -d
Logfiles:
/var/log/ufdbguard/ufdbguardd.log /var/log/ufdbguard/ufdbgclient.log