ADELINE E InfoEmiAsp wrote:
> In 2.0, authentication is done by external authenticator. AFAIK
> the username  validated by the authenticator is stored in a
> different place than the ident lookup result
This is a bug/misfeature.
Here is a preleminary patch that addresses this bug.
Warning: The syntax for the proxy_auth ACL type is changed by this
patch. You are required to update squid.conf if you apply this patch.
1. Changed "acl user" to "acl ident" since this is what it really is.
2. Moved the proxy_auth timeout from the ACL type to a global
configuration variable (authenticate_ttl).
3. Changed "acl proxy_auth" to include a list of allowed users. Any
authenticated user is "acl authenticated proxy_auth REQUIRED". 
4. Removed restrictions on how and when "acl proxy_auth" can be used. It
is now a normal ACL check like all the other blocking ACL checks.
Logged username is
1. Authenticated user
2. Ident lookup (if enabled)
3. -
I also had plans on changing "acl ident" into a more normal ACL control
that triggers the ident call when needed, but this looks like a bit to
much work right now (requires changes both to the internal ACL interface
and the ident module).
Why ident acl:s should do the ident lookups when needed: Some hosts does
not respond to ident calls or is not trusted. Ident is only useful if it
is known to work and the called host is trusted to return valid replies.
Without the possibility to exlude certain (or most) hosts from ident
lookups the ident feature is not practically usable (long delays and/or
invalid usernames).
--- Henrik Nordstrom Spare time Squid Hacker
Index: squid/src/acl.c
diff -u squid/src/acl.c:1.1.1.23 squid/src/acl.c:1.1.1.23.4.1
--- squid/src/acl.c:1.1.1.23	Thu Sep 24 00:19:27 1998
+++ squid/src/acl.c	Thu Oct  8 05:11:58 1998
@@ -51,13 +51,12 @@
 static char *strtokFile(void);
 static void aclDestroyAclList(acl_list * list);
 static void aclDestroyTimeList(acl_time_data * data);
-static void aclDestroyProxyAuth(acl_proxy_auth * p);
 static void aclDestroyIntRange(intrange *);
 static FREE aclFreeProxyAuthUser;
 static int aclMatchAcl(struct _acl *, aclCheck_t *);
 static int aclMatchIntegerRange(intrange * data, int i);
 static int aclMatchTime(acl_time_data * data, time_t when);
-static int aclMatchIdent(wordlist * data, const char *ident);
+static int aclMatchUser(wordlist * data, const char *ident);
 static int aclMatchIp(void *dataptr, struct in_addr c);
 static int aclMatchDomainList(void *dataptr, const char *);
 static int aclMatchIntegerRange(intrange * data, int i);
@@ -69,7 +68,8 @@
 static IPH aclLookupDstIPforASNDone;
 static FQDNH aclLookupSrcFQDNDone;
 static FQDNH aclLookupDstFQDNDone;
-static void aclProxyAuthDone(void *data, char *result);
+static void aclLookupProxyAuthStart(aclCheck_t * checklist);
+static void aclLookupProxyAuthDone(void *data, char *result);
 static wordlist *aclDumpIpList(void *);
 static wordlist *aclDumpDomainList(void *data);
 static wordlist *aclDumpTimeSpecList(acl_time_data *);
@@ -78,7 +78,6 @@
 static wordlist *aclDumpIntRangeList(intrange * data);
 static wordlist *aclDumpProtoList(intlist * data);
 static wordlist *aclDumpMethodList(intlist * data);
-static wordlist *aclDumpProxyAuthList(acl_proxy_auth * data);
 static SPLAYCMP aclIpNetworkCompare;
 static SPLAYCMP aclHostDomainCompare;
 static SPLAYCMP aclDomainCompare;
@@ -160,8 +159,8 @@
         return ACL_URL_REGEX;
     if (!strcmp(s, "port"))
         return ACL_URL_PORT;
-    if (!strcmp(s, "user"))
-	return ACL_USER;
+    if (!strcmp(s, "ident"))
+	return ACL_IDENT;
     if (!strncmp(s, "proto", 5))
         return ACL_PROTO;
     if (!strcmp(s, "method"))
