From cb459a728971143fd8386f6f25218ab0d2c9e273 Mon Sep 17 00:00:00 2001 From: Luke Kysow <1034429+lkysow@users.noreply.github.com> Date: Fri, 29 Nov 2019 09:43:42 -0800 Subject: [PATCH] Document how to json encode envoy config It wasn't clear how users should encode their config. --- website/source/docs/connect/proxies/envoy.md | 50 ++++++++++++++++++++ 1 file changed, 50 insertions(+) diff --git a/website/source/docs/connect/proxies/envoy.md b/website/source/docs/connect/proxies/envoy.md index 69ff2368de..7ff90a1542 100644 --- a/website/source/docs/connect/proxies/envoy.md +++ b/website/source/docs/connect/proxies/envoy.md @@ -317,6 +317,56 @@ field set to the appropriate type (for example `type.googleapis.com/envoy.api.v2.Listener`), or it may be the direct encoding with no `@type` field. +For example, given a tracing config: + +```json +"tracing": { + "http": { + "name": "envoy.zipkin", + "config": { + "collector_cluster": "zipkin", + "collector_endpoint": "/api/v1/spans", + "shared_span_context": false + } + } +} +``` + +JSON escape the value of `tracing` into a string, for example using [https://codebeautify.org/json-escape-unescape](https://codebeautify.org/json-escape-unescape), +and then use that as the value for `envoy_tracing_json`: + +```json +{ + "kind": "proxy-defaults", + "name": "global", + "config": { + "envoy_tracing_json": "{\"http\":{\"name\":\"envoy.zipkin\",\"config\":{\"collector_cluster\":\"zipkin\",\"collector_endpoint\":\"/api/v1/spans\",\"shared_span_context\":false}}}" + } +} +``` + +If using HCL, this escaping is done automatically: + +```hcl +Kind = "proxy-defaults" +Name = "global" +Config { + envoy_tracing_json = <