Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
B
brpc
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
brpc
Commits
4a0927af
Commit
4a0927af
authored
Sep 28, 2018
by
gejun
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix many issues around impl. of grpc
parent
798e9a11
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
80 additions
and
84 deletions
+80
-84
client.cpp
example/grpc_c++/client.cpp
+4
-5
server.cpp
example/grpc_c++/server.cpp
+0
-1
http_message.cpp
src/brpc/details/http_message.cpp
+11
-9
http_message.h
src/brpc/details/http_message.h
+3
-3
global.cpp
src/brpc/global.cpp
+0
-12
grpc.cpp
src/brpc/grpc.cpp
+24
-0
grpc.h
src/brpc/grpc.h
+4
-1
http_header.h
src/brpc/http_header.h
+0
-2
options.proto
src/brpc/options.proto
+0
-1
http2_rpc_protocol.cpp
src/brpc/policy/http2_rpc_protocol.cpp
+15
-41
http2_rpc_protocol.h
src/brpc/policy/http2_rpc_protocol.h
+14
-5
http_rpc_protocol.cpp
src/brpc/policy/http_rpc_protocol.cpp
+0
-0
http_rpc_protocol.h
src/brpc/policy/http_rpc_protocol.h
+5
-4
No files found.
example/grpc_c++/client.cpp
View file @
4a0927af
...
...
@@ -21,7 +21,7 @@
#include <brpc/channel.h>
#include "helloworld.pb.h"
DEFINE_string
(
protocol
,
"
grp
c"
,
"Protocol type. Defined in src/brpc/options.proto"
);
DEFINE_string
(
protocol
,
"
h2
c"
,
"Protocol type. Defined in src/brpc/options.proto"
);
DEFINE_string
(
server
,
"0.0.0.0:50051"
,
"IP Address of server"
);
DEFINE_string
(
load_balancer
,
""
,
"The algorithm for load balancing"
);
DEFINE_int32
(
timeout_ms
,
100
,
"RPC timeout in milliseconds"
);
...
...
@@ -59,22 +59,21 @@ int main(int argc, char* argv[]) {
helloworld
::
HelloReply
response
;
brpc
::
Controller
cntl
;
request
.
set_name
(
"grpc client example"
);
request
.
set_name
(
"grpc_req_from_brpc"
);
cntl
.
http_request
().
set_content_type
(
"application/grpc"
);
if
(
FLAGS_gzip
)
{
cntl
.
set_request_compress_type
(
brpc
::
COMPRESS_TYPE_GZIP
);
}
// Because `done'(last parameter) is NULL, this function waits until
// the response comes back or error occurs(including timedout).
stub
.
SayHello
(
&
cntl
,
&
request
,
&
response
,
NULL
);
//cntl.http_request().uri() = FLAGS_server;
//channel.CallMethod(NULL, &cntl, &request, &response, NULL);
if
(
!
cntl
.
Failed
())
{
LOG
(
INFO
)
<<
"Received response from "
<<
cntl
.
remote_side
()
<<
" to "
<<
cntl
.
local_side
()
<<
": "
<<
response
.
message
()
<<
" latency="
<<
cntl
.
latency_us
()
<<
"us"
;
}
else
{
LOG
(
WARNING
)
<<
cntl
.
Error
Code
()
<<
": "
<<
cntl
.
Error
Text
();
LOG
(
WARNING
)
<<
cntl
.
ErrorText
();
}
usleep
(
FLAGS_interval_ms
*
1000L
);
}
...
...
example/grpc_c++/server.cpp
View file @
4a0927af
...
...
@@ -42,7 +42,6 @@ public:
if
(
FLAGS_gzip
)
{
cntl
->
set_response_compress_type
(
brpc
::
COMPRESS_TYPE_GZIP
);
}
LOG
(
INFO
)
<<
"req="
<<
req
->
name
();
res
->
set_message
(
"Hello "
+
req
->
name
());
// If an error happens, use controller::set_grpc_error_code to set errors
// e.g., cntl->set_grpc_error_code(brpc::GRPC_RESOURCEEXHAUSTED, "test grpc message");
...
...
src/brpc/details/http_message.cpp
View file @
4a0927af
...
...
@@ -225,12 +225,14 @@ int HttpMessage::OnBody(const char *at, const size_t length) {
delete
_vmsgbuilder
;
_vmsgbuilder
=
NULL
;
}
else
{
if
(
_
body_length
<
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
if
(
_
vbodylen
<
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
int
plen
=
std
::
min
(
length
,
(
size_t
)
FLAGS_http_verbose_max_body_length
-
_body_length
);
_vmsgbuilder
->
write
(
at
,
plen
);
-
_vbodylen
);
std
::
string
str
=
butil
::
ToPrintableString
(
at
,
plen
,
std
::
numeric_limits
<
size_t
>::
max
());
_vmsgbuilder
->
write
(
str
.
data
(),
str
.
size
());
}
_
body_length
+=
length
;
_
vbodylen
+=
length
;
}
}
if
(
_stage
!=
HTTP_ON_BODY
)
{
...
...
@@ -280,8 +282,8 @@ int HttpMessage::OnBody(const char *at, const size_t length) {
int
HttpMessage
::
OnMessageComplete
()
{
if
(
_vmsgbuilder
)
{
if
(
_
body_length
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
*
_vmsgbuilder
<<
"
\n
<skipped "
<<
_
body_length
if
(
_
vbodylen
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
*
_vmsgbuilder
<<
"
\n
<skipped "
<<
_
vbodylen
-
(
size_t
)
FLAGS_http_verbose_max_body_length
<<
" bytes>"
;
}
std
::
cerr
<<
_vmsgbuilder
->
buf
()
<<
std
::
endl
;
...
...
@@ -396,7 +398,7 @@ HttpMessage::HttpMessage(bool read_body_progressively)
,
_body_reader
(
NULL
)
,
_cur_value
(
NULL
)
,
_vmsgbuilder
(
NULL
)
,
_
body_length
(
0
)
{
,
_
vbodylen
(
0
)
{
http_parser_init
(
&
_parser
,
HTTP_BOTH
);
_parser
.
data
=
this
;
}
...
...
@@ -534,7 +536,7 @@ std::ostream& operator<<(std::ostream& os, const http_parser& parser) {
// | "CONNECT" ; Section 9.9
// | extension-method
// extension-method = token
void
Serialize
HttpRequest
(
butil
::
IOBuf
*
request
,
void
MakeRaw
HttpRequest
(
butil
::
IOBuf
*
request
,
HttpHeader
*
h
,
const
butil
::
EndPoint
&
remote_side
,
const
butil
::
IOBuf
*
content
)
{
...
...
@@ -611,7 +613,7 @@ void SerializeHttpRequest(butil::IOBuf* request,
// CRLF
// [ message-body ] ; Section 7.2
// Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF
void
Serialize
HttpResponse
(
butil
::
IOBuf
*
response
,
void
MakeRaw
HttpResponse
(
butil
::
IOBuf
*
response
,
HttpHeader
*
h
,
butil
::
IOBuf
*
content
)
{
butil
::
IOBufBuilder
os
;
...
...
src/brpc/details/http_message.h
View file @
4a0927af
...
...
@@ -113,7 +113,7 @@ private:
protected
:
// Only valid when -http_verbose is on
butil
::
IOBufBuilder
*
_vmsgbuilder
;
size_t
_
body_length
;
size_t
_
vbodylen
;
};
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
http_parser
&
parser
);
...
...
@@ -122,7 +122,7 @@ std::ostream& operator<<(std::ostream& os, const http_parser& parser);
// header: may be modified in some cases
// remote_side: used when "Host" is absent
// content: could be NULL.
void
Serialize
HttpRequest
(
butil
::
IOBuf
*
request
,
void
MakeRaw
HttpRequest
(
butil
::
IOBuf
*
request
,
HttpHeader
*
header
,
const
butil
::
EndPoint
&
remote_side
,
const
butil
::
IOBuf
*
content
);
...
...
@@ -130,7 +130,7 @@ void SerializeHttpRequest(butil::IOBuf* request,
// Serialize a http response.
// header: may be modified in some cases
// content: cleared after usage. could be NULL.
void
Serialize
HttpResponse
(
butil
::
IOBuf
*
response
,
void
MakeRaw
HttpResponse
(
butil
::
IOBuf
*
response
,
HttpHeader
*
header
,
butil
::
IOBuf
*
content
);
...
...
src/brpc/global.cpp
View file @
4a0927af
...
...
@@ -504,18 +504,6 @@ static void GlobalInitializeOrDieImpl() {
}
#endif
// grpc protocol is based on http2
Protocol
grpc_protocol
=
{
ParseH2Message
,
SerializeHttpRequest
,
PackH2Request
,
ProcessHttpRequest
,
ProcessHttpResponse
,
VerifyHttpRequest
,
ParseHttpServerAddress
,
GetHttpMethodName
,
CONNECTION_TYPE_SINGLE
,
"grpc"
};
if
(
RegisterProtocol
(
PROTOCOL_GRPC
,
grpc_protocol
)
!=
0
)
{
exit
(
1
);
}
// Only valid at client side
Protocol
ubrpc_compack_protocol
=
{
ParseNsheadMessage
,
...
...
src/brpc/grpc.cpp
View file @
4a0927af
...
...
@@ -24,6 +24,30 @@
namespace
brpc
{
const
char
*
GrpcStatusToString
(
GrpcStatus
s
)
{
switch
(
s
)
{
case
GRPC_OK
:
return
"GRPC_OK"
;
case
GRPC_CANCELED
:
return
"GRPC_CANCELED"
;
case
GRPC_UNKNOWN
:
return
"GRPC_UNKNOWN"
;
case
GRPC_INVALIDARGUMENT
:
return
"GRPC_INVALIDARGUMENT"
;
case
GRPC_DEADLINEEXCEEDED
:
return
"GRPC_DEADLINEEXCEEDED"
;
case
GRPC_NOTFOUND
:
return
"GRPC_NOTFOUND"
;
case
GRPC_ALREADYEXISTS
:
return
"GRPC_ALREADYEXISTS"
;
case
GRPC_PERMISSIONDENIED
:
return
"GRPC_PERMISSIONDENIED"
;
case
GRPC_RESOURCEEXHAUSTED
:
return
"GRPC_RESOURCEEXHAUSTED"
;
case
GRPC_FAILEDPRECONDITION
:
return
"GRPC_FAILEDPRECONDITION"
;
case
GPRC_ABORTED
:
return
"GPRC_ABORTED"
;
case
GRPC_OUTOFRANGE
:
return
"GRPC_OUTOFRANGE"
;
case
GRPC_UNIMPLEMENTED
:
return
"GRPC_UNIMPLEMENTED"
;
case
GRPC_INTERNAL
:
return
"GRPC_INTERNAL"
;
case
GRPC_UNAVAILABLE
:
return
"GRPC_UNAVAILABLE"
;
case
GRPC_DATALOSS
:
return
"GRPC_DATALOSS"
;
case
GRPC_UNAUTHENTICATED
:
return
"GRPC_UNAUTHENTICATED"
;
case
GRPC_MAX
:
return
"GRPC_MAX"
;
}
return
"Unknown-GrpcStatus"
;
}
GrpcStatus
ErrorCodeToGrpcStatus
(
int
error_code
)
{
switch
(
error_code
)
{
case
0
:
...
...
src/brpc/grpc.h
View file @
4a0927af
...
...
@@ -142,8 +142,11 @@ enum GrpcStatus {
GRPC_MAX
,
};
GrpcStatus
ErrorCodeToGrpcStatus
(
int
error_code
);
// Get description of the error.
const
char
*
GrpcStatusToString
(
GrpcStatus
);
// Convert between error code and grpc status with similar semantics
GrpcStatus
ErrorCodeToGrpcStatus
(
int
error_code
);
int
GrpcStatusToErrorCode
(
GrpcStatus
grpc_status
);
void
PercentEncode
(
const
std
::
string
&
str
,
std
::
string
*
str_out
);
...
...
src/brpc/http_header.h
View file @
4a0927af
...
...
@@ -154,8 +154,6 @@ friend void policy::ProcessHttpRequest(InputMessageBase *msg);
std
::
string
_content_type
;
std
::
string
_unresolved_path
;
std
::
pair
<
int
,
int
>
_version
;
int
_h2_stream_id
;
H2Error
_h2_error
;
};
const
HttpHeader
&
DefaultHttpHeader
();
...
...
src/brpc/options.proto
View file @
4a0927af
...
...
@@ -47,7 +47,6 @@ enum ProtocolType {
PROTOCOL_CDS_AGENT
=
24
;
// Client side only
PROTOCOL_ESP
=
25
;
// Client side only
PROTOCOL_HTTP2
=
26
;
PROTOCOL_GRPC
=
27
;
}
enum
CompressType
{
...
...
src/brpc/policy/http2_rpc_protocol.cpp
View file @
4a0927af
...
...
@@ -1592,8 +1592,7 @@ size_t H2UnsentRequest::EstimatedByteSize() {
return
sz
;
}
void
H2UnsentRequest
::
Describe
(
butil
::
IOBuf
*
desc
)
const
{
butil
::
IOBufBuilder
os
;
void
H2UnsentRequest
::
Print
(
std
::
ostream
&
os
)
const
{
os
<<
"[ H2 REQUEST @"
<<
butil
::
my_ip
()
<<
" ]
\n
"
;
for
(
size_t
i
=
0
;
i
<
_size
;
++
i
)
{
os
<<
"> "
<<
_list
[
i
].
name
<<
" = "
<<
_list
[
i
].
value
<<
'\n'
;
...
...
@@ -1613,33 +1612,23 @@ void H2UnsentRequest::Describe(butil::IOBuf* desc) const {
if
(
!
body
->
empty
())
{
os
<<
">
\n
"
;
}
os
.
move_to
(
*
desc
);
if
(
body
->
size
()
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
size_t
nskipped
=
body
->
size
()
-
(
size_t
)
FLAGS_http_verbose_max_body_length
;
body
->
append_to
(
desc
,
FLAGS_http_verbose_max_body_length
);
if
(
nskipped
)
{
char
str
[
48
];
snprintf
(
str
,
sizeof
(
str
),
"
\n
<skipped %"
PRIu64
" bytes>"
,
nskipped
);
desc
->
append
(
str
);
}
}
else
{
desc
->
append
(
*
body
);
}
os
<<
butil
::
BinaryPrinter
(
*
body
,
FLAGS_http_verbose_max_body_length
);
}
H2UnsentResponse
::
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
grpc
)
H2UnsentResponse
::
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
)
:
_size
(
0
)
,
_stream_id
(
stream_id
)
,
_http_response
(
c
->
release_http_response
())
,
_
grpc
(
grpc
)
{
,
_
is_grpc
(
is_
grpc
)
{
_data
.
swap
(
c
->
response_attachment
());
if
(
grpc
)
{
if
(
is_
grpc
)
{
_grpc_status
=
ErrorCodeToGrpcStatus
(
c
->
ErrorCode
());
PercentEncode
(
c
->
ErrorText
(),
&
_grpc_message
);
}
}
H2UnsentResponse
*
H2UnsentResponse
::
New
(
Controller
*
c
,
int
stream_id
,
bool
grpc
)
{
H2UnsentResponse
*
H2UnsentResponse
::
New
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
)
{
const
HttpHeader
*
const
h
=
&
c
->
http_response
();
const
CommonStrings
*
const
common
=
get_common_strings
();
const
bool
need_content_length
=
...
...
@@ -1650,7 +1639,7 @@ H2UnsentResponse* H2UnsentResponse::New(Controller* c, int stream_id, bool grpc)
+
(
size_t
)
need_content_type
;
const
size_t
memsize
=
offsetof
(
H2UnsentResponse
,
_list
)
+
sizeof
(
HPacker
::
Header
)
*
maxsize
;
H2UnsentResponse
*
msg
=
new
(
malloc
(
memsize
))
H2UnsentResponse
(
c
,
stream_id
,
grpc
);
H2UnsentResponse
*
msg
=
new
(
malloc
(
memsize
))
H2UnsentResponse
(
c
,
stream_id
,
is_
grpc
);
// :status
if
(
h
->
status_code
()
==
200
)
{
msg
->
push
(
common
->
H2_STATUS
,
common
->
STATUS_200
);
...
...
@@ -1720,18 +1709,17 @@ H2UnsentResponse::AppendAndDestroySelf(butil::IOBuf* out, Socket* socket) {
butil
::
IOBuf
frag
;
appender
.
move_to
(
frag
);
butil
::
IOBufAppender
trailer_appender
;
butil
::
IOBuf
trailer_frag
;
if
(
_grpc
)
{
if
(
_
is_
grpc
)
{
HPacker
::
Header
status_header
(
"grpc-status"
,
butil
::
string_printf
(
"%d"
,
_grpc_status
));
hpacker
.
Encode
(
&
trailer_
appender
,
status_header
,
options
);
hpacker
.
Encode
(
&
appender
,
status_header
,
options
);
if
(
!
_grpc_message
.
empty
())
{
HPacker
::
Header
msg_header
(
"grpc-message"
,
_grpc_message
);
hpacker
.
Encode
(
&
trailer_
appender
,
msg_header
,
options
);
hpacker
.
Encode
(
&
appender
,
msg_header
,
options
);
}
appender
.
move_to
(
trailer_frag
);
}
trailer_appender
.
move_to
(
trailer_frag
);
PackH2Message
(
out
,
frag
,
trailer_frag
,
_data
,
_stream_id
,
ctx
);
return
butil
::
Status
::
OK
();
...
...
@@ -1752,8 +1740,7 @@ size_t H2UnsentResponse::EstimatedByteSize() {
return
sz
;
}
void
H2UnsentResponse
::
Describe
(
butil
::
IOBuf
*
desc
)
const
{
butil
::
IOBufBuilder
os
;
void
H2UnsentResponse
::
Print
(
std
::
ostream
&
os
)
const
{
os
<<
"[ H2 RESPONSE @"
<<
butil
::
my_ip
()
<<
" ]
\n
"
;
for
(
size_t
i
=
0
;
i
<
_size
;
++
i
)
{
os
<<
"> "
<<
_list
[
i
].
name
<<
" = "
<<
_list
[
i
].
value
<<
'\n'
;
...
...
@@ -1767,18 +1754,7 @@ void H2UnsentResponse::Describe(butil::IOBuf* desc) const {
if
(
!
_data
.
empty
())
{
os
<<
">
\n
"
;
}
os
.
move_to
(
*
desc
);
if
(
_data
.
size
()
>
(
size_t
)
FLAGS_http_verbose_max_body_length
)
{
size_t
nskipped
=
_data
.
size
()
-
(
size_t
)
FLAGS_http_verbose_max_body_length
;
_data
.
append_to
(
desc
,
FLAGS_http_verbose_max_body_length
);
if
(
nskipped
)
{
char
str
[
48
];
snprintf
(
str
,
sizeof
(
str
),
"
\n
<skipped %"
PRIu64
" bytes>"
,
nskipped
);
desc
->
append
(
str
);
}
}
else
{
desc
->
append
(
_data
);
}
os
<<
butil
::
BinaryPrinter
(
_data
,
FLAGS_http_verbose_max_body_length
);
}
void
PackH2Request
(
butil
::
IOBuf
*
,
...
...
@@ -1806,9 +1782,7 @@ void PackH2Request(butil::IOBuf*,
*
user_message
=
h2_req
;
if
(
FLAGS_http_verbose
)
{
butil
::
IOBuf
desc
;
h2_req
->
Describe
(
&
desc
);
std
::
cerr
<<
desc
<<
std
::
endl
;
std
::
cerr
<<
*
h2_req
<<
std
::
endl
;
}
}
...
...
src/brpc/policy/http2_rpc_protocol.h
View file @
4a0927af
...
...
@@ -135,7 +135,7 @@ friend void PackH2Request(butil::IOBuf*, SocketMessage**,
Controller
*
,
const
butil
::
IOBuf
&
,
const
Authenticator
*
);
public
:
static
H2UnsentRequest
*
New
(
Controller
*
c
);
void
Describe
(
butil
::
IOBuf
*
)
const
;
void
Print
(
std
::
ostream
&
)
const
;
int
AddRefManually
()
{
return
_nref
.
fetch_add
(
1
,
butil
::
memory_order_relaxed
);
}
...
...
@@ -194,9 +194,9 @@ private:
class
H2UnsentResponse
:
public
SocketMessage
{
public
:
static
H2UnsentResponse
*
New
(
Controller
*
c
,
int
stream_id
,
bool
grpc
);
static
H2UnsentResponse
*
New
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
);
void
Destroy
();
void
Describe
(
butil
::
IOBuf
*
)
const
;
void
Print
(
std
::
ostream
&
)
const
;
// @SocketMessage
butil
::
Status
AppendAndDestroySelf
(
butil
::
IOBuf
*
out
,
Socket
*
)
override
;
size_t
EstimatedByteSize
()
override
;
...
...
@@ -208,7 +208,7 @@ private:
void
push
(
const
std
::
string
&
name
,
const
std
::
string
&
value
)
{
new
(
&
_list
[
_size
++
])
HPacker
::
Header
(
name
,
value
);
}
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
grpc
);
H2UnsentResponse
(
Controller
*
c
,
int
stream_id
,
bool
is_
grpc
);
~
H2UnsentResponse
()
{}
H2UnsentResponse
(
const
H2UnsentResponse
&
);
void
operator
=
(
const
H2UnsentResponse
&
);
...
...
@@ -218,7 +218,7 @@ private:
uint32_t
_stream_id
;
std
::
unique_ptr
<
HttpHeader
>
_http_response
;
butil
::
IOBuf
_data
;
bool
_grpc
;
bool
_
is_
grpc
;
GrpcStatus
_grpc_status
;
std
::
string
_grpc_message
;
HPacker
::
Header
_list
[
0
];
...
...
@@ -409,6 +409,15 @@ inline bool H2Context::RunOutStreams() const {
return
(
_last_client_stream_id
>
0x7FFFFFFF
);
}
inline
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
H2UnsentRequest
&
req
)
{
req
.
Print
(
os
);
return
os
;
}
inline
std
::
ostream
&
operator
<<
(
std
::
ostream
&
os
,
const
H2UnsentResponse
&
res
)
{
res
.
Print
(
os
);
return
os
;
}
}
// namespace policy
}
// namespace brpc
...
...
src/brpc/policy/http_rpc_protocol.cpp
View file @
4a0927af
This diff is collapsed.
Click to expand it.
src/brpc/policy/http_rpc_protocol.h
View file @
4a0927af
...
...
@@ -41,7 +41,6 @@ struct CommonStrings {
std
::
string
ACCEPT_ENCODING
;
std
::
string
CONTENT_ENCODING
;
std
::
string
CONTENT_LENGTH
;
std
::
string
IDENTITY
;
std
::
string
GZIP
;
std
::
string
CONNECTION
;
std
::
string
KEEP_ALIVE
;
...
...
@@ -69,6 +68,7 @@ struct CommonStrings {
std
::
string
TRAILERS
;
std
::
string
GRPC_ENCODING
;
std
::
string
GRPC_ACCEPT_ENCODING
;
std
::
string
GRPC_ACCEPT_ENCODING_VALUE
;
std
::
string
GRPC_STATUS
;
std
::
string
GRPC_MESSAGE
;
...
...
@@ -138,13 +138,14 @@ enum HttpContentType {
HTTP_CONTENT_OTHERS
=
0
,
HTTP_CONTENT_JSON
=
1
,
HTTP_CONTENT_PROTO
=
2
,
HTTP_CONTENT_GRPC
=
3
};
HttpContentType
ParseContentType
(
butil
::
StringPiece
content_type
);
// Parse from the textual content type. One type may have more than one literals.
// Returns a numerical type. *is_grpc_ct is set to true if the content-type is
// set by gRPC.
HttpContentType
ParseContentType
(
butil
::
StringPiece
content_type
,
bool
*
is_grpc_ct
);
}
// namespace policy
}
// namespace brpc
#endif // BRPC_POLICY_HTTP_RPC_PROTOCOL_H
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment