20#ifndef ORES_REFDATA_CORE_SERVICE_BOOK_SERVICE_HPP
21#define ORES_REFDATA_CORE_SERVICE_BOOK_SERVICE_HPP
26#include <boost/uuid/uuid.hpp>
27#include "ores.logging/make_logger.hpp"
28#include "ores.database/domain/context.hpp"
29#include "ores.refdata.api/domain/book.hpp"
30#include "ores.refdata.core/repository/book_repository.hpp"
32namespace ores::refdata::service {
42 inline static std::string_view logger_name =
43 "ores.refdata.service.book_service";
45 [[nodiscard]]
static auto& lg() {
47 static auto instance = make_logger(logger_name);
69 std::optional<domain::book>
75 std::optional<domain::book>
90 void save_books(
const std::vector<domain::book>& books);
105 std::vector<domain::book>
Implements logging infrastructure for ORE Studio.
Definition boost_severity.hpp:28
Context for the operations on a postgres database.
Definition context.hpp:47
Operational ledger leaf that holds trades.
Definition book.hpp:37
Reads and writes books to data storage.
Definition book_repository.hpp:36
Service for managing books.
Definition book_service.hpp:40
std::optional< domain::book > find_book_by_code(const std::string &code)
Finds a book by its code.
Definition book_service.cpp:51
std::vector< domain::book > get_book_history(const boost::uuids::uuid &id)
Gets the version history for a book.
Definition book_service.cpp:90
std::vector< domain::book > list_books()
Lists all books.
Definition book_service.cpp:35
void save_books(const std::vector< domain::book > &books)
Saves multiple books (creates or updates).
Definition book_service.cpp:71
std::optional< domain::book > find_book(const boost::uuids::uuid &id)
Finds a book by its ID.
Definition book_service.cpp:41
void save_book(const domain::book &book)
Saves a book (creates or updates).
Definition book_service.cpp:60
void remove_book(const boost::uuids::uuid &id)
Removes a book.
Definition book_service.cpp:83