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