#include "rbac_model.h" #include "core/database/database.h" #include "core/database/database_manager.h" #include "core/database/query_builder.h" #include "core/database/query_result.h" #include "core/database/table_builder.h" #define RBAC_RANK_TABLE "rbac_ranks" #define RBAC_PERMISSION_TABLE "rbac_permissions" std::map > RBACModel::load_permissions() { std::map > ranks; Ref qb = DatabaseManager::get_singleton()->ddb->get_query_builder(); qb->select("id,name,name_internal,settings,rank_permissions")->from(RBAC_RANK_TABLE); Ref res = qb->run(); while (res->next_row()) { Ref r; r.instance(); r->id = res->get_cell_int(0); r->name = res->get_cell_str(1); r->name_internal = res->get_cell_str(2); r->settings = res->get_cell_str(3); r->rank_permissions = res->get_cell_int(4); ranks[r->id] = r; } /* qb->reset(); qb->select("id,name,name_internal,settings,rank_permissions")->from(RBAC_PERMISSION_TABLE); res = qb->run(); */ return ranks; } void RBACModel::save(const Ref &rank) { save_rank(rank); for (int i = 0; i < rank->permissions.size(); ++i) { Ref permission = rank->permissions[i]; if (permission->rank_id == 0) { permission->rank_id = rank->id; } save_permission(permission); } } void RBACModel::save_rank(const Ref &rank) { Ref qb = DatabaseManager::get_singleton()->ddb->get_query_builder(); if (rank->id == 0) { qb->insert(RBAC_RANK_TABLE, "name,name_internal,settings,rank_permissions")->values(); qb->val(rank->name)->val(rank->name_internal)->val(rank->settings)->val(rank->rank_permissions); qb->cvalues(); qb->select_last_insert_id(); Ref res = qb->run(); qb->print(); Ref r = rank; r->id = res->get_last_insert_rowid(); } else { qb->update(RBAC_RANK_TABLE)->set(); qb->setp("name", rank->name); qb->setp("name_internal", rank->name_internal); qb->setp("settings", rank->settings); qb->setp("rank_permissions", rank->rank_permissions); qb->cset(); qb->where()->wp("id", rank->id); qb->end_command(); qb->run_query(); qb->print(); } } void RBACModel::save_permission(const Ref &permission) { } void RBACModel::create_table() { Ref tb = DatabaseManager::get_singleton()->ddb->get_table_builder(); tb->create_table(RBAC_RANK_TABLE); tb->integer("id")->auto_increment()->next_row(); tb->varchar("name", 60)->not_null()->next_row(); tb->varchar("name_internal", 100)->not_null()->next_row(); tb->varchar("settings", 200)->not_null()->next_row(); tb->integer("rank_permissions")->not_null()->next_row(); tb->primary_key("id"); tb->ccreate_table(); //tb->run_query(); //tb->print(); //tb->result = ""; tb->create_table(RBAC_PERMISSION_TABLE); tb->integer("id")->auto_increment()->next_row(); tb->integer("rank_id")->not_null()->next_row(); tb->varchar("name", 60)->not_null()->next_row(); tb->varchar("url", 100)->not_null()->next_row(); tb->integer("revoke")->not_null()->next_row(); tb->integer("sort_order")->not_null()->next_row(); tb->integer("permissions")->not_null()->next_row(); tb->primary_key("id"); tb->foreign_key("rank_id")->references(RBAC_RANK_TABLE, "id"); tb->ccreate_table(); tb->run_query(); //tb->print(); } void RBACModel::drop_table() { Ref tb = DatabaseManager::get_singleton()->ddb->get_table_builder(); tb->drop_table_if_exists(RBAC_PERMISSION_TABLE)->drop_table_if_exists(RBAC_RANK_TABLE)->run_query(); //tb->print(); } void RBACModel::migrate() { drop_table(); create_table(); } RBACModel *RBACModel::get_singleton() { return _self; } RBACModel::RBACModel() : Model() { if (_self) { printf("RBACModel::RBACModel(): Error! self is not null!/n"); } _self = this; } RBACModel::~RBACModel() { if (_self == this) { _self = nullptr; } } RBACModel *RBACModel::_self = nullptr;