generated from Sithas/conan_template
База для ручки GetUserDiariesExecutor.h
This commit is contained in:
@@ -8,7 +8,7 @@ namespace uad
|
|||||||
{
|
{
|
||||||
class IUserTreatmentSchemeDAO {
|
class IUserTreatmentSchemeDAO {
|
||||||
public:
|
public:
|
||||||
virtual std::vector<user_treatment_scheme_dto> FindByUserLogin(const std::string& login) = 0;
|
virtual std::vector<user_treatment_scheme_dto> FindByUserUUID(const std::string& login) = 0;
|
||||||
|
|
||||||
virtual ~IUserTreatmentSchemeDAO() = default;
|
virtual ~IUserTreatmentSchemeDAO() = default;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -10,8 +10,8 @@ MySQLUserTreatmentSchemesDAO::MySQLUserTreatmentSchemesDAO(mysqlx::Session& sess
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<user_treatment_scheme_dto> MySQLUserTreatmentSchemesDAO::FindByUserLogin(
|
std::vector<user_treatment_scheme_dto> MySQLUserTreatmentSchemesDAO::FindByUserUUID(
|
||||||
const std::string& login)
|
const std::string& user_uuid)
|
||||||
{
|
{
|
||||||
static const std::string query = R"(
|
static const std::string query = R"(
|
||||||
SELECT
|
SELECT
|
||||||
@@ -24,11 +24,14 @@ std::vector<user_treatment_scheme_dto> MySQLUserTreatmentSchemesDAO::FindByUserL
|
|||||||
ON uts.user_uuid = u.uuid
|
ON uts.user_uuid = u.uuid
|
||||||
LEFT JOIN up_and_down.treatment_schemes ts
|
LEFT JOIN up_and_down.treatment_schemes ts
|
||||||
ON ts.user_treatment_schemes_uuid = uts.uuid
|
ON ts.user_treatment_schemes_uuid = uts.uuid
|
||||||
WHERE u.login = ?
|
WHERE u.uuid = ?
|
||||||
ORDER BY uts.uuid
|
ORDER BY uts.uuid
|
||||||
)";
|
)";
|
||||||
|
|
||||||
mysqlx::SqlResult result = session_.sql(query).bind(login).execute();
|
mysqlx::SqlResult result = session_
|
||||||
|
.sql(query)
|
||||||
|
.bind(user_uuid)
|
||||||
|
.execute();
|
||||||
|
|
||||||
std::unordered_map<std::string, user_treatment_scheme_dto> scheme_map;
|
std::unordered_map<std::string, user_treatment_scheme_dto> scheme_map;
|
||||||
|
|
||||||
@@ -62,6 +65,6 @@ std::vector<user_treatment_scheme_dto> MySQLUserTreatmentSchemesDAO::FindByUserL
|
|||||||
schemes.push_back(std::move(dto));
|
schemes.push_back(std::move(dto));
|
||||||
}
|
}
|
||||||
|
|
||||||
return schemes;
|
return std::move(schemes);
|
||||||
}
|
}
|
||||||
} // uad
|
} // uad
|
||||||
|
|||||||
@@ -11,6 +11,6 @@ class MySQLUserTreatmentSchemesDAO : public IUserTreatmentSchemeDAO
|
|||||||
public:
|
public:
|
||||||
explicit MySQLUserTreatmentSchemesDAO(mysqlx::Session& session);
|
explicit MySQLUserTreatmentSchemesDAO(mysqlx::Session& session);
|
||||||
|
|
||||||
std::vector<user_treatment_scheme_dto> FindByUserLogin(const std::string& login) override;
|
std::vector<user_treatment_scheme_dto> FindByUserUUID(const std::string& uuid) override;
|
||||||
};
|
};
|
||||||
} // uad
|
} // uad
|
||||||
|
|||||||
@@ -65,57 +65,7 @@ public:
|
|||||||
std::string_view user_login_ref = auth_dao_->GetUUID(auth_token);
|
std::string_view user_login_ref = auth_dao_->GetUUID(auth_token);
|
||||||
const std::string user_uuid{user_login_ref.begin(), user_login_ref.end()};
|
const std::string user_uuid{user_login_ref.begin(), user_login_ref.end()};
|
||||||
|
|
||||||
static const std::string query = R"(
|
std::vector<user_treatment_scheme_dto> schemes = user_treatment_scheme_dao_->FindByUserUUID(user_uuid);
|
||||||
SELECT
|
|
||||||
uts.uuid,
|
|
||||||
uts.treatment_name,
|
|
||||||
uts.instructions,
|
|
||||||
ts.medication_uuid
|
|
||||||
FROM up_and_down.users u
|
|
||||||
JOIN up_and_down.user_treatment_schemes uts
|
|
||||||
ON uts.user_uuid = u.uuid
|
|
||||||
LEFT JOIN up_and_down.treatment_schemes ts
|
|
||||||
ON ts.user_treatment_schemes_uuid = uts.uuid
|
|
||||||
WHERE u.uuid = ?
|
|
||||||
ORDER BY uts.uuid
|
|
||||||
)";
|
|
||||||
|
|
||||||
mysqlx::SqlResult result = session_
|
|
||||||
.sql(query)
|
|
||||||
.bind(user_uuid)
|
|
||||||
.execute();
|
|
||||||
|
|
||||||
std::unordered_map<std::string, user_treatment_scheme_dto> scheme_map;
|
|
||||||
|
|
||||||
for (const mysqlx::Row& row : result)
|
|
||||||
{
|
|
||||||
const std::string scheme_uuid = row[0].get<std::string>();
|
|
||||||
|
|
||||||
if (scheme_map.find(scheme_uuid) == scheme_map.end())
|
|
||||||
{
|
|
||||||
user_treatment_scheme_dto dto;
|
|
||||||
dto.uuid = scheme_uuid;
|
|
||||||
dto.treatment_name = row[1].isNull() ? "" : row[1].get<std::string>();
|
|
||||||
dto.instructions = row[2].isNull() ? "" : row[2].get<std::string>();
|
|
||||||
|
|
||||||
scheme_map.emplace(scheme_uuid, std::move(dto));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!row[3].isNull())
|
|
||||||
{
|
|
||||||
scheme_map[scheme_uuid]
|
|
||||||
.medication_uuids
|
|
||||||
.push_back(row[3].get<std::string>());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<user_treatment_scheme_dto> schemes;
|
|
||||||
schemes.reserve(scheme_map.size());
|
|
||||||
|
|
||||||
for (auto& [_, dto] : scheme_map)
|
|
||||||
{
|
|
||||||
schemes.push_back(std::move(dto));
|
|
||||||
}
|
|
||||||
|
|
||||||
http::response<ResponseType> res{http::status::ok, req.version()};
|
http::response<ResponseType> res{http::status::ok, req.version()};
|
||||||
value response_body;
|
value response_body;
|
||||||
|
|||||||
Reference in New Issue
Block a user