Il y a actuellement 102 visiteurs
Jeudi 28 Novembre 2024
accueilactualitésdossierscomparer les prixtélécharger gratuitement vos logicielsoffres d'emploiforum informatique
Connexion
Créer un compte

Mixer les ACLs de Squid

L'informatique, ce n'est pas qu'un PC équipé de Windows. Ce forum est dédié aux utilisateurs de systèmes d'exploitation dérivés d'unix (GNU/Linux, *BSD, etc...) et aux autres OS alternatifs.

Mixer les ACLs de Squid

Message le 16 Juin 2012 00:24

Bien le bonjour ! :)

Si je me permets de créer un topic sur ce forum, c'est parce que je suis un peu perdu ! :(

Je vais essayer d'être clair, ce n'est pas évident ^^

Je suis actuellement entrain de mettre en place mon projet de stage en entreprise, remplacer un ancien proxy ISA 2000 par un proxy filtrant firewall Linux dans une grosse infrastructure en réseaux !

Pour l'instant, tout va bien ! J'ai réussi pas mal de choses comme l’authentification des groupes d'utilisateurs LDAP Active Directory sur Squid, les règles IPtables etc.

Malheureusement je bloque sur la chose suivante :

Nous voulons autoriser le FTP sur le réseau (mais seulement sur une section du réseau, grâce à une plage d'adresses IP, via IPtables).
L'histoire de règles IPtables, je me débrouille !

PAR CONTRE, j'ai de gros soucis avec Squid...

Si je laisse mon " squid.conf " sans rien changer, la connexion FTP (via FileZilla) est bloquée.

J'ai deux solutions (mais non viables) pour que la connexion FTP fonctionne :

- Commenter la ligne " http_access deny CONNECT !SSL_ports " pour qu'elle ne soit pas prise en compte.
- Ajouter dans l'ACL " acl SSL_ports port " TOUS les ports imaginables (0-65535)

J'ai remarqué dans l'access.log de Squid que lors d'une connexion FTP, le port du serveur FTP (AdresseIP:Port) changeait à chaque tentative de connexion. Je me suis dit que cela est normal, il s'agit sûrement de ports dynamiques.

Alors je me suis demandé (oui je sais, j'écris comme je parle lol :D) comme puis-je savoir à l'avance quels ports indiquer dans l'ACL " acl SSL_ports port " pour qu'ils soient validés par la requête " CONNECT " et que la connexion FTP fonctionne ?

J'ai pensé alors à autoriser TOUS les ports pour la requête " CONNECT " MAIS uniquement quand c'est une connexion FTP qui est initiée.

Quelque chose du genre :

acl FTP proto FTP
acl PORTS_FTP port 0-65535
http_access allow CONNECT FTP PORTS_FTP

Mais ça ne fonctionne pas... j'ai cherché sur des tas de sites, sans résultats.

Peut-être que mon idée est mauvaise ou encore que c'est tout simplement impossible à mettre en place.
Je voudrais simplement faire fonctionner le FTP, ça ne doit pas être sorcier d'autant plus que c'est uniquement cette ligne qui me pose problème étant donné que quand je la vire, la connexion marche très bien ^^

Je vous serais très reconnaissant de m'aider, je suis bloqué sur cette étape depuis trop longtemps :P

Merci d'avance et bonne soirée ! :)

clpeter
clpeter
Visiteur
Visiteur
 
Messages: 2
Inscription: 16 Juin 2012 00:22
 


Re: Mixer les ACLs de Squid

Message le 18 Juin 2012 08:27

clpeter a écrit:- Commenter la ligne " http_access deny CONNECT !SSL_ports " pour qu'elle ne soit pas prise en compte.

Une config SQUID par défaut donne un certains nombre de ports configurés et listés par les règles "Safe_ports". Et notamment :
Code: Tout sélectionner
acl Safe_ports port 21          # ftp

Si tu ajoutes à ta règle :
Code: Tout sélectionner
http_access deny CONNECT !SSL_ports !Safe_ports

... ça donnerait quoi ? (j'ai pas analysé le truc pour savoir si c'est sécure... c'est juste une suggestion)

Pour info tu ne peux pas savoir à l'avance les ports qui seront utilisés par la connexion FTP car c'est le serveur FTP distant (que tu ne connais pas) qui délivre dynamiquement les ports de la data.
Avatar de l'utilisateur
CaSa
PC-Infopraticien
PC-Infopraticien
 
Messages: 9048
Inscription: 13 Mai 2003 16:32
Localisation: Sisteron... et jamais loin d'une Debian
 

Re: Mixer les ACLs de Squid

Message le 18 Juin 2012 12:34

Voilà, j'ai plus d'informations à vous donner ;-)

Il s'agit donc d'un proxy filtrant firewall Linux qui se trouve entre la box Internet et le réseau interne. Les postes clients du réseau interne s'identifie sur un domaine Windows AD 2008 et ce dernier est connecté avec le proxy Linux. Ils sont connectés ensemble car le proxy filtre les accès Internet en fonction du groupe dans lequel est l'utilisateur du LDAP AD.

Concernant le FTP, ce n'est pas " notre " FTP… je parle d'un accès FTP sur ftp.ubuntu.com via FileZilla par exemple ! Pas de proxy FTP configuré ni de proxy transparent, pour finir le proxy n'est pas le routeur !

Voici donc en premier le squid.conf qui fonctionne avec le FTP (en gras les lignes qui me semblent importantes) :

auth_param ntlm program /usr/bin/ntlm_auth --helper-protocol=squid-2.5-ntlmssp --require-membership-of=XXX\"Utilisateurs Autorisés Internet"
auth_param ntlm children 5
auth_param ntlm keep_alive on
auth_param basic program /usr/bin/ntlm_auth --helper-protocol=squid-2.5-basic
auth_param basic children 20
auth_param basic realm XXX
auth_param basic credentialsttl 2 hours
auth_param basic casesensitive off
acl snmppublic snmp_community public
acl password proxy_auth REQUIRED
acl manager proto cache_object
acl PURGE method purge
acl localhost src 127.0.0.1/32
acl localdest dst 127.0.0.1/32
acl SSL_ports port 443 563 631 8501 4000-5000 8070 8090 8443 8753 7070
acl Safe_ports port 80 21 443 563 70 210 631 1025-65535

acl Safe_ports port 280
acl Safe_ports port 488
acl Safe_ports port 591
acl Safe_ports port 777
acl Reserved port 8501 4200
acl CONNECT method CONNECT
acl noauth dstdomain "/etc/squid/domaines_noauth"
acl noauth dstdomain "/etc/squid/domaines_noauth_user"
acl noauth dstdomain "/etc/squid/domaines_noauth_acad"
acl nocache dstdomain "/etc/squid/domaines_nocache"
acl nocache dstdomain "/etc/squid/domaines_nocache_user"
acl nocache dstdomain "/etc/squid/domaines_nocache_acad"
acl srcnoauth src "/etc/squid/src_noauth"
acl srcnoauth src "/etc/squid/src_noauth_user"
acl srcnoauth src "/etc/squid/src_noauth_acad"
acl srcnocache src "/etc/squid/src_nocache"
acl srcnocache src "/etc/squid/src_nocache_user"
acl srcnocache src "/etc/squid/src_nocache_acad"
acl nopeerproxy dstdomain "/etc/squid/domaines_nopeerproxy"
acl amon_lan src 10.100.0.0/16
acl amon_lan src 101.0.0.0/255.0.0.0
acl localhosteth1 dst 10.100.1.250/32
acl reseaueth1 dst 10.100.0.0/16
acl reseaueth1 dst 101.0.0.0/255.0.0.0
acl eth1admin0 src 10.100.0.0/16
acl localdom dstdomain XXX
acl lxcroot src 127.0.0.1/32
follow_x_forwarded_for allow localhost
acl_uses_indirect_client on
delay_pool_uses_indirect_client on
log_uses_indirect_client on
http_access allow manager localhost
http_access deny manager
http_access allow purge localhost
http_access deny purge
http_access deny !Safe_ports
http_access deny CONNECT !SSL_ports !Safe_ports
http_access allow localhost
http_access deny reseaueth1 !amon_lan
http_access allow noauth
http_access allow srcnoauth
http_access deny Reserved localhosteth1 !eth1admin0
http_access allow password
http_access deny all
http_reply_access allow all
icp_access deny all
htcp_access deny all
ident_lookup_access allow amon_lan
http_port 127.0.0.1:8080 intercept
dead_peer_timeout 10 seconds
hierarchy_stoplist cgi-bin ?
cache_mem 16 MB
maximum_object_size_in_memory 16 KB
memory_replacement_policy lru
cache_replacement_policy lru
cache_dir ufs /var/spool/squid 1000 16 256
minimum_object_size 0 KB
maximum_object_size 32768 KB
cache_swap_low 90
cache_swap_high 95
access_log syslog:LOG_LOCAL7|LOG_INFO squid
cache_store_log none
emulate_httpd_log off
log_ip_on_direct on
log_mime_hdrs off
pid_filename /var/run/squid.pid
log_fqdn off
client_netmask 255.255.255.255
cache_log /var/log/squid/cache.log
coredump_dir /var/spool/squid3
ftp_user XXX
ftp_passive on
ftp_sanitycheck on
ftp_telnet_protocol on
cache deny reseaueth1
cache deny nocache
cache deny srcnocache
refresh_pattern ftp: 1440 20% 10080
refresh_pattern gopher: 1440 0% 1440
refresh_pattern -i (/cgi-bin/|\?) 0 0% 0
refresh_pattern . 0 20% 4320
quick_abort_min 16 KB
quick_abort_max 16 KB
quick_abort_pct 95
read_ahead_gap 16 KB
negative_ttl 5 minutes
positive_dns_ttl 6 hours
negative_dns_ttl 1 minutes
range_offset_limit 0 KB
request_header_max_size 20 KB
request_body_max_size 10 MB
ignore_expect_100 off
forward_timeout 4 minutes
connect_timeout 1 minutes
peer_connect_timeout 30 seconds
read_timeout 15 minutes
request_timeout 5 minutes
persistent_request_timeout 1 minutes
client_lifetime 120 minutes
half_closed_clients on
pconn_timeout 120 minutes
ident_timeout 10 seconds
shutdown_lifetime 30 seconds
cache_effective_user proxy
cache_effective_group proxy
snmp_port 3401
snmp_access allow snmppublic lxcroot
snmp_access allow snmppublic localhost
snmp_access deny all
snmp_incoming_address 127.0.0.1
icp_port 3130
htcp_port 4827
icp_query_timeout 0
maximum_icp_query_timeout 2000
mcast_icp_query_timeout 2000
always_direct allow localdom
check_hostnames on
allow_underscore on
dns_defnames off
hosts_file /etc/hosts
ipcache_size 1024
ipcache_low 90
ipcache_high 95
fqdncache_size 1024
cache_mgr XXX


On remarquera ici que la requête CONNECT est autorisée sur presque tous les ports (80 21 443… 1025-65535).. est-ce que cela est sécurisé ??

Voici maintenant le squid.conf qui pose problème pour le FTP (la plus grosse différence avec la première version c'est qu'il n'y a pas tous les ports autorisés pour la requête CONNECT) :

auth_param ntlm program /usr/bin/ntlm_auth --helper-protocol=squid-2.5-ntlmssp --require-membership-of=XXX\"Utilisateurs Autorisés Internet"
auth_param ntlm children 5
auth_param ntlm keep_alive on
auth_param basic program /usr/bin/ntlm_auth --helper-protocol=squid-2.5-basic
auth_param basic children 20
auth_param basic realm XXX
auth_param basic credentialsttl 2 hours
auth_param basic casesensitive off
acl snmppublic snmp_community public
acl password proxy_auth REQUIRED
acl manager proto cache_object
acl PURGE method purge
acl localhost src 127.0.0.1/32
acl localdest dst 127.0.0.1/32
acl SSL_ports port 21 443 563 631 8501 4000-5000 8070 8090 8443 8753 7070
acl Safe_ports port 80 21 443 563 70 210 631 1025-65535

acl Safe_ports port 280
acl Safe_ports port 488
acl Safe_ports port 591
acl Safe_ports port 777
acl Reserved port 8501 4200
acl CONNECT method CONNECT
acl noauth dstdomain "/etc/squid/domaines_noauth"
acl noauth dstdomain "/etc/squid/domaines_noauth_user"
acl noauth dstdomain "/etc/squid/domaines_noauth_acad"
acl nocache dstdomain "/etc/squid/domaines_nocache"
acl nocache dstdomain "/etc/squid/domaines_nocache_user"
acl nocache dstdomain "/etc/squid/domaines_nocache_acad"
acl srcnoauth src "/etc/squid/src_noauth"
acl srcnoauth src "/etc/squid/src_noauth_user"
acl srcnoauth src "/etc/squid/src_noauth_acad"
acl srcnocache src "/etc/squid/src_nocache"
acl srcnocache src "/etc/squid/src_nocache_user"
acl srcnocache src "/etc/squid/src_nocache_acad"
acl nopeerproxy dstdomain "/etc/squid/domaines_nopeerproxy"
acl amon_lan src 10.100.0.0/16
acl amon_lan src 101.0.0.0/255.0.0.0
acl localhosteth1 dst 10.100.1.250/32
acl reseaueth1 dst 10.100.0.0/16
acl reseaueth1 dst 101.0.0.0/255.0.0.0
acl eth1admin0 src 10.100.0.0/16
acl localdom dstdomain XXX
acl lxcroot src 127.0.0.1/32
acl ftp proto ftp
follow_x_forwarded_for allow localhost
acl_uses_indirect_client on
delay_pool_uses_indirect_client on
log_uses_indirect_client on
http_access allow manager localhost
http_access deny manager
http_access allow purge localhost
http_access deny purge
http_access deny !Safe_ports
http_access deny CONNECT !SSL_ports
http_access allow localhost
http_access deny reseaueth1 !amon_lan
http_access allow noauth
http_access allow srcnoauth
http_access deny Reserved localhosteth1 !eth1admin0
http_access allow password
http_access allow ftp
http_access deny all
http_reply_access allow all
icp_access deny all
htcp_access deny all
ident_lookup_access allow amon_lan
http_port 127.0.0.1:8080 intercept
dead_peer_timeout 10 seconds
hierarchy_stoplist cgi-bin ?
cache_mem 16 MB
maximum_object_size_in_memory 16 KB
memory_replacement_policy lru
cache_replacement_policy lru
cache_dir ufs /var/spool/squid 1000 16 256
minimum_object_size 0 KB
maximum_object_size 32768 KB
cache_swap_low 90
cache_swap_high 95
access_log syslog:LOG_LOCAL7|LOG_INFO squid
cache_store_log none
emulate_httpd_log off
log_ip_on_direct on
log_mime_hdrs off
pid_filename /var/run/squid.pid
log_fqdn off
client_netmask 255.255.255.255
cache_log /var/log/squid/cache.log
coredump_dir /var/spool/squid3
ftp_user XXX
ftp_passive on
ftp_sanitycheck on
ftp_telnet_protocol on
cache deny reseaueth1
cache deny nocache
cache deny srcnocache
refresh_pattern ftp: 1440 20% 10080
refresh_pattern gopher: 1440 0% 1440
refresh_pattern -i (/cgi-bin/|\?) 0 0% 0
refresh_pattern . 0 20% 4320
quick_abort_min 16 KB
quick_abort_max 16 KB
quick_abort_pct 95
read_ahead_gap 16 KB
negative_ttl 5 minutes
positive_dns_ttl 6 hours
negative_dns_ttl 1 minutes
range_offset_limit 0 KB
request_header_max_size 20 KB
request_body_max_size 10 MB
ignore_expect_100 off
forward_timeout 4 minutes
connect_timeout 1 minutes
peer_connect_timeout 30 seconds
read_timeout 15 minutes
request_timeout 5 minutes
persistent_request_timeout 1 minutes
client_lifetime 120 minutes
half_closed_clients on
pconn_timeout 120 minutes
ident_timeout 10 seconds
shutdown_lifetime 30 seconds
cache_effective_user proxy
cache_effective_group proxy
snmp_port 3401
snmp_access allow snmppublic lxcroot
snmp_access allow snmppublic localhost
snmp_access deny all
snmp_incoming_address 127.0.0.1
icp_port 3130
htcp_port 4827
icp_query_timeout 0
maximum_icp_query_timeout 2000
mcast_icp_query_timeout 2000
always_direct allow localdom
check_hostnames on
allow_underscore on
dns_defnames off
hosts_file /etc/hosts
ipcache_size 1024
ipcache_low 90
ipcache_high 95
fqdncache_size 1024
cache_mgr XXX


Voici le message d'erreur de FileZilla et un extrait de l'access.log de Squid :

http://www.hostingpics.net/viewer.php?i ... ezilla.jpg

http://www.hostingpics.net/viewer.php?i ... access.jpg

Voilà voilà, j'espère avoir été compréhensible et complet !

Si la première version de Squid ne pose pas de problèmes de sécurité (malgré tous les ports autorisés -1025 à 65535- pour la requête CONNECT), je ne vais pas me prendre le choux, hein ? Mais je n'ai pas la certitude qu'elle soit safe !

Je vous remercie d'avance pour l'aide que vous pourrez m'apporter :-)

clpeter
clpeter
Visiteur
Visiteur
 
Messages: 2
Inscription: 16 Juin 2012 00:22
 



Sujets similaires

Message proxy squid et authentification mysql
Bonjour,je dois mettre en place un proxy squid avec authentification mysql. J'ai donc suivi des tutoriels comme celui-ci :http://wiki.squid-cache.org/ConfigExamples/Authenticate/MysqlUne fois le proxy configuré de cette manière, je teste sous firefox mais celui ci ne me demande aucun login ni mot de ...
Réponses: 2

Message Linux-Squid sous Vmware
Bonjour, Je suis en stage en entreprise pour 2 mois, et mon objectif est d'installer un serveur proxy « Squid » sous RedHat et de faire un script pour la configuration automatique du proxy pour chacun des postes des membres de l'entreprise. Dans un premier temps, j'effectuerais mes tests ...
Réponses: 9

Message nvidia mixer et spdif
Bonjour, ma config: Asus A8N SLI deluxe + AMD3500+ Je me sers de mon PC comme lecteur DVD, video vers projo et son vers ampli 5.1. J'ai récemment installé la derniere version des drivers nforce4 et je n'ai plus de sortie sur la prise SPDIF. les sorties analogiques fonctionnent, mais plus les nu ...
Réponses: 0

Message Recherche petit mixer de musique ET éditeur.
Salut à tous. Je suis desespérement à la recherche d'un petit locigiel qui puisse mixer et surtout éditer après les morceaux mixés (en MP3 ou autres). Il ne faut pas que cela soit une usine à gaz, juste le minimum pour bricoler un peu. L'autre demande, bien-sur, c'est que de préfèrence il soit gratu ...
Réponses: 1

Message Squid et cache
J'ai un soucis egalement avec Squid. Celui-ci m'empeche de telechager les cookies, les images et autres fichiers temporaire de navigation internet. Quelle ligne est a ajouter ou suprimer dans ma config pour résolver ce probleme?
Réponses: 0

Message Le PROXY SQUID est-il aussi firewall ?
Un serveur PROXY SQUID, équipé de 2 cartes réseau et ne remplissant pas la fonction de routage, suffit-il pour protéger un Intranet contre des attaques venant d'internet ? Si non, comment les attaques sont-elles possibles sachant que l'ordinateur client ne peut (à mon sens) être contrôlé à distance ...
Réponses: 4

Message Besoin d'aide pour MIXER !!! ;)
Bonjour à tous J'aimerais juste savoir quel est le meilleur logiciel (En Français et Gratuit ) pour mixer des morceaux de Musique. Même s'il y a un bon soft qui "Dechire" en Français et PAYANT dites le moi comme même voilà Merci à tous Momo
Réponses: 8


Qui est en ligne

Utilisateurs parcourant ce forum: Aucun utilisateur enregistré et 9 invités


.: Nous contacter :: Flux RSS :: Données personnelles :.