ORE Studio 0.0.4
Loading...
Searching...
No Matches
feature_flags_service.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_VARIABILITY_SERVICE_FEATURE_FLAGS_SERVICE_HPP
21#define ORES_VARIABILITY_SERVICE_FEATURE_FLAGS_SERVICE_HPP
22
23#include <string>
24#include <vector>
25#include <optional>
26#include "ores.utility/log/make_logger.hpp"
27#include "ores.database/domain/context.hpp"
28#include "ores.variability/domain/feature_flags.hpp"
29#include "ores.variability/repository/feature_flags_repository.hpp"
30
31namespace ores::variability::service {
32
40private:
41 inline static std::string_view logger_name =
42 "ores.variability.service.feature_flags_service";
43
44 [[nodiscard]] static auto& lg() {
45 using namespace ores::utility::log;
46 static auto instance = make_logger(logger_name);
47 return instance;
48 }
49
50public:
57
64 [[nodiscard]] std::optional<domain::feature_flags> get_feature_flag(
65 const std::string& name);
66
72 [[nodiscard]] std::vector<domain::feature_flags> get_all_feature_flags();
73
84
93 void delete_feature_flag(const std::string& name);
94
95private:
97};
98
99}
100
101#endif
Implements logging for ORE Studio.
Definition lifecycle_manager.hpp:30
Context for the operations on a postgres database.
Definition context.hpp:30
Represents a feature flag in the domain layer.
Definition feature_flags.hpp:30
Reads and writes feature flags from data storage.
Definition feature_flags_repository.hpp:35
Service for managing feature flags.
Definition feature_flags_service.hpp:39
std::vector< domain::feature_flags > get_all_feature_flags()
Retrieves all currently active feature flags.
Definition feature_flags_service.cpp:46
void delete_feature_flag(const std::string &name)
Logically removes a feature flag.
Definition feature_flags_service.cpp:63
std::optional< domain::feature_flags > get_feature_flag(const std::string &name)
Retrieves a single feature flag by name.
Definition feature_flags_service.cpp:31
void save_feature_flag(const domain::feature_flags &flag)
Saves a feature flag.
Definition feature_flags_service.cpp:51