-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathHttpMessageParser
More file actions
61 lines (46 loc) · 1.43 KB
/
HttpMessageParser
File metadata and controls
61 lines (46 loc) · 1.43 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
* Copyright (C) 2021 Frank Mertens.
*
* Distribution and use is allowed under the terms of the GNU General Public License version 3
* (see CoreComponents/LICENSE-gpl-3.0).
*
*/
#pragma once
#include <cc/HttpMessage>
#include <cc/HttpStream>
namespace cc {
class LineSource;
/** \class HttpMessageParser cc/HttpMessageParser
* \ingroup http_protocol
* \brief HTTP message parser
*/
class HttpMessageParser: public Object
{
public:
/** Create a null HTTP message parser
*/
HttpMessageParser() = default;
/** Read next HTTP message
* \param message Returns the next message
*/
void readMessage(Out<HttpMessage> message) { return me().readMessage(message); }
/** Payload has been fully consumed
*/
bool isPayloadConsumed() const { return me().isPayloadConsumed(); }
protected:
friend class HttpMessageGenerator;
struct State: public Object::State
{
State(const Stream &stream);
bool isPayloadConsumed() const;
void readMessage(Out<HttpMessage> message);
virtual void onFirstLineReceived(const String &line, HttpMessage &message) {}
virtual void onHeaderReceived(HttpMessage &message) {}
HttpStream httpStream_;
String lineBuffer_;
};
explicit HttpMessageParser(State *newState);
const State &me() const { return Object::me.as<State>(); }
State &me() { return Object::me.as<State>(); }
};
} // namespace cc