Forum |  HardWare.fr | News | Articles | PC | S'identifier | S'inscrire | Shop Recherche
2541 connectés 

  FORUM HardWare.fr
  Linux et OS Alternatifs
  réseaux et sécurité

  [Squid] SSL interception & analyse

 


 Mot :   Pseudo :  
 
Bas de page
Auteur Sujet :

[Squid] SSL interception & analyse

n°1410227
nuitn0ire
Posté le 17-11-2017 à 13:08:46  profilanswer
 

Hello,
 
J'ai un squid 3.5, recompilé avec '--with-openssl' '--enable-ssl' '--enable-ssl-crtd' et mon objectif en lab est de capturer dans mes logs l'intégralité de l'url du site web visité. Actuellement, dans mes logs, j'ai quelquechose du style :
 
16/Nov/2017:09:15:31 +0000     46 192.168.1.98 TCP_MISS/403 661 GET  http://monsite.com/monpath/monscript.php
17/Nov/2017:12:34:36 +0000    953 192.168.1.98 TCP_MISS/200 21007 CONNECT www.my.commbank.com.au:443

 
 
Ce que je souhaiterais, c'est obtenir l'url complète visitée en en https (pour derrière faire un traitement approprié dans une autre partie de mon infra, en fonction du chemin pris dans le site web), autrement dit :  
 
17/Nov/2017:12:34:36 +0000    953 192.168.1.98 TCP_MISS/200 21007 GET https://www.my.commbank.com.au/netbank/Logon/Logon.aspx - HIER_DIRECT/www.my.commbank.com.au text/html
 
 
Je me fiche du contenu de la page, ce qui m'intéresse c'est juste d'avoir l'url complète dès lorsque l'on passe par SSL.
 
J'ai bien tenté ceci (au plus simple) à base de ssl_bump, mais ça ne va pas mieux :  
 

acl step1 at_step SslBump1
acl step2 at_step SslBump2
 
 
# Peek at client's TLS-request in order to find the SNI
ssl_bump peek step1 all          
 
# bumping all other SSL connections
ssl_bump bump    

 
 
Quelqu'un aurait une conf fonctionnelle pour ce que je veux faire ?
 
A noter que je ne veux pas le faire via un MITM (pas propre techniquement et d'un point de vue éthique, car je récupère plus que nécessaire).
 
/edit :
 
J'avance un peu, avec la config suivante (une génération dynamique de certificat), avec curl, en poussant mon .pem, j'arrive à mon résultat :
 
curl -x http://192.168.1.98:3128 -L https://www.my.commbank.com.au/netbank/Logon/Logon.aspx --cacert /etc/squid/ssl/myCA.pem
 
==>  
 
17/Nov/2017:13:56:04 +0100    432 192.168.1.98 TCP_MISS/200 21007 GET https://www.my.commbank.com.au/netbank/Logon/Logon.aspx - HIER_DIRECT/www.my.commbank.com.au text/html
 
Mais ça implique de pousser le "/etc/squid/ssl/myCA.der" sur chaque poste.
 
Pour info, la conf est la suivante :
 

http_port 3128 ssl-bump generate-host-certificates=on dynamic_cert_mem_cache_size=4MB cert=/etc/squid/ssl/myCA.pem key=/etc/squid/ssl/myCA.pem
 
# SSL BUMP
always_direct allow all
ssl_bump allow all
 
sslproxy_cert_error allow all
sslproxy_flags DONT_VERIFY_PEER
 
sslcrtd_program /usr/lib/squid/ssl_crtd -s /var/lib/ssl_db -M 4MB
sslcrtd_children 5
 
acl SSL_ports port 443
acl Safe_ports port 80          # http
acl Safe_ports port 21          # ftp
acl Safe_ports port 443         # https
acl Safe_ports port 70          # gopher
acl Safe_ports port 210         # wais
acl Safe_ports port 1025-65535  # unregistered ports
acl Safe_ports port 280         # http-mgmt
acl Safe_ports port 488         # gss-http
acl Safe_ports port 591         # filemaker
acl Safe_ports port 777         # multiling http
 
acl lan src 192.168.1.0/24
 
acl CONNECT method CONNECT
 
#http_access deny !Safe_ports
#http_access deny CONNECT !SSL_ports
http_access allow localhost manager
#http_access deny manager
http_access allow localhost
http_access allow lan
http_access deny all
 
strip_query_terms off
 
coredump_dir /var/spool/squid
 
logformat squid %tl %6tr %>a %Ss/%03Hs %<st %rm %ru %un %Sh/%<A %mt
 
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


 
Est-ce que cette conf vous parait cohérente ?  
 
Mais je ne suis pas dans le cas où je fais un MITM (quoi que sous cette forme, ça ne me dérange pas) ?
 
Est-il possible d'arriver au même résultat sans avoir à pousser un certificat root sur chaque machine ?


Message édité par nuitn0ire le 17-11-2017 à 14:01:47
mood
Publicité
Posté le 17-11-2017 à 13:08:46  profilanswer
 

n°1410250
Ivy gu
we are legion uwu
Posté le 17-11-2017 à 18:26:24  profilanswer
 

pousser le certificat sur les postes c'est justement ce qui te permet de faire du MITM (= déchiffrer les données sans en être le destinataire).
Tu peux pas en même temps garantir la confidentialité des conversations et lire le contenu chiffré (la partie de l'URL après le nom d'hôte fait partie du contenu chiffré), faut faire un choix.


---------------
Une mouvance de plus et j'attaque le gros œuvre !

Aller à :
Ajouter une réponse
  FORUM HardWare.fr
  Linux et OS Alternatifs
  réseaux et sécurité

  [Squid] SSL interception & analyse

 

Sujets relatifs
Squid/SquidGuard ne filtre pas google[Résolu] Analyse logs Postfix - Boîte piraté ?
Phpmyadmin Nginx SSL/TLSAvis sur un script d'analyse de logs
Squid et affectation de black-lists dans des groupes ADsquid, DDWRT et opkg
Passerelle transparente qui analyse tout le traffic (proto, ip, etc)Installer un server Squid sur son server dédié
Squid transparent et ADIptables - ouvrir le port SMTP SSL 465
Plus de sujets relatifs à : [Squid] SSL interception & analyse


Copyright © 1997-2022 Hardware.fr SARL (Signaler un contenu illicite / Données personnelles) / Groupe LDLC / Shop HFR