Mise en place proxy avec squid3, samba, kerberos (DEBIAN)

Bonjour tout le monde,

Étant en stage informatique dans un hôpital, mon responsable m’as demandé de créer un proxy (transparent) avec squid3 sous Débian (only commandes), avec authentification sur l’AD de mon serveur.

Et après 2 semaines de travail intensif, avec énormément de problèmes qui s’accumuler jours après jours, je viens ici demander votre aide.

Au début, je l’ai fais sur une machine de l’hôpital et tester sur le réseau, mais ayant eu énormément de problème, sachant que le réseau posséder déjà un proxy basic sur le réseau, alors j’ai tout fait en local sur mon pc portable, avec 3 machines virtuels, un windows xp pro client pour les test, un windows serveur 2003 (AD), et un debian qu’en ligne de commande, je vais poster mes configuration pour être plus clair:

Je vais commencer par mon “/etc/squid3/squid.conf”

acl manager proto cache_object acl localhost src 127.0.0.1/32 acl monreseau src 192.168.209.0/24 acl to_localhost dst 127.0.0.0/8 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 CONNECT method CONNECT http_access allow manager localhost http_access deny manager http_access allow monreseau http_access deny !Safe_ports http_access deny CONNECT !SSL_ports http_access allow localhost http_access deny all icp_access allow monreseau icp_access deny all htcp_access deny all http_port 3128 transparent hierarchy_stoplist cgi-bin ? access_log /var/log/squid3/access.log squid refresh_pattern ^ftp: 1440 20% 10080 refresh_pattern ^gopher: 1440 0% 1440 refresh_pattern (cgi-bin|\?) 0 0% 0 refresh_pattern . 0 20% 4320 icp_port 3130

Donc voici mon “/etc/samba/smb.conf”

workgroup = DOMAINE netbios name = debian security = ADS realm = DOMAINE.FR server string = seveur ; wins server = w.x.y.z dns proxy = no ; name resolve order = lmhosts host wins bcast ; interfaces = 127.0.0.0/8 eth0 ; bind interfaces only = yes log file = /var/log/samba/log.%m max log size = 1000 syslog = 0 panic action = /usr/share/samba/panic-action %d encrypt passwords = true passdb backend = tdbsam obey pam restrictions = yes unix password sync = yes passwd program = /usr/bin/passwd %u passwd chat = *Enter\snew\s*\spassword:* %n\n *Retype\snew\s*\spassword:* %n\n *password\supdated\ssuccessfully* . pam password change = yes password server = serveur local master = no winbind use default domain = yes ; winbind enum users = yes ; usershare max shares = 100 [homes] comment = Home Directories browseable = no read only = yes create mask = 0700 directory mask = 0700 valid users = %S ;[netlogon] ; comment = Network Logon Service ; path = /home/samba/netlogon ; guest ok = yes ; read only = yes ; share modes = no ;[profiles] ; comment = Users profiles ; path = /home/samba/profiles ; guest ok = no ; browseable = no ; create mask = 0600 ; directory mask = 0700 [printers] comment = All Printers browseable = no path = /var/spool/samba printable = yes guest ok = no read only = yes create mask = 0700 [print$] comment = Printer Drivers path = /var/lib/samba/printers browseable = yes read only = yes guest ok = no ; write list = root, @lpadmin ;[cdrom] ; comment = Samba server's CD-ROM ; read only = yes ; locking = no ; path = /cdrom ; guest ok = yes ; preexec = /bin/mount /cdrom ; postexec = /bin/umount /cdrom

Maintenant mon “/etc/krb5.conf”

[code][libdefaults]
default_realm = DOMAINE.FR
dns_lookup_realm = false
dns_lookup_kdc = false

The following krb5.conf variables are only for MIT Kerberos.

    krb4_config = /etc/krb.conf
    krb4_realms = /etc/krb.realms
    kdc_timesync = 1
    ccache_type = 4
    forwardable = true
    proxiable = true

    v4_instance_resolve = false
    v4_name_convert = {
            host = {
                    rcmd = host
                    ftp = ftp
            }
            plain = {
                    something = something-else
            }
    }
    fcc-mit-ticketflags = true

