]>
git.ipfire.org Git - thirdparty/squid.git/blob - src/store_key_md5.cc
3 * $Id: store_key_md5.cc,v 1.27 2002/10/13 20:35:05 robertc Exp $
5 * DEBUG: section 20 Storage Manager MD5 Cache Keys
6 * AUTHOR: Duane Wessels
8 * SQUID Web Proxy Cache http://www.squid-cache.org/
9 * ----------------------------------------------------------
11 * Squid is the result of efforts by numerous individuals from
12 * the Internet community; see the CONTRIBUTORS file for full
13 * details. Many organizations have provided support for Squid's
14 * development; see the SPONSORS file for full details. Squid is
15 * Copyrighted (C) 2001 by the Regents of the University of
16 * California; see the COPYRIGHT file for full details. Squid
17 * incorporates software developed and/or copyrighted by other
18 * sources; see the CREDITS file for full details.
20 * This program is free software; you can redistribute it and/or modify
21 * it under the terms of the GNU General Public License as published by
22 * the Free Software Foundation; either version 2 of the License, or
23 * (at your option) any later version.
25 * This program is distributed in the hope that it will be useful,
26 * but WITHOUT ANY WARRANTY; without even the implied warranty of
27 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
28 * GNU General Public License for more details.
30 * You should have received a copy of the GNU General Public License
31 * along with this program; if not, write to the Free Software
32 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
38 static cache_key null_key
[MD5_DIGEST_CHARS
];
41 storeKeyText(const unsigned char *key
)
43 static MemBuf mb
= MemBufNULL
;
46 for (i
= 0; i
< MD5_DIGEST_CHARS
; i
++)
47 memBufPrintf(&mb
, "%02X", *(key
+ i
));
52 storeKeyScan(const char *buf
)
54 static unsigned char digest
[MD5_DIGEST_CHARS
];
58 for (i
= 0; i
< MD5_DIGEST_CHARS
; i
++) {
59 t
[0] = *(buf
+ (j
++));
60 t
[1] = *(buf
+ (j
++));
62 *(digest
+ i
) = (unsigned char) strtol(t
, NULL
, 16);
68 storeKeyHashCmp(const void *a
, const void *b
)
70 const unsigned char *A
= (const unsigned char *)a
;
71 const unsigned char *B
= (const unsigned char *)b
;
73 for (i
= 0; i
< MD5_DIGEST_CHARS
; i
++) {
83 storeKeyHashHash(const void *key
, unsigned int n
)
85 /* note, n must be a power of 2! */
86 const unsigned char *digest
= (const unsigned char *)key
;
87 unsigned int i
= digest
[0]
95 storeKeyPrivate(const char *url
, method_t method
, int id
)
97 static cache_key digest
[MD5_DIGEST_CHARS
];
100 debug(20, 3) ("storeKeyPrivate: %s %s\n",
101 RequestMethodStr
[method
], url
);
103 MD5Update(&M
, (unsigned char *) &id
, sizeof(id
));
104 MD5Update(&M
, (unsigned char *) &method
, sizeof(method
));
105 MD5Update(&M
, (unsigned char *) url
, strlen(url
));
106 MD5Final(digest
, &M
);
111 storeKeyPublic(const char *url
, const method_t method
)
113 static cache_key digest
[MD5_DIGEST_CHARS
];
114 unsigned char m
= (unsigned char) method
;
117 MD5Update(&M
, &m
, sizeof(m
));
118 MD5Update(&M
, (unsigned char *) url
, strlen(url
));
119 MD5Final(digest
, &M
);
124 storeKeyPublicByRequest(request_t
* request
)
126 return storeKeyPublicByRequestMethod(request
, request
->method
);
130 storeKeyPublicByRequestMethod(request_t
* request
, const method_t method
)
132 static cache_key digest
[MD5_DIGEST_CHARS
];
133 unsigned char m
= (unsigned char) method
;
134 const char *url
= urlCanonical(request
);
137 MD5Update(&M
, &m
, sizeof(m
));
138 MD5Update(&M
, (unsigned char *) url
, strlen(url
));
139 if (request
->vary_headers
)
140 MD5Update(&M
, (unsigned char *) request
->vary_headers
, strlen(request
->vary_headers
));
141 MD5Final(digest
, &M
);
146 storeKeyDup(const cache_key
* key
)
148 cache_key
*dup
= (cache_key
*)memAllocate(MEM_MD5_DIGEST
);
149 xmemcpy(dup
, key
, MD5_DIGEST_CHARS
);
154 storeKeyCopy(cache_key
* dst
, const cache_key
* src
)
156 xmemcpy(dst
, src
, MD5_DIGEST_CHARS
);
161 storeKeyFree(const cache_key
* key
)
163 memFree((void *) key
, MEM_MD5_DIGEST
);
167 storeKeyHashBuckets(int nbuckets
)
176 storeKeyNull(const cache_key
* key
)
178 if (memcmp(key
, null_key
, MD5_DIGEST_CHARS
) == 0)
187 memset(null_key
, '\0', MD5_DIGEST_CHARS
);