fix logout set domain.
All checks were successful
Deploy / Build (push) Successful in 5m49s

This commit is contained in:
amass 2025-01-09 19:38:36 +08:00
parent 64c2450121
commit 69cecf8022

View File

@ -16,7 +16,7 @@ DBO_INSTANTIATE_TEMPLATES(MyMessage)
void AuthenticationResource::handleRequest(const Wt::Http::Request &request, Wt::Http::Response &response) { void AuthenticationResource::handleRequest(const Wt::Http::Request &request, Wt::Http::Response &response) {
auto tag = request.urlParam("tag"); auto tag = request.urlParam("tag");
// LOG(info) << "path: " << request.path() << ", tag: " << tag; // LOG(info) << "path: " << request.path() << ", tag: " << tag << ", server: " << request.hostName();
response.setMimeType("application/json"); response.setMimeType("application/json");
MyMessage message; MyMessage message;
auto app = Amass::Singleton<WebToolkit::Server>::instance(); auto app = Amass::Singleton<WebToolkit::Server>::instance();
@ -47,8 +47,12 @@ void AuthenticationResource::handleRequest(const Wt::Http::Request &request, Wt:
using namespace boost::beast::http; using namespace boost::beast::http;
response.setStatus(static_cast<int>(state == Wt::Auth::AuthTokenState::Valid ? status::ok : status::unauthorized)); response.setStatus(static_cast<int>(state == Wt::Auth::AuthTokenState::Valid ? status::ok : status::unauthorized));
} else { // logout } else { // logout
response.addHeader("Set-Cookie", std::format("{}=; path={}; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT", auto domain = request.hostName();
service.authTokenCookieName(), AuthModel::CookiePath)); if (domain.find("amass.fun") != std::string::npos) {
domain = AuthModel::CookieDomain;
}
response.addHeader("Set-Cookie", std::format("{}=; path={}; Domain={}; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT",
service.authTokenCookieName(), AuthModel::CookiePath, domain));
} }
Wt::Dbo::JsonSerializer writer(response.out()); Wt::Dbo::JsonSerializer writer(response.out());
writer.serialize(message); writer.serialize(message);