/* */ #include "HttpHeaderProcessor.h" #include "message.h" #include "Util.h" void HttpHeaderProcessor::update(const char* data, int32_t length) throw(DlAbortEx*) { checkHeaderLimit(length); strm.write(data, length); } void HttpHeaderProcessor::update(const string& data) throw(DlAbortEx*) { checkHeaderLimit(data.size()); strm << data; } void HttpHeaderProcessor::checkHeaderLimit(int32_t incomingLength) throw(DlAbortEx*) { strm.seekg(0, ios::end); if((int32_t)strm.tellg()+incomingLength > _limit) { throw new DlAbortEx("Too large http header"); } } bool HttpHeaderProcessor::eoh() const { string str = strm.str(); if(str.find("\r\n\r\n") == string::npos && str.find("\n\n") == string::npos) { return false; } else { return true; } } int32_t HttpHeaderProcessor::getPutBackDataLength() const { string str = strm.str(); string::size_type delimpos = string::npos; if((delimpos = str.find("\r\n\r\n")) != string::npos) { return str.size()-(delimpos+4); } else if((delimpos = str.find("\n\n")) != string::npos) { return str.size()-(delimpos+2); } else { return 0; } } void HttpHeaderProcessor::clear() { strm.str(""); } pair HttpHeaderProcessor::getHttpStatusHeader() throw(DlRetryEx*) { strm.seekg(0, ios::beg); string line; getline(strm, line); // check HTTP status value if(line.size() <= 12) { throw new DlRetryEx(EX_NO_STATUS_HEADER); } string status = line.substr(9, 3); HttpHeaderHandle httpHeader = new HttpHeader(); while(getline(strm, line)) { line = Util::trim(line); if(line.empty()) { break; } pair hp; Util::split(hp, line, ':'); httpHeader->put(hp.first, hp.second); } return pair(status, httpHeader); } string HttpHeaderProcessor::getHeaderString() const { string str = strm.str(); string::size_type delimpos = string::npos; if((delimpos = str.find("\r\n\r\n")) != string::npos || (delimpos = str.find("\n\n")) != string::npos) { return str.substr(0, delimpos); } else { return str; } }