generated from Sithas/conan_template
Рабочая сборка второго executor'а
This commit is contained in:
@@ -12,7 +12,7 @@
|
|||||||
- ~~Пройтись по коду и максимально наставить const~~
|
- ~~Пройтись по коду и максимально наставить const~~
|
||||||
- Указать возможные исключения в интерфейсах DAO
|
- Указать возможные исключения в интерфейсах DAO
|
||||||
- Вынести User в структуру. Hashed Password структура должна изначально состоять в другой структуре
|
- Вынести User в структуру. Hashed Password структура должна изначально состоять в другой структуре
|
||||||
- SharedPtr - передавать по константной ссылке.
|
- ~~SharedPtr - передавать по константной ссылке.~~
|
||||||
- Сделать интеграционный тест по ручкам
|
- Сделать интеграционный тест по ручкам
|
||||||
|
|
||||||
# UseCase'ы приложения:
|
# UseCase'ы приложения:
|
||||||
|
|||||||
@@ -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)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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));
|
||||||
|
|||||||
@@ -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>(
|
||||||
|
|||||||
Reference in New Issue
Block a user