ORE Studio 0.0.4
Loading...
Searching...
No Matches
telemetry_source.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_TELEMETRY_DOMAIN_TELEMETRY_SOURCE_HPP
21#define ORES_TELEMETRY_DOMAIN_TELEMETRY_SOURCE_HPP
22
23#include <string_view>
24
26
33enum class telemetry_source {
39 client = 0,
40
46 server = 1
47};
48
52[[nodiscard]] constexpr std::string_view to_string(telemetry_source s) {
53 switch (s) {
54 case telemetry_source::client: return "client";
55 case telemetry_source::server: return "server";
56 default: return "unknown";
57 }
58}
59
63[[nodiscard]] constexpr telemetry_source
64telemetry_source_from_string(std::string_view s) {
65 if (s == "client") return telemetry_source::client;
66 if (s == "server") return telemetry_source::server;
67 return telemetry_source::client; // Default fallback
68}
69
70}
71
72#endif
Domain types for telemetry and observability.
Definition attribute_value.hpp:29
telemetry_source
Source type for telemetry log entries.
Definition telemetry_source.hpp:33
@ client
Log entry from a client application.
@ server
Log entry from the server itself.
constexpr telemetry_source telemetry_source_from_string(std::string_view s)
Converts a string to telemetry_source.
Definition telemetry_source.hpp:64
constexpr std::string_view to_string(telemetry_source s)
Converts a telemetry_source to its string representation.
Definition telemetry_source.hpp:52
@ client
Indicates that the span describes a request to some remote service. This is often the client-side of ...
@ server
Indicates that the span covers the server-side handling of a synchronous RPC or other remote request.