Current Path: > > usr > lib > python2.7 > site-packages > pip > _vendor > > > cachecontrol
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
caches | Directory | - | - | |
__init__.py | File | 302 bytes | April 21 2022 18:08:21. | |
__init__.pyc | File | 583 bytes | April 21 2022 18:08:34. | |
__init__.pyo | File | 583 bytes | April 21 2022 18:08:34. | |
_cmd.py | File | 1320 bytes | April 21 2022 18:08:21. | |
_cmd.pyc | File | 2059 bytes | April 21 2022 18:08:34. | |
_cmd.pyo | File | 2059 bytes | April 21 2022 18:08:34. | |
adapter.py | File | 4608 bytes | April 21 2022 18:08:21. | |
adapter.pyc | File | 3523 bytes | April 21 2022 18:08:34. | |
adapter.pyo | File | 3523 bytes | April 21 2022 18:08:34. | |
cache.py | File | 790 bytes | April 21 2022 18:08:21. | |
cache.pyc | File | 2401 bytes | April 21 2022 18:08:34. | |
cache.pyo | File | 2401 bytes | April 21 2022 18:08:34. | |
compat.py | File | 380 bytes | April 21 2022 18:08:21. | |
compat.pyc | File | 618 bytes | April 21 2022 18:08:34. | |
compat.pyo | File | 618 bytes | April 21 2022 18:08:34. | |
controller.py | File | 13024 bytes | April 21 2022 18:08:21. | |
controller.pyc | File | 9078 bytes | April 21 2022 18:08:34. | |
controller.pyo | File | 9078 bytes | April 21 2022 18:08:34. | |
filewrapper.py | File | 2531 bytes | April 21 2022 18:08:21. | |
filewrapper.pyc | File | 2667 bytes | April 21 2022 18:08:34. | |
filewrapper.pyo | File | 2667 bytes | April 21 2022 18:08:34. | |
heuristics.py | File | 4141 bytes | April 21 2022 18:08:21. | |
heuristics.pyc | File | 5937 bytes | April 21 2022 18:08:34. | |
heuristics.pyo | File | 5937 bytes | April 21 2022 18:08:34. | |
serialize.py | File | 6536 bytes | April 21 2022 18:08:21. | |
serialize.pyc | File | 6096 bytes | April 21 2022 18:08:34. | |
serialize.pyo | File | 6096 bytes | April 21 2022 18:08:34. | |
wrapper.py | File | 498 bytes | April 21 2022 18:08:21. | |
wrapper.pyc | File | 696 bytes | April 21 2022 18:08:34. | |
wrapper.pyo | File | 696 bytes | April 21 2022 18:08:34. |
import types import functools from pip._vendor.requests.adapters import HTTPAdapter from .controller import CacheController from .cache import DictCache from .filewrapper import CallbackFileWrapper class CacheControlAdapter(HTTPAdapter): invalidating_methods = set(['PUT', 'DELETE']) def __init__(self, cache=None, cache_etags=True, controller_class=None, serializer=None, heuristic=None, *args, **kw): super(CacheControlAdapter, self).__init__(*args, **kw) self.cache = cache or DictCache() self.heuristic = heuristic controller_factory = controller_class or CacheController self.controller = controller_factory( self.cache, cache_etags=cache_etags, serializer=serializer, ) def send(self, request, **kw): """ Send a request. Use the request information to see if it exists in the cache and cache the response if we need to and can. """ if request.method == 'GET': cached_response = self.controller.cached_request(request) if cached_response: return self.build_response(request, cached_response, from_cache=True) # check for etags and add headers if appropriate request.headers.update( self.controller.conditional_headers(request) ) resp = super(CacheControlAdapter, self).send(request, **kw) return resp def build_response(self, request, response, from_cache=False): """ Build a response by making a request or using the cache. This will end up calling send and returning a potentially cached response """ if not from_cache and request.method == 'GET': # Check for any heuristics that might update headers # before trying to cache. if self.heuristic: response = self.heuristic.apply(response) # apply any expiration heuristics if response.status == 304: # We must have sent an ETag request. This could mean # that we've been expired already or that we simply # have an etag. In either case, we want to try and # update the cache if that is the case. cached_response = self.controller.update_cached_response( request, response ) if cached_response is not response: from_cache = True # We are done with the server response, read a # possible response body (compliant servers will # not return one, but we cannot be 100% sure) and # release the connection back to the pool. response.read(decode_content=False) response.release_conn() response = cached_response # We always cache the 301 responses elif response.status == 301: self.controller.cache_response(request, response) else: # Wrap the response file with a wrapper that will cache the # response when the stream has been consumed. response._fp = CallbackFileWrapper( response._fp, functools.partial( self.controller.cache_response, request, response, ) ) if response.chunked: super_update_chunk_length = response._update_chunk_length def _update_chunk_length(self): super_update_chunk_length() if self.chunk_left == 0: self._fp._close() response._update_chunk_length = types.MethodType(_update_chunk_length, response) resp = super(CacheControlAdapter, self).build_response( request, response ) # See if we should invalidate the cache. if request.method in self.invalidating_methods and resp.ok: cache_url = self.controller.cache_url(request.url) self.cache.delete(cache_url) # Give the request a from_cache attr to let people use it resp.from_cache = from_cache return resp def close(self): self.cache.close() super(CacheControlAdapter, self).close()
SILENT KILLER Tool