Рабочая сборка второго executor'а

This commit is contained in:
Антон
2025-09-21 10:43:54 +03:00
parent 72f3603dd0
commit b2b1ebe794
5 changed files with 16 additions and 13 deletions
+1 -1
View File
@@ -12,7 +12,7 @@
- ~~Пройтись по коду и максимально наставить const~~ - ~~Пройтись по коду и максимально наставить const~~
- Указать возможные исключения в интерфейсах DAO - Указать возможные исключения в интерфейсах DAO
- Вынести User в структуру. Hashed Password структура должна изначально состоять в другой структуре - Вынести User в структуру. Hashed Password структура должна изначально состоять в другой структуре
- SharedPtr - передавать по константной ссылке. - ~~SharedPtr - передавать по константной ссылке.~~
- Сделать интеграционный тест по ручкам - Сделать интеграционный тест по ручкам
# UseCase'ы приложения: # UseCase'ы приложения:
+4 -4
View File
@@ -17,13 +17,13 @@ template <class Body, class Allocator, class ResponseType>
class AuthLoginExecutor : public IExecutor<Body, Allocator, ResponseType> class AuthLoginExecutor : public IExecutor<Body, Allocator, ResponseType>
{ {
mysqlx::Session& session_; mysqlx::Session& session_;
std::shared_ptr<IUserDAO> user_dao_; const std::shared_ptr<IUserDAO>& user_dao_;
std::shared_ptr<IAuthDAO> auth_dao_; const std::shared_ptr<IAuthDAO>& auth_dao_;
public: public:
AuthLoginExecutor(mysqlx::Session& session, AuthLoginExecutor(mysqlx::Session& session,
std::shared_ptr<IUserDAO> user_dao, const std::shared_ptr<IUserDAO>& user_dao,
std::shared_ptr<IAuthDAO> auth_dao) const std::shared_ptr<IAuthDAO>& auth_dao)
: session_(session), user_dao_(user_dao), auth_dao_(auth_dao) : session_(session), user_dao_(user_dao), auth_dao_(auth_dao)
{ {
} }
@@ -15,11 +15,11 @@ template <class Body, class Allocator, class ResponseType>
class AuthRegistrationExecutor : public IExecutor<Body, Allocator, ResponseType> class AuthRegistrationExecutor : public IExecutor<Body, Allocator, ResponseType>
{ {
mysqlx::Session& session_; mysqlx::Session& session_;
std::shared_ptr<IUserDAO> user_dao_; const std::shared_ptr<IUserDAO>& user_dao_;
public: public:
AuthRegistrationExecutor(mysqlx::Session& session, AuthRegistrationExecutor(mysqlx::Session& session,
std::shared_ptr<IUserDAO> user_dao) const std::shared_ptr<IUserDAO>& user_dao)
: session_(session), user_dao_(user_dao) : session_(session), user_dao_(user_dao)
{ {
} }
+5 -2
View File
@@ -17,10 +17,13 @@ void HandleRequest(
boost::beast::http::request<Body, boost::beast::http::basic_fields<Allocator>>&& req, boost::beast::http::request<Body, boost::beast::http::basic_fields<Allocator>>&& req,
Send&& send) Send&& send)
{ {
static std::shared_ptr<IUserDAO> user_dao = std::make_shared<MySQLUserDAO>(GetMySqlSession());
static std::shared_ptr<IAuthDAO> auth_dao = std::make_shared<MemoryAuthDAO>(GetMySqlSession());
static RootExecutor<Body, Allocator, boost::beast::http::string_body, Send> root_executor( static RootExecutor<Body, Allocator, boost::beast::http::string_body, Send> root_executor(
GetMySqlSession(), GetMySqlSession(),
std::make_shared<MySQLUserDAO>(GetMySqlSession()), user_dao,
std::make_shared<MemoryAuthDAO>(GetMySqlSession()) auth_dao
); );
root_executor(doc_root, std::move(req), std::forward<Send>(send)); root_executor(doc_root, std::move(req), std::forward<Send>(send));
+4 -4
View File
@@ -28,14 +28,14 @@ class RootExecutor
private: private:
RoutesPathes routes_pathes_; RoutesPathes routes_pathes_;
mysqlx::Session& session_; mysqlx::Session& session_;
std::shared_ptr<IUserDAO> user_dao_; const std::shared_ptr<IUserDAO>& user_dao_;
std::shared_ptr<IAuthDAO> auth_dao_; const std::shared_ptr<IAuthDAO>& auth_dao_;
public: public:
RootExecutor( RootExecutor(
mysqlx::Session& session, mysqlx::Session& session,
std::shared_ptr<IUserDAO> user_dao, const std::shared_ptr<IUserDAO>& user_dao,
std::shared_ptr<IAuthDAO> auth_dao) : const std::shared_ptr<IAuthDAO>& auth_dao) :
session_(session), user_dao_(user_dao), auth_dao_(auth_dao) session_(session), user_dao_(user_dao), auth_dao_(auth_dao)
{ {
routes_pathes_["/api/v1/Auth/Register"] = std::make_unique<RouteController>( routes_pathes_["/api/v1/Auth/Register"] = std::make_unique<RouteController>(