56 #define READV_MAXCHUNKS 512
57 #define READV_MAXCHUNKSIZE (1024*128)
133 virtual void reset();
142 int parseBody(
char *body,
long long len);
404 void trim(std::string &str);
long filemodtime
Definition: XrdHttpReq.hh:257
virtual bool Data(XrdXrootd::Bridge::Context &info, const struct iovec *iovP, int iovN, int iovL, bool final)
int depth
Definition: XrdHttpReq.hh:210
XResponseType xrdresp
The last response data we got.
Definition: XrdHttpReq.hh:243
void clientMarshallReadAheadList(int nitems)
Definition: XrdHttpReq.hh:174
std::string requestverb
Definition: XrdHttpReq.hh:183
Definition: XrdHttpReq.hh:170
long modtime
Definition: XrdHttpReq.hh:70
long fileflags
Definition: XrdHttpReq.hh:256
std::string buildPartialHdr(long long bytestart, long long byteend, long long filesize, char *token)
Build a partial header for a multipart response.
int parseFirstLine(char *line, int len)
Parse the first line of the header.
long long writtenbytes
In a long write, we track where we have arrived.
Definition: XrdHttpReq.hh:268
Definition: XProtocol.hh:653
bool sendcontinue
Definition: XrdHttpReq.hh:211
XrdHttpProtocol * prot
Definition: XrdHttpReq.hh:93
std::string destination
The destination field specified in the req.
Definition: XrdHttpReq.hh:216
Definition: XrdXrootdBridge.hh:225
XrdOucString resourceplusopaque
The resource specified by the request, including all the opaque data.
Definition: XrdHttpReq.hh:194
XrdOucString m_resource_with_digest
Definition: XrdHttpReq.hh:223
Definition: XrdHttpReq.hh:77
void parseResource(char *url)
void trim(std::string &str)
virtual bool Redir(XrdXrootd::Bridge::Context &info, int port, const char *hname)
Definition: XrdHttpReq.hh:177
ReqType
These are the HTTP/DAV requests that we support.
Definition: XrdHttpReq.hh:165
bool fopened
Definition: XrdHttpReq.hh:259
long long size
Definition: XrdHttpReq.hh:67
Definition: XrdHttpReq.hh:59
XrdOucEnv * opaque
The opaque data, after parsing.
Definition: XrdHttpReq.hh:192
XResponseType
Definition: XProtocol.hh:891
std::size_t hash(const BasicJsonType &j)
hash a JSON value
Definition: XrdOucJson.hh:5221
int parseLine(char *line, int len)
Parse the header.
int iovL
byte count
Definition: XrdHttpReq.hh:251
std::string etext
Definition: XrdHttpReq.hh:245
long long bytestart
Definition: XrdHttpReq.hh:61
virtual bool Error(XrdXrootd::Bridge::Context &info, int ecode, const char *etext)
Definition: XrdHttpReq.hh:178
bool headerok
Tells if we have finished reading the header.
Definition: XrdHttpReq.hh:198
bool keepalive
Definition: XrdHttpReq.hh:208
std::vector< ReadWriteOp > rwOps
The original list of multiple reads to perform.
Definition: XrdHttpReq.hh:203
char fhandle[4]
Definition: XrdHttpReq.hh:258
virtual int File(XrdXrootd::Bridge::Context &info, int dlen)
Definition: XrdHttpReq.hh:166
int httpStatusCode
Definition: XrdHttpReq.hh:80
Definition: XrdHttpReq.hh:65
virtual bool Done(XrdXrootd::Bridge::Context &info)
the result context
Definition: XrdHttpReq.hh:176
long long m_current_chunk_size
Definition: XrdHttpReq.hh:86
std::string buildPartialHdrEnd(char *token)
Build the closing part for a multipart response.
std::string hdr2cgistr
Additional opaque info that may come from the hdr2cgi directive.
Definition: XrdHttpReq.hh:228
int PostProcessHTTPReq(bool final=false)
XErrorCode
Definition: XProtocol.hh:982
readahead_list * ralist
Definition: XrdHttpReq.hh:146
Definition: XrdOucEnv.hh:41
std::string host
The host field specified in the req.
Definition: XrdHttpReq.hh:214
std::string httpStatusText
Definition: XrdHttpReq.hh:81
std::vector< ReadWriteOp > rwOps_split
Definition: XrdHttpReq.hh:206
int parseBody(char *body, long long len)
Parse the body of a request, assuming that it's XML and that it's entirely in memory.
std::string m_req_digest
The requested digest type.
Definition: XrdHttpReq.hh:219
unsigned int rwOpDone
To coordinate multipart responses across multiple calls.
Definition: XrdHttpReq.hh:237
bool m_transfer_encoding_chunked
Definition: XrdHttpReq.hh:84
std::string m_digest_header
The computed digest for the HTTP response header.
Definition: XrdHttpReq.hh:225
int PostProcessChecksum(std::string &digest_header)
int ReqReadV()
Prepare the buffers for sending a readv request.
void mapXrdErrorToHttpStatus()
Definition: XrdHttpProtocol.hh:76
long id
Definition: XrdHttpReq.hh:68
Definition: XrdXrootdBridge.hh:293
Definition: XrdHttpReq.hh:168
void clientUnMarshallReadAheadList(int nitems)
ClientRequest xrdreq
The last issued xrd request, often pending.
Definition: XrdHttpReq.hh:240
std::string stringresp
If we want to give a string as a response, we compose it here.
Definition: XrdHttpReq.hh:262
long long length
Definition: XrdHttpReq.hh:209
int iovN
array count
Definition: XrdHttpReq.hh:250
Definition: XrdHttpReq.hh:175
long long m_current_chunk_offset
Definition: XrdHttpReq.hh:85
int reqstate
State machine to talk to the bridge.
Definition: XrdHttpReq.hh:265
long long filesize
Definition: XrdHttpReq.hh:255
XrdHttpReq(XrdHttpProtocol *protinstance)
Definition: XrdHttpReq.hh:118
bool m_appended_hdr2cgistr
Definition: XrdHttpReq.hh:229
Definition: XrdHttpReq.hh:167
long long byteend
Definition: XrdHttpReq.hh:62
void appendOpaque(XrdOucString &s, XrdSecEntity *secent, char *hash, time_t tnow)
XErrorCode xrderrcode
Definition: XrdHttpReq.hh:244
Definition: XrdSecEntity.hh:63
Definition: XProtocol.hh:838
XrdOucString redirdest
Definition: XrdHttpReq.hh:246
ReqType request
The request we got.
Definition: XrdHttpReq.hh:182
XrdOucString resource
The resource specified by the request, stripped of opaque data.
Definition: XrdHttpReq.hh:190
Definition: XrdHttpReq.hh:171
Definition: XrdHttpReq.hh:169
struct iovec * iovP
The latest data chunks got from the xrd layer. These are valid only inside the callbacks! ...
Definition: XrdHttpReq.hh:249
std::map< std::string, std::string > allheaders
Definition: XrdHttpReq.hh:187
Definition: XrdHttpReq.hh:173
Definition: XrdOucString.hh:254
unsigned int rwOpPartialDone
Definition: XrdHttpReq.hh:237
long flags
Definition: XrdHttpReq.hh:69
Definition: XrdHttpReq.hh:172
std::string path
Definition: XrdHttpReq.hh:66
int parseContentRange(char *)