libdatadog 30.0.0.1.0 → 35.0.0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (99) hide show
  1. checksums.yaml +4 -4
  2. data/lib/libdatadog/version.rb +1 -1
  3. data/libdatadog.gemspec +43 -0
  4. data/rust-toolchain.toml +6 -0
  5. data/tasks/build.rake +177 -0
  6. data/tasks/gem.rake +249 -0
  7. data/vendor/libdatadog-35.0.0/aarch64-linux/LICENSE-3rdparty.csv +550 -0
  8. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/bin/libdatadog-crashtracking-receiver +0 -0
  9. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux}/include/datadog/common.h +105 -19
  10. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux}/include/datadog/data-pipeline.h +154 -8
  11. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux}/include/datadog/ffe.h +7 -3
  12. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/include/datadog/profiling.h +36 -0
  13. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux}/include/datadog/telemetry.h +21 -0
  14. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/lib/libdatadog_profiling.so +0 -0
  15. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
  16. data/vendor/libdatadog-35.0.0/aarch64-linux-musl/LICENSE-3rdparty.csv +550 -0
  17. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/bin/libdatadog-crashtracking-receiver +0 -0
  18. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/common.h +105 -19
  19. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/data-pipeline.h +154 -8
  20. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/ffe.h +7 -3
  21. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/profiling.h +36 -0
  22. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/telemetry.h +21 -0
  23. data/vendor/libdatadog-35.0.0/aarch64-linux-musl/lib/libdatadog_profiling.so +0 -0
  24. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
  25. data/vendor/libdatadog-35.0.0/arm64-darwin/LICENSE-3rdparty.csv +550 -0
  26. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/bin/libdatadog-crashtracking-receiver +0 -0
  27. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/arm64-darwin}/include/datadog/common.h +105 -19
  28. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/include/datadog/data-pipeline.h +154 -8
  29. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/include/datadog/ffe.h +7 -3
  30. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/arm64-darwin}/include/datadog/profiling.h +36 -0
  31. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/arm64-darwin}/include/datadog/telemetry.h +21 -0
  32. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/lib/libdatadog_profiling.dylib +0 -0
  33. data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
  34. data/vendor/libdatadog-35.0.0/x86_64-linux/LICENSE-3rdparty.csv +550 -0
  35. data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/bin/libdatadog-crashtracking-receiver +0 -0
  36. data/vendor/libdatadog-35.0.0/x86_64-linux/include/datadog/common.h +2900 -0
  37. data/vendor/libdatadog-35.0.0/x86_64-linux/include/datadog/data-pipeline.h +349 -0
  38. data/vendor/libdatadog-35.0.0/x86_64-linux/include/datadog/ffe.h +179 -0
  39. data/vendor/libdatadog-35.0.0/x86_64-linux/include/datadog/profiling.h +1130 -0
  40. data/vendor/libdatadog-35.0.0/x86_64-linux/include/datadog/telemetry.h +307 -0
  41. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux}/lib/libdatadog_profiling.so +0 -0
  42. data/vendor/libdatadog-35.0.0/x86_64-linux/lib/pkgconfig/datadog_profiling_with_rpath.pc +15 -0
  43. data/vendor/libdatadog-35.0.0/x86_64-linux-musl/LICENSE-3rdparty.csv +550 -0
  44. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/bin/libdatadog-crashtracking-receiver +0 -0
  45. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/common.h +105 -19
  46. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/data-pipeline.h +154 -8
  47. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/ffe.h +7 -3
  48. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/profiling.h +36 -0
  49. data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/telemetry.h +21 -0
  50. data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/lib/libdatadog_profiling.so +0 -0
  51. data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/lib/pkgconfig/datadog_profiling_with_rpath.pc +1 -1
  52. metadata +86 -82
  53. data/vendor/libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu/LICENSE-3rdparty.yml +0 -53656
  54. data/vendor/libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl/LICENSE-3rdparty.yml +0 -53656
  55. data/vendor/libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin/LICENSE-3rdparty.yml +0 -53656
  56. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/LICENSE-3rdparty.yml +0 -53656
  57. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/common.h +0 -2814
  58. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/data-pipeline.h +0 -203
  59. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/ffe.h +0 -175
  60. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/profiling.h +0 -1094
  61. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/include/datadog/telemetry.h +0 -286
  62. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/libdatadog_profiling.so +0 -0
  63. data/vendor/libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu/lib/pkgconfig/datadog_profiling_with_rpath.pc +0 -15
  64. data/vendor/libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl/LICENSE-3rdparty.yml +0 -53656
  65. /data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/LICENSE +0 -0
  66. /data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/NOTICE +0 -0
  67. /data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/include/datadog/blazesym.h +0 -0
  68. /data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/include/datadog/crashtracker.h +0 -0
  69. /data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/include/datadog/ddsketch.h +0 -0
  70. /data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/include/datadog/library-config.h +0 -0
  71. /data/vendor/{libdatadog-30.0.0/aarch64-linux/libdatadog-aarch64-unknown-linux-gnu → libdatadog-35.0.0/aarch64-linux}/include/datadog/log.h +0 -0
  72. /data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/LICENSE +0 -0
  73. /data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/NOTICE +0 -0
  74. /data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/blazesym.h +0 -0
  75. /data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/crashtracker.h +0 -0
  76. /data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/ddsketch.h +0 -0
  77. /data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/library-config.h +0 -0
  78. /data/vendor/{libdatadog-30.0.0/aarch64-linux-musl/libdatadog-aarch64-alpine-linux-musl → libdatadog-35.0.0/aarch64-linux-musl}/include/datadog/log.h +0 -0
  79. /data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/LICENSE +0 -0
  80. /data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/NOTICE +0 -0
  81. /data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/include/datadog/blazesym.h +0 -0
  82. /data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/include/datadog/crashtracker.h +0 -0
  83. /data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/include/datadog/ddsketch.h +0 -0
  84. /data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/include/datadog/library-config.h +0 -0
  85. /data/vendor/{libdatadog-30.0.0/arm64-darwin/libdatadog-aarch64-apple-darwin → libdatadog-35.0.0/arm64-darwin}/include/datadog/log.h +0 -0
  86. /data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/LICENSE +0 -0
  87. /data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/NOTICE +0 -0
  88. /data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/include/datadog/blazesym.h +0 -0
  89. /data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/include/datadog/crashtracker.h +0 -0
  90. /data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/include/datadog/ddsketch.h +0 -0
  91. /data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/include/datadog/library-config.h +0 -0
  92. /data/vendor/{libdatadog-30.0.0/x86_64-linux/libdatadog-x86_64-unknown-linux-gnu → libdatadog-35.0.0/x86_64-linux}/include/datadog/log.h +0 -0
  93. /data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/LICENSE +0 -0
  94. /data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/NOTICE +0 -0
  95. /data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/blazesym.h +0 -0
  96. /data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/crashtracker.h +0 -0
  97. /data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/ddsketch.h +0 -0
  98. /data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/library-config.h +0 -0
  99. /data/vendor/{libdatadog-30.0.0/x86_64-linux-musl/libdatadog-x86_64-alpine-linux-musl → libdatadog-35.0.0/x86_64-linux-musl}/include/datadog/log.h +0 -0
