This commit is contained in:
parent
0ac66001bf
commit
769e672ca0
@ -1,10 +1,10 @@
|
|||||||
#include "Session.h"
|
#include "Session.h"
|
||||||
#include "BoostLog.h"
|
#include "BoostLog.h"
|
||||||
#include <Wt/Auth/Dbo/UserDatabase.h>
|
#include <Wt/Auth/Dbo/UserDatabase.h>
|
||||||
#include <Wt/Dbo/WtJsonSqlTraits.h>
|
|
||||||
#include <Wt/Dbo/backend/Sqlite3.h>
|
|
||||||
#include <Wt/Dbo/FixedSqlConnectionPool.h>
|
#include <Wt/Dbo/FixedSqlConnectionPool.h>
|
||||||
#include <Wt/Dbo/SqlConnectionPool.h>
|
#include <Wt/Dbo/SqlConnectionPool.h>
|
||||||
|
#include <Wt/Dbo/WtJsonSqlTraits.h>
|
||||||
|
#include <Wt/Dbo/backend/Sqlite3.h>
|
||||||
|
|
||||||
namespace Database {
|
namespace Database {
|
||||||
std::unique_ptr<Wt::Dbo::SqlConnectionPool> sqlConnectionPool;
|
std::unique_ptr<Wt::Dbo::SqlConnectionPool> sqlConnectionPool;
|
||||||
|
@ -51,6 +51,7 @@ Application::Application(const Wt::WEnvironment &env, bool embedded) : Wt::WAppl
|
|||||||
bindWidget(std::move(topPtr), *div);
|
bindWidget(std::move(topPtr), *div);
|
||||||
} else {
|
} else {
|
||||||
LOG(error) << "Missing: parameter: 'div'";
|
LOG(error) << "Missing: parameter: 'div'";
|
||||||
|
m_root = nullptr;
|
||||||
}
|
}
|
||||||
auto externalPath = env.getParameter("path");
|
auto externalPath = env.getParameter("path");
|
||||||
if (externalPath != nullptr) {
|
if (externalPath != nullptr) {
|
||||||
@ -67,10 +68,16 @@ Application::Application(const Wt::WEnvironment &env, bool embedded) : Wt::WAppl
|
|||||||
LOG(info) << "relative resources url: " << relativeResourcesUrl();
|
LOG(info) << "relative resources url: " << relativeResourcesUrl();
|
||||||
LOG(info) << "resources url: " << resourcesUrl();
|
LOG(info) << "resources url: " << resourcesUrl();
|
||||||
LOG(info) << "internal path: " << internalPath();
|
LOG(info) << "internal path: " << internalPath();
|
||||||
|
LOG(info) << "bookmark url: " << bookmarkUrl("/");
|
||||||
|
LOG(info) << "relative url: " << resolveRelativeUrl("/");
|
||||||
|
|
||||||
auto app = Amass::Singleton<WebToolkit::Server>::instance();
|
auto app = Amass::Singleton<WebToolkit::Server>::instance();
|
||||||
m_loginPage = std::make_unique<LoginPage>(app->authService(), m_session->users(), m_session->login());
|
m_loginPage = std::make_unique<LoginPage>(app->authService(), m_session->users(), m_session->login());
|
||||||
m_loginPage->processEnvironment();
|
if (m_externalPath.empty()) {
|
||||||
|
m_loginPage->processEnvironment();
|
||||||
|
} else {
|
||||||
|
m_loginPage->processExternalEnvironment(m_externalPath, app->authService());
|
||||||
|
}
|
||||||
|
|
||||||
handlePathChange(m_externalPath.empty() ? internalPath() : m_externalPath);
|
handlePathChange(m_externalPath.empty() ? internalPath() : m_externalPath);
|
||||||
internalPathChanged().connect(this, &Application::handlePathChange);
|
internalPathChanged().connect(this, &Application::handlePathChange);
|
||||||
@ -116,9 +123,13 @@ void Application::authEvent() {
|
|||||||
|
|
||||||
void Application::handlePathChange(const std::string &path) {
|
void Application::handlePathChange(const std::string &path) {
|
||||||
LOG(info) << "handlePathChange: " << path;
|
LOG(info) << "handlePathChange: " << path;
|
||||||
|
if (m_root == nullptr) {
|
||||||
|
LOG(error) << "root container is null.";
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (path.starts_with("/wt/login")) {
|
if (path.starts_with("/wt/login")) {
|
||||||
if (m_session->login().loggedIn()) {
|
if (m_session->login().loggedIn()) {
|
||||||
std::exit(0);
|
LOG(info) << "already logged in.";
|
||||||
} else {
|
} else {
|
||||||
if (m_loginPage) {
|
if (m_loginPage) {
|
||||||
m_root->clear();
|
m_root->clear();
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#include "Application.h"
|
#include "Application.h"
|
||||||
#include <Wt/Auth/AuthService.h>
|
#include <Wt/Auth/AuthService.h>
|
||||||
#include <Wt/Auth/PasswordService.h>
|
#include <Wt/Auth/PasswordService.h>
|
||||||
|
#include <Wt/WEnvironment.h>
|
||||||
#include <Wt/WVBoxLayout.h>
|
#include <Wt/WVBoxLayout.h>
|
||||||
|
|
||||||
LoginPage::LoginPage(const Wt::Auth::AuthService &baseAuth, Wt::Auth::AbstractUserDatabase &users, Wt::Auth::Login &login)
|
LoginPage::LoginPage(const Wt::Auth::AuthService &baseAuth, Wt::Auth::AbstractUserDatabase &users, Wt::Auth::Login &login)
|
||||||
@ -12,3 +13,53 @@ LoginPage::LoginPage(const Wt::Auth::AuthService &baseAuth, Wt::Auth::AbstractUs
|
|||||||
setRegistrationEnabled(true);
|
setRegistrationEnabled(true);
|
||||||
// setAttributeValue("style", "transform: translateY(-100px);");
|
// setAttributeValue("style", "transform: translateY(-100px);");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LoginPage::processExternalEnvironment(const std::string &externalPath, Wt::Auth::AuthService &service) {
|
||||||
|
using namespace Wt::Auth;
|
||||||
|
std::string emailToken;
|
||||||
|
if (service.emailVerificationEnabled()) {
|
||||||
|
auto redirectPath = service.emailRedirectInternalPath();
|
||||||
|
auto pos = externalPath.find(redirectPath);
|
||||||
|
if (pos != std::string::npos) {
|
||||||
|
emailToken = externalPath.substr(pos + redirectPath.size());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!emailToken.empty()) {
|
||||||
|
EmailTokenResult result = model()->processEmailToken(emailToken);
|
||||||
|
switch (result.state()) {
|
||||||
|
case EmailTokenState::Invalid:
|
||||||
|
displayError(tr("Wt.Auth.error-invalid-token"));
|
||||||
|
break;
|
||||||
|
case EmailTokenState::Expired:
|
||||||
|
displayError(tr("Wt.Auth.error-token-expired"));
|
||||||
|
break;
|
||||||
|
case EmailTokenState::UpdatePassword:
|
||||||
|
letUpdatePassword(result.user(), false);
|
||||||
|
break;
|
||||||
|
case EmailTokenState::EmailConfirmed:
|
||||||
|
displayInfo(tr("Wt.Auth.info-email-confirmed"));
|
||||||
|
User user = result.user();
|
||||||
|
|
||||||
|
LoginState state = LoginState::Strong;
|
||||||
|
if (model()->hasMfaStep(user)) {
|
||||||
|
state = LoginState::RequiresMfa;
|
||||||
|
}
|
||||||
|
model()->loginUser(login(), user, state);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* In progressive bootstrap mode, this would cause a redirect w/o
|
||||||
|
* session ID, losing the dialog.
|
||||||
|
*/
|
||||||
|
if (Wt::WApplication::instance()->environment().ajax()) Wt::WApplication::instance()->setInternalPath("/");
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
User user = model()->processAuthToken();
|
||||||
|
LoginState state = LoginState::Weak;
|
||||||
|
if (model()->hasMfaStep(user)) {
|
||||||
|
state = LoginState::RequiresMfa;
|
||||||
|
}
|
||||||
|
model()->loginUser(login(), user, state);
|
||||||
|
}
|
@ -6,6 +6,7 @@
|
|||||||
class LoginPage : public Wt::Auth::AuthWidget {
|
class LoginPage : public Wt::Auth::AuthWidget {
|
||||||
public:
|
public:
|
||||||
LoginPage(const Wt::Auth::AuthService &baseAuth, Wt::Auth::AbstractUserDatabase &users, Wt::Auth::Login &login);
|
LoginPage(const Wt::Auth::AuthService &baseAuth, Wt::Auth::AbstractUserDatabase &users, Wt::Auth::Login &login);
|
||||||
|
void processExternalEnvironment(const std::string &externalPath, Wt::Auth::AuthService &service);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __LOGINWIDGET_H__
|
#endif // __LOGINWIDGET_H__
|
Loading…
Reference in New Issue
Block a user