def read(self): environ = {} headers = [] remain = CHUNK_SIZE buf = "" buf = read_partial(self.socket, CHUNK_SIZE) i = self.parser.filter_headers(headers, buf) if i == -1 and buf: while True: data = read_partial(self.socket, CHUNK_SIZE) if not data: break buf += data i = self.parser.filter_headers(headers, buf) if i != -1: break self.log.debug("%s", self.parser.status) self.log.debug("Got headers:\n%s" % headers) if self.parser.headers_dict.get('Except', '').lower() == "100-continue": self.socket.send("100 Continue\n") if not self.parser.content_len and not self.parser.is_chunked: wsgi_input = StringIO.StringIO() else: wsgi_input = TeeInput(self.socket, self.parser, buf[i:]) environ = { "wsgi.url_scheme": 'http', "wsgi.input": wsgi_input, "wsgi.errors": sys.stderr, "wsgi.version": (1, 0), "wsgi.multithread": False, "wsgi.multiprocess": True, "wsgi.run_once": False, "SCRIPT_NAME": "", "SERVER_SOFTWARE": self.SERVER_VERSION, "REQUEST_METHOD": self.parser.method, "PATH_INFO": unquote(self.parser.path), "QUERY_STRING": self.parser.query_string, "RAW_URI": self.parser.raw_path, "CONTENT_TYPE": self.parser.headers_dict.get('Content-Type', ''), "CONTENT_LENGTH": str(wsgi_input.len), "REMOTE_ADDR": self.client_address[0], "REMOTE_PORT": self.client_address[1], "SERVER_NAME": self.server_address[0], "SERVER_PORT": self.server_address[1], "SERVER_PROTOCOL": self.parser.raw_version } for key, value in self.parser.headers: key = 'HTTP_' + key.upper().replace('-', '_') if key not in ('HTTP_CONTENT_TYPE', 'HTTP_CONTENT_LENGTH'): environ[key] = value return environ
def read(self): environ = {} headers = [] buf = "" buf = read_partial(self.socket, CHUNK_SIZE) i = self.parser.filter_headers(headers, buf) if i == -1 and buf: while True: data = read_partial(self.socket, CHUNK_SIZE) if not data: break buf += data i = self.parser.filter_headers(headers, buf) if i != -1: break self.log.debug("%s", self.parser.status) self.log.debug("Got headers:\n%s" % headers) if self.parser.headers_dict.get('Except', '').lower() == "100-continue": self.socket.send("100 Continue\n") if not self.parser.content_len and not self.parser.is_chunked: wsgi_input = StringIO.StringIO() else: wsgi_input = TeeInput(self.socket, self.parser, buf[i:]) environ = { "wsgi.url_scheme": 'http', "wsgi.input": wsgi_input, "wsgi.errors": sys.stderr, "wsgi.version": (1, 0), "wsgi.multithread": False, "wsgi.multiprocess": True, "wsgi.run_once": False, "SCRIPT_NAME": "", "SERVER_SOFTWARE": self.SERVER_VERSION, "REQUEST_METHOD": self.parser.method, "PATH_INFO": unquote(self.parser.path), "QUERY_STRING": self.parser.query_string, "RAW_URI": self.parser.raw_path, "CONTENT_TYPE": self.parser.headers_dict.get('Content-Type', ''), "CONTENT_LENGTH": str(wsgi_input.len), "REMOTE_ADDR": self.client_address[0], "REMOTE_PORT": self.client_address[1], "SERVER_NAME": self.server_address[0], "SERVER_PORT": self.server_address[1], "SERVER_PROTOCOL": self.parser.raw_version } for key, value in self.parser.headers: key = 'HTTP_' + key.upper().replace('-', '_') if key not in ('HTTP_CONTENT_TYPE', 'HTTP_CONTENT_LENGTH'): environ[key] = value return environ
def _finalize(self): """ here we wil fetch final trailers if any.""" if self.parser.body_eof(): # handle trailing headers if self.parser.is_chunked and self._is_socket: while not self.parser.trailing_header(self.buf): data = read_partial(self.socket, CHUNK_SIZE) if not data: break self.buf += data del self.buf self._is_socket = False
def _tee(self, length): """ fetch partial body""" while not self.parser.body_eof(): data = read_partial(self.socket, length) self.buf += data chunk, self.buf = self.parser.filter_body(self.buf) if chunk: self.tmp.write(chunk) self.tmp.seek(0, os.SEEK_END) return chunk self._finalize() return ""
def read(self): environ = {} headers = [] buf = "" buf = read_partial(self.socket, CHUNK_SIZE) i = self.parser.filter_headers(headers, buf) if i == -1 and buf: while True: data = read_partial(self.socket, CHUNK_SIZE) if not data: break buf += data i = self.parser.filter_headers(headers, buf) if i != -1: break self.log.debug("%s", self.parser.status) self.log.debug("Headers:\n%s" % headers) if self.parser.headers_dict.get("Expect", "").lower() == "100-continue": self.socket.send("100 Continue\n") if not self.parser.content_len and not self.parser.is_chunked: wsgi_input = StringIO.StringIO() else: wsgi_input = TeeInput(self.socket, self.parser, buf[i:]) if self.debug: # This value should evaluate true if an equivalent application # object may be simultaneously invoked by another process, and # should evaluate false otherwise. In debug mode we fall to one # worker so we comply to pylons and other paster app. wsgi_multiprocess = False else: wsgi_multiprocess = True environ = { "wsgi.url_scheme": "http", "wsgi.input": wsgi_input, "wsgi.errors": sys.stderr, "wsgi.version": (1, 0), "wsgi.multithread": False, "wsgi.multiprocess": wsgi_multiprocess, "wsgi.run_once": False, "SCRIPT_NAME": "", "SERVER_SOFTWARE": self.SERVER_VERSION, "REQUEST_METHOD": self.parser.method, "PATH_INFO": unquote(self.parser.path), "QUERY_STRING": self.parser.query_string, "RAW_URI": self.parser.raw_path, "CONTENT_TYPE": self.parser.headers_dict.get("Content-Type", ""), "CONTENT_LENGTH": str(wsgi_input.len), "REMOTE_ADDR": self.client_address[0], "REMOTE_PORT": self.client_address[1], "SERVER_NAME": self.server_address[0], "SERVER_PORT": self.server_address[1], "SERVER_PROTOCOL": self.parser.raw_version, } for key, value in self.parser.headers: key = "HTTP_" + key.upper().replace("-", "_") if key not in ("HTTP_CONTENT_TYPE", "HTTP_CONTENT_LENGTH"): environ[key] = value return environ