support email confirm.
All checks were successful
Deploy / Build (push) Successful in 5m38s

This commit is contained in:
amass 2025-01-03 04:51:08 +08:00
parent 0ac66001bf
commit 769e672ca0
4 changed files with 67 additions and 4 deletions

View File

@ -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;

View File

@ -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();

View File

@ -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);
}

View File

@ -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__