@@ -0,0 +1,349 @@
1
+ // Copyright 2021-Present Datadog, Inc. https://www.datadoghq.com/
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+
5
+ #ifndef DDOG_DATA_PIPELINE_H
6
+ #define DDOG_DATA_PIPELINE_H
7
+
8
+ #include <stdarg.h>
9
+ #include <stdbool.h>
10
+ #include <stdint.h>
11
+ #include <stdlib.h>
12
+ #include "common.h"
13
+ #ifdef __cplusplus
14
+ extern "C" {
15
+ #endif // __cplusplus
16
+
17
+ /**
18
+ * Frees `error` and all its contents. After being called error will not point to a valid memory
19
+ * address so any further actions on it could lead to undefined behavior.
20
+ */
21
+ void ddog_trace_exporter_error_free(struct ddog_TraceExporterError *error);
22
+
23
+ /**
24
+ * Return a borrowed view of the response body. The returned slice is
25
+ * only valid as long as `response` is alive. Returns an empty slice
26
+ * when `response` is null or the body is absent.
27
+ */
28
+ ddog_ByteSlice ddog_trace_exporter_response_get_body(const struct ddog_TraceExporterResponse *response);
29
+
30
+ /**
31
+ * Free `response` and all its contents. After being called response will not point to a valid
32
+ * memory address so any further actions on it could lead to undefined behavior.
33
+ */
34
+ void ddog_trace_exporter_response_free(struct ddog_TraceExporterResponse *response);
35
+
36
+ void ddog_trace_exporter_config_new(struct ddog_TraceExporterConfig **out_handle);
37
+
38
+ /**
39
+ * Frees TraceExporterConfig handle internal resources.
40
+ */
41
+ void ddog_trace_exporter_config_free(struct ddog_TraceExporterConfig *handle);
42
+
43
+ /**
44
+ * Sets traces destination.
45
+ */
46
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_url(struct ddog_TraceExporterConfig *config,
47
+ ddog_CharSlice url);
48
+
49
+ /**
50
+ * Sets tracer's version to be included in the headers request.
51
+ */
52
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_tracer_version(struct ddog_TraceExporterConfig *config,
53
+ ddog_CharSlice version);
54
+
55
+ /**
56
+ * Sets tracer's language to be included in the headers request.
57
+ */
58
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_language(struct ddog_TraceExporterConfig *config,
59
+ ddog_CharSlice lang);
60
+
61
+ /**
62
+ * Sets tracer's language version to be included in the headers request.
63
+ */
64
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_lang_version(struct ddog_TraceExporterConfig *config,
65
+ ddog_CharSlice version);
66
+
67
+ /**
68
+ * Sets tracer's language interpreter to be included in the headers request.
69
+ */
70
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_lang_interpreter(struct ddog_TraceExporterConfig *config,
71
+ ddog_CharSlice interpreter);
72
+
73
+ /**
74
+ * Sets hostname information to be included in the headers request.
75
+ */
76
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_hostname(struct ddog_TraceExporterConfig *config,
77
+ ddog_CharSlice hostname);
78
+
79
+ /**
80
+ * Sets environment information to be included in the headers request.
81
+ */
82
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_env(struct ddog_TraceExporterConfig *config,
83
+ ddog_CharSlice env);
84
+
85
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_version(struct ddog_TraceExporterConfig *config,
86
+ ddog_CharSlice version);
87
+
88
+ /**
89
+ * Sets service name to be included in the headers request.
90
+ */
91
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_service(struct ddog_TraceExporterConfig *config,
92
+ ddog_CharSlice service);
93
+
94
+ /**
95
+ * Enables health metrics emission.
96
+ */
97
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_enable_health_metrics(struct ddog_TraceExporterConfig *config,
98
+ bool is_enabled);
99
+
100
+ /**
101
+ * Enables telemetry metrics.
102
+ */
103
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_enable_telemetry(struct ddog_TraceExporterConfig *config,
104
+ const struct ddog_TelemetryClientConfig *telemetry_cfg);
105
+
106
+ /**
107
+ * Set client-side stats computation status.
108
+ */
109
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_compute_stats(struct ddog_TraceExporterConfig *config,
110
+ bool is_enabled);
111
+
112
+ /**
113
+ * Sets `Datadog-Client-Computed-Stats` header to `true`.
114
+ * This indicates that the upstream system has already computed the stats,
115
+ * and no further stats computation should be performed.
116
+ *
117
+ * <div class="warning">
118
+ * This method must not be used when `compute_stats` is enabled, as it could
119
+ * result in duplicate stats computation.
120
+ * </div>
121
+ *
122
+ * A common use case is in Application Security Monitoring (ASM) scenarios:
123
+ * when APM is disabled but ASM is enabled, setting this header to `true`
124
+ * ensures that no stats are computed at any level (exporter or agent).
125
+ */
126
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_client_computed_stats(struct ddog_TraceExporterConfig *config,
127
+ bool client_computed_stats);
128
+
129
+ /**
130
+ * Sets the process tags to be included in the stats payload.
131
+ */
132
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_process_tags(struct ddog_TraceExporterConfig *config,
133
+ ddog_CharSlice process_tags);
134
+
135
+ /**
136
+ * Sets the `X-Datadog-Test-Session-Token` header. Only used for testing with the test agent.
137
+ */
138
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_test_session_token(struct ddog_TraceExporterConfig *config,
139
+ ddog_CharSlice token);
140
+
141
+ /**
142
+ * Sets the timeout in ms for all agent's connections.
143
+ */
144
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_connection_timeout(struct ddog_TraceExporterConfig *config,
145
+ uint64_t timeout_ms);
146
+
147
+ /**
148
+ * Sets a shared runtime for the TraceExporter to use for background workers.
149
+ *
150
+ * `handle` must have been initialized with [`ddog_shared_runtime_new`].
151
+ *
152
+ * When set, the exporter will use the provided runtime instead of creating its own.
153
+ * This allows multiple exporters (or other components) to share a single runtime.
154
+ * The config holds a clone of the `Arc` (increments the strong count), so the
155
+ * original handle remains valid and must still be freed with
156
+ * [`ddog_shared_runtime_free`].
157
+ */
158
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_shared_runtime(struct ddog_TraceExporterConfig *config,
159
+ struct ddog_SharedRuntime *handle);
160
+
161
+ /**
162
+ * Enables OTLP HTTP/JSON export and sets the endpoint URL.
163
+ *
164
+ * When set, traces are sent to this URL in OTLP HTTP/JSON format instead of the Datadog
165
+ * agent. The host language is responsible for resolving the endpoint from its configuration
166
+ * (e.g. `OTEL_EXPORTER_OTLP_TRACES_ENDPOINT`) before calling this function.
167
+ */
168
+ struct ddog_TraceExporterError *ddog_trace_exporter_config_set_otlp_endpoint(struct ddog_TraceExporterConfig *config,
169
+ ddog_CharSlice url);
170
+
171
+ /**
172
+ * Create a new TraceExporter instance.
173
+ *
174
+ * When an OTLP endpoint is configured via `TraceExporterConfig`, the exporter sends traces in
175
+ * OTLP HTTP/JSON to that endpoint instead of the Datadog agent. The same payload (e.g.
176
+ * MessagePack) is passed to `ddog_trace_exporter_send`; the library decodes and converts to
177
+ * OTLP when OTLP is enabled.
178
+ *
179
+ * # Arguments
180
+ *
181
+ * * `out_handle` - The handle to write the TraceExporter instance in.
182
+ * * `config` - The configuration used to set up the TraceExporter handle.
183
+ */
184
+ struct ddog_TraceExporterError *ddog_trace_exporter_new(ddog_TraceExporter **out_handle,
185
+ const struct ddog_TraceExporterConfig *config);
186
+
187
+ /**
188
+ * Free the TraceExporter instance.
189
+ *
190
+ * # Arguments
191
+ *
192
+ * * handle - The handle to the TraceExporter instance.
193
+ */
194
+ void ddog_trace_exporter_free(ddog_TraceExporter *handle);
195
+
196
+ /**
197
+ * Send traces to the Datadog Agent.
198
+ *
199
+ * # Arguments
200
+ *
201
+ * * `handle` - The handle to the TraceExporter instance.
202
+ * * `trace` - The traces to send to the Datadog Agent in the input format used to create the
203
+ * TraceExporter. The memory for the trace must be valid for the life of the call to this
204
+ * function.
205
+ * * `trace_count` - The number of traces to send to the Datadog Agent.
206
+ * * `response_out` - Optional handle to store a pointer to the agent response information.
207
+ */
208
+ struct ddog_TraceExporterError *ddog_trace_exporter_send(const ddog_TraceExporter *handle,
209
+ ddog_ByteSlice trace,
210
+ struct ddog_TraceExporterResponse **response_out);
211
+
212
+ /**
213
+ * Create a new span with all scalar fields set.
214
+ *
215
+ * String fields are copied from the provided slices. The `meta` and
216
+ * `metrics` maps start empty; use [`ddog_tracer_span_set_meta`] and
217
+ * [`ddog_tracer_span_set_metric`] to populate them.
218
+ *
219
+ * # Safety
220
+ *
221
+ * `out_handle` must point to valid, writable memory for a `Box<TracerSpan>`.
222
+ * All `CharSlice` fields in `fields` must point to valid memory for their
223
+ * stated length.
224
+ */
225
+ struct ddog_TraceExporterError *ddog_tracer_span_new(ddog_TracerSpan **out_handle,
226
+ const struct ddog_TracerSpanFields *fields);
227
+
228
+ /**
229
+ * Free a `TracerSpan` and all its contents.
230
+ *
231
+ * After this call the handle is invalid and must not be reused.
232
+ *
233
+ * # Safety
234
+ *
235
+ * `handle` must have been created by [`ddog_tracer_span_new`] and must not
236
+ * be used after this call.
237
+ */
238
+ void ddog_tracer_span_free(ddog_TracerSpan *handle);
239
+
240
+ /**
241
+ * Add or overwrite a string tag (`meta`) on the span.
242
+ *
243
+ * Both `key` and `value` are copied into the span.
244
+ *
245
+ * # Safety
246
+ *
247
+ * `handle` must be a valid pointer to a `TracerSpan`.
248
+ * `key` and `value` must point to valid UTF-8 memory.
249
+ */
250
+ struct ddog_TraceExporterError *ddog_tracer_span_set_meta(ddog_TracerSpan *handle,
251
+ ddog_CharSlice key,
252
+ ddog_CharSlice value);
253
+
254
+ /**
255
+ * Add or overwrite a numeric tag (`metric`) on the span.
256
+ *
257
+ * The `key` is copied into the span.
258
+ *
259
+ * # Safety
260
+ *
261
+ * `handle` must be a valid pointer to a `TracerSpan`.
262
+ * `key` must point to valid UTF-8 memory.
263
+ */
264
+ struct ddog_TraceExporterError *ddog_tracer_span_set_metric(ddog_TracerSpan *handle,
265
+ ddog_CharSlice key,
266
+ double value);
267
+
268
+ /**
269
+ * Create a new empty trace chunks container.
270
+ *
271
+ * `capacity` is a hint for the expected number of chunks; pass 0 if
272
+ * unknown.
273
+ *
274
+ * # Safety
275
+ *
276
+ * `out_handle` must point to valid, writable memory for a
277
+ * `Box<TracerTraceChunks>`.
278
+ */
279
+ struct ddog_TraceExporterError *ddog_tracer_trace_chunks_new(uintptr_t capacity,
280
+ ddog_TracerTraceChunks **out_handle);
281
+
282
+ /**
283
+ * Free a trace chunks container and all its contents.
284
+ *
285
+ * After this call the handle is invalid and must not be reused.
286
+ *
287
+ * # Safety
288
+ *
289
+ * `handle` must have been created by [`ddog_tracer_trace_chunks_new`].
290
+ */
291
+ void ddog_tracer_trace_chunks_free(ddog_TracerTraceChunks *handle);
292
+
293
+ /**
294
+ * Start a new chunk (trace) inside the container.
295
+ *
296
+ * Subsequent [`ddog_tracer_trace_chunks_push_span`] calls will append
297
+ * spans to this chunk until the next `begin_chunk` call.
298
+ *
299
+ * `capacity` is a hint for the expected number of spans in this chunk;
300
+ * pass 0 if unknown.
301
+ *
302
+ * # Safety
303
+ *
304
+ * `handle` must be a valid pointer to a `TracerTraceChunks`.
305
+ */
306
+ struct ddog_TraceExporterError *ddog_tracer_trace_chunks_begin_chunk(ddog_TracerTraceChunks *handle,
307
+ uintptr_t capacity);
308
+
309
+ /**
310
+ * Move a span into the current (last) chunk, consuming the span handle.
311
+ *
312
+ * A chunk must have been started with
313
+ * [`ddog_tracer_trace_chunks_begin_chunk`] before calling this function.
314
+ *
315
+ * # Safety
316
+ *
317
+ * * `handle` must be a valid pointer to a `TracerTraceChunks`.
318
+ * * `span` is consumed and must not be used after this call.
319
+ */
320
+ struct ddog_TraceExporterError *ddog_tracer_trace_chunks_push_span(ddog_TracerTraceChunks *handle,
321
+ ddog_TracerSpan *span);
322
+
323
+ /**
324
+ * Send trace chunks through a [`TraceExporter`], consuming the chunks.
325
+ *
326
+ * This calls `TraceExporter::send_trace_chunks` which processes stats,
327
+ * serializes in the configured output format, and sends to the agent
328
+ * with retry logic.
329
+ *
330
+ * On success, if `response_out` is non-null, a heap-allocated
331
+ * [`ExporterResponse`] is written there. The caller owns it and must
332
+ * free it with `ddog_trace_exporter_response_free`.
333
+ *
334
+ * # Safety
335
+ *
336
+ * * `exporter` must be a valid `TraceExporter` pointer.
337
+ * * `chunks` is consumed and must not be used after this call.
338
+ * * If `response_out` is non-null it must point to valid writable memory for a
339
+ * `Box<ExporterResponse>`.
340
+ */
341
+ struct ddog_TraceExporterError *ddog_trace_exporter_send_trace_chunks(const ddog_TraceExporter *exporter,
342
+ ddog_TracerTraceChunks *chunks,
343
+ struct ddog_TraceExporterResponse **response_out);
344
+
345
+ #ifdef __cplusplus
346
+ } // extern "C"
347
+ #endif // __cplusplus
348
+
349
+ #endif /* DDOG_DATA_PIPELINE_H */
@@ -0,0 +1,179 @@
1
+ // Copyright 2025-Present Datadog, Inc. https://www.datadoghq.com/
2
+ // SPDX-License-Identifier: Apache-2.0
3
+
4
+
5
+ #ifndef DDOG_FFE_H
6
+ #define DDOG_FFE_H
7
+
8
+ #pragma once
9
+
10
+ #include <stdbool.h>
11
+ #include <stddef.h>
12
+ #include <stdint.h>
13
+ #include "common.h"
14
+
15
+ #ifdef __cplusplus
16
+ extern "C" {
17
+ #endif // __cplusplus
18
+
19
+ /**
20
+ * Evaluates a feature flag.
21
+ *
22
+ * # Ownership
23
+ *
24
+ * The caller must call `ddog_ffe_assignment_drop` on the returned value to free resources.
25
+ *
26
+ * # Safety
27
+ *
28
+ * - `config` must be a valid `Configuration` handle
29
+ * - `flag_key` must be a valid C string
30
+ * - `context` must be a valid `EvaluationContext` handle
31
+ */
32
+ DDOG_CHECK_RETURN
33
+ ddog_ffe_Handle_ResolutionDetails ddog_ffe_get_assignment(ddog_ffe_Handle_Configuration config,
34
+ const char *flag_key,
35
+ enum ddog_ffe_ExpectedFlagType expected_type,
36
+ ddog_ffe_Handle_EvaluationContext context);
37
+
38
+ /**
39
+ * Get value produced by evaluation.
40
+ *
41
+ * # Ownership
42
+ *
43
+ * The returned `VariantValue` borrows from `assignment`. It must not be used after `assignment` is
44
+ * freed.
45
+ *
46
+ * # Safety
47
+ * `assignment` must be a valid handle.
48
+ */
49
+ struct ddog_ffe_VariantValue ddog_ffe_assignment_get_value(ddog_ffe_Handle_ResolutionDetails assignment);
50
+
51
+ /**
52
+ * Get variant key produced by evaluation. Returns `NULL` if evaluation did not produce any value.
53
+ *
54
+ * # Ownership
55
+ *
56
+ * The returned string borrows from `assignment`. It must not be used after `assignment` is
57
+ * freed.
58
+ *
59
+ * # Safety
60
+ * `assignment` must be a valid handle.
61
+ */
62
+ struct ddog_ffe_BorrowedStr ddog_ffe_assignment_get_variant(ddog_ffe_Handle_ResolutionDetails assignment);
63
+
64
+ /**
65
+ * Get allocation key produced by evaluation. Returns `NULL` if evaluation did not produce any
66
+ * value.
67
+ *
68
+ * # Ownership
69
+ *
70
+ * The returned string borrows from `assignment`. It must not be used after `assignment` is
71
+ * freed.
72
+ *
73
+ * # Safety
74
+ * `assignment` must be a valid handle.
75
+ */
76
+ struct ddog_ffe_BorrowedStr ddog_ffe_assignment_get_allocation_key(ddog_ffe_Handle_ResolutionDetails assignment);
77
+
78
+ /**
79
+ * # Safety
80
+ * `assignment` must be a valid handle.
81
+ */
82
+ enum ddog_ffe_Reason ddog_ffe_assignment_get_reason(ddog_ffe_Handle_ResolutionDetails assignment);
83
+
84
+ /**
85
+ * # Safety
86
+ * `assignment` must be a valid handle.
87
+ */
88
+ enum ddog_ffe_ErrorCode ddog_ffe_assignment_get_error_code(ddog_ffe_Handle_ResolutionDetails assignment);
89
+
90
+ /**
91
+ * # Safety
92
+ * `assignment` must be a valid handle.
93
+ */
94
+ struct ddog_ffe_BorrowedStr ddog_ffe_assignment_get_error_message(ddog_ffe_Handle_ResolutionDetails assignment);
95
+
96
+ /**
97
+ * Get the serial_id produced by evaluation.
98
+ *
99
+ * Returns `None` if the assignment has no serial_id or evaluation did not produce any value.
100
+ *
101
+ * # Safety
102
+ * `assignment` must be a valid handle.
103
+ */
104
+ struct ddog_Option_I32 ddog_ffe_assignment_get_serial_id(ddog_ffe_Handle_ResolutionDetails assignment);
105
+
106
+ /**
107
+ * # Safety
108
+ * `assignment` must be a valid handle.
109
+ */
110
+ bool ddog_ffe_assignment_get_do_log(ddog_ffe_Handle_ResolutionDetails assignment);
111
+
112
+ /**
113
+ * # Safety
114
+ * `assignment` must be a valid handle.
115
+ */
116
+ struct ddog_ffe_ArrayMap_BorrowedStr ddog_ffe_assignnment_get_flag_metadata(ddog_ffe_Handle_ResolutionDetails assignment);
117
+
118
+ /**
119
+ * Frees an Assignment handle.
120
+ *
121
+ * # Safety
122
+ * - `assignment` must be a valid Assignment handle
123
+ */
124
+ void ddog_ffe_assignment_drop(ddog_ffe_Handle_ResolutionDetails *assignment);
125
+
126
+ /**
127
+ * Creates a new Configuration from JSON bytes.
128
+ *
129
+ * # Ownership
130
+ *
131
+ * The caller must call `ddog_ffe_configuration_drop` to release resources allocated for
132
+ * configuration.
133
+ *
134
+ * # Safety
135
+ *
136
+ * - `json_bytes` must point to valid memory.
137
+ */
138
+ DDOG_CHECK_RETURN
139
+ struct ddog_ffe_Result_HandleConfiguration ddog_ffe_configuration_new(struct ddog_ffe_BorrowedStr json_bytes);
140
+
141
+ /**
142
+ * Frees a Configuration.
143
+ *
144
+ * # Safety
145
+ *
146
+ * `config` must be a valid Configuration handle created by `ddog_ffe_configuration_new`.
147
+ */
148
+ void ddog_ffe_configuration_drop(ddog_ffe_Handle_Configuration *config);
149
+
150
+ /**
151
+ * Creates a new EvaluationContext with the given targeting key and attributes.
152
+ *
153
+ * # Ownership
154
+ *
155
+ * `ddog_ffe_evaluation_context_drop` must be called on the result value to free resources.
156
+ *
157
+ * # Safety
158
+ * - `targeting_key` must be a valid C string or NULL.
159
+ * - `attributes` must point to a valid array of valid `AttributePair` structs (can be null if
160
+ * `attributes_count` is 0)
161
+ */
162
+ DDOG_CHECK_RETURN
163
+ ddog_ffe_Handle_EvaluationContext ddog_ffe_evaluation_context_new(const char *targeting_key,
164
+ const struct ddog_ffe_AttributePair *attributes,
165
+ uintptr_t attributes_count);
166
+
167
+ /**
168
+ * Frees an EvaluationContext
169
+ *
170
+ * # Safety
171
+ * `context` must be a valid EvaluationContext handle created by `ddog_ffe_evaluation_context_new`
172
+ */
173
+ void ddog_ffe_evaluation_context_drop(ddog_ffe_Handle_EvaluationContext *context);
174
+
175
+ #ifdef __cplusplus
176
+ } // extern "C"
177
+ #endif // __cplusplus
178
+
179
+ #endif /* DDOG_FFE_H */