Association Générale des Utilisateurs de logiciels libres en Côte-d'Or
Rubriques
Notre ami Tux en rodéo sur l'escargot de Bourgogne :-) |
Contrôle parental avec DansGuardian et TinyProxy
Rubrique :
Sécurité
Le : jeudi 22 février 2007 Par : Tony Visites : 22620 Tags : DansGuardian, Proxy, SquidGuard, TinyProxy But de ce documentCe document me sert de mémo pour installer DansGuardian et TinyProxy dans le but de mettre en place un contrôle parental pour l’accès web. Cela est particulièrement utile (voire indispensable) si vous avez des jeunes enfants désirant utiliser régulièrement un accès web. Cette installation a été effectuée sur Debian Testing mais elle doit fonctionner sans problème sur d’autres distributions. Différences entre DansGuardian et SquidGuardPour filtrer les URL, SquidGuard utilise une base de données des sites interdits. Pour fonctionner correctement, il est donc nécessaire de maintenir cette base de données à jour en permanence. De son coté, DansGuardian analyse le contenu des pages pour savoir si elle doit être bloquée ou pas. Il est possible également d’ajouter une liste de sites ou de mots interdits et il est même possible d’utiliser les listes noires de SquidGuard comme nous le verrons à la fin de ce document. Si vous souhaitez installer SquidGuard, vous pouvez lire cet article :
Installation de TinyProxyPour faire fonctionner DansGuardian, il faut commercer par installer un serveur proxy. Il est possible d’installer par exemple « Squid », mais nous allons dans ce document utiliser « TinyProxy » qui est plus léger mais suffisant pour notre besoin :
Remarque : Par défaut, « TinyProxy » utilise le port 8888. Pour le changer, il faut éditer son fichier de configuration « /etc/tinyproxy/tinyproxy.conf ». Configuration de TinyProxyLa configuration de TinyProxy s’effectue dans le fichier « /etc/tinyproxy/tinyproxy.conf ». Par exemple, pour changer le port en écoute, il faut modifier cette ligne :
Pour des raisons de sécurité et pour faciliter le filtrage avec « iptables » je conseille de créer un compte utilisateur spécifique pour le démon de TinyProxy :
Ensuite, il faut éditer le fichier de configuration « /etc/tinyproxy/tinyproxy.conf » et modifier ces lignes : User tinyPour finir, il faut démarrer ou redémarrer TinyProxy :
Et vérifier que le démon tourne bien sous le compte « tiny » : # ps aux | grep tinyTest de TinyProxyPour tester TinyProxy, il suffit de configurer un navigateur web pour qu’il l’utilise. Par exemple, pour Firefox, il faut faire :
Si après ce réglage, l’accès web fonctionne toujours c’est que le proxy est opérationnel. Et normalement en arrêtant le proxy, cela doit bloquer l’accès web :
Ensuite, il faut le démarrer pour refaire fonctionner l’accès web :
Installation de DansGuardian
L’installation de « DansGuardian entraîne l’installation de l’antivirus « Clamav ». Dans ce document, nous n’activerons pas cet antivirus car il n’est pas indispensable sous Linux et consomme pas mal de ressources. Configuration de DansGuardianDansGuardian utilise plusieurs fichiers de configuration enregistrés dans « /etc/dansguardian ». Configuration de « /etc/dansguardian/dansguardian.conf »Pour activer la configuration, il faut commenter ou supprimer cette ligne en début de fichier :
Cette ligne permet d’indiquer le port utilisé par le proxy :
Cette ligne permet d’avoir les messages en français en cas de blocage des sites :
Cette ligne permet de désactiver l’antivirus :
Configuration de « /etc/dansguardian/dansguardianf1.conf »La ligne suivante permet de paramétrer le filtrage en fonction de l’âge des personnes concernées :
La valeur par défaut de « 50 » donne un filtrage très dur et peu de sites sont accessibles. Plus cette valeur est élevée et plus le filtrage est faible. Personnellement, j’ai fait quelques tests et j’ai passé cette valeur à « 80 ». Cette ligne permet de désactiver l’antivirus :
Configuration du fichier « /etc/dansguardian/bannedextensionlist »Ce fichier permet de définir des types de fichiers qui seront interdits de télécharger. Par défaut, la liste est très restrictive. il faut donc commenter les types de fichiers autorisés : #.gz # Gziped fileConfiguration du fichier « /etc/dansguardian/bannedmimetypelist »Là encore il s’agit de restreindre des types de fichiers. #application/gzipConfiguration du fichier « /etc/dansguardian/bannedregexpurllist »L’ajout de cette ligne à la fin du fichier permet de bloquer la plupart des sites français de rencontres en ligne :
Configuration du fichier /etc/dansguardian/phraselists/pornography/weighted_french »Il est possible d’ajouter des mots ou des listes de mots dans ce fichier, avec des coefficients positifs (mauvais mot) ou négatifs (bons mots) : < tchat ><20>Prise en compte des modifications dans la configuration de DansGuardianPour prendre en compte les modifications, il faut exécuter cette commande :
Remarque : Un simple « reload » ne semble pas être suffisant. Configuration du navigateurPour tester « DansGuardian », il suffit de configurer un navigateur web pour qu’il l’utilise. Par exemple, pour Firefox, il faut faire :
Test de filtrageDans Firefox ,allez sur www.google.fr et faites une recherche sur le mot « chatte ». Normalement la page résultante de cette recherche devrait être bloquée et une page d’avertissements s’affiche à la place. Pour modifier cette page, il suffit de modifier le fichier html suivant :
Ensuite, faites une recherche dans « google » sur le mot « chat ». La page résultante n’est pas bloquée mais offre des liens vers des sites de rencontres. Si vous suivez les liens donnés, vous constaterez que certains sont immédiatement bloqués car ils contiennent un contenu sensible. Pour d’autres sites, vous accédez à la page d’accueil ne contenant rien de compromettant. Configuration d’iptables pour forcer les navigateurs à passer par le proxyAvec cette configuration, il suffit de supprimer la configuration du proxy dans le navigateur pour accéder à tout le web sans filtrage. Pour remédier à ce problème, il faut configurer iptables pour bloquer l’accès direct au web à tous les utilisateurs (sauf root et tiny). Pour cela il suffit d’ajouter ces lignes à la configuration de votre parefeu ou dans un script qui se lancera automatiquement au démarrage : # iptables -A OUTPUT -o eth0 -p tcp --dport http -j REJECT --reject-with tcp-resetPour plus d’informations sur la configuration d’iptables et la mise en place d’un parefeu, vous pouvez lire cet article :
ATTENTION : Avec cette configuration, aucun programme ne pourra avoir un accès http sans passer par le proxy. Par exemple, il faudra configurer Thunderbird pour pouvoir recevoir les fils RSS. Utilisation des listes noires de SquidGuardVous trouverez sur ce site, des listes noires régulièrement actualisées pour SquidGuard :
Le script suivant que vous pouvez placer dans la crontab de root, permet de récupérer et décompresser automatiquement la liste noire « adult » :
Ensuite, il suffit de décommenter la ligne suivante du fichier « /etc/dansguardian/bannedsitelist » :
Et de redémarrer DansGuardian :
Pour tester que la liste est bien opérationnelle, il faut tester l’un des sites proposés dans le fichier « domain » et regarder les logs :
Liens pour avoir plus d’informationsCet article est fortement inspiré des informations provenant de ce mail et de cet article :
Historique des modifications
Article précédent : Cryptage d’un dossier sur une clef USB
Article suivant : Installer un serveur de sauvegardes sous Linux
Forum
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||