[realms]
DOMAINE.FR = {
kdc = DOMAINE
admin_server = SERVEUR
default_domain = DOMAINE.FR
}
ATHENA.MIT.EDU = {
kdc = kerberos.mit.edu:88
kdc = kerberos-1.mit.edu:88
kdc = kerberos-2.mit.edu:88
admin_server = kerberos.mit.edu
default_domain = mit.edu
}
MEDIA-LAB.MIT.EDU = {
kdc = kerberos.media.mit.edu
admin_server = kerberos.media.mit.edu
}
ZONE.MIT.EDU = {
kdc = casio.mit.edu
kdc = seiko.mit.edu
admin_server = casio.mit.edu
}
MOOF.MIT.EDU = {
kdc = three-headed-dogcow.mit.edu:88
kdc = three-headed-dogcow-1.mit.edu:88
admin_server = three-headed-dogcow.mit.edu
}
CSAIL.MIT.EDU = {
kdc = kerberos-1.csail.mit.edu
kdc = kerberos-2.csail.mit.edu
admin_server = kerberos.csail.mit.edu
default_domain = csail.mit.edu
krb524_server = krb524.csail.mit.edu
}
IHTFP.ORG = {
kdc = kerberos.ihtfp.org
admin_server = kerberos.ihtfp.org
}
GNU.ORG = {
kdc = kerberos.gnu.org
kdc = kerberos-2.gnu.org
kdc = kerberos-3.gnu.org
admin_server = kerberos.gnu.org
}
1TS.ORG = {
kdc = kerberos.1ts.org
admin_server = kerberos.1ts.org
}
GRATUITOUS.ORG = {
kdc = kerberos.gratuitous.org
admin_server = kerberos.gratuitous.org
}
DOOMCOM.ORG = {
kdc = kerberos.doomcom.org
admin_server = kerberos.doomcom.org
}
ANDREW.CMU.EDU = {
kdc = vice28.fs.andrew.cmu.edu
kdc = vice2.fs.andrew.cmu.edu
kdc = vice11.fs.andrew.cmu.edu
kdc = vice12.fs.andrew.cmu.edu
admin_server = vice28.fs.andrew.cmu.edu
default_domain = andrew.cmu.edu
}
CS.CMU.EDU = {
kdc = kerberos.cs.cmu.edu
kdc = kerberos-2.srv.cs.cmu.edu
admin_server = kerberos.cs.cmu.edu
}
DEMENTIA.ORG = {
kdc = kerberos.dementia.org
kdc = kerberos2.dementia.org
admin_server = kerberos.dementia.org
}
stanford.edu = {
kdc = krb5auth1.stanford.edu
kdc = krb5auth2.stanford.edu
kdc = krb5auth3.stanford.edu
master_kdc = krb5auth1.stanford.edu
admin_server = krb5-admin.stanford.edu
default_domain = stanford.edu
}

[domain_realm]
.domaine.fr = DOMAINE.FR
domaine.fr = DOMAINE.FR
.mit.edu = ATHENA.MIT.EDU
mit.edu = ATHENA.MIT.EDU
.media.mit.edu = MEDIA-LAB.MIT.EDU
media.mit.edu = MEDIA-LAB.MIT.EDU
.csail.mit.edu = CSAIL.MIT.EDU
csail.mit.edu = CSAIL.MIT.EDU
.whoi.edu = ATHENA.MIT.EDU
whoi.edu = ATHENA.MIT.EDU
.stanford.edu = stanford.edu
.slac.stanford.edu = SLAC.STANFORD.EDU

[login]
krb4_convert = true
krb4_get_tickets = false

[/code]

Voici les principaux tuto que j’ai suivis:

http://iclementonline.free.fr/?p=425 (Je pense que mon squid.conf est en règle puisque j’arrive à accéder à internet après avoir rentrer l’adresse du proxy dans outil>option>avancé>réseau>paramètre (sous Firefox) )

iclementonline.free.fr/?p=435

http://client.olfeo.com/article.php3?id_article=49

En espérant que vous m’aidiez à résoudre mon problème.

Cordialement, morgane

Edit :
Je vais me taire ou je vais être désagréable.

Quelle est ta question exactement ?

Ui c’est vrai…,

en faites je n’arrive pas à joindre mon AD, pour aller chercher les utilisateurs qu’il y a et leur mettre les restriction du proxy, c’est tout le temps ce messages:

failed to join domain failed to find dc for domain

Tu tapes quelle commande pour joindre le domaine ?
net ads join -S SERVER -U USER
Tu peu aussi utiliser cette commande (moin sécurisé je crois)
net join -S SERVER -U USER -W DOMAIN

Je l’ai fait il y longtemps mais je crois que tu dois déja indiquer le nom complet de ton pdc dans tes fichiers de conf.
Ex :
kdc = SERVEUR.DOMAINE:88
admin_server = SERVEUR.DOMAINE:749

DAns smb.conf ajouter un :
passwd server = serveur.domaine ou adresse IP

As tu installé Winbind ?

Merci de vos réponses, alors

[quote=“infernum”]
net ads join -S SERVER -U USER[/quote]

et

me donne tout les deux

Failed to join domain: failed to find DC for domain DOMAINE.FR

J’ai remplacer ce que tu as dis (rajouter)

[quote=“infernum”]
As tu installé Winbind ?[/quote]

Oui je l’ai installé (mais je n’ai pas trop compris à quoi il servait)…

winbind permet de récupérer la liste des users de ton domaine et de les faire connaitre au système.
Tu trouves pas mal d’infos sur son utilisé sur le net.

Pour ton intégration au domaine, ton problème semble être coté DNS apparement, tu arrives à pinguer ton pdc via son nom ?
dans /etc/hosts ajoute
XXX.XXX.XXX.XXX serveur
XXX.XXX.XXX.XXX serveur.domaine.fr

ca devrait aller mieux

Problème réglé (enfin si on peut dire sa comme sa…)

