MQTTSuite
Loading...
Searching...
No Matches
MappingAdminRouter.h
Go to the documentation of this file.
1/*
2 * MQTTSuite - A lightweight MQTT Integration System
3 * Copyright (C) Tobias Pfeil
4 * 2025, 2026
5 *
6 * This program is free software: you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the Free
8 * Software Foundation, either version 3 of the License, or (at your option)
9 * any later version.
10 *
11 * This program is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 * more details.
15 *
16 * You should have received a copy of the GNU General Public License along
17 * with this program. If not, see <https://www.gnu.org/licenses/>.
18 */
19
20/*
21 * MIT License
22 *
23 * Permission is hereby granted, free of charge, to any person obtaining a copy
24 * of this software and associated documentation files (the "Software"), to deal
25 * in the Software without restriction, including without limitation the rights
26 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
27 * copies of the Software, and to permit persons to whom the Software is
28 * furnished to do so, subject to the following conditions:
29 *
30 * The above copyright notice and this permission notice shall be included in
31 * all copies or substantial portions of the Software.
32 *
33 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
39 * THE SOFTWARE.
40 */
41
42#ifndef MQTTBROKER_LIB_MAPPINGADMINROUTER_H
43#define MQTTBROKER_LIB_MAPPINGADMINROUTER_H
44
45namespace mqtt::lib {
47}
48
49#include <express/Router.h>
50
51#ifndef DOXYGEN_SHOULD_SKIP_THIS
52
53#include <cstddef>
54#include <functional>
55#include <string>
56
57#endif // DOXYGEN_SHOULD_SKIP_THIS
58
59namespace mqtt::lib::admin {
60
61 struct AdminOptions {
62 std::string user{"admin"};
63 std::string pass{"admin"};
64 std::string realm{"mqttsuite-admin"};
65 };
66
67 struct ReloadResult {
68 std::string mode;
69 std::size_t instances{0};
70 std::size_t subscribed{0};
71 std::size_t unsubscribed{0};
72 };
73
74 // Callback to trigger reload in the main application
75 using ReloadCallback = std::function<ReloadResult(bool)>;
76
77 // Creates and returns a Router that handles /config/* endpoints.
78 express::Router makeMappingAdminRouter(ConfigApplication* configApplication, const AdminOptions& opt, ReloadCallback onDeploy = {});
79
80} // namespace mqtt::lib::admin
81
82#endif // MQTTBROKER_LIB_MAPPINGADMINROUTER_H
std::string getMappingFilename() const
const std::shared_ptr< MqttMapper > getMqttMapper() const
bool setMapping(const nlohmann::json &json)
static nlohmann::json deployDraft(const std::string &mapFilePath)
static nlohmann::json rollbackTo(const std::string &mapFilePath, const std::string &versionId)
static std::vector< VersionEntry > getHistory(const std::string &mapFilePath)
static std::string getDraftPath(const std::string &mapFilePath)
static void saveDraft(const std::string &mapFilePath, const nlohmann::json &content)
static const nlohmann::json validate(const nlohmann::json &json, nlohmann::json_schema::basic_error_handler &err)
const nlohmann::json & getMapping() const
static const std::string & getSchema()
express::Router makeMappingAdminRouter(ConfigApplication *configApplication, const AdminOptions &opt, ReloadCallback onDeploy)
std::function< ReloadResult(bool)> ReloadCallback