diff options
Diffstat (limited to 'lib/group.cpp')
| -rw-r--r-- | lib/group.cpp | 44 |
1 files changed, 31 insertions, 13 deletions
| diff --git a/lib/group.cpp b/lib/group.cpp index 8b6d985..d5790e9 100644 --- a/lib/group.cpp +++ b/lib/group.cpp | |||
| @@ -1,43 +1,61 @@ | |||
| 1 | #include "group.h" | 1 | #include "group.h" |
| 2 | #include <sqlite3.h> | 2 | #include <sqlite3.h> |
| 3 | #include "frame.h" | 3 | #include <json.hpp> |
| 4 | #include "database.h" | 4 | #include "database.h" |
| 5 | #include "query.h" | 5 | #include "query.h" |
| 6 | 6 | ||
| 7 | namespace verbly { | 7 | namespace verbly { |
| 8 | 8 | ||
| 9 | const object group::objectType = object::group; | 9 | const object group::objectType = object::group; |
| 10 | 10 | ||
| 11 | const std::list<std::string> group::select = {"group_id", "data"}; | 11 | const std::list<std::string> group::select = {"group_id", "data"}; |
| 12 | 12 | ||
| 13 | const field group::id = field::integerField(object::group, "group_id"); | 13 | const field group::id = field::integerField(object::group, "group_id"); |
| 14 | 14 | ||
| 15 | const field group::frame = field::joinThrough(object::group, "group_id", object::frame, "groups_frames", "frame_id"); | 15 | const field group::frame = field::joinThrough(object::group, "group_id", object::frame, "groups_frames", "frame_id"); |
| 16 | const field group::word = field::joinField(object::group, "group_id", object::word); | 16 | const field group::word = field::joinField(object::group, "group_id", object::word); |
| 17 | 17 | ||
| 18 | group::group(const database& db, sqlite3_stmt* row) : db_(&db), valid_(true) | 18 | group::group(const database& db, sqlite3_stmt* row) : db_(&db), valid_(true) |
| 19 | { | 19 | { |
| 20 | id_ = sqlite3_column_int(row, 0); | 20 | id_ = sqlite3_column_int(row, 0); |
| 21 | 21 | ||
| 22 | // TODO: Initialize role data from row. | 22 | std::string rolesJsonStr(reinterpret_cast<const char*>(sqlite3_column_blob(row, 1))); |
| 23 | nlohmann::json rolesJson = nlohmann::json::parse(std::move(rolesJsonStr)); | ||
| 24 | for (const nlohmann::json& roleJson : rolesJson) | ||
| 25 | { | ||
| 26 | std::string roleName = roleJson["type"]; | ||
| 27 | selrestr roleSelrestr; | ||
| 28 | |||
| 29 | if (roleJson.find("selrestrs") != roleJson.end()) | ||
| 30 | { | ||
| 31 | roleSelrestr = selrestr(roleJson["selrestrs"]); | ||
| 32 | } | ||
| 33 | |||
| 34 | roles_[roleName] = role(roleName, std::move(roleSelrestr)); | ||
| 35 | } | ||
| 23 | } | 36 | } |
| 24 | 37 | ||
| 25 | const std::vector<frame>& group::getFrames() const | 38 | const std::vector<frame>& group::getFrames() const |
| 26 | { | 39 | { |
| 27 | if (!valid_) | 40 | if (!valid_) |
| 28 | { | 41 | { |
| 29 | throw std::domain_error("Bad access to uninitialized group"); | 42 | throw std::domain_error("Bad access to uninitialized group"); |
| 30 | } | 43 | } |
| 31 | 44 | ||
| 32 | if (!initializedFrames_) | 45 | if (!initializedFrames_) |
| 33 | { | 46 | { |
| 34 | frames_ = db_->frames(frame::group %= *this, false, -1).all(); | 47 | frames_ = db_->frames(frame::group %= *this, false, -1).all(); |
| 35 | 48 | ||
| 36 | initializedFrames_ = true; | 49 | initializedFrames_ = true; |
| 37 | } | 50 | } |
| 38 | 51 | ||
| 39 | return frames_; | 52 | return frames_; |
| 40 | } | 53 | } |
| 41 | 54 | ||
| 55 | const role& group::getRole(std::string roleName) const | ||
| 56 | { | ||
| 57 | return roles_.at(roleName); | ||
| 58 | } | ||
| 59 | |||
| 42 | }; | 60 | }; |
| 43 | 61 | ||
