From c92964f05b8fb791f4114096e2e51728eaf61812 Mon Sep 17 00:00:00 2001 From: carsonzhu Date: Thu, 16 Mar 2023 10:32:56 +0800 Subject: [PATCH] out_opentelemetry: make add_label have an effect on logs --- plugins/out_opentelemetry/opentelemetry.c | 44 +++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/plugins/out_opentelemetry/opentelemetry.c b/plugins/out_opentelemetry/opentelemetry.c index 6ddc2f1fea2..cb52a6be44c 100644 --- a/plugins/out_opentelemetry/opentelemetry.c +++ b/plugins/out_opentelemetry/opentelemetry.c @@ -707,6 +707,13 @@ static int flush_to_otel(struct opentelemetry_context *ctx, Opentelemetry__Proto__Logs__V1__ResourceLogs resource_log; Opentelemetry__Proto__Logs__V1__ResourceLogs *resource_logs[1]; Opentelemetry__Proto__Logs__V1__ScopeLogs *scope_logs[1]; + Opentelemetry__Proto__Common__V1__KeyValue **attributes_list; + Opentelemetry__Proto__Common__V1__KeyValue *attributes; + size_t kv_size; + size_t kv_index; + struct mk_list *kv_head; + struct flb_kv *kv; + void *body; unsigned len; int res; @@ -723,6 +730,37 @@ static int flush_to_otel(struct opentelemetry_context *ctx, resource_log.n_scope_logs = 1; resource_logs[0] = &resource_log; + kv_size = mk_list_size(&(ctx->kv_labels)); + attributes_list = flb_calloc(kv_size, sizeof(Opentelemetry__Proto__Common__V1__KeyValue *)); + if (attributes_list == NULL) { + flb_errno(); + return -1; + } + attributes = flb_calloc(kv_size, sizeof(Opentelemetry__Proto__Common__V1__KeyValue)); + if (attributes == NULL) { + flb_errno(); + return -1; + } + for(int index = 0; index < kv_size; index++) { + attributes_list[index] = &attributes[index]; + } + + + kv_index = 0; + mk_list_foreach(kv_head, &ctx->kv_labels) { + kv = mk_list_entry(kv_head, struct flb_kv, _head); + opentelemetry__proto__common__v1__key_value__init(&attributes[kv_index]); + attributes[kv_index].key = kv->key; + attributes[kv_index].value = otlp_any_value_initialize(MSGPACK_OBJECT_STR, 0); + attributes[kv_index].value->string_value = kv->val; + kv_index++; + } + + resource_log.resource = flb_calloc(1, sizeof(Opentelemetry__Proto__Resource__V1__Resource)); + opentelemetry__proto__resource__v1__resource__init(resource_log.resource); + resource_log.resource->n_attributes = kv_size; + resource_log.resource->attributes = attributes_list; + export_logs.resource_logs = resource_logs; export_logs.n_resource_logs = 1; @@ -742,6 +780,12 @@ static int flush_to_otel(struct opentelemetry_context *ctx, ctx->logs_uri); flb_free(body); + flb_free(resource_log.resource); + for (int index = 0; index < kv_size; index++) { + flb_free(attributes[index].value); + } + flb_free(attributes); + flb_free(attributes_list); return res; }