@@ -208,8 +207,8 @@
         return "url_regex";
     if (type == ACL_URL_PORT)
         return "port";
-    if (type == ACL_USER)
-	return "user";
+    if (type == ACL_IDENT)
+	return "ident";
     if (type == ACL_PROTO)
         return "proto";
     if (type == ACL_METHOD)
@@ -609,36 +608,6 @@
     }
 }
 
-/* default proxy_auth timeout is 3600 seconds */
-#define PROXY_AUTH_TIMEOUT 3600
-
-static void
-aclParseProxyAuth(void *data)
-{
-    acl_proxy_auth *p;
-    acl_proxy_auth **q = data;
-    char *t;
-
-    p = xcalloc(1, sizeof(acl_proxy_auth));
-
-    /* read timeout value (if any) */
-    t = strtok(NULL, w_space);
-    if (t == NULL) {
-	p->timeout = PROXY_AUTH_TIMEOUT;
-    } else {
-	p->timeout = atoi(t);
-    }
-    /* the minimum timeout is 10 seconds */
-    if (p->timeout < 10)
-	p->timeout = 10;
-
-    /* First time around, 7921 should be big enough */
-    p->hash = hash_create((HASHCMP *) strcmp, 7921, hash_string);
-    assert(p->hash);
-    *q = p;
-    return;
-}
-
 static void
 aclParseSnmpComm(void *data)
 {
@@ -728,7 +697,7 @@
     case ACL_URL_PORT:
         aclParseIntRange(&A->data);
         break;
-    case ACL_USER:
+    case ACL_IDENT:
         Config.onoff.ident_lookup = 1;
         aclParseWordList(&A->data);
         break;
@@ -742,7 +711,12 @@
         aclParseRegexList(&A->data);
         break;
     case ACL_PROXY_AUTH:
-	aclParseProxyAuth(&A->data);
+	aclParseWordList(&A->data);
+	if (!proxy_auth_cache) {
+	    /* First time around, 7921 should be big enough */
+	    proxy_auth_cache = hash_create((HASHCMP *) strcmp, 7921, hash_string);
+	    assert(proxy_auth_cache);
+	}
         break;
     case ACL_SNMP_COMM:
         aclParseSnmpComm(&A->data);
@@ -974,109 +948,149 @@
 }
 
 static int
-aclMatchIdent(wordlist * data, const char *ident)
+aclMatchUser(wordlist * data, const char *user)
 {
-    if (ident == NULL)
+    if (user == NULL)
         return 0;
-    debug(28, 3) ("aclMatchIdent: checking '%s'\n", ident);
+    debug(28, 3) ("aclMatchUser: checking '%s'\n", user);
     while (data) {
-	debug(28, 3) ("aclMatchIdent: looking for '%s'\n", data->key);
-	if (strcmp(data->key, "REQUIRED") == 0 && *ident != '\0')
+	debug(28, 3) ("aclMatchUser: looking for '%s'\n", data->key);
+	if (strcmp(data->key, "REQUIRED") == 0 && *user != '\0')
             return 1;
-	if (strcmp(data->key, ident) == 0)
+	if (strcmp(data->key, user) == 0)
             return 1;
         data = data->next;
     }
     return 0;
 }
 