Je viens de me faire enguirlandé par le chef du services informatique de mon hôpital, car j’ai installé un second AD sur leur réseau, et il ma ordonné de supprimer tout cela, car il ne voulait pas avoir de souci sur ce serveur ^^

Donc, je vais tout recommencer du début, et tout réinstaller…

Merci quand même de votre aide et bonne journée!

[quote=“rotordao”]
Oui je l’ai installé (mais je n’ai pas trop compris à quoi il servait)…[/quote]
Change d’option ton futur s’annonce bien sombre.

Désolé de ne pas savoir sa, j’oubliais que les personnes qui ne savent pas sa ne sont pas faîtes pour l’informatique !

J’ai très peu fait de linux, donc ligne de commande, je commence seulement.

SUR CE…

[quote=“tuxshake”][quote=“rotordao”]
Oui je l’ai installé (mais je n’ai pas trop compris à quoi il servait)…[/quote]
Change d’option ton futur s’annonce bien sombre.[/quote]

Pour une fois que je vois une fille en informatique tu veux la démotiver !!

[quote=“rotordao”]Désolé de ne pas savoir sa, j’oubliais que les personnes qui ne savent pas sa ne sont pas faîtes pour l’informatique !

J’ai très peu fait de linux, donc ligne de commande, je commence seulement.

SUR CE…[/quote]
Tu l’as mal pris, pourtant j’ai pris la peine de te répondre au lieu de t’ignorer.
Apprend déjà a explorer un minimum avant de poser des questions débiles sur des sujets aussi pointus.

En plus tu le prend de haut sans essayer de comprendre pourquoi tu suscites cette réaction.
Un peu d’introspection te ferai le plus grand bien et ça t’éviterai de cumuler les tares sur un fil unique.

Le mot de la fin :
Ce n’est clairement pas a une débutante de mettre en place un tel service sur l’architecture réseau d’un hôpital.
Et ce n’est certainement pas en faisant un copier coller de 3 fichiers que tu vas t’en sortir.

C’est beau la théorie, mais tu oublie que nous vivons dans une société capitaliste et que la sécurité à un prix…et un coût que le stagiaire n’a pas.

Re,

[quote=“tuxshake”]
Tu l’as mal pris,[…][/quote]

J’étais énervée, car sa faisait 2 semaines que je ne comprenais pas mon problème…

Tu as pris la peine de me répondre.

Est ce que au moins les 2 seules messages que tu as poster mon aidé à résoudre mon problème?
Est ce que tes messages parler avais un rapport avec mon problème?
Non,je ne crois pas.

[quote=“tuxshake”]
Apprend déjà a explorer un minimum[…] [/quote]

Pendant les 2 dernières semaines, je n’ai fais que fouiller le net, en cherchant une solution à mon problème, j’ai du visiter des dizaines et des dizaines (voir une bonne centaine) de pages web qui parler du proxy squid et sa configuration avec samba, kerberos, winbind…

Connaît-tu le mot “débutant”?..

[quote=“tuxshake”]
Le mot de la fin :
Ce n’est clairement pas a une débutante de mettre en place un tel service sur l’architecture réseau d’un hôpital.[/quote]
C’est dommage… car grâce à mes efforts j’ai réussie à régler mon problème et à visualiser les utilisateurs sur mon AD, en clair j’ai enfin réussi à joindre mon Active Directory.

Et le proxy que j’ai mis en place, même si il ne l’est pas tout à fait car il me reste à configurer les autorisations et interdictions des utilisateurs, servira à un hôpital de petite taille (environ 300 lits), et un second hôpital de taille moyenne (environ 700 lits).

[quote=“tuxshake”]
Et ce n’est certainement pas en faisant un copier coller de 3 fichiers que tu vas t’en sortir.[/quote]

“Ce copier coller”, comme tu le dis, c’est le fichier de base que j’ai retravailler avec mes connaissances, et comme je l’ai dis plus haut j’avoue ne pas avoir tout compris au début, même si maintenant j’ai compris le principales.

Maintenant, je recherche un ou plusieurs sites afin de configurer correctement le squid, il y a tout sur le site officiel de squid, mais en anglais, et j’avoue que mon Anglais n’est pas fameux.

Donc si quelqu’un à des propositions, j’en serais ravie.

Cordialement

Si tu veux absolument avoir le dernier mot, je te le laisse volontiers.
Par contre vu que tu t’obstines, on va suivre ce fil avec attention .

“You make my day… pebkac”

Cordialement

Petit up

J’ai une nouvelle question (même si j’ai énormément chercher sur le net)

J’aimerais par exemple, que dans mon fichier /var/log/squid3/access.log

Que j’ai l’heure d’afficher et le nom d’utilisateur du post concerné, sachant que mon proxy est déjà connecté avec mon l’AD de mon réseau.

Merci

Je vais encore paraître odieux mais poster sur 3/4 forums en même temps :clap:

Pour tes longues recherches, utilise google ça marche vraiment bien.
google.fr/intl/fr_ALL/help/basics.html

Je conseille aussi de lire cet article.
linux-france.org/article/the … ns-fr.html