ORE Studio 0.0.4
Loading...
Searching...
No Matches
compute_telemetry_repository.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2026 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_COMPUTE_REPOSITORY_COMPUTE_TELEMETRY_REPOSITORY_HPP
21#define ORES_COMPUTE_REPOSITORY_COMPUTE_TELEMETRY_REPOSITORY_HPP
22
23#include <optional>
24#include <vector>
25#include <sqlgen/postgres.hpp>
26#include "ores.logging/make_logger.hpp"
27#include "ores.database/domain/context.hpp"
28#include "ores.compute.api/domain/grid_sample.hpp"
29#include "ores.compute.api/domain/node_sample.hpp"
30
31namespace ores::compute::repository {
32
40private:
41 inline static std::string_view logger_name =
42 "ores.compute.repository.compute_telemetry_repository";
43
44 [[nodiscard]] static auto& lg() {
45 using namespace ores::logging;
46 static auto instance = make_logger(logger_name);
47 return instance;
48 }
49
50public:
52
56 void insert_grid_sample(context ctx, const domain::grid_sample& sample);
57
61 void insert_node_sample(context ctx, const domain::node_sample& sample);
62
68 std::optional<domain::grid_sample>
70
77 std::vector<domain::node_sample>
79
88};
89
90}
91
92#endif
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
A single point-in-time snapshot of server-side compute grid metrics.
Definition grid_sample.hpp:35
A single point-in-time sample of per-node execution metrics.
Definition node_sample.hpp:36
Persistence for compute grid telemetry time-series samples.
Definition compute_telemetry_repository.hpp:39
std::optional< domain::grid_sample > latest_grid_sample(context ctx)
Return the most recent grid sample for the context's tenant.
Definition compute_telemetry_repository.cpp:147
domain::grid_sample compute_grid_stats(context ctx)
Compute current grid statistics using SQL aggregations.
Definition compute_telemetry_repository.cpp:210
void insert_grid_sample(context ctx, const domain::grid_sample &sample)
Insert one grid-level sample row.
Definition compute_telemetry_repository.cpp:123
void insert_node_sample(context ctx, const domain::node_sample &sample)
Insert one node-level sample row.
Definition compute_telemetry_repository.cpp:134
std::vector< domain::node_sample > latest_node_samples(context ctx)
Return the most recent sample per node for the context's tenant.
Definition compute_telemetry_repository.cpp:164
Context for the operations on a postgres database.
Definition context.hpp:47