mirror of
https://github.com/Relintai/rcpp_framework.git
synced 2025-05-06 17:51:36 +02:00
Reworked sessions.
This commit is contained in:
parent
a4e3f5d3cd
commit
9d8a752707
@ -1,16 +1,16 @@
|
|||||||
#include "user_controller.h"
|
#include "user_controller.h"
|
||||||
|
|
||||||
#include "user_model.h"
|
|
||||||
#include "core/http/request.h"
|
|
||||||
#include "core/html/form_validator.h"
|
#include "core/html/form_validator.h"
|
||||||
#include "core/html/html_builder.h"
|
#include "core/html/html_builder.h"
|
||||||
#include "core/http/http_session.h"
|
|
||||||
#include "core/http/session_manager.h"
|
|
||||||
#include "core/http/cookie.h"
|
#include "core/http/cookie.h"
|
||||||
|
#include "core/http/http_session.h"
|
||||||
|
#include "core/http/request.h"
|
||||||
|
#include "core/http/session_manager.h"
|
||||||
|
#include "user_model.h"
|
||||||
|
|
||||||
void UserController::handle_request_default(Request *request) {
|
void UserController::handle_request_default(Request *request) {
|
||||||
if (request->session) {
|
if (request->session) {
|
||||||
Ref<User> u = request->session->get_reference("user");
|
Ref<User> u = request->reference_data["user"];
|
||||||
|
|
||||||
if (u.is_valid()) {
|
if (u.is_valid()) {
|
||||||
handle_request(u, request);
|
handle_request(u, request);
|
||||||
@ -66,7 +66,7 @@ void UserController::handle_login_request_default(Request *request) {
|
|||||||
} else {
|
} else {
|
||||||
HTTPSession *session = request->get_or_create_session();
|
HTTPSession *session = request->get_or_create_session();
|
||||||
|
|
||||||
session->add_int("user", user->id);
|
session->add_int("user_id", user->id);
|
||||||
//session->save();
|
//session->save();
|
||||||
|
|
||||||
request->add_cookie(::Cookie("session_id", session->session_id));
|
request->add_cookie(::Cookie("session_id", session->session_id));
|
||||||
@ -475,6 +475,25 @@ void UserController::create_validators() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UserController::user_session_setup_middleware(Object *instance, Request *request) {
|
||||||
|
if (request->session) {
|
||||||
|
int user_id = request->session->get_int("user_id");
|
||||||
|
|
||||||
|
if (user_id != 0) {
|
||||||
|
Ref<User> u = UserModel::get_singleton()->get_user(user_id);
|
||||||
|
|
||||||
|
if (u.is_valid()) {
|
||||||
|
request->reference_data["user"] = u;
|
||||||
|
} else {
|
||||||
|
//log
|
||||||
|
request->session->remove_int("user_id");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
request->next_stage();
|
||||||
|
}
|
||||||
|
|
||||||
UserController *UserController::get_singleton() {
|
UserController *UserController::get_singleton() {
|
||||||
return _self;
|
return _self;
|
||||||
}
|
}
|
||||||
@ -487,6 +506,8 @@ UserController::UserController() :
|
|||||||
}
|
}
|
||||||
|
|
||||||
_self = this;
|
_self = this;
|
||||||
|
|
||||||
|
create_validators();
|
||||||
}
|
}
|
||||||
|
|
||||||
UserController::~UserController() {
|
UserController::~UserController() {
|
||||||
|
@ -23,7 +23,9 @@ public:
|
|||||||
virtual void handle_logout_request(Ref<User> &user, Request *request);
|
virtual void handle_logout_request(Ref<User> &user, Request *request);
|
||||||
virtual void handle_delete_request(Ref<User> &user, Request *request);
|
virtual void handle_delete_request(Ref<User> &user, Request *request);
|
||||||
|
|
||||||
static void create_validators();
|
virtual void create_validators();
|
||||||
|
|
||||||
|
static void user_session_setup_middleware(Object *instance, Request *request);
|
||||||
|
|
||||||
static UserController *get_singleton();
|
static UserController *get_singleton();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user