-/* aclMatchProxyAuth can return three exit codes:
- * 0 : No such user; invalid Proxy-authorization: header;
- * ask for Proxy-Authorization: header
- * 1 : user validated OK
- * -1 : check the password for this user via an external authenticator
- */
-
-static int
-aclMatchProxyAuth(acl_proxy_auth * p, aclCheck_t * checklist)
+static int aclDecodeProxyAuth(const char *proxy_auth, char **user, char **password, char *buf, size_t bufsize)
 {
-    LOCAL_ARRAY(char, sent_user, USER_IDENT_SZ);
-    const char *s;
-    char *cleartext;
     char *sent_auth;
-    char *passwd = NULL;
-    acl_proxy_auth_user *u;
-    s = httpHeaderGetStr(&checklist->request->header, HDR_PROXY_AUTHORIZATION);
-    if (s == NULL)
+    char *cleartext;
+
+    if (proxy_auth == NULL)
         return 0;
-    if (strlen(s) < SKIP_BASIC_SZ)
+    if (strlen(proxy_auth) < SKIP_BASIC_SZ)
         return 0;
-    s += SKIP_BASIC_SZ;
-    sent_auth = xstrdup(s);	/* username and password */
+    proxy_auth += SKIP_BASIC_SZ;
+    sent_auth = xstrdup(proxy_auth);	/* username and password */
     /* Trim trailing \n before decoding */
     strtok(sent_auth, "\n");
+    /* Trim leading whitespace before decoding */
+    while(isspace(*proxy_auth))
+	proxy_auth++;
     cleartext = uudecode(sent_auth);
     xfree(sent_auth);
-    debug(28, 6) ("aclMatchProxyAuth: cleartext = '%s'\n", cleartext);
-    xstrncpy(sent_user, cleartext, USER_IDENT_SZ);
+    debug(28, 6) ("aclDecodeProxyAuth: cleartext = '%s'\n", cleartext);
+    xstrncpy(buf, cleartext, bufsize);
     xfree(cleartext);
-    if ((passwd = strchr(sent_user, ':')) != NULL)
-	*passwd++ = '\0';
-    if (passwd == NULL) {
-	debug(28, 1) ("aclMatchProxyAuth: no passwd in proxy authorization header\n");
+    *user=buf;
+    if ((*password = strchr(*user, ':')) != NULL)
+	*(*password)++ = '\0';
+    if (password == NULL) {
+	debug(28, 1) ("aclDecodeProxyAuth: no password in proxy authorization header\n");
         return 0;
     }
-    debug(28, 5) ("aclMatchProxyAuth: checking user '%s'\n", sent_user);
-    /* copy username to checklist for logging on client-side */
-    xstrncpy(checklist->request->user_ident, sent_user, USER_IDENT_SZ);
-
-    /* see if we already know this user */
-    u = hash_lookup(p->hash, sent_user);
-    if (NULL == u) {
-	/* user not yet known, ask external authenticator */
-	debug(28, 4) ("aclMatchProxyAuth: user '%s' not yet known\n", sent_user);
-    } else {
-	/* user already known, check password with the cached one */
-	if ((0 == strcmp(u->passwd, passwd)) &&
-	    (u->expiretime > current_time.tv_sec)) {
+    return 1;
+}
+
+/* aclMatchProxyAuth can return three exit codes:
+ * 0 : No such user; invalid Proxy-authorization: header;
+ * ask for Proxy-Authorization: header
+ * 1 : user validated OK
+ * -1 : check the password for this user via an external authenticator
+ */
+
+static int
+aclMatchProxyAuth(const char * proxy_auth, acl_proxy_auth_user * auth_user, aclCheck_t * checklist)
+{
+    /* checklist is used to register user name when identified, nothing else */
+    LOCAL_ARRAY(char, login_buf, USER_IDENT_SZ);
+    char *user, *password;
+
+    if (!aclDecodeProxyAuth(proxy_auth, &user, &password, login_buf, sizeof(login_buf)))
+	/* No or invalid Proxy-Auth header */
+	return 0;
+
+    debug(28, 5) ("aclMatchProxyAuth: checking user '%s'\n", user);
+
+    if (!auth_user)  {
+	/* see if we already know this user */
+	auth_user = hash_lookup(proxy_auth_cache, user);
+	if (!auth_user) {
+	    /* user not yet known, ask external authenticator */
+	    debug(28, 4) ("aclMatchProxyAuth: user '%s' not yet known\n", user);
+	    return -1;
+	} else if ((0 == strcmp(auth_user->passwd, password)) &&
+	    (auth_user->expiretime > current_time.tv_sec)) {
+	    /* user already known and valid */
             debug(28, 5) ("aclMatchProxyAuth: user '%s' previously validated\n",
-		sent_user);
+		user);
+	    /* copy username to request for logging on client-side */
+	    xstrncpy(checklist->request->user_ident, user, USER_IDENT_SZ);
             return 1;
+	} else {
+	    /* password mismatch/timeout */
+	    debug(28, 4) ("aclMatchProxyAuth: user '%s' password mismatch/timeout\n",
+		user);
+	    /* remove this user from the hash, making him unknown */
+	    hash_remove_link(proxy_auth_cache, (hash_link *) auth_user);
+	    aclFreeProxyAuthUser(auth_user);
+	    /* copy username to request for logging on client-side unless ident
+	     * is known (do not override ident with false proxy auth names) */
+	    if (!*checklist->request->user_ident)
+		xstrncpy(checklist->request->user_ident, user, USER_IDENT_SZ);
+	    return -1;
         }
-	/* password mismatch/timeout */
-	debug(28, 4) ("aclMatchProxyAuth: user '%s' password mismatch/timeout\n",
-	    sent_user);
-	/* remove this user from the hash, making him unknown */
-	hash_remove_link(p->hash, (hash_link *) u);
-	aclFreeProxyAuthUser(u);
-    }
-
-    /* we've got an unknown user now */
-    if (checklist->auth_user == NULL) {
-	/* we must still check this user's password */
-	u = memAllocate(MEM_ACL_PROXY_AUTH_USER);
-	u->user = xstrdup(sent_user);
-	u->passwd = xstrdup(passwd);
-	u->passwd_ok = 0;
-	u->expiretime = 0;
-	checklist->auth_user = u;
-	debug(28, 4) ("aclMatchProxyAuth: going to ask authenticator\n");
-	return -1;
-    }
-    /* checklist->auth_user has just been checked, check result */
-    if (checklist->auth_user->passwd_ok == -1) {
-	/* password was checked but did not match */
-	debug(28, 4) ("aclMatchProxyAuth: authentication failed for user '%s'\n",
-	    sent_user);
-	return 0;
+	/* NOTREACHED */
+    } else {
+	/* Check result from external validation */
+	if (checklist->auth_user->passwd_ok != 1) {
+	    /* password was checked but did not match */
+	    assert(checklist->auth_user->passwd_ok == 0);
+	    debug(28, 4) ("aclMatchProxyAuth: authentication failed for user '%s'\n",
+		user);
+	    return 0;
+	}
+	debug(28, 4) ("aclMatchProxyAuth: user '%s' validated OK\n", user);
+	/* store validated user in hash, after filling in expiretime */
+	checklist->auth_user->expiretime = current_time.tv_sec + Config.authenticateTTL;
+	hash_join(proxy_auth_cache, (hash_link *) checklist->auth_user);
+
+	return 1;
     }
-    /* checklist->auth_user->passwd_ok == 1, passwd check OK */
-    debug(28, 4) ("aclMatchProxyAuth: user '%s' validated OK\n", sent_user);
-    /* store validated user in hash, after filling in expiretime */
-    checklist->auth_user->expiretime = current_time.tv_sec + p->timeout;
-    hash_join(p->hash, (hash_link *) checklist->auth_user);
 
-    return 1;
+    /* NOTREACHED */
+    
+}
+
+static void
+aclLookupProxyAuthStart(aclCheck_t * checklist)
+{
+    LOCAL_ARRAY(char, login_buf, USER_IDENT_SZ);
+    const char *proxy_auth;
+    char *user, *password;
+    int ok;
+    acl_proxy_auth_user * auth_user;
+
+    assert(!checklist->auth_user);
+
+    proxy_auth=httpHeaderGetStr(&checklist->request->header, HDR_PROXY_AUTHORIZATION);
+    ok=aclDecodeProxyAuth(proxy_auth, &user, &password, login_buf, sizeof(login_buf));
+    assert(ok); /* We should never get here unless the above succeeds in aclMatchProxyAuth */
+
+    debug(28, 4) ("aclLookupProxyAuthStart: going to ask authenticator on %s\n", user);
+    /* we must still check this user's password */
+    auth_user = memAllocate(MEM_ACL_PROXY_AUTH_USER);
+    auth_user->user = xstrdup(user);
+    auth_user->passwd = xstrdup(password);
+    auth_user->passwd_ok = -1;
+    auth_user->expiretime = -1;
+    checklist->auth_user = auth_user;
+    
+    authenticateStart(checklist->auth_user, aclLookupProxyAuthDone,
+	checklist);
 }
 
 static int
@@ -1254,8 +1268,8 @@
     case ACL_URL_PORT:
         return aclMatchIntegerRange(acl->data, r->port);
         /* NOTREACHED */
-    case ACL_USER:
-	return aclMatchIdent(acl->data, checklist->ident);
+    case ACL_IDENT:
+	return aclMatchUser(acl->data, checklist->ident);
         /* NOTREACHED */
     case ACL_PROTO:
         return aclMatchInteger(acl->data, r->protocol);
@@ -1267,19 +1281,24 @@
         return aclMatchRegex(acl->data, checklist->browser);
         /* NOTREACHED */
     case ACL_PROXY_AUTH:
-	k = aclMatchProxyAuth(acl->data, checklist);
+	k = aclMatchProxyAuth(httpHeaderGetStr(&checklist->request->header, HDR_PROXY_AUTHORIZATION), checklist->auth_user, checklist);
         if (k == 0) {
             /* no such user OR we need a proxy authentication header */
             checklist->state[ACL_PROXY_AUTH] = ACL_PROXY_AUTH_NEEDED;
+	    /* XXX This is a bit oddly done.. should perhaps use different
+	     * return codes here
+	     */
             return 0;
         } else if (k == 1) {
-	    /* register that we used the proxy authentication header */
-	    checklist->state[ACL_PROXY_AUTH] = ACL_PROXY_AUTH_USED;
+	    /* Authentication successful. Register that we used the proxy
+	     * authentication header so that it is not forwarded to the
+	     * next proxy
+	     */
             r->flags.used_proxy_auth = 1;
             return 1;
         } else if (k == -1) {
-	    /* register that we need to check the password */
-	    checklist->state[ACL_PROXY_AUTH] = ACL_PROXY_AUTH_CHECK;
+	    /* we need to validate the password */
+	    checklist->state[ACL_PROXY_AUTH] = ACL_LOOKUP_NEEDED;
             return 0;
         }
         /* NOTREACHED */
@@ -1399,26 +1418,30 @@
                 aclLookupDstFQDNDone,
                 checklist);
             return;
-	}
-	/* extra case for proxy_auth */
-	if (checklist->state[ACL_PROXY_AUTH] == ACL_PROXY_AUTH_CHECK) {
+	} else if (checklist->state[ACL_PROXY_AUTH] == ACL_LOOKUP_NEEDED) {
             debug(28, 3) ("aclCheck: checking password via authenticator\n");
-	    authenticateStart(checklist->auth_user, aclProxyAuthDone,
-		checklist);
+	    aclLookupProxyAuthStart(checklist);
+	    checklist->state[ACL_PROXY_AUTH] = ACL_LOOKUP_PENDING;
+	    return;
+	} else if (checklist->state[ACL_PROXY_AUTH] == ACL_PROXY_AUTH_NEEDED) {
+	    /* Special case. Client is required to resend the request
+	     * with authentication. The request is denied.
+	     */
+	    allow = ACCESS_REQ_PROXY_AUTH;
+	    match = -1;
+	} else if (checklist->state[ACL_IDENT] == ACL_LOOKUP_NEEDED) {
+	    debug(28, 3) ("aclCheck: Doing ident lookup\n");
+	    /* XXX how to do ident lookup? */
+	    checklist->state[ACL_IDENT] = ACL_LOOKUP_PENDING;
             return;
         }
         /*
          * We are done with this _acl_access entry.  Either the request
-	 * is allowed, denied, or we move on to the next entry.
+	 * is allowed, denied, requires authentication, or we move on to
+	 * the next entry.
          */
         cbdataUnlock(A);
