This commit is contained in:
parent
0ac66001bf
commit
769e672ca0
@ -1,10 +1,10 @@
|
||||
#include "Session.h"
|
||||
#include "BoostLog.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/SqlConnectionPool.h>
|
||||
#include <Wt/Dbo/WtJsonSqlTraits.h>
|
||||
#include <Wt/Dbo/backend/Sqlite3.h>
|
||||
|
||||
namespace Database {
|
||||
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);
|
||||
} else {
|
||||
LOG(error) << "Missing: parameter: 'div'";
|
||||
m_root = nullptr;
|
||||
}
|
||||
auto externalPath = env.getParameter("path");
|
||||
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) << "resources url: " << resourcesUrl();
|
||||
LOG(info) << "internal path: " << internalPath();
|
||||
LOG(info) << "bookmark url: " << bookmarkUrl("/");
|
||||
LOG(info) << "relative url: " << resolveRelativeUrl("/");
|
||||
|
||||
auto app = Amass::Singleton<WebToolkit::Server>::instance();
|
||||
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);
|
||||
internalPathChanged().connect(this, &Application::handlePathChange);
|
||||
@ -116,9 +123,13 @@ void Application::authEvent() {
|
||||
|
||||
void Application::handlePathChange(const std::string &path) {
|
||||
LOG(info) << "handlePathChange: " << path;
|
||||
if (m_root == nullptr) {
|
||||
LOG(error) << "root container is null.";
|
||||
return;
|
||||
}
|
||||
if (path.starts_with("/wt/login")) {
|
||||
if (m_session->login().loggedIn()) {
|
||||
std::exit(0);
|
||||
LOG(info) << "already logged in.";
|
||||
} else {
|
||||
if (m_loginPage) {
|
||||
m_root->clear();
|
||||
|
@ -2,6 +2,7 @@
|
||||
#include "Application.h"
|
||||
#include <Wt/Auth/AuthService.h>
|
||||
#include <Wt/Auth/PasswordService.h>
|
||||
#include <Wt/WEnvironment.h>
|
||||
#include <Wt/WVBoxLayout.h>
|
||||
|
||||
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);
|
||||
// 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 {
|
||||
public:
|
||||
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__
|
Loading…
Reference in New Issue
Block a user