ORE Studio 0.0.4
Loading...
Searching...
No Matches
application.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_SERVICE_APP_APPLICATION_HPP
21#define ORES_SERVICE_APP_APPLICATION_HPP
22
23#include <optional>
24#include <boost/asio/awaitable.hpp>
25#include "ores.utility/log/make_logger.hpp"
26#include "ores.database/domain/context.hpp"
27#include "ores.database/domain/database_options.hpp"
28#include "ores.service/config/options.hpp"
29
30namespace ores::service::app {
31
35class application final {
36private:
37 inline static std::string_view logger_name = "ores.service.app.application";
38
39 static auto& lg() {
40 using namespace ores::utility::log;
41 static auto instance = make_logger(logger_name);
42 return instance;
43 }
44
45public:
47 application(const application&) = delete;
48 application& operator=(const application&) = delete;
49
50private:
52 make_context(const std::optional<database::database_options>& db_opts);
53
54public:
55 boost::asio::awaitable<void> run(boost::asio::io_context& io_ctx,
56 const config::options& cfg) const;
57};
58
59}
60
61#endif
Implements logging for ORE Studio.
Definition lifecycle_manager.hpp:30
Context for the operations on a postgres database.
Definition context.hpp:30
Entry point for the ores command line application.
Definition application.hpp:35
All of the configuration options required by the service.
Definition options.hpp:34