Squid Web Cache wiki

Squid Web Cache documentation

🔗 Configuring Squid to authenticate against multiple services

by Joseph Spadavecchia

🔗 Outline

We have a requirement to use different authentication mechanisms based on the subnet/ip-address of the client.

The use case:

To date this is normally done by running multiple instances of squid; but we have the requirement to do it with a single instance. One way of achieving this would be to modify squid to pass the client’s ip-address along with the authentication information. However, I’d like to do it cleanly without modifying squid.

I created a custom authenticator that always returns “OK” and linked it to the external acl.

:information_source: Squid-3.2 bundles one called basic_fake_auth

🔗 Squid Configuration

auth_param basic program /usr/local/bin/basic_fake_auth

external_acl_type myAclType %SRC %LOGIN %{Proxy-Authorization} /usr/local/bin/my-acl.pl

acl MyAcl external myAclType

http_access allow MyAcl

:information_source: myAclType’s dependence on %LOGIN is required for triggering authentication and, thus, setting %{Proxy-Authorization}.

🔗 my-acl.pl

use URI::Escape;
use MIME::Base64;

$|=1;

while (<>) {
  ($ip,$user,$auth) = split();

  # Retrieve the password from the authentication header
  $auth = uri_unescape($auth);
  ($type,$authData) = split(/ /, $auth);
  $authString = decode_base64($authData);
  ($username,$password) = split(/:/, $authString);

  # do the authentication and pass results back to Squid.
  print my_awsome_auth($ip, $username, $password);
}

:warning: Add your own version of my_awsome_auth() to do the authentication actions you need.


⚠️ Disclaimer: Any example presented here is provided "as-is" with no support
or guarantee of suitability. If you have any further questions about
these examples please email the squid-users mailing list.

Categories: ConfigExample

Navigation: Site Search, Site Pages, Categories, 🔼 go up