ORE Studio 0.0.4
Loading...
Searching...
No Matches
change_management_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_DQ_SERVICE_CHANGE_MANAGEMENT_SERVICE_HPP
21#define ORES_DQ_SERVICE_CHANGE_MANAGEMENT_SERVICE_HPP
22
23#include <string>
24#include <vector>
25#include <optional>
26#include "ores.logging/make_logger.hpp"
27#include "ores.database/domain/context.hpp"
28#include "ores.dq/domain/change_reason_category.hpp"
29#include "ores.dq/domain/change_reason.hpp"
30#include "ores.dq/repository/change_reason_category_repository.hpp"
31#include "ores.dq/repository/change_reason_repository.hpp"
32
33namespace ores::dq::service {
34
44private:
45 inline static std::string_view logger_name =
46 "ores.iam.service.change_management_service";
47
48 [[nodiscard]] static auto& lg() {
49 using namespace ores::logging;
50 static auto instance = make_logger(logger_name);
51 return instance;
52 }
53
54public:
56
63
64 // ========================================================================
65 // Category Management
66 // ========================================================================
67
71 std::vector<domain::change_reason_category> list_categories();
72
76 std::vector<domain::change_reason_category>
77 list_categories(std::uint32_t offset, std::uint32_t limit);
78
82 std::uint32_t get_category_count();
83
87 std::optional<domain::change_reason_category>
88 find_category(const std::string& code);
89
96
102 void remove_category(const std::string& code);
103
110 std::vector<domain::change_reason_category>
111 get_category_history(const std::string& code);
112
113 // ========================================================================
114 // Reason Management
115 // ========================================================================
116
120 std::vector<domain::change_reason> list_reasons();
121
125 std::vector<domain::change_reason>
126 list_reasons(std::uint32_t offset, std::uint32_t limit);
127
131 std::vector<domain::change_reason>
132 list_reasons_by_category(const std::string& category_code);
133
137 std::uint32_t get_reason_count();
138
142 std::optional<domain::change_reason> find_reason(const std::string& code);
143
149 void save_reason(const domain::change_reason& reason);
150
156 void remove_reason(const std::string& code);
157
164 std::vector<domain::change_reason> get_reason_history(const std::string& code);
165
166 // ========================================================================
167 // Validation
168 // ========================================================================
169
176 bool is_valid_reason_code(const std::string& code);
177
184 bool is_valid_category_code(const std::string& code);
185
186private:
189};
190
191}
192
193#endif
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
Context for the operations on a postgres database.
Definition context.hpp:30
Defines a specific reason for record changes.
Definition change_reason.hpp:47
Groups change reasons into logical categories.
Definition change_reason_category.hpp:45
Reads and writes change_reason_categories to data storage.
Definition change_reason_category_repository.hpp:35
Reads and writes change_reasons to data storage.
Definition change_reason_repository.hpp:35
Service for managing change reason categories and change reasons.
Definition change_management_service.hpp:43
bool is_valid_reason_code(const std::string &code)
Validates that a change reason code exists.
Definition change_management_service.cpp:172
std::vector< domain::change_reason_category > get_category_history(const std::string &code)
Gets the version history for a category.
Definition change_management_service.cpp:98
void save_reason(const domain::change_reason &reason)
Saves a change reason (creates or updates).
Definition change_management_service.cpp:144
std::vector< domain::change_reason > list_reasons_by_category(const std::string &category_code)
Lists change reasons for a specific category.
Definition change_management_service.cpp:122
void save_category(const domain::change_reason_category &category)
Saves a change reason category (creates or updates).
Definition change_management_service.cpp:69
void remove_category(const std::string &code)
Removes a change reason category.
Definition change_management_service.cpp:81
std::vector< domain::change_reason > get_reason_history(const std::string &code)
Gets the version history for a reason.
Definition change_management_service.cpp:163
void remove_reason(const std::string &code)
Removes a change reason.
Definition change_management_service.cpp:154
std::vector< domain::change_reason > list_reasons()
Lists all change reasons.
Definition change_management_service.cpp:108
std::uint32_t get_reason_count()
Gets the total count of active reasons.
Definition change_management_service.cpp:129
std::optional< domain::change_reason > find_reason(const std::string &code)
Finds a reason by its code.
Definition change_management_service.cpp:135
std::optional< domain::change_reason_category > find_category(const std::string &code)
Finds a category by its code.
Definition change_management_service.cpp:60
std::vector< domain::change_reason_category > list_categories()
Lists all change reason categories.
Definition change_management_service.cpp:41
bool is_valid_category_code(const std::string &code)
Validates that a category code exists.
Definition change_management_service.cpp:176
std::uint32_t get_category_count()
Gets the total count of active categories.
Definition change_management_service.cpp:54