xref: /aosp_15_r20/external/grpc-grpc/examples/cpp/metadata/README.md (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker# Metadata Example
2*cc02d7e2SAndroid Build Coastguard Worker
3*cc02d7e2SAndroid Build Coastguard Worker## Overview
4*cc02d7e2SAndroid Build Coastguard Worker
5*cc02d7e2SAndroid Build Coastguard WorkerThis example shows you how to add custom headers on the client and server and
6*cc02d7e2SAndroid Build Coastguard Workerhow to access them.
7*cc02d7e2SAndroid Build Coastguard Worker
8*cc02d7e2SAndroid Build Coastguard WorkerCustom metadata must follow the "Custom-Metadata" format listed in
9*cc02d7e2SAndroid Build Coastguard Workerhttps://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md, with the
10*cc02d7e2SAndroid Build Coastguard Workerexception of binary headers, which don't have to be base64 encoded.
11*cc02d7e2SAndroid Build Coastguard Worker
12*cc02d7e2SAndroid Build Coastguard Worker### Get the tutorial source code
13*cc02d7e2SAndroid Build Coastguard Worker The example code for this and our other examples lives in the `examples` directory. Clone this repository
14*cc02d7e2SAndroid Build Coastguard Worker at the [latest stable release tag](https://github.com/grpc/grpc/releases) to your local machine by running the following command:
15*cc02d7e2SAndroid Build Coastguard Worker ```sh
16*cc02d7e2SAndroid Build Coastguard Worker$ git clone -b RELEASE_TAG_HERE https://github.com/grpc/grpc
17*cc02d7e2SAndroid Build Coastguard Worker```
18*cc02d7e2SAndroid Build Coastguard Worker Change your current directory to examples/cpp/metadata
19*cc02d7e2SAndroid Build Coastguard Worker ```sh
20*cc02d7e2SAndroid Build Coastguard Worker$ cd examples/cpp/metadata
21*cc02d7e2SAndroid Build Coastguard Worker```
22*cc02d7e2SAndroid Build Coastguard Worker
23*cc02d7e2SAndroid Build Coastguard Worker### Generating gRPC code
24*cc02d7e2SAndroid Build Coastguard Worker To generate the client and server side interfaces:
25*cc02d7e2SAndroid Build Coastguard Worker ```sh
26*cc02d7e2SAndroid Build Coastguard Worker$ make helloworld.grpc.pb.cc helloworld.pb.cc
27*cc02d7e2SAndroid Build Coastguard Worker```
28*cc02d7e2SAndroid Build Coastguard WorkerWhich internally invokes the proto-compiler as:
29*cc02d7e2SAndroid Build Coastguard Worker ```sh
30*cc02d7e2SAndroid Build Coastguard Worker$ protoc -I ../../protos/ --grpc_out=. --plugin=protoc-gen-grpc=grpc_cpp_plugin ../../protos/helloworld.proto
31*cc02d7e2SAndroid Build Coastguard Worker$ protoc -I ../../protos/ --cpp_out=. ../../protos/helloworld.proto
32*cc02d7e2SAndroid Build Coastguard Worker```
33*cc02d7e2SAndroid Build Coastguard Worker### Try it!
34*cc02d7e2SAndroid Build Coastguard WorkerBuild client and server:
35*cc02d7e2SAndroid Build Coastguard Worker
36*cc02d7e2SAndroid Build Coastguard Worker```sh
37*cc02d7e2SAndroid Build Coastguard Worker$ make
38*cc02d7e2SAndroid Build Coastguard Worker```
39*cc02d7e2SAndroid Build Coastguard Worker
40*cc02d7e2SAndroid Build Coastguard WorkerRun the server, which will listen on port 50051:
41*cc02d7e2SAndroid Build Coastguard Worker
42*cc02d7e2SAndroid Build Coastguard Worker```sh
43*cc02d7e2SAndroid Build Coastguard Worker$ ./greeter_server
44*cc02d7e2SAndroid Build Coastguard Worker```
45*cc02d7e2SAndroid Build Coastguard Worker
46*cc02d7e2SAndroid Build Coastguard WorkerRun the client (in a different terminal):
47*cc02d7e2SAndroid Build Coastguard Worker
48*cc02d7e2SAndroid Build Coastguard Worker```sh
49*cc02d7e2SAndroid Build Coastguard Worker$ ./greeter_client
50*cc02d7e2SAndroid Build Coastguard Worker```
51*cc02d7e2SAndroid Build Coastguard Worker
52*cc02d7e2SAndroid Build Coastguard WorkerIf things go smoothly, you will see in the client terminal:
53*cc02d7e2SAndroid Build Coastguard Worker
54*cc02d7e2SAndroid Build Coastguard Worker"Client received initial metadata from server: initial metadata value"
55*cc02d7e2SAndroid Build Coastguard Worker"Client received trailing metadata from server: trailing metadata value"
56*cc02d7e2SAndroid Build Coastguard Worker"Client received message: Hello World"
57*cc02d7e2SAndroid Build Coastguard Worker
58*cc02d7e2SAndroid Build Coastguard Worker
59*cc02d7e2SAndroid Build Coastguard WorkerAnd in the server terminal:
60*cc02d7e2SAndroid Build Coastguard Worker
61*cc02d7e2SAndroid Build Coastguard Worker"Header key: custom-bin , value: 01234567"
62*cc02d7e2SAndroid Build Coastguard Worker"Header key: custom-header , value: Custom Value"
63*cc02d7e2SAndroid Build Coastguard Worker"Header key: user-agent , value: grpc-c++/1.16.0-dev grpc-c/6.0.0-dev (linux; chttp2; gao)"
64*cc02d7e2SAndroid Build Coastguard Worker
65*cc02d7e2SAndroid Build Coastguard WorkerWe did not add the user-agent metadata as a custom header. This shows how
66*cc02d7e2SAndroid Build Coastguard Workerthe gRPC framework adds some headers under the hood that may show up in the
67*cc02d7e2SAndroid Build Coastguard Workermetadata map.
68