-	if (checklist->state[ACL_PROXY_AUTH] == ACL_PROXY_AUTH_NEEDED) {
-	    allow = ACCESS_REQ_PROXY_AUTH;
-	    debug(28, 3) ("aclCheck: match pending, returning %d\n", allow);
-	    aclCheckCallback(checklist, allow);
-	    return;
-	}
-	/* checklist->state[ACL_PROXY_AUTH] == ACL_PROXY_AUTH_USED */
+
         if (match) {
             debug(28, 3) ("aclCheck: match found, returning %d\n", allow);
             aclCheckCallback(checklist, allow);
@@ -1495,15 +1518,15 @@
 }
 
 static void
-aclProxyAuthDone(void *data, char *result)
+aclLookupProxyAuthDone(void *data, char *result)
 {
     aclCheck_t *checklist = data;
     checklist->state[ACL_PROXY_AUTH] = ACL_LOOKUP_DONE;
-    debug(28, 4) ("aclProxyAuthDone: result = %s\n", result);
+    debug(28, 4) ("aclLookupProxyAuthDone: result = %s\n", result);
     if (result && (strncasecmp(result, "OK", 2) == 0))
         checklist->auth_user->passwd_ok = 1;
     else
-	checklist->auth_user->passwd_ok = -1;
+	checklist->auth_user->passwd_ok = 0;
     aclCheck(checklist);
 }
 
@@ -1586,15 +1609,6 @@
     memFree(MEM_ACL_PROXY_AUTH_USER, u);
 }
 
-static void
-aclDestroyProxyAuth(acl_proxy_auth * p)
-{
-    hashFreeItems(p->hash, aclFreeProxyAuthUser);
-    hashFreeMemory(p->hash);
-    p->hash = NULL;
-    safe_free(p);
-}
-
 void
 aclDestroyAcls(acl ** head)
 {
@@ -1613,7 +1627,8 @@
         case ACL_SRC_DOMAIN:
             splay_destroy(a->data, xfree);
             break;
-	case ACL_USER:
+	case ACL_IDENT:
+	case ACL_PROXY_AUTH:
             wordlistDestroy((wordlist **) & a->data);
             break;
         case ACL_TIME:
@@ -1633,9 +1648,6 @@
         case ACL_URL_PORT:
             aclDestroyIntRange(a->data);
             break;
-	case ACL_PROXY_AUTH:
-	    aclDestroyProxyAuth(a->data);
-	    break;
         case ACL_NONE:
         default:
             assert(0);
@@ -1959,21 +1971,6 @@
     return W;
 }
 
-static wordlist *
-aclDumpProxyAuthList(acl_proxy_auth * data)
-{
-    wordlist *W = NULL;
-    wordlist **T = &W;
-    char buf[MAXPATHLEN];
-    wordlist *w = xcalloc(1, sizeof(wordlist));
-    assert(data != NULL);
-    snprintf(buf, sizeof(buf), "%d\n", data->timeout);
-    w->key = xstrdup(buf);
-    *T = w;
-    T = &w->next;
-    return W;
-}
-
 wordlist *
 aclDumpGeneric(const acl * a)
 {
@@ -1984,7 +1981,8 @@
         break;
     case ACL_SRC_DOMAIN:
     case ACL_DST_DOMAIN:
-    case ACL_USER:
+    case ACL_IDENT:
+    case ACL_PROXY_AUTH:
         return aclDumpDomainList(a->data);
         break;
     case ACL_TIME:
@@ -2007,9 +2005,6 @@
         break;
     case ACL_METHOD:
         return aclDumpMethodList(a->data);
-	break;
-    case ACL_PROXY_AUTH:
-	return aclDumpProxyAuthList(a->data);
         break;
 #if USE_ARP_ACL
     case ACL_SRC_ARP:
Index: squid/src/cf.data.pre
diff -u squid/src/cf.data.pre:1.1.1.24 squid/src/cf.data.pre:1.1.1.24.2.1
--- squid/src/cf.data.pre:1.1.1.24	Sat Oct  3 02:58:10 1998
+++ squid/src/cf.data.pre	Thu Oct  8 05:11:58 1998
@@ -974,6 +974,19 @@
 authenticate_children 5
 DOC_END
 
+NAME: authenticate_ttl
+TYPE: int
+DEFAULT: 3600
+LOC: Config.authenticateTTL
+DOC_START
+	The time a checked username/password combination remains cached
+	(default 3600). If a wrong password is given for a cached user,
+	the user gets removed from the username/password cache forcing
+	a revalidation.
+
+authenticate_ttl 3600
+DOC_END
+
 COMMENT_START
  OPTIONS FOR TUNING THE CACHE
  -----------------------------------------------------------------------------
@@ -1352,9 +1365,9 @@
         acl aclname proto    HTTP FTP ...
         acl aclname method   GET POST ...
         acl aclname browser  regexp
-	acl aclname user     username ...	# string match on ident output.
-						# use REQUIRED to accept any
-						# non-null ident.
+	acl aclname ident    username ...
+	  # string match on ident output.
+	  # use REQUIRED to accept any non-null ident.
         acl aclname src_as   number ... 
         acl aclname dst_as   number ...
           # Except for access control, AS numbers can be used for
@@ -1365,22 +1378,16 @@
           # cache_peer_access allow mycache.mydomain.net asexample
           # cache_peer_access deny mycache_mydomain.net all
 
-	acl aclname proxy_auth [ refresh ]
+	acl aclname proxy_auth username ...
           # Use an EXTERNAL authentication program to check username/password
           # combinations (see authenticate_program).
           #
-	  # 'timeout' is the time a checked username/password combination
-	  # remains cached (default = 3600 secs). If a wrong password
-	  # is given for a cached user, the user gets removed from the
-	  # username/password cache forcing a revalidation.
-	  #
-	  # When using a proxy_auth ACL in an http_access rule, make sure
-	  # it is the *last* in the list and the only proxy_auth ACL in
-	  # the list.
+	  # use REQUIRED to accept any valid username.
           #
           # NOTE: when a Proxy-Authentication header is sent but it is not
           # needed during ACL checking the username is NOT logged
           # in access.log.
+	  #
 
 acl manager proto cache_object
 acl localhost src 127.0.0.1/255.255.255.255
Index: squid/src/enums.h
diff -u squid/src/enums.h:1.1.1.26 squid/src/enums.h:1.1.1.26.2.1
--- squid/src/enums.h:1.1.1.26	Sat Oct  3 02:58:13 1998
+++ squid/src/enums.h	Thu Oct  8 05:11:59 1998
@@ -96,7 +96,7 @@
     ACL_URLPATH_REGEX,
     ACL_URL_REGEX,
     ACL_URL_PORT,
-    ACL_USER,
+    ACL_IDENT,
     ACL_PROTO,
     ACL_METHOD,
     ACL_BROWSER,
@@ -114,9 +114,7 @@
     ACL_LOOKUP_NEEDED,
     ACL_LOOKUP_PENDING,
     ACL_LOOKUP_DONE,
-    ACL_PROXY_AUTH_NEEDED,
-    ACL_PROXY_AUTH_USED,
-    ACL_PROXY_AUTH_CHECK
+    ACL_PROXY_AUTH_NEEDED
 } acl_lookup_state;
 
 enum {
Index: squid/src/globals.h
diff -u squid/src/globals.h:1.1.1.21 squid/src/globals.h:1.1.1.21.4.1
--- squid/src/globals.h:1.1.1.21	Thu Sep 24 00:19:34 1998
+++ squid/src/globals.h	Thu Oct  8 05:11:59 1998
@@ -143,3 +143,4 @@
 #endif
 extern request_flags null_request_flags;
 extern int open_disk_fd;	/* 0 */
+extern hash_table *proxy_auth_cache; /* NULL */
Index: squid/src/structs.h
diff -u squid/src/structs.h:1.1.1.29 squid/src/structs.h:1.1.1.29.2.1
--- squid/src/structs.h:1.1.1.29	Sat Oct  3 02:58:27 1998
+++ squid/src/structs.h	Thu Oct  8 05:11:59 1998
@@ -58,11 +58,6 @@
     acl_name_list *next;
 };
 
-struct _acl_proxy_auth {
-    int timeout;		/* timeout value for cached usercode:password entries */
-    hash_table *hash;
-};
-
 struct _acl_proxy_auth_user {
     /* first two items must be same as hash_link */
     char *user;
@@ -296,6 +291,7 @@
     int dnsChildren;
     int redirectChildren;
     int authenticateChildren;
+    int authenticateTTL;
     struct {
         char *host;
         u_short port;
Received on Thu Oct 08 1998 - 21:37:03 MDT
This archive was generated by hypermail pre-2.1.9 : Tue Dec 09 2003 - 16:42:24 MST