ORE Studio 0.0.4
Loading...
Searching...
No Matches
postgres_event_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_EVENTING_SERVICE_POSTGRES_EVENT_SOURCE_HPP
21#define ORES_EVENTING_SERVICE_POSTGRES_EVENT_SOURCE_HPP
22
23#include <memory>
24#include <functional>
25#include <unordered_map>
26#include "ores.utility/log/make_logger.hpp"
27#include "ores.database/domain/context.hpp"
28#include "ores.eventing/domain/entity_change_event.hpp"
29#include "ores.eventing/service/event_bus.hpp"
30#include "ores.eventing/service/postgres_listener_service.hpp"
31
32namespace ores::eventing::service {
33
58private:
59 [[nodiscard]] static auto& lg() {
60 using namespace ores::utility::log;
61 static auto instance = make_logger(
62 "ores.eventing.service.postgres_event_source");
63 return instance;
64 }
65
71 using publisher_fn = std::function<void(std::chrono::system_clock::time_point)>;
72
73 struct entity_mapping {
74 std::string channel_name;
75 publisher_fn publisher;
76 };
77
78public:
86
88
90 postgres_event_source& operator=(const postgres_event_source&) = delete;
91
103 template<typename Event>
104 void register_mapping(const std::string& entity_name,
105 const std::string& channel_name) {
106 using namespace ores::utility::log;
107 BOOST_LOG_SEV(lg(), info)
108 << "Registering entity-to-event mapping: entity='" << entity_name
109 << "', channel='" << channel_name << "'";
110
111 entity_mappings_[entity_name] = entity_mapping{
112 .channel_name = channel_name,
113 .publisher = [this, entity_name](std::chrono::system_clock::time_point ts) {
114 using namespace ores::utility::log;
115 BOOST_LOG_SEV(lg(), info)
116 << "Publishing domain event for entity: " << entity_name;
117 bus_.publish(Event{ts});
118 }
119 };
120
121 listener_.subscribe(channel_name);
122 BOOST_LOG_SEV(lg(), debug)
123 << "Subscribed to PostgreSQL channel: " << channel_name;
124 }
125
131 void start();
132
138 void stop();
139
140private:
146 void on_entity_change(const domain::entity_change_event& e);
147
148 event_bus& bus_;
150 std::unordered_map<std::string, entity_mapping> entity_mappings_;
151};
152
153}
154
155#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 low-level notification about a change to an entity at the repository level.
Definition entity_change_event.hpp:32
A typed, thread-safe, in-process publish/subscribe event bus.
Definition event_bus.hpp:119
void publish(const Event &event)
Publish an event to all subscribers.
Definition event_bus.hpp:188
Event source that bridges PostgreSQL LISTEN/NOTIFY to the event bus.
Definition postgres_event_source.hpp:57
void start()
Start the event source.
Definition postgres_event_source.cpp:41
void stop()
Stop the event source.
Definition postgres_event_source.cpp:47
void register_mapping(const std::string &entity_name, const std::string &channel_name)
Register a mapping from entity name to typed domain event.
Definition postgres_event_source.hpp:104
Manages a dedicated PostgreSQL connection to listen for NOTIFY events.
Definition postgres_listener_service.hpp:48
void subscribe(const std::string &channel_name)
Subscribes to a PostgreSQL NOTIFY channel.
Definition postgres_listener_service.cpp:117